/* RESET */

  html, body, div, span, object, iframe,
  h1, h2, h3, h4, h5, h6, p, blockquote, pre,
  abbr, address, cite, code,
  del, dfn, em, img, ins, kbd, q, samp,
  small, strong, sub, sup, var,
  b, i,
  dl, dt, dd, ol, ul, li,
  fieldset, form, label, legend,
  table, caption, tbody, tfoot, thead, tr, th, td,
  article, aside, canvas, details, figcaption, figure,
  footer, header, hgroup, menu, nav, section, summary,
  time, mark, audio, video {
  margin:0;
  padding:0;
  border:0;
  outline:0;
  vertical-align:baseline;
  background:transparent;
  }
  
  
  *,*:focus,*:hover{
    outline:none;
}

html, body {
   min-height: 100%;
   scroll-behavior: smooth;
}
*{ 
  -webkit-box-sizing: border-box; /* Safari/Chrome, other WebKit */
  -moz-box-sizing: border-box;    /* Firefox, other Gecko */
  box-sizing: border-box;         /* Opera/IE 8+ */
}
.wrapper:after,
.bg-row:after {
  content: "";
  display: block;
  clear: both; 
}

.bg1 {
	background: #fff;
}
.bg2 {
	background: #c6c5f1;
}
li {
	margin-left: 17px;
}

.clear {
  clear: both;
  line-height: 0;
}

.marginauto {
	margin-left: auto;
	margin-right: auto;
}

.uppercase {
	text-transform: uppercase;
}

img {
	display: block;
	max-width: 100%;
}


.nowrap {
  white-space: nowrap;
}

.center {
  text-align: center;
}

.uppercase {
	text-transform: uppercase;
	
}

.float-right {
  float: right;
}


.mobile-only {
  display: block;
}

.desktop-only {
  display: none;
}


h1 {
	font-family: "Montserrat", sans-serif;	
	letter-spacing: 0px;
	font-weight: 600;
	font-size: 24px;
	line-height: 1.1;
	color: #000;
	text-align: center;
	margin: 0;
	margin-bottom: 20px;
   
}


h2 {  
	font-family: "Montserrat";
	font-size: 30px;
	font-weight: 200;
	text-align: center;
	line-height: 1.5;
	color: #000;
	margin: 0 0 24px;
}


h3 {
	font-family: "Montserrat";
	font-size: 28px;
	line-height: 1.2;
	font-weight: 500;
	color: #1D2740;
	margin: 0 0 10px 0;
	text-align: center;
}

.small {
	font-size: 13px;
	line-height: 1.2;
}

a {
  color: #000;
  font-weight: 400;
}

a:hover {
	color: #000;
	text-decoration: underline;
}

.event a {
	
	color: navy;
}

.cookie-bar a:hover {
	color: yellow;
}



a.no-line {
  text-decoration: none !important;
}

select {
    padding: 5px 5px 5px 5px;
    border-radius: 3px;
    font-family: Montserrat, Arial;
    font-size: 14px;
    height: 32px;
    background: #fff;
    width: 120px;
    cursor: pointer;
}



body {	
	
	font-family: "Montserrat", "Arial", sans-serif;
	font-display: swap;
	font-size: 15px;
	line-height: 1.7; 
	color: #000;
	background-color: #fff;
	font-weight: 400;
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
}


section {
	padding: 50px 0 30px;
}

#bgtop {
	width: 100%;
	background-size: cover;
	background-position: center 15%;
	padding: 20px;
	position: relative;
	background-color: #c6c5f1;
	padding-bottom: 50px;
}

.wrapper {
	width: 100%;
	max-width: 1040px;
	margin: 0 auto;	
	padding: 0 10px;
}

#switch-lang {
	margin-top: 10px;
	font-family: "Alegreya Sans";
	font-size: 16px;
}
#switch-lang a{
	color: #fff;
}


.divider {
	margin: 50px auto 5px;
	width: 100%;
	max-width: 1100px;
	background: #26466D;
	height: 1px;
}



#intro {	
	margin: 30px 0;
}

#intro-image, #about-image {
	max-width: 400px;
	margin: 0 auto;
}

#intro-image img, #about-image img{
	width: 100%;
	height: auto;
}

#intro-text {
	font-size: 18px;
	line-height: 1.8;
	background: #fff;
	border-radius: 5px;
	padding: 10px;
	margin-top: 50px;
}

.cta {
	margin-top: 20px;
	background: #ffc1f4;
    border-radius: 4px;
    border: 1px solid #FF83FA;
    text-align: center;
    padding: 5px;
    font-weight: 500;
    cursor: pointer;
}

.ctalink{
	text-decoration: none;
}

.mp-wrap {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.col-wrapper {
    width: 100%;
    padding: 0;
    margin: 30px auto;
    list-style: none;
    -ms-box-orient: horizontal;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -moz-flex;
    display: -webkit-flex;
    display: flex;
    justify-content: center;
}

.col {
	width: 280px;
	margin: 30px 15px;
	background: #fff;
	color: #1D2740;
	padding: 15px 20px 20px;
	border: 1px solid #bfffca;
	min-height: 350px;
	position: relative;
}
.col h3{	
	font-size: 18px;
	font-weight: 600;
	color: #000;
}
.col-img {
	height: 280px;
	//background-color: grey;
	margin-bottom: 10px;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}
.modal-top {
	display: table;
	margin-bottom: 20px;
}
.modal-img {
	display:table-cell;
	height: 100px;
	width: 100px;
	//background-color: grey;
	margin-bottom: 10px;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}
.modal-intro {
	display:table-cell;
    vertical-align:middle;
	padding-left: 20px;
	font-weight: 500;
}

.col-txt{	
	margin-bottom: 45px;
	position: relative;
}

.col-bottom{	
	position: absolute;
	bottom: 18px;
	left: 20px;
	right: 20px;
	background: #ffc1f4;
	border-radius: 4px;
	border: 1px solid #FF83FA;
	text-align: center;
	padding: 5px;
	text-transform: uppercase;
	font-weight: 600;
	cursor: pointer;
}

#portfolio-wrapper{
	width: 300px;
	margin: 0 auto 50px;
	position: relative;
}

#portfolioSlider {
    position: relative;      /* recommended */
}
#portfolioSlider .MS-content {
    white-space: nowrap;     /* required */
    overflow: hidden;        /* required */
    margin: 0 25px;            /* makes room for L/R arrows */
	border-radius: 5px;
}
#portfolioSlider .MS-content .item {
    display: inline-block;   /* required */
    width: 100%;              /* required * Determines number of visible slides */
    position: relative;      /* required */
    vertical-align: top;     /* required */
    overflow: hidden;        /* required */
    //height: 100%;            /* recommended */
    white-space: normal;     /* recommended */
	background: #c6c5f1;
	padding: 20px;
}
#portfolioSlider .MS-controls button {
    position: absolute;      /* recommended */
    top: 45%;
	
	width: 40px;
	height: 40px;
	background: #F0F0F0;
    border: 1px solid #A8A8A8;
    border-radius: 50%;
	cursor:pointer;
}
#portfolioSlider .MS-controls .MS-left {
    left: 0px;
}
#portfolioSlider .MS-controls .MS-left img{
    padding-left: 2px;
}

#portfolioSlider .MS-controls .MS-right {
    right: 0px;
}
#portfolioSlider .MS-controls .MS-right img{
    padding-left: 7px;
}

.portfolio-slide {	
	background: #fff;
	border: 1px solid #bfffca;
	height: 315px;
	border-radius: 4px;
}

.portfolio-image {
	background-color: #f5f5f5;
	height: 140px;
	padding: 10px;
	border-radius: 4px 4px 0 0;
}

.portfolio-image img {
	height: 120px;
	width: 188px;
	object-fit: contain;
	object-position: center;
}
.portfolio-text {
	padding: 10px;
	height: 175px;		
	display: grid;
    grid-template-rows: 50px 1fr 20px;
    grid-gap: 10px;
	text-align: center;
	line-height: 1.3;
}



.portfolio-top {
	font-style: italic;
}
.portfolio-middle {
	font-size: 16px;
	font-weight: 500;
}
.portfolio-bottom {
}



.slick-prev,
.slick-next
{
    width: 40px;
    height: 40px;
    padding: 0;    
}



.slick-prev:before,
.slick-next:before
{
   
    font-size: 0;
    
}

#contact {	
	position: relative;
	background-size: cover;
	background-position: center;
	padding: 30px 0 0 0;
}

#contact h2{
	padding-top: 12px;
	
}

#contact-logo {
	display: none;
}

#contact-wrapper {
	line-height: 2.5;
	background-color: #fff;
	border: 1px solid #bfffca;
	padding: 15px;
	border-radius: 5px;
	width: 100%;
	max-width: 320px;
	margin: 20px auto 50px;
}
.contact-toptext {
	margin: 0 0 34px;
	font-size: 22px;
	text-align: center;
}

#contact-bg {	
	
}


.c-text {
	white-space: nowrap;
}

.c-text img{
	width: 20px;
	display: inline-block;
	vertical-align: middle;
}
.c-text a {
	color: black;
}

.soc_desktop {
	display: none;
}

.event {
	max-width: 100%;
	width: 500px;
	background: #E0EEEE;	
	color: #1D2740;	
	border-radius: 4px;
	margin: 0 auto;
}
.event-left, .event-right {
	padding: 20px;
}
.event-left {	
	max-height: 460px;
	max-width: 100%;
	border-radius: 0 0 4px 4px;
}
.event-left img{
	
	margin: 0 auto;
}	
.event-right {	
	overflow-wrap: break-word;
}

.event-title {
	font-size: 24px;
	font-weight: bold;
}

#footer {
	width: 100%;
	padding-bottom: 10px;
}

.footercol {
	text-align: center;
	margin: 20px auto;
	
}

#cookies-link {
	cursor: pointer;
}

#links {
	font-size: 14px;
	line-height: 2;
}

#fb-share img {	
	width: 140px;
	margin: 0 auto 20px;
}
#attributions {
	font-size: 13px;
}



@media all and (min-width: 570px){
	
	#portfolio-wrapper {
		width: 550px;
	}
	#portfolioSlider .MS-content .item {    
		width: 50%;  
	}
	
	
}


@media all and (min-width: 600px){
	
	
	h1 {
		font-size: 30px;
	}
		
	.footercol {
		width: calc((100% - 140px) / 2);
		float: left;
		text-align: left;
	}
	
	#fb-share.footercol {
		width: 140px;
	}
	
	#attributions {
		text-align: right !important;
	}
}

@media all and (min-width: 690px){
	
	#contact-wrapper {
		max-width: 520px;
	}
	
	.soc_desktop {
		display: block;
		font-size: 16px;
	}
	
	.soc_mobile {
		display: none;
	}

}
@media all and (min-width: 900px){
	
	.table {
		display: table;
	}
	
	#intro-image, #about-text{
		width: 53%;	
		display: table-cell;
		padding-right: 6%;
		vertical-align: top;
	}
	
	#intro-text, #about-image {
		width: 47%;	
		display: table-cell;
		font-size: 20px;
		
		background: transparent;
		border-radius: 0;
		padding: 0;
		margin-top: 0;
		
		vertical-align: top;

	}
	#about-image {
		padding-top: 0;
	}
	
	#intro-text {
		font-size: 18px;
	}
	#about-text {
		font-size: 16px;
		line-height: 1.7;
	}
	
	#mobile_lang {
		display: none;
	}
	
	#lang a{
		color: #fff;
	}

	
	.wrapper {
		//padding: 0;
	}
	
	#logo {
	
	}

	
	
	.col-wrapper {
		display: flex;
        margin: 30px 0;		
		column-gap: 30px;
	}
	
	.col {
		flex: 1;
		margin: 0;
		border-radius: 4px;
	}
	
	.double-col {
		flex: 2 0 0%;
		border: 1px solid white;
	}
	.single-col {
		flex: 1 0 0%;
		border: 1px solid white;
	}
	
	
	.event {	
		max-width: 800px;
        margin: 30px auto;	
		width: 800px;	
		position: relative;
		overflow: auto;
	}
	
	.event-left, .event-right {
		width: 400px;
		float: left;
		padding: 20px;
	}
	.event-left  {
		text-align: center;
	}
	.event-left img{
		max-width: 360px;
		max-height: 360px;
	}	
	.event-right {
		
	}
	
	
	h1 {
		font-size: 26px;
		margin-top: -10px;
		margin-bottom: 0;
	}
	
	#services_footer {
		font-size:22px;
	}
	
	#contact {
		font-size:16px;
	}
	
	
	
}

@media all and (min-width: 840px){
	
	#portfolio-wrapper {
		width: 800px;
	}
	#portfolioSlider .MS-content .item {    
		width: 33.3333%;  
	}
	
	#contact-outerwrapper {
		width: 780px;
		margin: 20px auto 50px;
		overflow: auto;
	}
	
	#contact-logo {
		display: block;
		float: left;
		width: 240px;
		padding-right: 20px;
	}
	#contact-name {
		font-size: 16px;
		font-weight: 600;
		text-align: center;
		padding-top: 5px;
	}
	
	#contact-wrapper {
		width: 520px;
		float: right;
		margin: 0;
	}
	
	#contact-wrapper:after{
		clear: both;
	}
}

@media all and (min-width: 1000px){
	
	#intro-text {
		font-size: 20px;
	}
	#about-text {
		font-size: 17px;
		line-height: 1.7;
	}
	
	h2 {
		font-size: 40px;
	}
	
	
}


@media all and (min-width: 1100px){
	
	#intro-text {
		font-size: 21px;
	}
	
	.cta {
		margin-top: 10px;
	}
	
	#about-text {
		font-size: 18px;
		line-height: 1.7;
	}
	
	
	#portfolio-wrapper {
		width: 1050px;
	}
	#portfolioSlider .MS-content .item {    
		width: 25%;  
	}

	
}


@media all and (min-width: 1900px){
	
	#content-wrapper {
		margin-bottom: 80px;
	}
	
	#footer {		
		padding-bottom: 30px;
	}
}


/* reviews slider */

.highlight {display: none}


/* Slideshow container */
.slideshow-container {
	width: 800px;
	max-width: 80%;
	position: relative;
	margin: 30px auto 10px;
	height: 410px;
	border: 1px solid #26466D;
	background-color: #fff;
	border-radius: 3px;
}

/* Next & previous buttons */
.prev, .next {
  cursor: pointer;
  position: absolute;
  top: 50%;
  width: auto;
  padding: 12px;
  margin-top: -42px;
  color: white;
  font-weight: bold;
  font-size: 40px;
  transition: 0.6s ease;
  border-radius: 0 3px 3px 0;
  user-select: none;
  text-decoration: none;
}

/* Position the "next button" to the right */
.next {
  right: -44px;
  border-radius: 3px 0 0 3px;
}
.prev {
  left: -44px;
  border-radius: 3px 0 0 3px;
}

/* On hover, add a black background color with a little bit see-through */
.prev:hover, .next:hover {
  background-color: rgba(256,256,256,0.5);
  text-decoration: none;
}


/* The dots/bullets/indicators */
.slideshow-container.dot {
  cursor: pointer;
  height: 15px;
  width: 15px;
  margin: 0 2px;
  background-color: #bbb;
  border-radius: 50%;
  display: inline-block;
  transition: background-color 0.6s ease;
}

.slideshow-container.active, .slideshow-container.dot:hover {
  //background-color: #717171;
}

/* Fading animation */
.fade {
  animation-name: fade;
  animation-duration: 1.5s;
}

@keyframes fade {
  from {opacity: .4} 
  to {opacity: 1}
}

.slide-content{
	margin: 0 40px;
	overflow: hidden;
}
.card{
	position: relative;
    
    height: 400px;
    border: 1px solid #D6D6D6;
    display: block;
    cursor: pointer;
    background: #fff;
    box-shadow: none;
	border-radius: 5px;
}

.card-content{
	padding: 10px 14px;  
	overflow-y: scroll;
	height: 400px;
}

.card-image {
	height: 150px;
	width: 150px;
	background: transparent;
	margin: 0 auto;
}
.card-image img{
	height: 100%;
	width: 100%;
	object-fit: cover;
	border-radius: 90px;
}
.reviewer {	
	text-align: center;
}

.name{
	font-size: 18px;
	font-weight: 500;
	color: #333;
  
}
.description{
	margin-top: 10px;
	font-size: 14px;
	color: #141414;
	text-align: left;
}

@media all and (min-width: 600px){
	
	.card-top {
		display:flex;
		align-items: center;
	}
	
	.card-image {
		
		margin-right: 20px;
	}
	.reviewer {
		width: calc(100% - 180px);
		text-align: left;
	}
	.description {
		clear: both;
	}
}

@media all and (min-width: 800px){
	
	.card-content{
		padding: 10px 14px;  
		overflow-y: auto;
	}
}	



@media all and (min-width: 900px){

.slideshow-container {			
		height: 340px;
	}
	.card-content{
		height: 330px;
	}
	
}
/* end reviews slider */