/*TCG tyylitiedosto, Otosto Oy, 2018*/
/*YLEISET TYYLIT*/

* {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}

body {
	background: white;
	color: black;
	font-family: 'Open Sans', sans-serif;
}

img {
	border: 0;
}

.clear {
	clear: both;
}

footer {
	clear: both;
	width: 100%;
	text-align: center;
	font-size: 12px;
    padding: 30px;
}

.middle {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 40px 0 20px 0;
}


/*YLÄRIVIT*/
header {
	width: 100%;
	max-width: 1000px;
	margin: 20px auto 10px auto;
	text-align: center;
	overflow: hidden;
}

@media screen and (max-width : 680px) {
	header {
		float: none;
		text-align: center;
		margin: 10px auto 0px auto;
	}
}

header img {
	width: 200px;
}

header .language {
	float: right;
	text-align: right;
	font-size: 12px;
	border: solid 1px #387527;
	padding: 10px;
}

@media screen and (max-width : 680px) {
	header .language {
		float: none;
		text-align: center;
		margin: 5px 10px 20px 10px;
	}
}

/*Vihreä menupalkki*/
.menu {
	background-color: #387527;
	width: 100%;
	height: 50px;
	line-height: 50px;
	text-align: center;
}

.menu .icon {
    display: none;
}

ul.topnav {
	list-style-type: none;
	margin: 0 auto;
	text-align: center;
	max-width: 1000px;
	width: 100%;
    padding: 0;
}

ul.topnav li {
  display: inline-block;
  padding: 0 30px;
	background-color: #387527;
  text-align: left;
  float: none;
}


ul.topnav li a {
	color: white;
	text-decoration: none;
}

ul.topnav li a:hover {
    font-weight: bold;
}

ul.topnav li.icon {
	display: none;
}

@media screen and (max-width: 900px) {
	ul.topnav li {
	  padding: 0 8px;
	}
}

@media screen and (max-width:680px) {
  ul.topnav li:not(:first-child) {
  	display: none;
  }

  ul.topnav li.icon {
    float: right;
    display: inline-block;
  }
}

@media screen and (max-width:680px) {
  ul.topnav li {
	  float: left;
  }

  .menu.responsive ul.topnav {
  	position: relative;
  }

  .menu.responsive  ul.topnav li.icon {
    position: absolute;
    right: 0;
    top: 0;
  }

  .menu.responsive ul.topnav li {
    float: none;
    display: block;
  }

  .menu.responsive ul.topnav li a {
/*
		padding: 10px 30px 10px 30px;
*/
		color: white;
  }
}


/*kuvat*/
.pic {
	width: 100%;
	max-width: 1000px;
	height: 380px;
	margin: 0px auto 20px auto;
	background: url('Images/konsultti.jpg') no-repeat;
    background-size: cover;
}

@media screen and (max-width : 680px) {
.pic {
	width: 100%;
	max-width: 680px;
	height: 300px;
	margin: 20px auto 20px auto;
	background: url('Images/konsultit.jpg') no-repeat;
    background-size: cover;
}
    }

.pic-tapa {
	width: 100%;
	max-width: 1000px;
	height: 350px;
	margin: 0px auto 20px auto;
	background: url('Images/konsultti-tavat-toimia.jpg') no-repeat;
    background-size: cover;
}

@media screen and (max-width : 680px) {
.pic-tapa {
	width: 100%;
	max-width: 680px;
	height: 170px;
	margin: 20px auto 20px auto;
	background: url('Images/konsultti-tavat-toimia.jpg') no-repeat;
    background-size: cover;
}
    }
   
.pic-palvelu {
	width: 100%;
	max-width: 1000px;
	height: 350px;
	margin: 0px auto 20px auto;
	background: url('Images/konsultti-palvelut.jpg') no-repeat;
    background-size: cover;
}

@media screen and (max-width : 680px) {
.pic-palvelu {
	width: 100%;
	max-width: 680px;
	height: 170px;
	margin: 20px auto 20px auto;
	background: url('Images/konsultti-palvelut.jpg') no-repeat;
    background-size: cover;
}
    }

.pictext {
	width: 100%;
	height: 100%;
	padding: 120px 0 0 0;
	font-size: 4em;
	font-style: normal;
	text-align: center;
	font-weight: bold;
	color: black;
    text-transform: uppercase;
}

@media screen and (max-width : 680px) {
    .pictext {
	width: 100%;
	height: 100%;
	padding: 80px 0 0 0;
	font-size: 3em;
	font-style: normal;
	text-align: center;
	font-weight: bold;
	color: white;
}}
 


/*Palvelut*/

p.menutitle	{
  font-size: 24px;
  margin: 0 0 20px 0;
  padding: 0 0 0 5px;

}

.sidenav-area	{
    float: left;
    text-align: left;
    width: 100%;
}

.service-menu {
  display: block;
  margin-top: 5px;
  position: relative;
  width: 100%;
}

.service-menu i { 
  position: absolute;
  right: 10px;
}

.service-menu .menu-level-1 {
  background-color: #D7D7D7;
  padding: 10px 0 10px 10px;
  text-transform: uppercase;
}

.service-menu .menu-level-2 {
  background-color: white;
  border: 1px solid lightgray;
  display: none;
  padding: 10px 0 10px 20px;
}

.service-menu-content {
  display: none;
  padding: 10px;
}

.service-menu-content h1{
    color: #387527;
    margin-top: 0;
    text-align: left;
    padding: 0 20px;
    font-weight: normal;
}

.accordion-content {
  height: auto;
  overflow: auto;
  padding: 10px;
  width: 100%;
}



/*TEKSTIT*/
.text-fp {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 0 auto;
	padding: 0;
	text-align: center;
	overflow: hidden;
}

.text-fp p {font-size: 16px;
    }

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.bold {
	font-weight: bold;
}

h1 {	
	margin: 20px 0 0 0;
	font-size: 30px;
	font-style: normal;
	text-align: center;
}

h2 {
	font-size: 18px;
	font-style: normal;
	font-weight: bold;
	padding: 20px 20px 0 20px;
}

h3 {	
	font-size: 16px;
	font-style: normal;
	font-weight: bold;
    padding: 20px 20px 0 20px;
}

p {
	text-transform : none;
	padding: 20px 20px 0 20px;
    font-size: 14px;
}

a:link, a:visited {
	color: #387527;
	text-decoration: none;
}

a:hover, a:active {
	color: #387527;
	text-decoration: underline;
}

ul {
    list-style: square;
    margin: 20px;
    text-align: left;
    padding-left: 20px;
    font-size: 14px;
}

ol {
    margin: 20px;
    padding-left: 20px;
    font-size: 14px;
}

hr {
	border: 0;
	border-bottom: solid #387527 1px;
	width: 100%;
}



/*Laatikot*/
.laatikot {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 20px auto;
	padding: 0;
	overflow: hidden;
}

.green {
	float: left;
	width: 280px;
	height: 420px;
	border: solid #387527 1px;
	text-align: center;
	font-size: 12px;
	margin-left: 20px;
	margin-right: 20px;
	margin-bottom: 20px;
	margin-top: 20px;
}

.green img {
	width: 120px;
    padding-top: 15px;
}

.nimi	{
	text-transform: uppercase;
	font-size: 18px;
}

.green p {
    font-size: 12px;
    padding-top: 5px;
}

h1.nimi {
    text-transform: uppercase;
    font-weight: normal;
	font-size: 18px;
    padding: 0;
}

h2.key {
	font-size: 15px;
    font-weight: normal;
    padding: 5px 0 0 0;
}


@media screen and (max-width : 680px) {
	.green { 
		float: none; 
		width: 280px;
		height: 420px;
		border: solid #387527 1px;
		text-align: center; 
		margin: 20px auto 20px auto;
	}
}



/*Palvelut Sisältö*/

.palvelukuvaus {
    width: 75%;
    float: left;
    background: white;
    margin: 20px 0 20px 0;
    }

@media screen and (max-width : 680px) {
    .palvelukuvaus {
    width: 100%;
    } }

.palvelukuvaus h1{
    color: #387527;
    margin-top: 0;
    text-align: left;
    padding: 0 20px;
    font-weight: normal;
    }

.konsultti {
	float: left;
	width: 25%;
	border: solid #387527 1px;
	font-size: 12px;
    text-align: center;
    margin-top: 20px;
}
    
    @media screen and (max-width : 680px) {
        .konsultti {
            width: 100%;
    } }

.konsultti h2 {
    text-transform: uppercase;
    font-weight: normal;
	font-size: 18px;
    padding-top: 20px;
}

.konsultti img {
    width: 150px;
    padding: 15px 0 0 0;
}

.firma	{
	text-transform: none;
	font-size: 14px;
    padding: 0 0 10px 0;
    margin: 0;
}



/*Tapamme toimia*/
.tavat {
max-width: 600px; margin: 0 auto; padding: 0 20px;
}



/*Yhteys*/
.yhteys {
	width: 100%;
	max-width: 1000px;
	margin: 0px auto 20px auto;
	padding: 0;
	overflow: hidden;
}

@media screen and (min-width : 680px) {
	.yhteys h1 {
		text-align: center;
		margin: 0 0 40px 0;
	}
}

.yhteyslaatikko {
	float: left;
	width: 280px;
	margin: 0px 20px 24px 20px;
	text-align: left;
}

@media screen and (max-width : 680px) {
	.yhteyslaatikko {
		float: none;
		width: 280px;
		margin: 0px auto 10px auto;
		padding: 0;
		text-align: left;
	}
}

/*
.yhteyslaatikko-560 {
	float: left;
	width: 560px;
	margin: 0px 20px 24px 20px;
	text-align: left;
}

@media screen and (max-width : 680px) {
	.yhteyslaatikko-560 {
		float: none;
		width: 280px;
		margin: 0px auto 10px auto;
		padding: 0;
		text-align: left;
	}
}
*/
.yhteyslaatikko img {
	margin-top: 10px;
	border: none;
}

.yhteyslaatikko h2 {
	text-transform: uppercase;
	font-size: 18px;
	font-weight: normal;
	padding: 0px 20px 0 0px;
}

.yhteyslaatikko p {
	font-size: 14px;
	padding: 5px 14px 0 0px;
}



/*Painikkeet*/
a.painike {
    border: solid #387527 1px;
	text-transform : none;
	padding: 0;
	font-size: 12px;
    padding: 10px;
    text-decoration: none;
    color: black;
}

button {
	border: solid 1px #4ab3aa;
	padding: 10px 22px;
	color: white;
	background-color: #4ab3aa;
	margin-top: 15px;
}

a.linkki-painike {
	text-transform : none;
	font-size: 1.5em;
	color: white;
	text-decoration: none;
}

a.linkki-painike hover {
	text-transform : none;
	font-size: 1.5em;
	color: white;
	text-decoration: none;
}
