/*	==========================================================================
	GENERAL STYLING
	========================================================================== */
/* 	Font Styling
	============================================= */
.bold {
	font-weight:700;
}

/* 	Wrapping Container
	============================================= */
.container {
	padding:0;
}

/* 	Headings
	============================================= */
h2 {
	margin-bottom:17px;
}

h3 {
	margin:0 0 5px;
}

/* 	Links
	============================================= */

/*	==========================================================================
	MAP, FLAGS, HUBS
	========================================================================== */
/* 	Site Layout
	============================================= */
.map {
	width: 700px;
	padding: 0 0 0 10px;
}
/* 	Canvas and Map
	============================================= */
canvas {
	z-index:8;
	position:relative;
}

.mapcontainer {
	position:relative;
	margin: 30px 0 30px;
	height:404px;
	background-image:url(../img/map.png);
	background-size:580px;
	background-repeat:no-repeat;
	background-position:center center;
}

[class^="pinpoint"] {
	width:1px;
	height:1px;
	border-radius:50%;
	position:relative;
}

/* 	Images: Train for Animation, Arrow
	============================================= */
.img-canvaselement {
	position:absolute;
	left:-9999em;
}

.img-arrow {
	position:absolute;
	width: 160px;
	height: auto;
	top:125px;
	left:15px;
	animation:flashing 500ms 8 ease-in alternate;
}

/* 	Keyframes for Arrow Animation
	============================================= */
@keyframes flashing {
	from {
		opacity:1;
	}

	to {
		opacity:0;
	}
}

/* 	Flags Starting Box
	============================================= */
.flags {
	position:absolute;
	/*top: -100px;*/
  top: 0;
	font-weight:700;
}

.flags p,.flag {
	font-size:.625em;
}

.flag-box {
	float:left;
	width:74px;
	height:85px;
	margin-top:30px;
	padding:15px 5px;
	background-color:#e2e2e2;
	text-align:center;
}

.flag-box.start {
	margin-right:1px;
}

.flag-circle {
	width:29px;
	height:29px;
	padding:14px;
	border-radius:50%;
	margin-bottom:13px;
	margin-left:15px;
}

.start .flag-circle {
	background-color:#6bc1d9;
}

.end .flag-circle {
	background-color:#7bbb50;
}

/* 	Flags
	============================================= */
.flag {
	width:63px;
	height:54px;
	line-height: 11px;
	color:#fff;
	font-style:italic;
	text-align:left;
	padding:6px 12px 6px 5px;
	background-repeat: no-repeat;
	position:absolute;
	left:-1px;
	bottom:0;
	transition:.2s bottom ease;
}

.flag:hover {
	cursor:move;
}

.flag:active {
	bottom:6px;
}

.flag-start {
	top:61px;
	left:36px;
}

.flag-end {
	top:60px;
	left:111px;
}

.flag-start .flag {
	background-image:url(../img/flag-start-blue.svg);
}

.flag-end .flag {
	background-image:url(../img/flag-end-green.svg);
}

.pinpoint-flag {
	z-index:10;
}

/* 	Hubs
	============================================= */
.hub {
	position:absolute;
	font-size:.625em;
	line-height:15px;
}

.pinpoint-hub {
	float:left;
	top:7px;
	left:7px;
	margin-right:20px;
}

.hub-bullet {
	width:11px;
	height:11px;
	background-color:#7CBB50;
	box-shadow:0 0 0 2px #fff;
	border-radius:50%;
	position:relative;
	top:-5px;
	left:-5px;
	transition:.2s box-shadow ease;
}

.activeHub {
	font-weight:700;
	z-index:9;
	text-shadow:0 1px white,1px 0 white,0 -1px white,-1px 0 #fff;
}

.activeHub .hub-bullet {
	box-shadow:0 0 0 4px #000;
}

/*	==========================================================================
	BOTTOM FORM
	========================================================================== */
.form {
	margin-bottom: 60px
}

.form-wrapper {
	padding: 25px 15px 0;
	background-color:#f4f4f4;
}

.form-wrapper [class^="form-col"] {
	margin-bottom: 30px;
}

.form-wrapper > .form-col-amount,
.form-wrapper > .form-col-type {
	margin-bottom: 25px;
}

.form-col-end {
	border-right:1px solid #fff;
}

.form p {
	font-size:.625em;
	margin-bottom:1px;
}

.form-select {
	position:relative;
}

.form-control {
	padding: 6px 8px;
}

option {
	font-weight:400;
}

/*	==========================================================================
	SIDEBAR
	========================================================================== */
/* 	General Styles
	============================================= */
[class^="info-box"] {
	background-color:#EDEDED;
	padding:20px;
}

/* 	Infobox Savings (Emission and Duration)
	============================================= */
.savings-info-box {
	border-radius: 4px;
	background: #eee;
	padding: 20px 30px;
	margin-bottom: 50px;
}

.info-value {
	font-size:1.625em;
	margin:0;
	font-weight:700;
	color:#83BB26;
}

.info-box-duration .info-value {
	margin-bottom:3px;
}

.info-description {
	margin-bottom: 0;
}

.info-icon {
	height:1px;
	overflow:visible;
	cursor:pointer;
}

.info-icon span {
	font-size:2em;
	font-weight:700;
	text-align:center;
	background:#fff;
	display:block;
	position:relative;
	top:-25px;
	left:150px;
	width:50px;
	line-height:50px;
	border-radius:50%;
}

/* 	Extendable Description Box
	============================================= */
.box-extendable {
	overflow:hidden;
	padding-bottom:11px;
	margin-top:-15px;
}

.box-extendable > div {
	min-height:0;
}

.info-box-calculation {
	position:relative;
	padding: 25px 30px 20px;
	line-height:normal;
	margin-bottom: 30px;
}

.info-box-calculation .bold {
	margin-bottom:13px;
}

.close-button {
	background-color:rgba(0,0,0,0.1);
	cursor:pointer;
	display:block;
	width:39px;
	line-height:39px;
	font-weight:700;
	font-size:1.6em;
	text-align:center;
	position:absolute;
	right:0;
	top:0;
	z-index:10;
}

/* 	Call-to-Action Contact Box
	============================================= */
.info-box-contact {
	background-color:#A2C64B;
	color:#fff;
	line-height:normal;
	padding:20px 20px 25px 20px;
	background-image:linear-gradient(to top left,#7ea032 0%,#a1c54b 100%);
}

.info-box-contact h2 {
	margin-top:4px;
}

.info-box-contact a:not(.btn) {
	color: white;
}

[class^="contact-"] {
	font-weight:700;
}

.contact-phone, .contact-mail {
	margin-bottom:6px;
}

/*	==========================================================================
	CONTACT PAGE
	========================================================================== */
/* 	Map
	============================================= */
.map-regions {
	width:100%;
}

/* 	SVG Map
	============================================= */
.svg-map {
	fill:#D1CFC5;
}

.svg-river {
	fill:none;
	stroke:#0971B8;
	stroke-width:.5;
}

.svg-lake {
	fill:#BAE3F9;
	stroke:#0971B8;
	stroke-width:.1;
	stroke-miterlimit:10;
}

.svg-hubs {
	opacity:.4;
	fill:#949494;
	stroke:#F9F9FA;
	stroke-width:.6;
	stroke-miterlimit:10;
}

/* .svg-hubs > a {
	transition: transform .225s ease-out;
} */

.svg-hub1 {
	fill:#BAD583;
	stroke:none;
}

.svg-hub2 {
	fill:#89BE3B;
	transition: fill .225s ease-out;
}

.svg-hub3 {
	fill:none;
	stroke:#FFF;
	stroke-width:.8;
	stroke-miterlimit:10;
	transition: stroke-width .225s ease-out;
}

.svg-hubs > a:hover .svg-hub2 {
	fill: #292b2c;
}

.svg-hubs > a:hover .svg-hub3 {
	stroke: #89BE3B;
	stroke-width: 16px;
}

.svg-text {
	font-family:Arial,sans-serif;
	font-weight:700;
	fill:#fff;
	font-size:.8em;
}

.svg-split {
	fill:none;
	stroke:#FFF;
	stroke-width:2;
	stroke-miterlimit:10;
}

.svg-hover-fill {
	fill:#A1C64B;
	opacity:0;
	transition:.2s all ease;
}

/* .svg-hover:hover .svg-hover-fill {
	opacity:.66;
} */

/*	==========================================================================
	MEDIA QUERIES
	========================================================================== */
@media (max-width: 1200px) {
	.mapcontainer,.map h3 {
		display:none;
	}

	.info-value {
		font-size:1.875em;
	}

	.info-icon span {
		left:160px;
	}
}

@media (max-width: 991px and min-width: 767px) {
	.sidebar h1 {
		margin-top:0;
	}

	.info-icon span {
		left:80%;
	}
}

@media (max-width: 767px) {
	.map {
		padding: 0 15px;
		width: 100%;
	}
	.sidebar {
		padding: 0 15px;
		width: 100%;
	}
	.info-icon span {
		left: 80%;
	}
}
