/** Generated: Tuesday, 1st of July 2025, 03:09:05 PM // Powered by AIOM+ (All In One Minify) created by FlipZoom Media Inc. - David Karich (flipzoom.de) **/
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
/*@font-face { font-family: 'Open Sans'; src:  url('/files/fonts/OpenSans-Regular.woff2') format('woff2'), url('/files/fonts/OpenSans-Regular.woff') format('woff'); }*/
@font-face {
	font-family: 'Montserrat';
	src:  url('/files/fonts/Montserrat-Regular.woff2') format('woff2'), url('/files/fonts/Montserrat-Regular.woff') format('woff');
	font-weight: 400;
	font-style: normal;
	font-display: swap
}
@font-face {
	font-family: 'Montserrat';
	src:  url('/files/fonts/Montserrat-ExtraBold.woff2') format('woff2'), url('/files/fonts/Montserrat-ExtraBold.woff') format('woff');
	font-weight: 800;
	font-style: normal;
	font-display: swap
}

* {
	text-decoration: none;
	margin: 0;
	padding: 0;
}

*,
:after,
:before { box-sizing: border-box }

textarea,
select,
input:not([type=checkbox]):not([type=radio]),
button {
	-webkit-appearance: none;
	outline: none;
}

a:hover { transition: all .3s ease }

body {
	width: 100vw;
	overflow-x: hidden;
}

.up { text-transform: uppercase }

img {
	max-width: 100%;
	height: auto
}

html,
body,
.h-100 { height: 100% }

#wrap {
	min-height: 100%;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	width: 100vw;
}

header,
main,
footer { flex-shrink: 0 }

main { flex-grow: 1 }

#hero,
.rel,
.video { position: relative }

.abs,
.video iframe,
.video video { position: absolute }

.btn,
.tc { text-align: center }

.tr { text-align: right }

.tl { text-align: left }

.text-white { color: #fff }

html { -ms-overflow-style: scrollbar }

#menu-toggler,
.hidden,
.tab-content,
[hidden],
input.hidden:not([type=checkbox]):not([type=radio]){ display: none }

#logo,
.block,
.nav-item a,
input:not([type=checkbox]):not([type=radio]),
label,
select,
textarea,
.panel.show { display: block }

.inl,
.btn,
.nav-item {
	display: inline-block;
	position: relative
}

.mid { vertical-align: middle }

strong { font-weight: bolder }
.vh-100 { min-height: 100vh }
.vw-100 { width: 100vw }

h1,
h2 { line-height: 1.15em }

#details .item,
h1,
h2,
h3,
main ul,
ol,
p,
table { margin-bottom: 15px }

header .ui-title,
header ul,
main ul:last-child,
ol:last-child,
p:last-child,
.mb-0 { margin-bottom: 0 }

main ul,
ol { margin-left: 18px }

.clear { clear: both }

.w-100,
input[type=submit].btn-block,
input[type=reset].btn-block,
input[type=button].btn-block { width: 100% }

.w-50 { width: 50% }

#menu-toggler {
	border: none;
	z-index: 1500
}
a,
#menu-toggler,
.point,
button { cursor: pointer }

select.custom {
	background-image: url(data:image/svg+xml;charset=utf-8,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20x%3D%220px%22%20y%3D%220px%22%20fill%3D%22%23555555%22%20%0A%09%20width%3D%2224px%22%20height%3D%2224px%22%20viewBox%3D%22-261%20145.2%2024%2024%22%20style%3D%22enable-background%3Anew%20-261%20145.2%2024%2024%3B%22%20xml%3Aspace%3D%22preserve%22%3E%0A%3Cpath%20d%3D%22M-245.3%2C156.1l-3.6-6.5l-3.7%2C6.5%20M-252.7%2C159l3.7%2C6.5l3.6-6.5%22%2F%3E%0A%3C%2Fsvg%3E);
	padding-right: 25px;
	background-repeat: no-repeat;
	background-position: right center;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none
}

input:not([type=checkbox]):not([type=radio]),
select,
textarea {
	width: 100%;
	font-size: 1rem;
	padding: .375rem .75rem;
	color: #495057;
	background-color: #fff;
	border: 1px solid #ced4da;
	border-radius: 5px;
	line-height: 1.4rem
}

label { margin-bottom: 4px }

.container {
	width: 95%;
	max-width: 1200px;
	padding-right: 15px;
	padding-left: 15px;
	margin-right: auto;
	margin-left: auto;
	position: relative
}

.flex,
.cell,
.row {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.cell {
	-webkit-flex-direction: column;
	-moz-flex-direction: column;
	-ms-flex-direction: column;
	-o-flex-direction: column;
	flex-direction: column;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.jr {
	justify-content: flex-end;
	flex-grow: 1
}

.row {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-right: -15px;
	margin-left: -15px
}

.rr { flex-direction: row-reverse }

.col,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9 {
	position: relative;
	width: 100%;
	min-height: 1px;
	padding-right: 15px;
	padding-left: 15px;
	-webkit-box-flex: 0
}

.col {
	-ms-flex-preferred-size: 0;
	flex-basis: 0;
	-ms-flex-positive: 1;
	flex-grow: 1;
	max-width: 100%;
}

.col-9 {
	-ms-flex: 0 0 75%;
	flex: 0 0 75%;
	max-width: 75%
}

.col-8 {
	-ms-flex: 0 0 66.6666%;
	flex: 0 0 66.6666%;
	max-width: 66.6666%
}

.col-7 {
	flex: 0 0 58,333333%;
	max-width: 58.333333%
}

.col-6 {
	-ms-flex: 0 0 50%;
	flex: 0 0 50%;
	max-width: 50%
}

.col-5 {
	-ms-flex: 0 0 41.666666%;
	flex: 0 0 41.666666%;
	max-width: 41.666666%
}

.col-4 {
	-ms-flex: 0 0 33.3333%;
	flex: 0 0 33.3333%;
	max-width: 33.3333%
}

.col-3 {
	-ms-flex: 0 0 25%;
	flex: 0 0 25%;
	max-width: 25%
}

.col-2 {
	-ms-flex: 0 0 16.666666%;
	flex: 0 0 16.666666%;
	max-width: 16.666666%
}

.p-2 { padding: .6rem }

.pt-2,
.py-2 { padding-top: .6rem }

.pr-2,
.px-2 { padding-right: .6rem }

.pb-2,
.py-2 { padding-bottom: .6rem }

.pl-2,
.px-2 { padding-left: .6rem }

.p-3 { padding: 1rem }

.pt-3,
.py-3 { padding-top: 1rem }

.pr-3,
.px-3 { padding-right: 1rem }

.pb-3,
.py-3 { padding-bottom: 1rem }

.pl-3,
.px-3 { padding-left: 1rem }

.p-4 { padding: 1.5rem }

.pt-4,
.py-4 { padding-top: 1.5rem }

.pr-4,
.px-4 { padding-right: 1.5rem }

.pb-4,
.py-4,
.py-54 { padding-bottom: 1.5rem }

.pl-4,
.px-4 { padding-left: 1.5rem }

.p-5 {
	padding: 3rem
}

.pt-5,
.py-5,
.py-54 {
	padding-top: 3rem
}

.pr-5,
.px-5 {
	padding-right: 3rem
}

.pb-5,
.py-5 {
	padding-bottom: 3rem
}

.pl-5,
.px-5 {
	padding-left: 3rem
}

.p-0,
.px-0,
.pl-0 {
	padding-left: 0;
}

.p-0,
.px-0,
.pr-0 {
	padding-right: 0;
}

.p-0,
.py-0,
.pt-0 {
	padding-top: 0;
}

.p-0,
.py-0,
.pb-0 {
	padding-bottom: 0;
}

.m-2,
.my-2,
.mt-2 { margin-top: .6rem }

.m-2,
.my-2,
.mb-2 { margin-bottom: .6rem }

.m-2,
.mx-2,
.ml-2 { margin-left: .6rem }

.m-2,
.mx-2,
.mr-2 { margin-right: .6rem }

.m-3,
.mt-3,
.my-3 {
	margin-top: 1rem
}

.m-3,
.mr-3,
.mx-3 {
	margin-right: 1rem
}

.m-3,
.mb-3,
.my-3 {
	margin-bottom: 1rem
}

.m-3,
.ml-3,
.mx-3 {
	margin-left: 1rem
}

.m-4,
.mt-4,
.my-4 {
	margin-top: 1.5rem
}

.m-4,
.mr-4,
.mx-4 {
	margin-right: 1.5rem
}

.m-4,
.mb-4,
.my-4 {
	margin-bottom: 1.5rem
}

.m-4,
.ml-4,
.mx-4 {
	margin-left: 1.5rem
}

.m-5,
.mt-5,
.my-5 {
	margin-top: 3rem
}

.m-5,
.mr-5,
.mx-5 {
	margin-right: 3rem
}

.m-5,
.mb-5,
.my-5 {
	margin-bottom: 3rem
}

.m-5,
.ml-5,
.mx-5 {
	margin-left: 3rem
}

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

.m-0,
.my-0,
.mt-0 {
	margin-top: 0;
}

.m-0,
.my-0,
.mb-0 {
	margin-bottom: 0;
}

.m-0,
.mx-0,
.ml-0 {
	margin-left: 0;
}

.m-0,
.mx-0,
.mr-0 {
	margin-right: 0;
}

.video {
	padding-bottom: 56.25%;
	max-width: 100%;
}

.video iframe,
.video video {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none
}

@media screen and (max-width:1200px) {
	.r2 {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
		max-width: 100%
	}
	.r22 {
		-ms-flex: 0 0 50%;
		flex: 0 0 50%;
		max-width: 50%
	}
	.r23 {
		-ms-flex: 0 0 33.3333%;
		flex: 0 0 33.3333%;
		max-width: 33.3333%
	}
	.rh2 { display: none }
}

@media screen and (max-width:1000px) {
	.r1 {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
		max-width: 100%
	}
	.r12 {
		-ms-flex: 0 0 50%;
		flex: 0 0 50%;
		max-width: 50%
	}
	.r13 {
		-ms-flex: 0 0 33.3333%;
		flex: 0 0 33.3333%;
		max-width: 33.3333%
	}
	.rh1 { display: none }
}

@media screen and (max-width:750px) {
	.r7 {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
		max-width: 100%
	}
	.r72 {
		-ms-flex: 0 0 50%;
		flex: 0 0 50%;
		max-width: 50%
	}
	.rh7 {
		display: none
	}
}

@media screen and (max-width:550px) {
	.r5 {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
		max-width: 100%
	}
	.r52 {
		-ms-flex: 0 0 50%;
		flex: 0 0 50%;
		max-width: 50%
	}
	.rh5 {
		display: none
	}
}

@media screen and (max-width:400px) {
	.r4 {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
		max-width: 100%
	}
}

@media screen and (max-width:360px) {
	.r3 {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
		max-width: 100%
	}
}

table { border-collapse: collapse }

td { padding: 8px 10px }
th { padding: 5px 10px }

.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 1rem;
	list-style: none
}

.breadcrumb-item+.breadcrumb-item:before {
	display: inline-block;
	padding-right: .5rem;
	padding-left: .5rem;
	color: #6c757d;
	content: "/"
}

#menu .open_menu {
	position: absolute;
	top: 0;
	right: 0;
	font-size: 1.4rem;
	height: 42px;
	width: 42px;
	z-index: 60;
	border: 0;
	background: transparent
}

body {
    font-family: "Inter", sans-serif;
    font-weight: 400;
    background: #fff;
    color: #333;
}

h1,h2,.strong {
    font-weight: 700;
}

header{
    background-color:#fefefe;
    border-color:#fefefe;
    height: 88px;
    margin: 0 auto;
    box-shadow: 0 3px 28px rgba(0,0,0,.20);
    position:fixed;
    top:0;
    z-index: 900;
    width:100%;
}
.adminbar-loaded header{
    top:50px;
}

.right{
    float:right;
}
.left{
    float:left;
}
.clear{
    clear:both;
}

#menu a{
    color: #333;
    font-size:17px;
}

#menu a.active, #menu a:hover{
    color: #39bcf1;
}

#navigation .container{
    padding: 10px 0px;
}

.front_info{
    /*margin-top:-100px;*/
    background: #fff;
    padding: 10px;
    margin-top: 15px;
}

.img-container {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 10px;
}
.grid-three{
    display:grid;
    grid-template-columns: repeat(auto-fill,minmax(20rem,1fr));
    grid-gap: 1rem;
}

.service-box {
    text-align: center;
}

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

.caption{
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#hero, #sub_hero{
    margin-top:88px;
    
    
}

#sub_hero{
    position: relative;
}

#hero img{

    width: 100%;
    object-fit: cover;
    min-height: 400px;
    display: block;
}

#sub_hero img{

    width: 100%;
    object-fit: cover;
    min-height: 400px;
    display: block;
}

#hero{
    margin-top:88px;
}

.overlay{
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    background:rgba(97,140,177,.35);
}

.molentum-logo img {
    max-width: 90px;
}


.caption h1 {
    color: #fff;
    font-size: 52px;
    text-shadow: 0 0 9px rgba(89, 93, 89, 0.67);
}
.caption{
    font-size: 18px;
}
.caption p {
    font-size: 18px;
}

.white{
    color: #fff;
    text-shadow: 0 0 9px rgba(89,93,89,.67);
}

.info_text{
    background-color:#fff;
    padding: 20px;
    margin: 25px;
    margin-top: 25px;
    margin-bottom: 25px;
    position: relative;
    z-index: 99;
    /*margin-top: -80px;*/
    margin-bottom: 0;
    color: #333;
}

.info_text p{
    font-size:14px;
}

.front_text{
    padding: 100px 0 115px;
}

.social{
    text-align: center;
    background:#eee;
    padding: 115px 0 100px 0;
}


footer{
    background-color:white;
    padding-top: 30px;
    font-size: 16px;
    border-top: 1px solid#dcdcdc;
    margin-top: 10px;
    .footericon{
        svg{
            margin-right: 7px;
            margin-left: 0px;
        }
    }
    .first{
        max-width: 250px;
    }
    .molentum-logo{
        a{
            color:var(--black);
        }
        img{
            max-width: 90px;
        }
    }
    #footer-menu{
        .nav-item{
            display: block;
            margin-bottom: 5px;
            a{
                color:var(--black);
                text-decoration:unset;
                &:hover,&.active{
                    color:var(--primary);
                }
            }
        }
    }
    .some li a{
        color: var(--black);
        font-size: 25px;
        text-decoration: unset;
        &:hover{
            color:var(--primary);
        }
    }
    a{
        text-decoration: underline;
        color:var(--black);
    }
}

.btn{
    margin-top:10px;
    color: white;
    font-weight: 600;
    font-size: 15px;
    background: #39bcf1;
    padding: 15px 30px;
}

.btn:hover{
    color:white;
    text-decoration: none;
    background:#333;
}
/*
.catalog_title{
        background:#39bcf1;
        padding: 10px 15px;
        color:white;
        margin-bottom: 25px;
        margin-top: 0;
}*/

#map{
    width:100%;
    height:450px;
    border: 0;
}

footer a{
    color: #333;
}

#Inputfield_etunimi,#Inputfield_sukunimi, #Inputfield_puhelinnumero,#Inputfield_sahkopostiosoite{
    border: 1px solid #333;
    border-radius: 0;
}


#Inputfield_viesti{
    border: 1px solid black;
    border-radius: 0;

}

/*#wrap_Inputfield_haluan_etta_minuun_otetaan_yhteytta,#wrap_ota-yhteytta_submit {
        text-align: right;
}*/

#menu ul {
    padding-left:0px;
}

#menu a, main a:hover{
    text-decoration: none;
}

.staff ul{
    padding-left:0px;
}

#reservation,
#reservation iframe {
    min-height: 460px
}

.question-title{
    border-top:1px solid #39bcf1;
    border-bottom: 1px solid #39bcf1;
    color:#000;
    margin-bottom: 25px;
    margin-top: 0;
    font-size: 20px;
    cursor: pointer;
}

.question-title:hover{
    background: #eee;
    color:#000;
}


.question-title::after {
    content: "+";
    position: absolute;
    right: 10px;
    height: 100%;
    display: grid;
    align-items: center;
    top: 0;
}


.question-title.open::after{
    content: "-";
}

.answer{
    display: none;

}

.answer.show{
    display: block;
}



@media screen and (max-width: 1080px){
    #menu{
        display:none;
        position: absolute;
        background: rgba(34,34,34,.93);
        top:72px;
        width: 100%;
    }

    #menu-toggler{
        display:block;
        background: #308dc1 url(/files/images/menu.png) no-repeat 95% center;
        right:5px;
        width: 40px;
        height: 40px;
        position:absolute;
        top:20px;
    }

    #menu.show, #menu .nav-item{
        display: block
    }

    header .container{
        width:100%;
    }

    .nav-link{
        padding: 10px 15px;
        font-size:1.0rem;
        color: #fff;
        border-top: 1px solid #fff;
    }
    #menu a{
        color: #fff;
    }

    #logo{
        margin-left:10px;
    }

}

@media screen and (max-width: 570px){



    .adminbar-loaded header{
        top:101px;
    }
}
@media screen and (max-width: 400px){
        .grid-three,.grid-four{
                grid-template-columns: minmax(0,1fr);
        }
}

@media screen and (max-width: 365px){



    .adminbar-loaded header{
        top:150px;
    }
}

