:root {
	--theme-red: #7b2027;
}

@font-face {
    font-family: Trivia-Light;
    src: url("/fonts/trivial-light.otf") format("opentype");
}

@font-face {
    font-family: Rubik;
    src: url("/fonts/Rubik-Regular.ttf") format("truetype");
}

@font-face {
    font-family: RubikMedium;
    src: url("/fonts/Rubik-Medium.ttf") format("truetype");
}

body {
	position: relative;
	background: #fff;
	color: #666;
	font-family: 'Rubik', Arial, Helvetica, sans-serif;
	font-size:14px;
}
/*
img {
	flex-shrink: 0 !important;
}
*/
a {
	color:var(--theme-red);
	text-decoration: underline;
}

a:hover, a:active, a:focus {
	color:var(--theme-red);
	outline: none;
	text-decoration: none;
}


a.pdf_small {
	display:inline-block;
    background-image: url("/img/pdf_small.png");
    background-position: 0 0;
    background-repeat: no-repeat;
    padding: 1px 0 0px 26px;
	text-align: right;

}

p {
	padding: 0;
	margin: 0 0 25px 0;
	line-height: 20px;
}

.partial-image {
	margin: 0 0 25px 0;
}

.underlined {
	text-decoration: underline;
}

.lowercase {
	text-transform: lowercase;
}

.green {
	color:var(--theme-red);
}

strong, b {
	font-family: "RubikMedium", Arial, Helvetica, sans-serif;
	font-weight:normal;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 400;
  margin: 0 0 20px 0;
  padding: 0;
}


@media (max-width: 768px) {
	
	section {
		position: relative;
	}

}

@media (min-width: 768px) {
	
	section {
		position: relative;
		padding-top: 0rem;
		padding-bottom:0rem;
	}
		
}

#navbar.header-fixed,
#header.header-fixed,
#navbar-fixed {
	display:none;
	position: fixed;
	top:0px;
	left:0px;
	width:100vw;
	
	background:#FFF;
	-webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	z-index: 150;
}

hr {
	height:1px;
	border-bottom:1px dotted #000;
}

h1 {
	font-family: Trivia-Light, Arial, Helvetica, sans-serif;
	text-transform: uppercase;
	font-weight: normal;
	font-size: 32px;
	margin-bottom:0.5rem;
	margin-top:-5px;
	color:#000;
	line-height: 1.1;
}

h2 {
	color:var(--theme-red);
	position: relative;
	text-transform: uppercase;
	font-size: 14px;
	margin-bottom:2rem;
	padding: 0 0 15px 0;
	border-bottom: 1px solid #c0beb1;
	line-height: 1.4;
}

h2:after, h2:before {
	top: 100%;
	left: 60px;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
}

h2:after {
	border-color: rgba(255, 255, 255, 0);
	border-top-color: #FFF;
	border-top-width: 10px;
	border-right-width: 10px;
	border-bottom-width: 10px;
	border-left-width: 10px;
	margin-left: -20px;
}
h2:before {
	border-color: rgba(192, 190, 177, 0);
	border-top-color: #c0beb1;
	border-top-width: 11px;
	border-right-width: 11px;
	border-bottom-width: 11px;
	border-left-width: 11px;
	margin-left: -21px;
}

h3 {
	padding: 0;
	margin: 0;
	line-height: 20px;
	font-family: "RubikMedium", Arial, Helvetica, sans-serif;
	font-weight:normal;
	color:#000;
	font-size:14px;
}


h4 {
	font-size: 28px;
	margin-bottom:1.2rem;
	line-height:1.3;
}

iframe {
	width:100%;
}


/* Aspect Ratios */
.ratio-16-9 {
	position:relative;
}

.ratio-16-9::after {
	display: block;
	content: "";
	width: 100%;
	padding-top: 56.25%;
}

/* Listen */
#content ul {
	margin:0px 0 25px 16px;
	padding: 0;

}

#content ul li {
	position: relative;
	margin:0;
	padding: 0 0px 0 0px;

}


.bg-cover { 
	background-repeat: no-repeat;
	background-position: center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.h1-icon .row > div:last-child .partial {
	margin-right:15px;
}

@media (min-width: 992px) {
	.h1-icon .row > div:last-child .partial {
		margin-left:15px;
		margin-right:0;
	}
}
/* old ? */
.h1-icon .col-right {
	flex: 0 0 150px;
	flex:1;
}

@media (min-width: 576px) {
	.h1-icon .col-right {
		flex: 0 0 180px;
		flex:1;
	}
}


.trans-40 {
	opacity:0.4;
}


.image-teaser {
	position:relative;
	padding-bottom:200px !important;
	
}

.image-teaser p {
	font-size:26px;
	text-transform: uppercase;
}

.image-teaser .container {
	/*margin-top:-150px;*/
}

.image-teaser .bg {
    position: absolute;
    left: 0px;
    top: 150px;
    width: 100%;
    height: calc(100% - 150px);
}

.img-fit-cover .partial-image {
    position: absolute;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.img-fit-cover .partial-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}




/* table */
.responsive-table h3 {

	background-color: #455460;
	color:#FFF;
	font-size:26px;
	line-height: 31px;
	padding: 10px 50px;
	position: relative;
	margin:0 0 0px 0;
	font-weight: normal;
	text-transform: uppercase;
}

.responsive-table h3::after {
	top: 100%;
	left: 70px;
	border: solid transparent;
	content: " ";
	width: 22px;
	height: 11px;
	position: absolute;
	pointer-events: none;
	z-index: 800;
	border-color: rgba(255, 255, 255, 0);
	border-top-color: #455460;
	border-width: 11px 11px 0 11px;	
}

.responsive-table .row {
	margin:0;
	background-color: #fbfbfa;
}

.responsive-table .row:nth-of-type(2n+1) {
    background-color: #f2f2ef;
}

.responsive-table .row > div {
	font-size:18px;
	padding:25px 50px;
}



.responsive-table > div:first-child {
	margin-top:10px;
}

@media (max-width: 767px) {
	.responsive-table > div:first-child {
		margin-top:10px;
	}
	
	.responsive-table .row > div {
		padding:10px 30px;
	}

	
}

@media (min-width: 768px) {
	.responsive-table .row > div {
		padding:20px 30px;
	}
	
	
}

@media (min-width: 992px) {
	.responsive-table .row > div {
		padding:30px 30px;
	}
}

@media (min-width: 1200px) {
	.responsive-table .row > div {
		padding:30px 30px;
	}
	
	.responsive-table .row > div:first-child {
		padding-left: 50px;
	}
	
}

.table.table-striped th {

	background-color: #455460;
	color:#FFF;
	font-size:26px;
	line-height: 31px;
	padding: 10px 50px;
	position: relative;
	margin:0 0 30px 0;
	font-weight: normal;
	text-transform: uppercase;
}

.table.table-striped tr th:first-child::after {
	top: 100%;
	left: 70px;
	border: solid transparent;
	content: " ";
	width: 22px;
	height: 11px;
	position: absolute;
	pointer-events: none;
	z-index: 800;
	border-color: rgba(255, 255, 255, 0);
	border-top-color: #455460;
	border-width: 11px 11px 0 11px;	
}


.table-striped tbody tr {
    background-color: #fbfbfa;
}

.table-striped tbody tr:nth-of-type(2n+1) {
    background-color: #f2f2ef;
}
.table.table-striped td {
	font-size:18px;
	padding:30px 50px;
}



/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
#logo {
	max-width: 190px;
	margin: 15px 50px 15px 0;
}
@media (min-width: 768px) {
	#logo {
		max-width: 336px;
		margin: 40px 0 25px -20px;
	}
	
	#logo-fixed {
		max-width: 220px;
		margin: 15px 45px 15px -20px;
	}
}

#logo img, #logo-fixed img {
	width:100%;
	height:auto;
	max-width:100%;
}

#header {
	display:block;
	background: url(/img/header-background.png) repeat-x;
	position: relative;
}

.header-shadow {
	-webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
}

#header > div {
	position: relative;
}

#header > div::before, #header > div::after {
	display:block;
	content: "";
	height: 80px;
	background: rgba(255,255,255,0);
	position:absolute;
	left:0;
	bottom:0;
	width:20px;
	z-index: 2;
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#ffffff+0,ffffff+100&0+0,1+83 */
background: -moz-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 83%, rgba(255,255,255,1) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 83%,rgba(255,255,255,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 83%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 ); /* IE6-9 */
}

#header > div::after {
	left:auto;
	right:0;
}
	


#title {
	padding: 15px;
	background:#FFF;
}

#title > div {
	background-image: url(/img/title-background.png);
	background-position: right top;
	background-size: auto 100%;
	background-repeat: no-repeat;

}

#title .row {
	min-height:180px;
}

#titleimage {
	position: relative;
	line-height: 1;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	height: 100% !important;
	/*min-height:200px;*/
}


#quote {
	padding: 30px 30px 0 30px;
	color:#000;
}

#quote span {
	font-size:12px;
}


#quote, #quote p {
	font-size:14px;
	line-height:1.3;
}

@media (max-width: 767px) {
	#quote p {
		margin-bottom:10px;	
	}
	
	#quote {
		padding-bottom:10px;
		padding-top:20px;
	}
	
	#title > div {
		-webkit-border-bottom-right-radius: 30px;
		-moz-border-radius-bottomright: 30px;
		border-bottom-right-radius: 30px;
	}
	
	#titleimage::after {
		display: block;
		content: "";
		width: 100%;
		padding-top: 56.25%;
	}
}

@media (min-width: 768px) {
	#title .row {
		min-height:226px;
	}
	
	#quote, #quote p {
		font-size:16px;
		line-height:1.3;
	}
	
	#titleimage {
		-webkit-border-top-right-radius: 30px;
		-moz-border-radius-topright: 30px;
		border-top-right-radius: 30px;
	}
}

@media (min-width: 992px) {
	#title .row, #titleimage {
		min-height:326px;
	}
	
	#quote, #quote p {
		font-size:24px;
		line-height:1.1;
	}
	
	#quote span {
		font-size:16px;
	}
}


/* CONTENT */
#content {
	position: relative;
	background-color:#FFF;
	padding-top:15px;


	z-index: 40;
	
	
}

.col-left {
	padding: 0 15px;
}



@media (min-width: 768px) {
	.col-left {
		padding: 0 30px 0 15px;
	}
}



@media (min-width: 992px) {
	.col-right {
		padding-left:0 !important;
	}	
}


.box {
	background-color: #F6F6F6;
	-webkit-border-bottom-right-radius: 30px;
	-moz-border-radius-bottomright: 30px;
	border-bottom-right-radius: 30px;
	-webkit-box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.4);
	-moz-box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.4);
	box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.4);
}


.box > div {
	padding: 30px 30px 5px 30px;
}

h4 {
	font-size: 18px;
	background:var(--theme-red);
	color:#FFF;
	padding: 13px 31px;
	text-transform: uppercase;
	position: relative;
	margin: -31px -31px 0 -31px;
}


@media (max-width: 767px) {
	.col-right {
		padding: 0;
	}
	
	.box > div {
		padding: 15px 15px 5px 15px;
	}
	
	h4 {
		margin: -16px -16px 0 -16px;
		padding: 13px 16px;
	}
}

h4::after {
    top: 100%;
    left: 30px;
    border: solid transparent;
    content: " ";
    width: 22px;
    height: 11px;
    position: absolute;
    pointer-events: none;
    z-index: 800;
    border-color: rgba(255, 255, 255, 0);
    border-top-color: var(--theme-red);
    border-width: 11px 11px 0 11px;

}

.box h3 {
	margin-bottom: 15px;
}

/* news */
.newsTeaser {
	margin-bottom:25px;
}

.newsDate {
	color:var(--theme-red);
	border-bottom: 1px solid var(--theme-red);
	margin-bottom:10px;
}

.newsMore {
	display:block;

	
	text-align:right;
	text-decoration: none;
	
}

.newsMore:hover {
	font-family: "RubikMedium", Arial, Helvetica, sans-serif;
	text-decoration: none;
}

/* Navbar */

#navbar {
	width:100%;
	position: relative;
	transition: all 0.5s;
}

@media (max-width: 767px) {
	#navbar {
		display: none;
	}
}

.sf-menu {
	width:100%;
	background-color:#FFF;
	margin-bottom:0;
}

.dropdown-toggle::after {
	display: none;
}

.sf-menu li {
    background: rgba(255,255,255,0);
    white-space: nowrap;
    white-space: normal;
    -webkit-transition: background .2s;
	border-right: 1px solid #FFF;
}

.sf-menu > li:first-child {
	border-left: 1px solid #FFF;
}

.nav-pills .nav-link {
	border-radius: 0;
}

.sf-menu > li > a,
.sf-menu > li > a.sf-with-ul {
	font-family: "Rubik";
	display:block;
	text-transform: uppercase;
	font-size: 15px;
	color:#FFF;
	letter-spacing: 0.02rem;
	border:0;
	padding: 0.7rem 0;
	border-radius: 0;
	background-color:var(--theme-red);
	transition: all .3s;
}

#navbar-fixed .sf-menu > li > a,
#navbar-fixed .sf-menu > li > a.sf-with-ul {
	color:var(--theme-red);
	padding: 0.7rem 0.7rem;
	background-color:#FFF;
	margin-top:8px;
}

.sf-arrows .sf-with-ul::after {
	display:none;  
}

.sf-menu > li > a::before {

    display: block;
    content: attr(data-name);
    font-family: "RubikMedium", Arial, sans-serif;
    visibility: hidden;
    overflow: hidden;
    height: 0px;
    letter-spacing: 0.02rem;
    text-transform: uppercase;

}

.sf-menu > a:hover,
.sf-menu > li:hover > a,
.sf-menu > li.sfHover > a,
.sf-menu > li.active > a{
	background-color: #61060d;
	text-decoration: none;
	border-radius: 0;
	font-family: "RubikMedium", Arial, sans-serif;
	/*padding-left: 1rem;
	padding-right: 1rem; */
}



.sf-menu li:hover,
.sf-menu li.sfHover {
	background-color:#FFF;
	text-decoration: none;
}

.sf-menu ul {
	border:0;
	padding:0;
	background: rgba(255,255,255,0);
	left:-1px;
}

.sf-menu ul li {
    background: #FFF;
	border:0;
}

.sf-menu ul li a {
    color: #075a44;
	border:0;
}

.sf-menu ul li:hover a,
.sf-menu ul li.sfHover a,
.sf-menu ul > li.sfHover > a,
.sf-menu ul > li.active > a {
	font-family: "RubikMedium", Arial, sans-serif;
	text-decoration: none;
}

.navbar {
	padding:0;
}




/* Mobile Nav Toggle */
#mobile-nav-toggle {
	position: fixed;
	left: 100%;
	top: 0;
	z-index: 1200;
	margin: 23px 0px 0 -55px;
	border: 0;
	background: none;
	font-size: 24px;
	display: none;
	transition: all 0.4s;
	outline: none;
	cursor: pointer;
	color: #455460;
}

body.mobile-nav-active #mobile-nav-toggle {
	left: 100%;

}

.mobile-nav-active #mobile-nav-toggle {
	color:#FFF;
}


@media (max-width: 767px) {
  #mobile-nav-toggle {
    display: inline;
  }
}

/* Mobile Nav Styling */
#mobile-nav {
	position: fixed;
	top: 0;
	padding-top: 18px;
	bottom: 0;
	z-index: 1190;
	background-color: rgba(255, 255, 255, 1);
	background-image: url(/img/flower-bg.png);
	background-position:  left bottom;
	background-repeat: no-repeat;
	background-size: contain;
	left: -260px;
	width: 260px;
	max-width:75vw;
	overflow-y: auto;
	transition: 0.4s;
}


#mobile-nav ul {
	padding: 0;
	margin: 0;
	list-style: none;
	width:100%;
}

#mobile-nav ul li {
	position: relative;
}

#mobile-nav ul li:last-child {
	margin-bottom:15px;
}

#mobile-nav ul li:hover i,
#mobile-nav ul li.active i,
#mobile-nav ul li i.fa-chevron-up {
	color:var(--theme-red);
}

#mobile-nav > ul > li > a {
	font-family: 'Rubik', sans-serif;
    font-style: normal;
	color: #000;
	font-size: 20px;
	overflow: hidden;
	padding: 8px 22px 8px 25px;
	position: relative;
	text-decoration: none;
	width: 100%;
	display: block;
	outline: none;
	text-transform: uppercase;
}

#mobile-nav ul li:hover > a,
#mobile-nav ul li.active > a,
#mobile-nav a.active,
#mobile-nav ul .menu-item-active {
	color: var(--theme-red);
	text-decoration: none;
	font-family: "RubikMedium", Arial, sans-serif;
}




#mobile-nav ul .menu-has-children i {
	position: absolute;
	right: 0;
	z-index: 99;
	padding: 15px;
	cursor: pointer;
}

#mobile-nav ul .menu-has-children ul li a {
	padding: 5px 22px 5px 35px;
	font-size: 16px;
	color:#000;

	display:block;
}


#mobile-body-overly {
	width: 100%;
	height: 100%;
	z-index: 1180;
	top: 0;
	left: 0;
	position: fixed;
	background: rgba(123, 32, 39, 0.7);
	display: none;
}

/* Mobile Nav body classes */
body.mobile-nav-active {
  overflow: hidden;
}

body.mobile-nav-active #mobile-nav {
  left: 0;
}

body.mobile-nav-active #mobile-nav-toggle {
  color: #fff;
}


/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
#footer {
	margin: 30px 0 30px 0;
	padding: 5px 0;
	line-height: 1rem;
	border-top: 1px solid #c0beb1;
	color:#999;
	text-align: right;
	font-size: 14px;
}

#footer a {
	color:#999;
	text-decoration:none;
}

#footer a:hover, #footer a.active {
	color:#999;
	text-decoration:underline;
}

#footer p {
	margin:0;
}

ul.social-menu {
	margin:0 -10px;
	padding: 0;
	list-style: none;
	display:flex;
	align-items: center;
}

ul.social-menu li {
	margin:0;
	list-style: none;
	float:left;
	padding: 0 10px;
}


@media (max-width: 575px) {
	
	
	
}


@media (max-width: 767px) {
	#main-content [class^="col-"] {
		margin-bottom:30px;
	}
	
	body {
		padding-top:75px;
	}
	
	#logo-header {
		position:fixed;
		top:0px;
		left:0px;
		width:100%;
		z-index:100;
		background:#FFF;
		height:75px;
		-webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3);
	}
	
	#header {
		padding-top:15px;
	}
	
	h1 {
		font-size:24px;
	}
}

@media (min-width: 768px) {

	
}

@media (min-width: 992px) {


}

@media (min-width: 1200px) {
	
	
	
}


@media (min-width: 768px) and (max-width: 1199px) {
	
}

@media print {
	a[href]:after {
		content: "";
	}
	
	h2, * {
	font-family: 'Arial', sans-serif;
	}
}
