/*  
Theme Name: Osteopathie in Erding
Theme URL: 
Version: 1.0
Author: Veronika Sattler
*/

/* --------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------

	INHALT:
	
	1. BASICS
	2. LAYOUT
	3. KOMPONENTEN
	4. MEDIA QUERIES
	5. PLUGINS

/* 1. BASICS
-----------------------------------------------------------------------------------------------
===============================================================================================*/
/* 1.1. Fonts
-----------------------------------------------------------------------------------------------*/

@font-face {
  font-family: 'Dosis';
  font-style: normal;
  font-weight: 400;
  src: url('../../files/layout-erding/css/fonts/dosis-v8-latin-regular.eot'); 
  src: local('Dosis Regular'), local('Dosis-Regular'),
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-regular.eot?#iefix') format('embedded-opentype'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-regular.woff2') format('woff2'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-regular.woff') format('woff'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-regular.ttf') format('truetype'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-regular.svg#Dosis') format('svg'); 
}

@font-face {
  font-family: 'Dosis';
  font-style: normal;
  font-weight: 600;
  src: url('../../files/layout-erding/css/fonts/dosis-v8-latin-600.eot'); 
  src: local('Dosis SemiBold'), local('Dosis-SemiBold'),
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-600.eot?#iefix') format('embedded-opentype'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-600.woff2') format('woff2'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-600.woff') format('woff'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-600.ttf') format('truetype'), 
       url('../../files/layout-erding/css/fonts/dosis-v8-latin-600.svg#Dosis') format('svg'); 
}




/* 1.2. HTML 5
-----------------------------------------------------------------------------------------------*/
article,aside, details, figcaption, figure, footer, header, hgroup, nav, section {
	display: block;
	}

/* 1.3. Reset
-----------------------------------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, input, textarea, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	box-sizing:border-box;
}

/* 1.4. Allgemeines
-----------------------------------------------------------------------------------------------*/
html, body {
	background:#fff;
	color:#474647;
	font-family: 'Dosis', sans-serif;
	font-size: 1em;
	text-size-adjust: none
	}
#main {
	padding-top: 120px;
	max-width: 100%;
	overflow: hidden;
		}
.inside {
	display: block;
	width: calc(100% - 40px);
	margin:auto;
	position: relative;
	}
#main .inside {
	max-width: 1200px;
}

.inside:after, .clear:after {
    content: ".";
    clear: both;
    display: block;
    visibility: hidden;
    height: 0px;
}	
.invisible {
	 position: absolute; 
	  overflow: hidden; 
	  clip: rect(0 0 0 0); 
	  height: 1px; width: 1px; 
	  margin: -1px; padding: 0; border: 0; 
	}
.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap:wrap; 
	}
.headline_block	{
	color:#fff;
	background: #2aa09d;
	text-align: center;
	padding: 40px 0px;
	}
.center {
	font-size: 120%;
	max-width: 1000px;
	text-align: center;
	margin: 60px auto;
	}
.width_1000	{
	max-width: 1000px;
	margin:auto;
	}
.grey {
	background:#F5F2F2;
}
.marg {
	padding: 100px 0px;
}
	
/* 1.5. Links
-----------------------------------------------------------------------------------------------*/
a {
	text-decoration:none; 
	transition: all 300ms ease-in-out; 
	color:#2aa09d;
	}
a:hover, a:focus {
	}	
a:visited {
	text-decoration:none;
	}
a:focus {
	text-decoration: underline;
	}
.more a {
	position: relative;
	display: inline-block;
	text-transform: uppercase;
	font-weight: bold;
	font-size: 95%;
	padding-bottom: 5px;
}
.more a:before {
	content:url('../../files/layout-erding/images/more.svg');
	margin-right: 10px;
	vertical-align: -2px;
}
.more a:after {
	content:'';
	position: absolute;
	display: block;
	width: 80%;
	height: 2px;
	background: #2aa09d;
	bottom: 15px;
	right:0;
	opacity: 0;
	transition: all 300ms linear;
}
.more a:hover:after, .more a:focus:after {
	opacity:1;
	bottom: 0;
}
.more a:hover, .more a:focus {
	text-decoration: none;
}

/* 1.6. Listen
-----------------------------------------------------------------------------------------------*/
ul {
	list-style: none;
	}
#main ul {
	padding-left: 20px;
	padding-bottom: 16px;
}
#main li {
	text-indent: -20px;
	padding-bottom: 10px;
}
#main li:before {
	content:'';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background:#2aa09d;
	margin-right: 6px;
}
		

/* 1.7. Typographie
-----------------------------------------------------------------------------------------------*/
p 	{
	padding-bottom: 16px;
	}
h1, h2, h3, h4 {
	color:#2aa09d;
	}
h1 {
	position: relative;
	font-size: 200%;
	margin-bottom:35px;
	}
		
h1:after {
	content:'';
	position: absolute;
	height: 3px;
	width: 80px;
	display: block;
	background:#2aa09d;
	margin-top:8px;
	}
.center h1:after {
	left: 50%;
	margin-left:-40px;
}
h2 {
	position: relative;
	font-size: 180%;
	width: 100%;
	margin-bottom:45px;
	}
h3 {
	font-size: 125%;
	margin-bottom:20px;
	text-transform: uppercase;
	}	
		
h2:after {
	content:'';
	position: absolute;
	height: 3px;
	width: 70px;
	display: block;
	background:#2aa09d;
	margin-top:8px;
	}	
.bg h2:after {
	display: none;
}						

/*1.8. Media
-----------------------------------------------------------------------------------------------*/

/*1.8.1. Iframes
-----------------------------------------------------------------------------------------------*/
object, embed, video, iframe {
max-width:100%;
}
	
/*1.8.2. Bilder
-----------------------------------------------------------------------------------------------*/
img {
	display: block;
	max-width: 100%;
	width: 100%;
	height: auto;
	}
figure {
	position: relative;
	}
	 		

/*1.9. Formulare
-----------------------------------------------------------------------------------------------*/
fieldset {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 20px;
	}
legend {
	width: 100%;
	color:#2aa09d;
	margin-bottom: 15px;
	display: block;
	font-size: 110%;
	}
legend:after {
	content:'';
	height: 3px;
	width: 80px;
	display: block;
	background:#2aa09d;
	margin-top:8px;
	}
.widget {
    width: 48%;
    position: relative;
	margin-bottom: 20px;
	}
.widget.long {
    width: 100%;
	}			
label {
	display: block;
	padding-bottom: 5px;
	}
input, select, textarea {
	border: 1px solid #2aa09d;
	border-radius: 7px;
	width: 100%;
	height: 36px;
	padding: 5px;
	color:#474647;
	font-family: 'Dosis', sans-serif;
	}
textarea {
	height: 100px;
	}	

input:focus, select:focus, textarea:focus {
	background: #2aa09d;
	color:#fff;
	}
input[type="checkbox"] {
	width: auto;
	height: auto;
	display: inline-block;
	}
.checkbox_container label {
	display: inline-block;
	}						
	


/* 2. LAYOUT
-----------------------------------------------------------------------------------------------
===============================================================================================*/
/*2.1. Header
-----------------------------------------------------------------------------------------------*/
#header {
	position: relative;
	top:0px;
	width: 100%;
	background:#fff;
	z-index:999;
	position:fixed;
	padding:20px 0px;
	}
.fixed-header {
	padding: 10px 0px;
}
#header .inside {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#logo {
	width: auto;
	max-width: 320px;
	}
.fixed-header #logo {
	max-width: 240px;
}
.header-div {
	margin-top:25px;
	display: flex;
	justify-content: flex-end;
	flex-grow: 2;
}
.fixed-header .header-div {
	margin-top:15px;
}

/*2.1.1. Haupt-Navigation
-----------------------------------------------------------------------------------------------*/
.navi_main {
	font-size: 0.95rem;
	}
.navi_main li {
	position: relative;
	display: inline-block;
	text-transform: uppercase;
	margin-right: 5rem;
	}
.navi_main .level_2 {
	padding-top: 53px;
	position: absolute;
    z-index: 1000;
    width: 300px;
    height: auto;
    max-height: 0px;
    border-radius: 10px;
    transition: all 300ms linear;
    overflow: hidden;
	margin-left:-20px;
}
.fixed-header .navi_main .level_2 {
	padding-top: 32px;
}	
.navi_main .opener:after {
    content: '';
    position: relative;
    height: 0;
    border-style: solid;
    border-width: 6px 5.5px 0 5.5px;
    border-color: #2aa09d transparent transparent transparent;
    margin-left: 7px;
    top: 12px;
}
.navi_main .level_2 li {
    background: rgba(250,250,250,0.85);
	text-transform: none;
    padding: 6px 20px;
	margin-right:0;
	display: block;
}
.navi_main .level_2 a:before, .navi_main .level_2 strong:before  {
	content:url('../../files/layout-erding/images/more_small.svg');
	margin-right: 10px;
	vertical-align: -2px;
}
.navi_main .level_2 li:first-child {
	padding-top: 30px;
}
.navi_main .level_2 li:last-child {
	padding-bottom: 30px;
}
.navi_main .level_2.show {
	max-height: none;
}
.navi_main a {
	color:#474647;
	}	
.navi_main strong, .navi_main a:hover, .navi_main a:focus, .navi_main .trail {
	color: #2aa09d;
	}

/*2.1.2. Menü-Button
----------------------------------h-------------------------------------------------------------*/
.menu {
	position: absolute;
	right:0px;
	top: 25px;
	display: none;
	cursor: pointer;
	transition-property: opacity, filter;
	transition-duration: 0.15s;
	transition-timing-function: linear;
	font: inherit;
	color: inherit;
	text-transform: none;
	background-color: transparent;
	border: 0;
	margin: 0;
	overflow: visible;
	z-index:2000;
	}
.fixed-header .menu {
	top: 15px;
}
.menu:hover {
	opacity: 0.7; 
	}
.menu-box {
	width: 26px;
	height: 20px;
	display: inline-block;
	position: relative; 
	}
.menu-inner {
	display: block;
	top: 50%;
	margin-top: -2px; 
	transition: transform 0.075s 0.15s cubic-bezier(0.55, 0.055, 0.675, 0.19), background-color 0s 0.075s linear; 
	}
.menu-inner, .menu-inner::before, .menu-inner::after {
	width: 26px;
	height: 3px;
	background-color: #2aa09d;
	border-radius: 4px;
	position: absolute;
	transition-property: transform;
	transition-duration: 0.15s;
	transition-timing-function: ease; 
	}
  .menu-inner::before, .menu-inner::after {
    content: "";
    display: block; 
	}
  .menu-inner::before {
    top: -8px; 
	transition: top 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19); 
	}
  .menu-inner::after {
	  bottom: -8px; 
	  transition: bottom 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19);
	  }	
.menu.active .menu-inner {
  transform: rotate(90deg);
  background-color: transparent !important;
  transition: transform 0.075s 0s cubic-bezier(0.215, 0.61, 0.355, 1), background-color 0s 0.15s linear;
  }
  .menu.active .menu-inner:before {
    top: 0;
    transform: rotate(-45deg);
    transition: top 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1);
	background-color: #fff;
	}
  .menu.active .menu-inner:after {
    bottom: 0;
    transform: rotate(45deg);
	transition: bottom 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1); 
	background-color: #fff;
	}	  

/*2.2. Footer
-----------------------------------------------------------------------------------------------*/
#footer {
	margin-top: 80px;
}
#footer .inside {
	border-top: 3px solid #2aa09d;
	padding: 30px 0px;
	}
#footer h3 {
	font-size: 110%;
	margin-bottom:12px;
	}	
#footer a {
	color:#474647;
	}
#footer strong {
	font-weight:600;
	}	
#footer a:hover, #footer a:focus {
	color:#2aa09d;
	}		
	
/* 3. Komponenten
-----------------------------------------------------------------------------------------------
===============================================================================================*/
/*3.1. Startbild
-----------------------------------------------------------------------------------------------*/
.heroimage figure {
	height: 800px;
	background-position: center;
	background-size:cover;
}
.bubble {
	position: absolute;
	width: 450px;
	height: 450px;
	border-radius: 50%;
	background: rgba(250,250, 250, 0.7);
	padding: 70px;
	display: flex;
	justify-content: center;
	align-items: start;
	flex-direction: column;
	transform: translateY(-140%);

}
.bubble h1 {
	font-size: 200%;
	font-weight: bold;
}
.bubble h1:after {
	display: none;
}
.bubble strong {
	font-size: 130%;
	font-weight: bold;
}
.bubble a {
	margin-top: 15px;
	
}

/*3.2. Titelbilder
-----------------------------------------------------------------------------------------------*/	
.titleimage figure {
	height: 600px;
	background-position: center;
	background-size:cover;
	margin-bottom: 100px;
}


/*3.3. Teaserbubble
-----------------------------------------------------------------------------------------------*/	
.bubbleholder {
	margin-left:-4%;
	display: flex;
	flex-wrap: wrap;
}
.teaser_bubble {
	position: relative;
	width: 21%;
	text-align: center;
	margin-bottom: 3rem;
	margin-left: 4%;
}
.teaser_bubble figure {
	overflow: hidden;
	border-radius: 50%;
	margin-bottom: 3rem;
	margin-left: auto;
	margin-right: auto;
}
.teaser_bubble a img {
	border-radius: 50%;
	transition: all 300ms ease;
}
.teaser_bubble a:hover img {
	transform: scale(1.3);
}


/*3.3. Teaser
-----------------------------------------------------------------------------------------------*/	
	
.teaser {
	position: relative;
	width: 48%;
	box-shadow: 0px 3px 15px rgba(0,0,0,0.2);
	padding: 2rem;
	margin-bottom: 2rem;
	}
.teaser.attention {
	width: 100%;
	margin-top: 60px;
}
.teaser h2 {
	margin-bottom: 20px;
}
.teaser a:before {
	transition: all 300ms ease-in-out; 
	display: inline-block;
	content:'>';
	background: #2aa09d;
	border: 1px solid #2aa09d;
	color:#fff;
	height: 24px;
	width: 24px;
	border-radius: 50%;
	color:#fff;
	font-weight: 600;
	text-align: center;
	line-height: 22px;
	margin-right: 10px;
	}
.teaser a:hover:before, .teaser a:focus:before {
	background: #fff;
	color:#2aa09d;
	}	


/*3.4. Accordion
-----------------------------------------------------------------------------------------------*/	
.toggler {
	cursor: pointer;
	position: relative;
	box-shadow: 0px 3px 15px rgba(0,0,0,0.2);
	padding: 1.5rem 2rem;
	margin-bottom: 12px;
	}
.toggler:before {
	display: inline-block;
	content:'>';
	background: #2aa09d;
	border: 1px solid #2aa09d;
	color:#fff;
	height: 24px;
	width: 24px;
	border-radius: 50%;
	color:#fff;
	font-weight: 600;
	text-align: center;
	line-height: 22px;
	margin-right: 10px;
	transition: all 300ms ease;
	}	
.toggler.ui-state-active:before {
	margin-right: 10px;
	transform: rotate(-90deg);
	}		
.accordion {
	padding: 2rem; 
	}	

/*3.6. Galerie
-----------------------------------------------------------------------------------------------*/
#main .gallery_default ul {
	display: flex;
	flex-wrap: wrap;
	padding-left: 0;
	margin-left: -4%;
}
#main .gallery_default figure {
	overflow:hidden;
	border-radius: 50%;
}
#main .gallery_default li {
	width: 21%;
    text-align: center;
    margin-bottom: 3rem;
    margin-left: 4%;
}
.gallery_default a img {
	border-radius: 50%;
	transition: all 300ms ease;
}
.gallery_default a:hover img {
	transform: scale(1.3);
}
#main .gallery_default li:before {
	display: none;
}

/*3.5. Bild-text
-----------------------------------------------------------------------------------------------*/
.septext .rte {
	position: relative;
	width: 55%;
	float: left;
	}
.standard {
	align-items: center;
	font-size: 110%;
}
.standard figure {
	width: 30%;
}
.standard img {
	border-radius: 50%;
}
.standard figcaption {
	text-align: center;
	text-align: middle;
	font-size: 80%;
	padding-top: 10px;
}
.standard .more a {
	text-align: right;
}
.bigtext p, .bigtext ul {
	font-size: 120%;
}
.pb_bottom {
	padding-bottom: 50px;
}


/*3.6. Video
-----------------------------------------------------------------------------------------------*/
.video video {
	width: 100%;
	height: auto;
	display: block;
}

/*3.7. Buchungslink
-----------------------------------------------------------------------------------------------*/
.booking-link a {
	position: relative;
	background:none;
	border: 1px solid #2aa09d;
	color:#fff;
	padding: 0.6rem 1rem;
	border-radius: 20px;
	display: inline-block;
	z-index:1000;
	margin-top:-10px;
}
.booking-link a:hover, .booking-link a:focus {
	color:#2aa09d;
}
.booking-link a:before {
	content:'';
	display: block;
	border-radius: 20px;
	z-index:-1;
	position: absolute;
	background:#2aa09d;
    width: 100%;
	height: 100%;
	left:0px;
	top: 0px;
	opacity:1;
	transition: all 466ms linear;
}
.booking-link a:hover:before, .booking-link a:focus:before {
	transform: scale(0.1, 0.1);
	opacity:0;
}


/*3.8. Popup
-----------------------------------------------------------------------------------------------*/
.popup {
	position: fixed;
    top: 50%;
    left: 50%;
    width: 80%;
	max-width: 800px;
    outline: 9999px solid rgba(0,0,0,0.8);
	transform: translate(-50%, -50%);
	opacity: 0;
	z-index:-1;
	transition: opacity 0.7s ease-in;
	background:rgba(0,0,0,0.8);
}
.popup.show {
	opacity: 1;
	z-index:1000;
}
.pop-up-modal {
	background-color: #ffff;
	position: relative;
	padding: 4rem;
	transform: translateY(-100%);
	transition: all 0.4s ease-in;
}
.show .pop-up-modal {
	transform: translateY(0%);
}
.pop-up-modal strong {
	position: absolute;
	width: 30px;
	height: 30px;
	overflow: hidden;
	right:0px;
	bottom: 0px;
	text-align: center;
	line-height: 30px;
	font-size: 180%;
	cursor: pointer;
}
.pop-up-modal strong:before {
	content:'×';
	background: #2aa09d;
	display: block;
	width: 30px;
	height: 30px;
	color:#fff;
} 


/* 4. Media Queries
-----------------------------------------------------------------------------------------------
===============================================================================================*/
@media only screen and (max-width: 1400px) {
	.navi_main li {
		margin-right:3rem;
		}
}
@media only screen and (max-width: 1280px) {
	#logo {
		max-width: 280px;
		margin-right:2rem;
		}
	.heroimage figure {
		height: 700px;
		}
	.navi_main li {
		margin-right:1.6rem;
		}
	.teaser_bubble {
		width: 46%;
	}
	.teaser_bubble figure {
		width: 450px;
		max-width: 100%;
	}
}
 @media only screen and (max-width: 1023px) {
	.heroimage figure {
		height: 550px;
		}
	.bubble {
		width: 380px;
		height: 380px;
		padding: 50px;
		transform: translateY(-120%);
		}
	.bubble h1 {
		font-size: 170%;
		}
	.bubble strong {
		font-size: 120%;
		}
	 .teaser_bubble figure {
		width: 380px;
	}
	 #main .gallery_default li {
		width: 46%;
	 }
	.menu {
		display: block;
		}
	 .booking-link {
		 margin-right: 50px;
	 }
	.navi_main {
		position: fixed;
		overflow-y:auto;
		height: 100%; 
		top:0px;
		visibility: hidden;
		width: 0;
		left: 50%;
		margin-top:0px;
		float: none;
		background: rgba(42,160,157,0.9);
		transform: translateX(-50%);
		transition: width 0.5s 0.3s, visibility 0s 0.8s;
		z-index: 1000;
		}
	.navi_main.show {
		visibility: visible;
		width: 100%;
		transition: width 0.5s;
		}	
	.navi_main nav {
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		position: absolute;
		transform: translateY(-50%);
		}
	.navi_main.show nav {
		opacity: 1;
		transition-delay: 0.5s;
		}
	.navi_main ul {
		padding: 0;
		margin: 0 auto;
		display: inline-block;
		height: 100%;
		position: relative;
		}
	.navi_main ul li {
		display: block;
		padding-bottom: 2rem;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		font-size: 1.5rem;
		margin-left: 1rem;
		}
	.navi_main a, .navi_main .opener {
		color:#fff;
		}
	.navi_main strong, .navi_main a:hover, .navi_main a:focus, .navi_main .trail {
		color: #beeeed;
		}	
	.navi_main .level_2 {
		padding-top: 0px;
		position: relative;
		width: 100%;
		max-height:none;
		border-radius: 0px;
		margin-left:0px;
		}
	.navi_main .level_2 li {
		background: none;
		padding-top: 5px;
		padding-bottom: 5px;
		font-size: 1.2rem;
		}
	.navi_main .level_2 li:last-child {
		padding-bottom: 0px;
		}
		.navi_main .level_2 a:before, .navi_main .level_2 strong:before {
		display: none;
		}
	 .titleimage figure {
		height: 400px;
		margin-bottom: 60px;
		}
	 }
@media only screen and (max-width: 800px)  {
	.titleimage figure {
		height: 300px;
		}
	h1 {
		font-size: 170%;
		}
	h2 {
		text-align: center;
		font-size: 170%;
	}
	h2:after {
		left: 50%;
		margin-left: -35px;
	}
	.standard figure {
		width: 380px;
		margin: 0px auto 2rem auto;
		max-width: 100%;
	}
	.bubble {
		left: 50%;
		transform: translateY(-130%) translatex(-50%);
	}
	.teaser_bubble {
		width: 100%;
		}
	.teaser_bubble h2 {
		text-align: center;
	}
	#footer .ce_text {
		width: 100%;
		}	
	#footer nav {
		width: 100%;
		margin-bottom: 10px;
		}
	.septext .rte {
		position: relative;
		width: 100%;
		float: none;
		}	
}
@media only screen and (max-width:600px)  {
	#main .gallery_default li {
		width: 100%;
		margin-left:0;
	 }
	.booking-link a {
		position: fixed;
		margin-right:0px;
		bottom: 30px;
		right: -10px;
		padding: 1rem;
	}
}

/* 5. Plugins
-----------------------------------------------------------------------------------------------
===============================================================================================*/
/* 5.1. Fresco
-----------------------------------------------------------------------------------------------*/
.fr-window,
.fr-window [class^="fr-"],
.fr-overlay,
.fr-overlay [class^="fr-"],
.fr-spinner,
.fr-spinner [class^="fr-"] {
  box-sizing: border-box;
}

.fr-window {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  font: 13px/20px "Lucida Sans", "Lucida Sans Unicode", "Lucida Grande", Verdana,
    Arial, sans-serif;
  /* Chrome hack, this fixes a visual glitch when quickly toggling a video */
  transform: translateZ(0px);
}

/* z-index */
.fr-overlay {
  z-index: 99998;
}
.fr-window {
  z-index: 99999;
}
.fr-spinner {
  z-index: 100000;
}

/* overlay */
.fr-overlay {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}
.fr-overlay-background {
  float: left;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.9;
  filter: alpha(opacity=90);
}

.fr-overlay-ui-fullclick .fr-overlay-background {
  background: #292929;
  opacity: 1;
  filter: alpha(opacity=100);
}

/* mobile touch has position:absolute to allow zooming */
.fr-window.fr-mobile-touch,
.fr-overlay.fr-mobile-touch {
  position: absolute;
  overflow: visible;
}

/* some properties on the window are used to toggle things
 * like margin and the fullclick mode,
 * we reset those properties after measuring them
 */
.fr-measured {
  margin: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
}

.fr-box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.fr-pages {
  position: absolute;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.fr-page {
  position: absolute;
  width: 100%;
  height: 100%;
}

.fr-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0;
  padding: 0;
  text-align: center;
}

.fr-hovering-clickable .fr-container {
  cursor: pointer;
}

/*
   padding:
   youtube & vimeo always have buttons on the outside
   side button = 72 = 54 + (2 * 9 margin)
   close button = 48
*/
/* padding ui:inside */
.fr-ui-inside .fr-container {
  padding: 20px 20px;
}
.fr-ui-inside.fr-no-sides .fr-container {
  padding: 20px;
}

/* padding ui:outside */
.fr-ui-outside .fr-container {
  padding: 20px 82px;
}
.fr-ui-outside.fr-no-sides .fr-container {
  padding: 20px 48px;
}

/* reduce padding on smaller screens */
@media all and (max-width: 700px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 700px) {
  /* padding ui:inside */
  .fr-ui-inside .fr-container {
    padding: 12px 12px;
  }
  .fr-ui-inside.fr-no-sides .fr-container {
    padding: 12px;
  }

  /* padding ui:outside */
  .fr-ui-outside .fr-container {
    padding: 12px 72px;
  }
  .fr-ui-outside.fr-no-sides .fr-container {
    padding: 12px 48px;
  }
}

@media all and (max-width: 500px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 500px) {
  /* padding ui:inside */
  .fr-ui-inside .fr-container {
    padding: 0px 0px;
  }
  .fr-ui-inside.fr-no-sides .fr-container {
    padding: 0px;
  }

  /* padding ui:outside */
  .fr-ui-outside .fr-container {
    padding: 0px 72px;
  }
  .fr-ui-outside.fr-no-sides .fr-container {
    padding: 0px 48px;
  }
}

/* padding ui:fullclick */
.fr-ui-fullclick .fr-container {
  padding: 0;
}
.fr-ui-fullclick.fr-no-sides .fr-container {
  padding: 0;
}

/* video fullclick */
.fr-ui-fullclick.fr-type-video .fr-container {
  padding: 0px 62px;
}
.fr-ui-fullclick.fr-no-sides.fr-type-video .fr-container {
  padding: 48px 0px;
}

/* overflow-y should always have 0 padding top and bottom */
.fr-overflow-y .fr-container {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.fr-content,
.fr-content-background {
  position: absolute;
  top: 50%;
  left: 50%;
  /* IE11 has a 1px blur bug on the edges of the caption (ui:inside)
     during animation with overflow:hidden */
  overflow: visible;
}

/* img/iframe/error */
.fr-content-element {
  float: left;
  width: 100%;
  height: 100%;
}

.fr-content-background {
  background: #101010;
}

.fr-info {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  color: #efefef;
  font-size: 13px;
  line-height: 20px;
  text-align: left;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  -webkit-user-select: text;
  -khtml-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}
.fr-info-background {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: #000;
  line-height: 1%;
  filter: none;
  opacity: 1;
}
.fr-ui-inside .fr-info-background {
  filter: alpha(opacity=80);
  opacity: 0.8;
  zoom: 1;
}
/* ui:outside has a slightly lighter info background to break up from black page backgrounds */
.fr-ui-outside .fr-info-background {
  background: #0d0d0d;
}

/* info at the bottom for ui:inside */
.fr-content .fr-info {
  top: auto;
  bottom: 0;
}

.fr-info-padder {
  display: block;
  overflow: hidden;
  padding: 12px;
  position: relative;
  width: auto;
}
.fr-caption {
  width: auto;
  display: inline;
}

.fr-position {
  color: #b3b3b3;
  float: right;
  line-height: 21px;
  opacity: 0.99;
  position: relative;
  text-align: right;
  margin-left: 15px;
  white-space: nowrap;
}

/* positions not within the info bar
   for ui:outside/inside */
.fr-position-outside,
.fr-position-inside {
  position: absolute;
  bottom: 0;
  right: 0;
  margin: 12px;
  width: auto;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  line-height: 20px;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.4);
  display: none;
  overflow: hidden;
  white-space: nowrap;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  -webkit-user-select: text;
  -khtml-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}
.fr-position-inside {
  border: 0;
}

.fr-position-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #0d0d0d;
  filter: alpha(opacity=80);
  opacity: 0.8;
  zoom: 1; /* oldIE */
}
.fr-position-text {
  color: #b3b3b3;
}
.fr-position-outside .fr-position-text,
.fr-position-inside .fr-position-text {
  float: left;
  position: relative;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  opacity: 1;
}

/* display it for the outside ui, hide the caption inside */
.fr-ui-outside .fr-position-outside {
  display: block;
}
.fr-ui-outside .fr-info .fr-position {
  display: none;
}

.fr-ui-inside.fr-no-caption .fr-position-inside {
  display: block;
}

/* links */
.fr-info a,
.fr-info a:hover {
  color: #ccc;
  border: 0;
  background: none;
  text-decoration: underline;
}
.fr-info a:hover {
  color: #eee;
}

/* no-caption */
.fr-ui-outside.fr-no-caption .fr-info {
  display: none;
}
.fr-ui-inside.fr-no-caption .fr-caption {
  display: none;
}

/* --- stroke */
.fr-stroke {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
}
.fr-stroke-vertical {
  width: 1px;
  height: 100%;
}
.fr-stroke-horizontal {
  padding: 0 1px;
}

.fr-stroke-right {
  left: auto;
  right: 0;
}
.fr-stroke-bottom {
  top: auto;
  bottom: 0;
}

.fr-stroke-color {
  float: left;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.08);
}

/* the stroke is brighter inside the info box */
.fr-info .fr-stroke-color {
  background: rgba(80, 80, 80, 0.3);
}

/* remove the stroke when outside ui has a caption */
.fr-ui-outside.fr-has-caption .fr-content .fr-stroke-bottom {
  display: none;
}

/* remove stroke and shadow when ui:fullclick */
.fr-ui-fullclick .fr-stroke {
  display: none;
}
.fr-ui-fullclick .fr-content-background {
  box-shadow: none;
}

/* the info box never bas a top stroke */
.fr-info .fr-stroke-top {
  display: none;
}

/* < > */
.fr-side {
  position: absolute;
  top: 50%;
  width: 54px;
  height: 72px;
  margin: 0 9px;
  margin-top: -36px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  zoom: 1;
}
.fr-side-previous {
  left: 0;
}
.fr-side-next {
  right: 0;
  left: auto;
}

.fr-side-disabled {
  cursor: default;
}
.fr-side-hidden {
  display: none !important;
}

.fr-side-button {
  float: left;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}
.fr-side-button-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #101010;
}
.fr-side-button-icon {
  float: left;
  position: relative;
  height: 100%;
  width: 100%;
  zoom: 1;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
/* smaller side buttons */
@media all and (max-width: 500px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 414px) {
  .fr-side {
    width: 54px;
    height: 60px;
    margin: 0;
    margin-top: -30px;
  }
  .fr-side-button {
    width: 48px;
    height: 60px;
    margin: 0 3px;
  }
}

/* X */
.fr-close {
  position: absolute;
  width: 48px;
  height: 48px;
  top: 0;
  right: 0;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.fr-close-background,
.fr-close-icon {
  position: absolute;
  top: 12px;
  left: 12px;
  height: 26px;
  width: 26px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
.fr-close-background {
  background-color: #000;
}

/* Thumbnails */
.fr-thumbnails {
  position: absolute;
  overflow: hidden;
}
.fr-thumbnails-disabled .fr-thumbnails {
  display: none !important;
}
.fr-thumbnails-horizontal .fr-thumbnails {
  width: 100%;
  height: 12%;
  min-height: 74px;
  max-height: 160px;
  bottom: 0;
}

.fr-thumbnails-vertical .fr-thumbnails {
  height: 100%;
  width: 10%;
  min-width: 74px;
  max-width: 160px;
  left: 0;
}

.fr-thumbnails,
.fr-thumbnails * {
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.fr-thumbnails-wrapper {
  position: absolute;
  top: 0;
  left: 50%;
  height: 100%;
}
.fr-thumbnails-vertical .fr-thumbnails-wrapper {
  top: 50%;
  left: 0;
}

.fr-thumbnails-slider {
  position: relative;
  width: 100%;
  height: 100%;
  float: left;
  zoom: 1;
}

.fr-thumbnails-slider-slide {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
}

.fr-thumbnails-thumbs {
  float: left;
  height: 100%;
  overflow: hidden;
  position: relative;
  top: 0;
  left: 0;
}

.fr-thumbnails-slide {
  position: absolute;
  top: 0;
  height: 100%;
  width: 100%;
}

.fr-thumbnail-frame {
  position: absolute;
  zoom: 1;
  overflow: hidden;
}

.fr-thumbnail {
  position: absolute;
  width: 30px;
  height: 100%;
  left: 50%;
  top: 50%;
  zoom: 1;
  cursor: pointer;
  margin: 0 10px;
}
.fr-ltIE9 .fr-thumbnail * {
  overflow: hidden; /* IE6(7) */
  z-index: 1;
  zoom: 1;
}

.fr-thumbnail-wrapper {
  position: relative;
  background: #161616;
  width: 100%;
  height: 100%;
  float: left;
  overflow: hidden;
  display: inline; /* IE6(7) */
  z-index: 0; /* IE8 */
}

.fr-thumbnail-overlay {
  cursor: pointer;
}
.fr-thumbnail-active .fr-thumbnail-overlay {
  cursor: default;
}
.fr-thumbnail-overlay,
.fr-thumbnail-overlay-background,
.fr-thumbnail-overlay-border {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-width: 0;
  overflow: hidden;
  border-style: solid;
  border-color: transparent;
}
.fr-ltIE9 .fr-thumbnail-overlay-border {
  border-width: 0 !important;
}
.fr-thumbnail .fr-thumbnail-image {
  position: absolute;
  filter: alpha(opacity=85);
  opacity: 0.85;
  max-width: none;
}
.fr-thumbnail:hover .fr-thumbnail-image,
.fr-thumbnail-active:hover .fr-thumbnail-image {
  filter: alpha(opacity=99);
  opacity: 0.99;
}
.fr-thumbnail-active .fr-thumbnail-image,
.fr-thumbnail-active:hover .fr-thumbnail-image {
  filter: alpha(opacity=35);
  opacity: 0.35;
}
.fr-thumbnail-active {
  cursor: default;
}

/* Thumbnails loading */
.fr-thumbnail-loading,
.fr-thumbnail-loading-background,
.fr-thumbnail-loading-icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.fr-thumbnail-loading-background {
  background-color: #161616;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  opacity: 0.8;
  position: relative;
  float: left;
}
/* this element is there as an alternative to putting the loading image on the background */
.fr-thumbnail-loading-icon {
  display: none;
}

/* error on thumbnail */
.fr-thumbnail-error .fr-thumbnail-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #202020;
}

/* Thumbnail < > */
.fr-thumbnails-side {
  float: left;
  height: 100%;
  width: 28px;
  margin: 0 5px;
  position: relative;
  overflow: hidden;
}
.fr-thumbnails-side-previous {
  margin-left: 12px;
}
.fr-thumbnails-side-next {
  margin-right: 12px;
}

.fr-thumbnails-vertical .fr-thumbnails-side {
  height: 28px;
  width: 100%;
  margin: 10px 0;
}
.fr-thumbnails-vertical .fr-thumbnails-side-previous {
  margin-top: 20px;
}
.fr-thumbnails-vertical .fr-thumbnails-side-next {
  margin-bottom: 20px;
}

.fr-thumbnails-side-button {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -14px;
  margin-left: -14px;
  width: 28px;
  height: 28px;
  cursor: pointer;
}

.fr-thumbnails-side-button-background {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  filter: alpha(opacity=80);
  opacity: 0.8;
  -moz-transition: background-color 0.2s ease-in;
  -webkit-transition: background-color 0.2s ease-in;
  transition: background-color 0.2s ease-in;
  background-color: #333;
  cursor: pointer;
  border-radius: 4px;
}
.fr-thumbnails-side-button:hover .fr-thumbnails-side-button-background {
  background-color: #3b3b3b;
}

.fr-thumbnails-side-button-disabled * {
  cursor: default;
}
.fr-thumbnails-side-button-disabled:hover
  .fr-thumbnails-side-button-background {
  background-color: #333;
}

.fr-thumbnails-side-button-icon {
  position: absolute;
  /*top: -7px;
  left: -7px;*/
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* vertical thumbnails */
.fr-thumbnails-vertical .fr-thumbnails-side,
.fr-thumbnails-vertical .fr-thumbnails-thumbs,
.fr-thumbnails-vertical .fr-thumbnail-frame {
  clear: both;
}

/* ui:fullclick has a dark thumbnail background */
.fr-window-ui-fullclick .fr-thumbnails {
  background: #090909;
}

/* put a stroke on the connecting caption*/
.fr-window-ui-fullclick.fr-thumbnails-enabled.fr-thumbnails-horizontal
  .fr-info
  .fr-stroke-bottom {
  display: block !important;
} /*({ box-shadow: inset 0 -1px 0 rgba(255,255,255,.1); } */
.fr-window-ui-fullclick.fr-thumbnails-enabled.fr-thumbnails-vertical
  .fr-info
  .fr-stroke-left {
  display: block !important;
}

/* thumbnail spacing  */
.fr-thumbnails-horizontal .fr-thumbnails-thumbs {
  padding: 12px 5px;
}
.fr-thumbnails-vertical .fr-thumbnails-thumbs {
  padding: 5px 12px;
}
.fr-thumbnails-measured .fr-thumbnails-thumbs {
  padding: 0 !important;
}
/* horizontal */
@media all and (min-height: 700px) {
  .fr-thumbnails-horizontal .fr-thumbnails-thumbs {
    padding: 16px 8px;
  }
  .fr-thumbnails-horizontal .fr-thumbnails-side {
    margin: 0 8px;
  }
  .fr-thumbnails-horizontal .fr-thumbnails-side-previous {
    margin-left: 16px;
  }
  .fr-thumbnails-horizontal .fr-thumbnails-side-next {
    margin-right: 16px;
  }
}
@media all and (min-height: 980px) {
  .fr-thumbnails-horizontal .fr-thumbnails-thumbs {
    padding: 20px 10px;
  }
  .fr-thumbnails-horizontal .fr-thumbnails-side {
    margin: 0 10px;
  }
  .fr-thumbnails-horizontal .fr-thumbnails-side-previous {
    margin-left: 20px;
  }
  .fr-thumbnails-horizontal .fr-thumbnails-side-next {
    margin-right: 20px;
  }
}

/* vertical */
@media all and (min-width: 1200px) {
  .fr-thumbnails-vertical .fr-thumbnails-thumbs {
    padding: 8px 16px;
  }
  .fr-thumbnails-vertical .fr-thumbnails-side {
    margin: 0 8px;
  }
  .fr-thumbnails-vertical .fr-thumbnails-side-previous {
    margin-top: 16px;
  }
  .fr-thumbnails-vertical .fr-thumbnails-side-next {
    margin-bottom: 16px;
  }
}
@media all and (min-width: 1800px) {
  .fr-thumbnails-vertical .fr-thumbnails-thumbs {
    padding: 10px 20px;
  }
  .fr-thumbnails-vertical .fr-thumbnails-side {
    margin: 10px 0;
  }
  .fr-thumbnails-vertical .fr-thumbnails-side-previous {
    margin-top: 20px;
  }
  .fr-thumbnails-vertical .fr-thumbnails-side-next {
    margin-bottom: 20px;
  }
}

/* hide thumbnails on smaller screens
   the js always hides them on touch based devices
*/
@media all and (max-width: 500px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 500px) {
  .fr-thumbnails-horizontal .fr-thumbnails {
    display: none !important;
  }
}
@media all and (max-width: 700px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 414px) {
  .fr-thumbnails-vertical .fr-thumbnails {
    display: none !important;
  }
}

/* force fullClick: true
   and force overflow: false */
@media all and (max-width: 500px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 414px) {
  .fr-page {
    min-width: 100%;
  } /* fullclick */
  .fr-page {
    min-height: 100%;
  } /* overflow: false */
}

/* switch between ui modes
   we force everything not in the current UI mode to hide
*/
.fr-window-ui-fullclick .fr-side-next-outside,
.fr-window-ui-fullclick .fr-side-previous-outside,
.fr-window-ui-fullclick .fr-close-outside,
.fr-window-ui-fullclick .fr-content .fr-side-next,
.fr-window-ui-fullclick .fr-content .fr-side-previous,
.fr-window-ui-fullclick .fr-content .fr-close,
.fr-window-ui-fullclick .fr-content .fr-info,
.fr-window-ui-outside .fr-side-next-fullclick,
.fr-window-ui-outside .fr-side-previous-fullclick,
.fr-window-ui-outside .fr-close-fullclick,
.fr-window-ui-outside .fr-content .fr-side-next,
.fr-window-ui-outside .fr-content .fr-side-previous,
.fr-window-ui-outside .fr-content .fr-close,
.fr-window-ui-outside .fr-content .fr-info,
.fr-window-ui-inside .fr-page > .fr-info,
.fr-window-ui-inside .fr-side-next-fullclick,
.fr-window-ui-inside .fr-side-previous-fullclick,
.fr-window-ui-inside .fr-close-fullclick,
.fr-window-ui-inside .fr-side-next-outside,
.fr-window-ui-inside .fr-side-previous-outside,
.fr-window-ui-inside .fr-close-outside {
  display: none !important;
}

/* some ui elements can be toggled on mousemove.
   filter:alpha(opacity) is bugged so we use display in oldIE
*/
.fr-toggle-ui {
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.fr-visible-fullclick-ui .fr-box > .fr-toggle-ui,
.fr-visible-inside-ui .fr-ui-inside .fr-toggle-ui {
  opacity: 1;
}

.fr-hidden-fullclick-ui .fr-box > .fr-toggle-ui,
.fr-hidden-inside-ui .fr-ui-inside .fr-toggle-ui {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.fr-ltIE9.fr-hidden-fullclick-ui .fr-box > .fr-toggle-ui,
.fr-ltIE9.fr-hidden-inside-ui .fr-ui-inside .fr-toggle-ui {
  display: none;
}

/* Spinner */
.fr-spinner {
  position: fixed;
  width: 52px;
  height: 52px;
  background: #101010;
  background: rgba(16, 16, 16, 0.85);
  border-radius: 5px;
}
.fr-spinner div {
  position: absolute;
  top: 0;
  left: 0;
  height: 64%;
  width: 64%;
  margin-left: 18%;
  margin-top: 18%;
  opacity: 1;
  -webkit-animation: fresco-12 1.2s infinite ease-in-out;
  animation: fresco-12 1.2s infinite ease-in-out;
}

.fr-spinner div:after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 8px;
  margin-left: -1px;
  background: #fff;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0); /* fixes rendering in Firefox */
}

.fr-spinner div.fr-spin-1 {
  -ms-transform: rotate(30deg);
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}
.fr-spinner div.fr-spin-2 {
  -ms-transform: rotate(60deg);
  -webkit-transform: rotate(60deg);
  transform: rotate(60deg);
  -webkit-animation-delay: -1s;
  animation-delay: -1s;
}
.fr-spinner div.fr-spin-3 {
  -ms-transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}
.fr-spinner div.fr-spin-4 {
  -ms-transform: rotate(120deg);
  -webkit-transform: rotate(120deg);
  transform: rotate(120deg);
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}
.fr-spinner div.fr-spin-5 {
  -ms-transform: rotate(150deg);
  -webkit-transform: rotate(150deg);
  transform: rotate(150deg);
  -webkit-animation-delay: -0.7s;
  animation-delay: -0.7s;
}
.fr-spinner div.fr-spin-6 {
  -ms-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  -webkit-animation-delay: -0.6s;
  animation-delay: -0.6s;
}
.fr-spinner div.fr-spin-6 {
  -ms-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  -webkit-animation-delay: -0.6s;
  animation-delay: -0.6s;
}
.fr-spinner div.fr-spin-7 {
  -ms-transform: rotate(210deg);
  -webkit-transform: rotate(210deg);
  transform: rotate(210deg);
  -webkit-animation-delay: -0.5s;
  animation-delay: -0.5s;
}
.fr-spinner div.fr-spin-8 {
  -ms-transform: rotate(240deg);
  -webkit-transform: rotate(240deg);
  transform: rotate(240deg);
  -webkit-animation-delay: -0.4s;
  animation-delay: -0.4s;
}
.fr-spinner div.fr-spin-9 {
  -ms-transform: rotate(270deg);
  -webkit-transform: rotate(270deg);
  transform: rotate(270deg);
  -webkit-animation-delay: -0.3s;
  animation-delay: -0.3s;
}
.fr-spinner div.fr-spin-10 {
  -ms-transform: rotate(300deg);
  -webkit-transform: rotate(300deg);
  transform: rotate(300deg);
  -webkit-animation-delay: -0.2s;
  animation-delay: -0.2s;
}
.fr-spinner div.fr-spin-11 {
  -ms-transform: rotate(330deg);
  -webkit-transform: rotate(330deg);
  transform: rotate(330deg);
  -webkit-animation-delay: -0.1s;
  animation-delay: -0.1s;
}
.fr-spinner div.fr-spin-12 {
  -ms-transform: rotate(360deg);
  -webkit-transform: rotate(360deg);
  transform: rotate(360deg);
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}

@-webkit-keyframes fresco-12 {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fresco-12 {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

/* Thumbnail spinner */
.fr-thumbnail-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -20px;
  margin-left: -20px;
  width: 40px;
  height: 40px;
}
.fr-thumbnail-spinner-spin {
  position: relative;
  float: left;
  margin: 8px 0 0 8px;
  text-indent: -9999em;
  border-top: 2px solid rgba(255, 255, 255, 0.2);
  border-right: 2px solid rgba(255, 255, 255, 0.2);
  border-bottom: 2px solid rgba(255, 255, 255, 0.2);
  border-left: 2px solid #fff;
  -webkit-animation: fr-thumbnail-spin 1.1s infinite linear;
  animation: fr-thumbnail-spin 1.1s infinite linear;
}
.fr-thumbnail-spinner-spin,
.fr-thumbnail-spinner-spin:after {
  border-radius: 50%;
  width: 24px;
  height: 24px;
}
@-webkit-keyframes fr-thumbnail-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes fr-thumbnail-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

/* Error */
.fr-error {
  float: left;
  position: relative;
  background-color: #ca3434;
  width: 160px;
  height: 160px;
}

.fr-error-icon {
  position: absolute;
  width: 42px;
  height: 42px;
  top: 50%;
  left: 50%;
  margin-left: -21px;
  margin-top: -21px;
}

/* skin: 'fresco' */

/* Sprite */
.fr-window-skin-fresco .fr-side-button-icon,
.fr-window-skin-fresco .fr-close-icon,
.fr-window-skin-fresco .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco .fr-error-icon {
  background-image: url("../../files/layout-erding/images/sprite.svg");
}
/* fallback png sprite */
.fr-window-skin-fresco.fr-no-svg .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg .fr-close-icon,
.fr-window-skin-fresco.fr-no-svg .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco .fr-error-icon {
  background-image: url("../../files/layout-erding/images/sprite.png");
}

.fr-window-skin-fresco .fr-error-icon {
  background-position: -160px -126px;
}

.fr-window-skin-fresco .fr-content-background {
  background: #101010;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.4);
}
.fr-window-skin-fresco.fr-window-ui-fullclick .fr-content-background {
  box-shadow: none;
}

/* thumbnail shadow */
.fr-window-skin-fresco .fr-thumbnail-wrapper {
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
}
.fr-window-skin-fresco .fr-thumbnail-active .fr-thumbnail-wrapper {
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
}

/* < > */
.fr-window-skin-fresco .fr-side-button-background {
  background-color: transparent;
}
.fr-window-skin-fresco .fr-side-previous .fr-side-button-icon {
  background-position: -13px -14px;
}
.fr-window-skin-fresco .fr-side-next .fr-side-button-icon {
  background-position: -93px -14px;
}

.fr-window-skin-fresco .fr-side-previous:hover .fr-side-button-icon {
  background-position: -13px -114px;
}
.fr-window-skin-fresco .fr-side-next:hover .fr-side-button-icon {
  background-position: -93px -114px;
}

/* transition (png) */
.fr-window-skin-fresco.fr-no-svg
  .fr-hovering-previous
  .fr-side-previous
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg.fr-mobile-touch
  .fr-side-previous
  .fr-side-button-icon {
  background-position: -13px -114px;
}
.fr-window-skin-fresco.fr-no-svg
  .fr-hovering-next
  .fr-side-next
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg.fr-mobile-touch
  .fr-side-next
  .fr-side-button-icon {
  background-position: -93px -114px;
}

/* disabled state (png) */
.fr-window-skin-fresco.fr-no-svg
  .fr-side-previous.fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg
  .fr-hovering-previous
  .fr-side-previous.fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg
  .fr-side-previous.fr-side-disabled:hover
  .fr-side-button-icon {
  background-position: -13px -214px;
}
.fr-window-skin-fresco.fr-no-svg
  .fr-side-next.fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg
  .fr-hovering-next
  .fr-side-next.fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-no-svg
  .fr-side-next.fr-side-disabled:hover
  .fr-side-button-icon {
  background-position: -93px -214px;
}

/* transition (svg) */
.fr-window-skin-fresco.fr-svg .fr-side-previous .fr-side-button-icon {
  background-position: -13px -114px;
}
.fr-window-skin-fresco.fr-svg .fr-side-next .fr-side-button-icon {
  background-position: -93px -114px;
}
.fr-window-skin-fresco.fr-svg .fr-side-button-icon {
  opacity: 0.5;
}

.fr-window-skin-fresco.fr-svg .fr-side:hover .fr-side-button-icon,
.fr-window-skin-fresco.fr-svg
  .fr-hovering-previous
  .fr-side-previous
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-svg
  .fr-hovering-next
  .fr-side-next
  .fr-side-button-icon {
  opacity: 1;
}

.fr-window-skin-fresco.fr-svg.fr-mobile-touch .fr-side .fr-side-button-icon {
  opacity: 0.8;
} /* touch always active but at lower opacity */

/* disabled (svg) */
.fr-window-skin-fresco.fr-svg .fr-side-disabled .fr-side-button-icon,
.fr-window-skin-fresco.fr-svg
  .fr-hovering-previous
  .fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-svg
  .fr-hovering-next
  .fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-svg .fr-side-disabled:hover .fr-side-button-icon,
.fr-window-skin-fresco.fr-svg.fr-mobile-touch
  .fr-side-disabled
  .fr-side-button-icon {
  opacity: 0.2;
}

/* hide for ui:inside/fullclick, only for the image type */
.fr-window-skin-fresco.fr-window-ui-inside
  .fr-type-image
  .fr-side-disabled
  .fr-side-button-icon,
.fr-window-skin-fresco.fr-window-ui-fullclick.fr-showing-type-image
  .fr-side-disabled
  .fr-side-button-icon {
  background-image: none;
}

/* < > responsive */
@media all and (max-width: 500px) and (orientation: portrait),
  all and (orientation: landscape) and (max-height: 414px) {
  .fr-window-skin-fresco .fr-side-previous .fr-side-button-icon {
    background-position: 0px -300px;
  }
  .fr-window-skin-fresco .fr-side-next .fr-side-button-icon {
    background-position: -48px -300px;
  }

  .fr-window-skin-fresco .fr-side-previous:hover .fr-side-button-icon {
    background-position: 0px -360px;
  }
  .fr-window-skin-fresco .fr-side-next:hover .fr-side-button-icon {
    background-position: -48px -360px;
  }

  /* transition (png) */
  .fr-window-skin-fresco.fr-no-svg
    .fr-hovering-previous
    .fr-side-previous
    .fr-side-button-icon,
  .fr-window-skin-fresco.fr-no-svg.fr-mobile-touch
    .fr-side-previous
    .fr-side-button-icon {
    background-position: 0px -360px;
  }
  .fr-window-skin-fresco.fr-no-svg
    .fr-hovering-next
    .fr-side-next
    .fr-side-button-icon,
  .fr-window-skin-fresco.fr-no-svg.fr-mobile-touch
    .fr-side-next
    .fr-side-button-icon {
    background-position: -48px -360px;
  }

  /* transition (svg) */
  .fr-window-skin-fresco.fr-svg .fr-side-previous .fr-side-button-icon {
    background-position: 0px -360px;
  }
  .fr-window-skin-fresco.fr-svg .fr-side-next .fr-side-button-icon {
    background-position: -48px -360px;
  }

  /* disabled state (png) */
  .fr-window-skin-fresco.fr-no-svg
    .fr-side-previous.fr-side-disabled
    .fr-side-button-icon,
  .fr-window-skin-fresco.fr-no-svg
    .fr-hovering-previous
    .fr-side-previous.fr-side-disabled
    .fr-side-button-icon,
  .fr-window-skin-fresco.fr-no-svg
    .fr-side-previous.fr-side-disabled:hover
    .fr-side-button-icon {
    background-position: 0px -420px;
  }

  .fr-window-skin-fresco.fr-no-svg
    .fr-side-next.fr-side-disabled
    .fr-side-button-icon,
  .fr-window-skin-fresco.fr-no-svg
    .fr-hovering-next
    .fr-side-next.fr-side-disabled
    .fr-side-button-icon,
  .fr-window-skin-fresco.fr-no-svg
    .fr-side-next.fr-side-disabled:hover
    .fr-side-button-icon {
    background-position: -48px -420px;
  }
}

/* X */
/* colors */
.fr-window-skin-fresco.fr-window-ui-outside .fr-close-background {
  background-color: #363636;
}
.fr-window-skin-fresco.fr-window-ui-outside
  .fr-close:hover
  .fr-close-background {
  background-color: #434343;
}

.fr-window-skin-fresco.fr-window-ui-inside .fr-close-background,
.fr-window-skin-fresco.fr-window-ui-fullclick .fr-close-background {
  background-color: #131313;
  filter: alpha(opacity=80);
  opacity: 0.8;
}
.fr-window-skin-fresco.fr-window-ui-inside .fr-close:hover .fr-close-background,
.fr-window-skin-fresco.fr-window-ui-fullclick
  .fr-close:hover
  .fr-close-background {
  background-color: #191919;
}

/* - image */
.fr-window-skin-fresco .fr-close .fr-close-icon {
  background-position: -168px -8px;
}
.fr-window-skin-fresco .fr-close:hover .fr-close-icon {
  background-position: -210px -8px;
}

/* - transition */
.fr-window-skin-fresco.fr-svg .fr-close .fr-close-icon {
  background-position: -210px -8px;
  opacity: 0.8;
}
.fr-window-skin-fresco .fr-close:hover .fr-close-icon {
  opacity: 1;
}
/* iOS 8.4.1 bug: when opacity changes it'll require 2 taps
   force a single opacity to fix this
*/
.fr-window-skin-fresco.fr-svg.fr-mobile-touch .fr-close .fr-close-icon,
.fr-window-skin-fresco.fr-mobile-touch .fr-close:hover .fr-close-icon {
  opacity: 1;
}

/* Thumbnails */
.fr-window-skin-fresco .fr-thumbnail-wrapper {
  border-color: transparent;
  border-style: solid;
  border-width: 0;
}
.fr-window-skin-fresco .fr-thumbnail-wrapper {
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
}
.fr-window-skin-fresco .fr-thumbnail-active .fr-thumbnail-wrapper {
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
}
.fr-window-skin-fresco .fr-thumbnail-wrapper {
  box-shadow: 0 -1px 4px rgba(0, 0, 0, 0.3);
}
.fr-window-skin-fresco .fr-thumbnail-overlay-border {
  border-width: 1px;
  border-color: rgba(255, 255, 255, 0.08); /* should remain rgba */
}
/* no inner border on active thumbnail */
.fr-window-skin-fresco .fr-thumbnail-active .fr-thumbnail-overlay-border,
.fr-window-skin-fresco .fr-thumbnail-active:hover .fr-thumbnail-overlay-border {
  border: 0;
}

/* Thumbnails < > */
.fr-window-skin-fresco
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-icon {
  background-position: -167px -49px;
}
.fr-window-skin-fresco
  .fr-thumbnails-side-previous:hover
  .fr-thumbnails-side-button-icon {
  background-position: -209px -49px;
}
.fr-window-skin-fresco
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-icon {
  background-position: -167px -91px;
}
.fr-window-skin-fresco
  .fr-thumbnails-side-next:hover
  .fr-thumbnails-side-button-icon {
  background-position: -209px -91px;
}
/* vertical ^ (up/down) adjustments */
.fr-window-skin-fresco.fr-thumbnails-vertical
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-icon {
  background-position: -293px -49px;
}
.fr-window-skin-fresco.fr-thumbnails-vertical
  .fr-thumbnails-side-previous:hover
  .fr-thumbnails-side-button-icon {
  background-position: -335px -49px;
}
.fr-window-skin-fresco.fr-thumbnails-vertical
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-icon {
  background-position: -293px -91px;
}
.fr-window-skin-fresco.fr-thumbnails-vertical
  .fr-thumbnails-side-next:hover
  .fr-thumbnails-side-button-icon {
  background-position: -335px -91px;
}

/* Thumbnails < > transition */
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side
  .fr-thumbnails-side-button-icon {
  -moz-transition: opacity 0.2s ease-in;
  -webkit-transition: opacity 0.2s ease-in;
  transition: opacity 0.2s ease-in;
  opacity: 0.8;
}
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-disabled {
  background-position: -167px -49px;
}
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-disabled {
  background-position: -209px -91px;
}
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side:hover
  .fr-thumbnails-side-button-icon {
  opacity: 1;
}
/* vertical ^ (up/down) adjustments */
.fr-window-skin-fresco.fr-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-disabled {
  background-position: -293px -49px;
}
.fr-window-skin-fresco.fr-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-disabled {
  background-position: -335px -91px;
}

/* lower opacity on disabled states */
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side
  .fr-thumbnails-side-button-disabled,
.fr-window-skin-fresco.fr-svg
  .fr-thumbnails-side:hover
  .fr-thumbnails-side-button-disabled {
  opacity: 0.5;
}

/* lower opacity IE < 9 using images */
.fr-window-skin-fresco.fr-no-svg
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-no-svg
  .fr-thumbnails-side-previous:hover
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon {
  background-position: -251px -49px;
}
.fr-window-skin-fresco.fr-no-svg
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-no-svg
  .fr-thumbnails-side-next:hover
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon {
  background-position: -251px -91px;
}
.fr-window-skin-fresco.fr-no-svg
  .fr-thumbnails-side
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-background,
.fr-window-skin-fresco.fr-no-svg
  .fr-thumbnails-side:hover
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-background {
  filter: alpha(opacity=50);
}
/* vertical ^ (up/down) adjustments */
.fr-window-skin-fresco.fr-no-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-previous
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-no-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-previous:hover
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon {
  background-position: -377px -49px;
}
.fr-window-skin-fresco.fr-no-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-next
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon,
.fr-window-skin-fresco.fr-no-svg.fr-thumbnails-vertical
  .fr-thumbnails-side-next:hover
  .fr-thumbnails-side-button-disabled
  .fr-thumbnails-side-button-icon {
  background-position: -377px -91px;
}

