
/*:root {
	--color-primary-0: #377E95;
	--color-primary-1: #E2E3E3;
	--color-primary-2: #97BBC7;
	--color-primary-3: #08617E;
	--color-primary-4: #014A62;
}
  */

body {
	font-family: Arial;
	background-color: #EFEFEF;
	width: 100%;
	height: 100%;
	font-size: 1.0em;
	margin: 0;
	padding: 0;
	line-height: 1.25;
}
div {
	margin: 0;
	padding: 0;
}

#main-layout {
	margin: 0px 50px 50px 50px;
	background-color: white;
	border: 1px solid #C0C0C0;
	box-shadow: 2px 5px 10px 2px #B0B0B0;
	padding: 20px;
	padding-top: 5px;
	padding-bottom: 40px;
	min-height: 500px;
	border-radius: 5px;
}

#menu {
	background-color: #377E95;
	margin: 0;
	padding: 10px;
	padding-top: 5px;
	padding-left: 50px;
	padding-bottom: 0;
	color: #E2E3E3;
	margin-bottom: 20px;
	border-bottom: 3px solid #08617E;
}

#menu h1 {
	color: white;
	margin: 0;
	padding: 0;
}
#menu h4 {
	padding: 0;
	margin: 0;
}
a > img {
	margin-right: 5px;
	vertical-align: middle;
}
#main-layout h1 > img {
	margin-right: 5px;
	vertical-align: middle;
}

#navigation .toggle_menu {
	margin: 0;
	position: absolute;
	left: 2px;
	top: 15px;
	color: white;
	text-decoration: none;
	display: none;
}
#navigation .toggle_menu:hover {
	background-color: #08617E;
}

#navigation {
	padding: 0;
	margin: 0;
	margin-top: 17px;
}
#navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
#navigation li {
	text-align: center;
	display: inline-block;
	margin: 0;
	padding: 0;
	width: 180px;
}
#navigation li.ico {
	text-align: center;
	display: inline-block;
	margin: 0;
	padding: 0;
	width: 35px;
}
#navigation ul.responsive li {
	display: block;
	text-align: left;
	width: 100%;
}
#navigation li a {
	text-decoration: none;
	color: white;
	padding: 10px;
	margin: 0;
	height: 17px;
	display: block;
}
#navigation li a:hover {
	background-color: #08617E;
}

#main-layout h1 {
	color: #08617E;
}
#main-layout h2 {
	color: #377E95;
	border-bottom: 1px solid #D0D0D0;
}
#main-layout h3 {
	color: #397C92;
}

#main-layout a {
	text-decoration: none;
	color: #377E95;
}
#main-layout a:hover {
	text-decoration: underline;
	color: #08617E;
}
#main-layout ul {
	margin: 0;
}

.bold {
	font-weight: bold;
}

#cv dl {
	display: table-row;
}
#cv dt {
	display: table-cell;
	color: #377E95;
	text-align: right;
	max-width: 120px;
}
#cv dd {
	display: table-cell;
	padding-left: 20px;
	padding-bottom: 5px;
}

.project {
	margin-bottom: 40px;
	border-bottom: 1px;
}
.project .info {
	margin-bottom: 10px;
}
.project .field {
	font-weight: bold;
	color: #377E95;
}
.project .link {
	font-weight: bold;
	margin: 5px 15px 5px 0;
	display: inline-block;
	padding: 10px;
	border-radius: 5px;
	border: 1px solid #b9e9f9;
}
.project .link:hover {
	background-color: #b9e9f9;
}

#blog img {
	display: block;
	margin: 5px auto 5px auto;
	border: 1px solid #D0D0D0;
}
#blog a img {
	margin: 0 5px 0 0;
	display: inline-block;
	border: 0;
	vertical-align: middle;
}

#blog .date {
	text-align: left;
	font-style: italic;
	font-weight: bold;
	color: #377E95;
	margin-bottom: 10px;
}

.blog_post {
	border-bottom: 1px solid #D0D0D0;
	padding: 10px;
	margin-bottom: 10px;
}
.blog_content {
	display: inline-block;
	margin-left: 90px;
}
.blog_thumbnail {
	display: inline-block;
	height: 80px;
	width: 80px;
	position: absolute;
}
.ref {
	text-align: center;
	font-style: italic;
	font-size: 0.85em;
}
.blog_post .title {
	color: #08617E;
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 5px;
}
.blog_post .date {
	font-style: italic;
	color: #377E95;
}
.blog_post .content {
	margin-top: 5px;
}

#blog .highlight_text {
	border: 1px solid rgb(79, 156, 69);
	padding: 2px;
	margin: 1px;
	font-weight: bold;
	border-radius: 2px;
}

.gist {
	max-height: 500px;
	overflow: auto;
	border: 1px solid #DFDFDF;
	border-left: 0;
	border-right: 0;
}

pre {
	border-radius: 2px;
	border: 1px solid #C0C0C0;
	max-height: 500px;
	overflow: auto;
}

#blog dt {
	font-weight: bold;
}

#blog code {
	font-size: 0.9em;
}

#blog .snippet {
	font-family: Monospace;
	padding-left: 3px;
	padding-right: 3px;
	padding-bottom: 2px;
	padding-top: 2px;
	font-size: 1.1em;
	background-color: #D2E7F7 /*#C9DBE1 */;
	color: #2F6678;
	border-radius: 4px;
}

#contents {
	margin-top: 30px;
	margin-bottom: 30px;
	margin-left: 20px;
}

.contents_title {
	font-weight: bold;
	margin-bottom: 5px;
}

.contents_h2 {
}

.contents_h3 {

}

#contents a:hover {
	text-decoration: none;
}

.contents_div_h2 {
	margin-top: 5px;
	font-weight: bold;
}

.contents_div_h3, .contents_div_h4 {
	margin: 0;
	padding: 0;
	margin-left: 15px;
	font-size: 0.9em;
	padding-left: 5px;
	border-left: 1px solid #BBBBBB;
}
.contents_div_h4 {
	margin-left: 30px;
	border-style: dotted;
	font-size: 0.85em;
	border: 0;
	border-left: 1px solid #BBBBBB;
}

#blog h2 {
	margin-top: 25px;
}

#blog h4 {
	margin-top: 15px;
	margin-bottom: 10px;
	padding: 0;
	border-bottom: 1px dotted #D0D0D0;
}

#blog h5 {
	font-family: Arial;
	padding: 0;
	margin: 0;
	font-size: 1.0em;
	-webkit-margin-before: 0;
	-webkit-margin-after: 0;
	font-weight: 500;
	color: #909090;
}

#blog ul {
	margin-bottom: 10px;
}

#blog blockquote {
	font-family: Georgia, serif;
	font-style: italic;
	margin: 0.25em 0;
	margin-bottom: 10px;
	font-size: 0.9em;
	padding: 0.25em 50px;
	line-height: 1.45;
	position: relative;
	color: #383838;
	border-left: 7px solid #C0C0C0;
	background-color: #F5F5F5;
}

#blog blockquote:before {
	display: block;
	content: "\201C";
	font-size: 80px;
	position: absolute;
	left: 0px;
	top: -20px;
	color: #7a7a7a;
}

#blog blockquote cite {
	color: #999999;
	font-size: 0.9em;
	display: block;
	margin-top: 5px;
}
 
#blog blockquote cite:before {
	content: "\2014 \2009";
}

::selection {
	background: #a8d1ff;
}

::-moz-selection {
	background: #a8d1ff;
}