@import url('https://fonts.googleapis.com/css?family=Aleo:700i|Montserrat:500,600&display=swap');
/* font-family: 'Montserrat', sans-serif;
font-family: 'Aleo', serif; */

* { padding: 0 0; margin: 0 0; }
html { scroll-behavior: smooth; scroll-padding: 6rem; }
body { font-size: 1rem; font-weight: 500; letter-spacing: -0.05rem; line-height: 1.9; color: #222; font-family: Montserrat, sans-serif; background: #fff; overflow-x: hidden; }
h1, h2, h3, h4, h5, h6 { font-weight: 600; line-height: 1.4; margin-bottom: 2.5rem; }
a { -webkit-transition: .2s linear; transition: .2s linear; color: inherit; text-decoration: none; cursor: pointer; }

h2 { font-size: 2.813rem; }
h3 { font-size: 2rem; margin-bottom: 1rem; }
p { font-size: 1.375rem; line-height: 1.9; }
ul { width: 100%; float: left; margin-top: 3rem; padding-left: 3rem; box-sizing: border-box; }
li { font-size: 1.375rem; line-height: 1.9; margin-bottom: 1.75rem; padding-left: .5rem; }

.container { position: absolute; top: 100%; left: 0; width: 100%; }

.wrapper { max-width: 1150px; text-align: center; margin: 0 auto; }
.wide { max-width: 1350px; }
.narrow { max-width: 825px; }
.hold { width: 100%; float: left; text-align: left; }

.white, .grey, .whiteandgrey, .black { width: 100%; float: left; padding: 10.94rem 0; }
.white a, .grey a, .whiteandgrey a, .black a { border-bottom: 2px solid #222; padding-bottom: 3px; }
.white a:hover, .grey a:hover, .whiteandgrey a:hover, .black a:hover { border-bottom: 2px solid transparent; }
.white { background: #fff; }
.grey { background: #f4f4f4; }
.whiteandgrey { background: linear-gradient(to bottom, #fff 50%, #222 50%); }
.black { background: #222; color: #fff; }
.nobotpad { padding-bottom: 0; }
.notoppad { padding-top: 0; }

.fivezero { margin-top: 50px; }
.sevenfive { margin-top: 75px; }
.gap { line-height: 2.2; }

.top { width: 100%; float: left; position: fixed; top: 0; left: 0; padding: 2rem; box-sizing: border-box; z-index: 9998 !important; transition: .3s linear; }
.top .logo { width: 150px; float: left; }
.top .logo img { float: left; transition: .3s linear; }
.top .logo img.fer { transition: .3s linear; height: 150px; max-width: 150px; }
.top .detail { width: calc(100% - 150px); float: right; text-align: right; position: relative; top: 3rem; transition: .3s linear; }
.top .detail a { background: #fff; color: #222; text-decoration: none; padding: 1.2rem 1.75rem; box-sizing: border-box; border-radius: 3rem; font-size: 1.25rem; margin-left: 1.5rem; }
.top .detail svg { display: inline-block; max-width: 1.8rem; max-height: 1.8rem; margin: 0 0; position: relative; top: 0.4rem; left: 0.15rem; }
.top .detail a:hover svg { fill: #fff; }
.top .detail a.img { padding: 1.2rem .9rem; }
.top .detail a:hover { background: #5DB7DE; color: #fff; }

.banner { position: absolute; z-index: 0 !important; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(0,0,0,0.7), rgba(0,0,0,0.4)), url('../images/banner.jpg') no-repeat center; background-size: cover; }
.header { width: auto; height: auto; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); text-align: center; z-index: 9999 !important; }
.header h1 { position: relative; color: #fff; font-size: 4.375rem; line-height: 1.2; margin-bottom: 1rem; letter-spacing: -0.2rem; text-shadow: 0px 3px 5px rgba(0,0,0,0.7); transition: .3s linear; }
.header h2 { color: #fff; font-size: 2.313rem; font-family: Aleo, serif; font-weight: 700; font-style: italic; letter-spacing: 0.04rem; text-shadow: 0px 2px 4px rgba(0,0,0,0.7); transition: .3s linear; }
.arrow { position: absolute; bottom: 1rem; left: 50%; transform: translateX(-50%); width: auto; z-index: 1 !important; }
.arrow img { width: 3.125rem; animation: scroll 2s infinite; position: relative; top: 0; }
@keyframes scroll {
	0% {}
	50% { top: -1rem; transform: scale(0.95); opacity: .5; }
	100% {}
}

.split { width: 100%; float: left; margin-top: 10.94rem; }
.split .itm { width: 48%; float: left; margin-right: 4%; }
.split .end { margin-right: 0; }
.split .itm img { width: 100%; float: left; border-radius: .8rem; box-shadow: 0 15px 15px -10px rgba(0,0,0,0.3); }
.split .right { text-align: right; }

.video { margin-bottom: 10.94rem; width: 100%; float: left; background: linear-gradient(to bottom, rgba(0,0,0,0.6), rgba(0,0,0,0.5)), url('../images/video.jpg') no-repeat center; background-size: cover; text-align: center; padding: 25% 0; border-radius: .8rem; box-shadow: 0 15px 15px -10px rgba(0,0,0,0.3); }
.video img { max-width: 3rem; display: inline-block; position: relative; top: .3rem; }

.map { width: 100%; float: left; overflow: hidden; border-radius: .8rem; box-shadow: 0 15px 15px -10px rgba(0,0,0,0.3); }
.map iframe { width: 100%; float: left; }

#contactform { display: none; width: 100%; height: 100%; background: rgba(0,0,0,0.5); z-index: 99997 !important; position: fixed; top: 0; left: 0; overflow: scroll; animation: blackbox .5s; }
@keyframes blackbox {
	0% { opacity: 0; }
	100% { opacity: 1; }
}
#contactform a { display: inline-block; float: right; background: #222; color: #fff; font-size: 1.1rem; padding: 1rem 1.5rem; border-radius: 3rem; }
#contactform a:hover { background: #5DB7DE; }
#contactform .theform { width: 50%; position: fixed; top: 0; right: 0; height: 100%; background: #f4f4f4; box-sizing: border-box; padding: 3rem 5rem 10rem; overflow: scroll; animation: whitebox 1s; }
@keyframes whitebox {
	0% { opacity: 0; right: -50%; }
	50% { opacity: 0; right: -50%; }
	100% { opacity: 1; right: 0; }
}
#contactform .theform .input-top { width: 100%; float: left; overflow: scroll; margin-top: 2rem; }
#contactform .theform .input-top label { width: 100%; float: left; margin-bottom: .5rem; font-size: .9rem; text-transform: uppercase; font-weight: 600; }
#contactform .theform .input-top input, #contactform .theform .input-top textarea { width: 100%; border: 1px solid #ccc; background: #fff; padding: 1rem; box-sizing: border-box; font-family: Montserrat, sans-serif; font-size: 1rem; margin-bottom: 2rem; }
#contactform .theform .input-top textarea { min-height: 200px; }
#contactform .theform .input-top button { padding: 1rem 1.5rem; background: #222; color: #fff; font-family: Montserrat, sans-serif; border: 0px solid transparent; font-size: 1.1rem; margin-top: 2rem; border-radius: 3rem; cursor: pointer; transition: .2s linear; }
#contactform .theform .input-top button:hover { background: #5DB7DE; }

@media only screen and (max-width: 1200px) {
	h1, h2, h3, h4, h5, h6 { margin-bottom: 1.5rem; }
	h2 { font-size: 1.75rem; }
	h3 { font-size: 1.4rem; margin-bottom: 1rem; }
	p { font-size: 1rem; line-height: 1.7; }
	ul { margin-top: 1.75rem; padding-left: 2rem; box-sizing: border-box; }
	li { font-size: 1rem; line-height: 1.7; margin-bottom: 1rem; padding-left: .25rem; }

	.wrapper { width: 100%; box-sizing: border-box; padding: 0 1.5rem; float: left; }
	.mobilenopad { padding: 0 0; }

	.white, .grey, .whiteandgrey, .black { padding: 5rem 0; }
	.white a, .grey a, .whiteandgrey a, .black a { border-bottom: 1px solid #222; padding-bottom: 2px; }
	.white a:hover, .grey a:hover, .whiteandgrey a:hover, .black a:hover { border-bottom: 1px solid transparent; }

	.fivezero { margin-top: 30px; }
	.sevenfive { margin-top: 50px; }
	.gap { line-height: 1.9; }

	.split { margin-top: 5rem; }
	.video { margin-bottom: 5rem; }
}

@media only screen and (max-width: 800px) {
	.top { padding: 1rem; }
	.top .logo img.fer { height: 4rem; }
	.top .detail { top: .7rem; }
	.top .gone { display: none; }
	.top .detail a.img { padding: 1rem .85rem; }
	.header h1 { font-size: 2.5rem; margin-bottom: .5rem; letter-spacing: -0.1rem; }
	.header h2 { font-size: 1.25rem; letter-spacing: 0.02rem; }
	.map iframe { height: 300px; }
	.txtsp .itm { width: 100%; margin-right: 0; margin-bottom: 2.5rem; }
	.txtsp .end { margin-bottom: 0; }
	#contactform .theform { width: 100%; padding: 2rem 1.5rem 5rem; overflow: scroll; animation: whitebox 1s; }
	@keyframes whitebox {
		0% { opacity: 0; right: 0; top: -100%; }
		50% { opacity: 0; right: 0; top: -100%; }
		100% { opacity: 1; right: 0; top: 0; }
	}
}


