/*

Theme Name: Putkiremontti24

Theme URI: https://www.putkiremontti24.fi

Description: Putkiremontti24 custom theme

Author: Taikalehto

Author URI: https://www.taikalehto.fi

Version: 1.0.0

*/ 

/* RESET */

html, body, div, span, applet, object, iframe,h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var,b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, landing, hgroup, menu, nav, output, ruby, section, summary,time, mark, audio, video
{
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, landing, hgroup, menu, nav, section {
	display: block;
}

body {
	line-height: 1;
}

ol, ul {	

}

ul li {
	list-style-type: disc;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;	border-spacing: 0;
}

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

html, body {
	-webkit-text-size-adjust: none;	

	color: #111;
	background-color: #fff;
}

::selection {
  background-color: #111; 
  color: #fff;
}
::-moz-selection {
  background-color: #111; 
  color: #fff;
}

a {
	text-decoration: none;

}

img {
	-webkit-user-select: none;  
	-moz-user-select: none;    
	-ms-user-select: none;      
	user-select: none;
    -webkit-user-drag: none;
    user-drag: none;
}

/*

UTILS

*/

.reset {
	float: none;
	clear: both;
}

.gap {
	height: 40px;
}

.noselect {
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}


.widthCheck {
	position: fixed;
	top: 1px;
	left: 0px;
	z-index: 999;
	width: 100vw;	
	height: 1px;
	background-color: black;
	visibility: hidden;
	pointer-events: none;
}

.heightCheck {
	position: fixed;
	top: 0px;
	left: 1px;
	z-index: 998;
	width: 1px;	
	height: 100vh;
	background-color: black;
	visibility: hidden;
	pointer-events: none;
}

.maxWidth {
	max-width: 1500px;
	box-sizing: border-box;
	padding: 0px 5%;
	margin: 0 auto;
}

.btnRect {
	padding: 12px 24px;
	border: 1px solid #eee;
	box-sizing: border-box;
	display: inline-block;
	cursor: pointer;
	transition: 0.2s background-color ease-in-out;
	border-radius: 3px;
}

.btnRect p {
	font-size: 15px;
	font-weight: 700;
	text-transform: uppercase;
	transition: 0.2s color ease-in-out;
}

.btnRect:hover {
	background-color: #eee;
}

.btnRect:hover p {
	color: #0F95D9;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/*

TYPOGRAPHY

*/

body {
	font-family: 'Lato', sans-serif;

	font-weight: 400;

	line-height: 140%;

	color: #666;
	background-color: #fff;
	
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center top;
	background-attachment: fixed;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Fredoka', sans-serif;
	font-weight: 500;
	line-height: 125%;

	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;	

	margin: 0;
	color: #147DCD;

	text-transform: uppercase;
}

h1 {
	font-size: 45px;
	letter-spacing: 0px;
	margin-bottom: 30px;
}

h2 {
	font-size: 32px;
	letter-spacing: 0px;
	margin-bottom: 20px;
}

h3 {
	font-weight: 500;
	font-size: 25px;
	letter-spacing: -0.25px;
	margin-bottom: 7px;
}

h4 {
	font-size: 20px;
	letter-spacing: -0.6px;
	margin-bottom: 5px;
}

a {
	color: #d20a3c;
	font-weight: 700;

	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;		

	transition: 0.15s color ease-in-out;

	//text-decoration: underline;
}

a:hover {
	color: #222;
}

p, li, div, i, em, h5, h6, select, input, textarea {
	font-family: "Lato", serif;
	font-weight: 400;

	font-size: 17px;
	letter-spacing: -0.3px;
	line-height: 140%;
	
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;		

	color: #111;
}

p {

}

i, em {

}

em {
	font-weight: 700;
}

strong {
	font-weight: 700;
}

.noMarginTop {
	margin-top: 0px;
}

ul {
	margin-top: 10px;
	margin-bottom: 20px;
	margin-left: 25px;
}

ul li {
	margin-bottom: 10px;
}

/*

STRUCTURE, HEADER & NAVIGATION

*/

.wrapper {
	position: relative;
	opacity: 1;
	width: 100%;
 	overflow: hidden;
}

.header,
.headerEtusivu {
	position: relative;
}

.headerLogo {
	position: relative;
	z-index: 11;
	width: 100%;
	background-color: #fff;
	box-sizing: border-box;
	padding: 40px 0;
}

.headerLogo img {
	position: relative;
	width: 80%;
	height: auto;
	max-width: 700px;
	box-sizing: border-box;
	padding: 0;
	margin: 0 auto;
}

.navi,
.fixedNavi {
	position: relative;
	z-index: 10;
	width: 100%;
	text-align: center;
	background-color: #147DCD;
	//background-color: #D20A3C;
	height: 64px;
	overflow: hidden;
	box-shadow: 0px 0px 20px rgba(0,0,0,0.2);
	//background: linear-gradient(180deg, rgba(35,38,82,1) 66%, rgba(42,47,91,1) 100%);
}

.naviItems {
	position: relative;
	display: inline-block;
	margin: 0px auto;
}

.fixedNavi {
	position: fixed;
	z-index: 1000;
	top: -64px;
}

.naviHolder {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	max-width: 1350px;
	margin: 0 auto;
	padding-right:  10px;
}

.btnToggleMenu {
	position: absolute;
	top: 0px;
	right: 0px;
	width: 64px;
	height: 64px;
	z-index: 1002;
	background-color: rgba(255,255,255,0);
	transition: background-color 0.15s ease-in-out;
	cursor: pointer;
	display: none;
}

.iconMenu,
.iconClose {
	position: absolute;
	width: 64px;
	height: 64px;
}

.iconClose {
	opacity: 0;
}


.btnToggleMenu:hover {
	background-color: rgba(255,255,255,0.3);
}

.menu {
	position: fixed;
	z-index: 990;
	left: 100vw;
	top: 0;
	background-color: #147DCD;
	width: 100%;
	box-sizing: border-box;
	padding-top: 90px;
	padding-bottom: 20px;
	text-align: center;
	box-shadow: 0px 0px 20px rgba(0,0,0,0.3);
	display: none;
}

.menuItem {

	position: relative;
	overflow: hidden;
	height: 60px;
	display: inline-block;
	cursor: pointer;
	box-sizing: border-box;
	overflow: hidden;
	margin: 0 auto;
	margin-bottom: 10px;

}

.btnMenu {

}

.menuText,
.menuHilite {
	font-family: "Fredoka", sans-serif;
	font-weight: 500;
	font-size: 15px;

	letter-spacing: 0px;
	text-transform: uppercase;

	position: relative;
	left: 0;
	top: 0;
	height: 60px;

	box-sizing: border-box;
	padding: 20px 12px 0 12px;
	transition: top 0.15s ease-in-out;
	color: #fff;
}

.menuHilite {
	position: absolute;
	color: #fff;
	top: -60px;
}

.menuItemBg {
	position: absolute;
	width: 100%;
	height: 60px;
	top: 60px;
	background-color: #aadcff;
	transition: top 0.2s ease-in-out;
}

.menuItem:hover .menuText {
	top: 60px;
}

.menuItem:hover .menuHilite {
	top: 0px;
}

.menuItem:hover .menuItemBg {
	top: 0px;
}

.naviLogo {
	position: absolute;
	left: 18px;
	top: 9px;
	z-index: 1001;
}

.naviLogo img {
	height: 46px;
	width: auto;
}

.naviItem {

	position: relative;
	overflow: hidden;

	height: 64px;
	
	margin: 0px;

	display: inline-block;

	cursor: pointer;

	box-sizing: border-box;

	overflow: hidden;

}

.fixedNavi {
	text-align: right;
	box-sizing: border-box;
}

.naviCurrent {
	border-bottom: 5px solid #fff;	
}

.naviText,
.naviHilite {
	font-family: "Fredoka", sans-serif;
	font-weight: 400;
	font-size: 17px;

	letter-spacing: 0px;
	text-transform: uppercase;

	position: relative;
	left: 0;
	top: 0;
	height: 50px;

	box-sizing: border-box;
	padding: 20px 10px 0 10px;
	transition: top 0.15s ease-in-out;
	color: #fff;
}

.naviHilite {
	position: absolute;
	color: #147DCD;
	top: -64px;
}

.naviItem:hover .naviText {
	top: 64px;
}

.naviItem:hover .naviHilite {
	top: 0px;
}

.naviItem:hover .naviItemBg {
	top: 0px;
}

.naviCurrent:hover .naviText {
	top: 0px;
}

.naviCurrent:hover .naviHilite {
	top: -64px;
}

.naviCurrent:hover .naviItemBg {
	top: 64px;
}

.naviItemBg {
	position: absolute;
	width: 100%;
	height: 64px;
	top: 64px;
	background-color: #fff;
	transition: top 0.2s ease-in-out;
}

.btnAnim {
	position: relative;
	top: 10px;
	opacity: 0;
}

.naviBreak {
	height: 12px;
	display: none;
}

.hero {
	position: relative;
	width: 100%;
	max-width: 1600px;
	height: 600px;
	margin: 0 auto;
	//overflow: hidden;

	background-position: 40% 0;
	background-size: 1600px 600px;
}

.heroImage {
	width: 100%;
}

.heroBottom {
	width: 1600px;
	height: 125px;
	position: absolute;
	left: 0;
	bottom: 0px;
	border: 0px solid;
	margin-left: 50%;
	transform: translateX(-50%);
}

.slogan {
	position: relative;
	z-index: 100;
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
	padding-bottom: 10px;
}

.sloganLogo {
	position: relative;
	width: 74px;
	height: auto;
	margin: 0 auto;
	margin-top: -48px;
}

.sloganText {
	text-align: center;
	margin-top: 25px;
}

.content {
	position: relative;
	width: 100%;
}

.section {
	position: relative;
	padding: 50px 5% 50px 5%;
}

.bgBlue {
	background-color: #147DCD;
	color:  #fff;
}

.bgBlue h1,
.bgBlue h2,
.bgBlue h3,
.bgBlue h4,
.bgBlue h5,
.bgBlue h6,
.bgBlue p {
	color:  #fff;
}

.bgBlue .phaseBox h1,
.bgBlue .phaseBox h3 {
	color:  #D20A3C;
}


.bgBlack {
	background-color:  #111;
}

.bgBlack p {
	color: #fff;
}

.bgGrey {
	background-color: #eee;
}

.sectionContent {
	position:  relative;
	max-width: 950px;
	margin: 0 auto;
	box-sizing: border-box;
}

.mainCol p {
	margin-bottom:  20px;
}

.sideCol {
	width: 200px;
	float: left;
}

.phaseBox {
	position:  relative;
	width:  200px;
	height:  150px;
	margin:  0 auto;
	background-repeat: no-repeat;
}

.phaseBox img {
	width:  200px;
	height:  auto;
	position: absolute;
	z-index:  2;
}

.phaseBox h1,
.phaseBox h3 {
	font-family: "Fredoka", sans-serif;
	font-weight: 500;
	text-transform: uppercase;
	color:  #fff;
	width:  100%;
	text-align: center;
	position:  relative;
	z-index:  3;
}

.phaseBox h3 {
	margin:  0;
	padding:  0;
	padding-top: 20px;
}

.phaseBox h1 {
	margin:  0;
	padding:  0;
	margin-top: -5px;
	font-size: 65px;
}

.mainCol {
	width:  calc(94% - 200px);
	float:  right;
}

.company {
	position: relative;
	z-index: 10;
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 80px 5%;
}

.companyLogo {
	width: 80%;
	max-width: 350px;
	height: auto;
	margin: 0 auto;
	margin-bottom: -10px;
	position: relative;
	top: -50px;
}

.company h1,
.company h2,
.company h3,
.company h4,
.company h5,
.company h6,
.company p {
	width: 80%;
	max-width: 500px;
	margin: 0 auto;
	text-align: center;
}

.companyInfo {
	width: 80%;
	max-width: 500px;
	margin: 0 auto;
	text-align: center;
}

.companyInfo h2 {
	margin-top: 40px;
	margin-bottom: 16px;
}

.company .borderBottom {
	background-color: #aadcff;
}

.areas {
	position: relative;
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
	text-align: center;
}

.areasContent {
	position: relative;
	width: 100%;
	max-width: 1000px;
	box-sizing: border-box;
	padding: 45px 5% 50px 5%;
	margin: 0 auto;
}

.contact {
	text-align: center;
	width: 80%;
	max-width: 600px;
	margin: 0 auto;
	position: relative;
	box-sizing: border-box;
	padding: 50px 0;
}

.contact h1 {
	padding-top: 30px;
	margin-bottom: 15px;
}

.contact p {
	margin-bottom: 25px;
}

.contact button {
	margin-top: 0px;
	margin-bottom: 20px;
}

.contact button p {
	margin-bottom: 0px;
}

.contactForm {
	margin-top: 32px;
}

.contactForm p {
	font-size: 15px;
	text-transform: uppercase;
	margin-bottom: 2px;
}

.contactForm input {
	background-color: #eee;
	border: 0px;
	width: 100%;
	max-width: 400px;
	margin-bottom: 10px;
	text-align: center;
	padding: 5px;
	font-family: "Lato", sans-serif;
	font-size: 16px;
}

.contactForm textarea {
	background-color: #eee;
	border: 0px;
	width: 100%;
	margin: 0 auto;
	margin-bottom: 10px;
	max-width: 400px;
	padding: 5px;
}

.contactForm .errorEmail {
	font-size: 12px;
	color: #999;
	padding-bottom: 10px;
	display: none;
}

.messageAttempt,
.messageSuccess,
.messageFail {
	display: none;
}

.footer {
	position: relative;
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;

}

.footerLogo {
	width: 60%;
	max-width: 360px;
	height: auto;
	margin: 0 auto;
	margin-bottom:  50px;
}

.footer p {
	margin-bottom: 20px;
}

.footerContent {
	position: relative;
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 80px 5%;
	text-align: center;
}


.contentPageImage {
	position: relative;
	width: 100%;
	max-width: 1600px;
	height: 300px;
	margin: 0 auto;
	overflow: hidden;

	background-position: 50% 0;
	background-size: 1600px 300px;
}

.contentPageHeader {
	position: relative;
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
}

. wpforms-container-full input {
	opacity:  0.2;
}

#wpforms-form-25 input {
	margin:  0 auto;
}

/*
div.wpforms-container-full .wpforms-form .wpforms-field-label {
	font-family: "Lato", sans-serif;
	font-weight:  400;
	display: block;
	font-size: 15px;
	text-transform: uppercase;
	margin-bottom: 2px;
}

.wpforms-field input {
	display: block;
	width: 100%;
	max-width: 300px;
	margin:  0 auto;
	margin-top: 10px;
	margin-bottom: 20px;

	background-color: #eee;
	border: 0px;
	width: 100%;
	text-align: center;
	padding: 5px;
	font-family: "Lato", sans-serif;
	color:  #f00;
	font-size: 16px;	
}

.wpforms-field-container textarea {
	width: 100%;
	max-width: 400px;
	height: 200px;
	margin-top: 5px;
	margin-bottom: 15px;

	background-color: #eee;
	border: 0px;
	width: 100%;
	margin: 0 auto;
	margin-bottom: 10px;
	max-width: 400px;
	padding: 5px;
}

.wpforms-submit-container button {
	position: relative;
	left: -10px;

	font-family: "Fredoka", sans-serif;
	font-weight: 400;
	text-transform: uppercase;	
	font-size: 17px;

	letter-spacing: 0px;
	color: #fff;
}

.wpforms-container {
	margin-bottom: 30px;
}

.contact .wpforms-field-label {
	margin-top: 10px;
	color:  #d00;
}

.contact .wpforms-field input {
	width:  100%;
	margin:  0 auto;
	margin-top: 5px;
	margin-bottom: 10px;
}

.contact .wpforms-field textarea {
	margin-top: 5px;
}

.contact .wpforms-submit-container button {
	left: 0px;
}

.wpforms-field-hp {
	display: none;
}

*/

ol {
	padding-left: 30px;
}

ol li {
	margin-bottom: 20px;

}

.has-text-align-center {
	text-align: center;
}

.has-text-align-left {
	text-align: left;
}

.has-text-align-right {
	text-align: right;
}

button {
	border: none;
	padding: 11px 20px 13px 20px;
	cursor: pointer;
	margin: 0;
	background-color: #147dcd;
	transition: background-color 0.15s ease-in-out, border 0.15s ease-in-out;
	border-radius: 4px;
}

button p {
	font-family: "Fredoka", sans-serif;
	font-weight: 400;
	font-size: 17px;

	letter-spacing: 0px;
	text-transform: uppercase;

	color: #fff;
	transition: color 0.15s ease-in-out;
}

button:hover {
	background-color: #222;
}

button:hover p {
	color: #147dcd;
}

.mainCol button p {
	margin-bottom:  0px;
}

.sectionContact {
	padding-top:  20px;
}

.bgBlue button {
	background-color: #fff;
}

.bgBlue button p {
	color:  #147dcd;
}

.bgBlue button:hover {
	background-color: #222;
}

.bgBlue button:hover p {
	color: #147dcd;
}
/*

MEDIA QUERIES

*/

@media (max-width: 1200px) {

	.naviText,
	.naviHilite {
		padding: 22px 6px 0 6px;
		font-size:  15px;
	}

	.naviLogo {
		height:  36px;
		padding-top:  4px;
	}
	.naviLogo img {
		height:  36px;
	}

	.hero {
		height: 450px;
		background-size: 1200px 450px;
	}

}

@media (max-width: 1000px) {

	.fixedNavi .naviItem {
		display: none;
	}

	.btnToggleMenu {
		display: block;
	}

	.menu {
		left: 0px;
	}

	.hero {
		height: 375px;
		background-size: 1000px 375px;
	}

	.phaseBox {
		width:  160px;
		height:  120px;
	}

	.phaseBox img {
		width:  160px;
	}

	.phaseBox h3 {
		padding-top: 12px;
	}

	.phaseBox h1 {
		margin-top: -5px;
		font-size:  50px;
	}

	.mainCol {
		width:  calc(94% - 160px);
	}


	h1 {
		font-size: 40px;
		margin-bottom: 16px;
	}

	h2 {
		font-size: 26px;
	}

	h3 {
		font-size: 22px;
	}


}

@media (max-width: 900px) {

	.headerLogo {
		display: none;
	}

	.navi {
		display: none;
	}

	.hero {
		margin-top: 64px;
	}

	.hero {
		height: 350px;
		background-size: 1018px 350px;
	}

	.mainCol {
		width: 100%;
	}

	.sideCol {
		width: 100%;
		padding-bottom:  30px;
	}

	.phaseBox {
		margin:  0;
		margin-bottom:  -10px;
	}

	.menuItem {
		height:  50px;
		margin-bottom: 0px;
	}

	.menuText, .menuHilite {
		padding: 13px 12px 0 12px;
	}


}











