@charset "UTF-8";
@import "common.sp.css";

/* ---------------------------------------------------------
	CSS Document hedar_navi
--------------------------------------------------------- */
#headar_navi {
	position: absolute;
	/* top: 20px; */
	top: 8px;
	right: 10px;
	/* width: 480px; */
}

#hnavi li {
	display: inline-block;
	*display: inline;
	*zoom: 1;
	vertical-align: top;
	margin-left: 20px;
	font-size: 14px;
	line-height: 35px;
}

#hnavi li.hnavi a {
	text-decoration: none;
	color: #394350;
	position: relative;
}

#hnavi li.hnavi a:before {
	content: "";
	width: 0;
	height: 0;
	margin-top: -5px;
	border: solid 5px transparent;
	border-left: solid 7px #394350;
	position: absolute;
	top: 50%;
	left: -12px;
}

#lang_btn {
	/* width: 120px; */
	border: 1px solid #394350;
	border-radius: 50px;
}
#hnavi #lang_btn {
	margin-left: 10px;
}
#lang_btn p {
	line-height: 30px;
	font-size: 14px;
	color: #394350;
	text-align: center;
	margin-bottom: 0px;
}
#lang_btn a {
	display: inline-block;
	margin: auto 8px;
	color: #394350;
	text-decoration: none;
}

/* ---------------------------------------------------------
	CSS Document h2
--------------------------------------------------------- */

h2 {
	margin-bottom: 30px;
	padding-left: 46px;
	text-align: left;
	font-weight: bold;
	font-size: 26px;
	line-height: 1.2;
	color: #0995e9;
	position: relative;
}

h2 span:nth-of-type(1) {
	display: inline-block;
	vertical-align: top;
	width: 36px;
	height: 36px;
	margin-top: -18px;
	background: #0995e9;
	text-align: center;
	font-weight: normal;
	font-size: 26px;
	line-height: 32px;
	color: #fff;
	position: absolute;
	top: 50%;
	left: 0;
}

/* ---------------------------------------------------------
	CSS Document about
--------------------------------------------------------- */

#about {
	margin: 0 20px 60px;
}

#about .section {
	margin-bottom: 40px;
	text-align: left;
}

#about .w560 {
	margin-bottom: 15px;
}

#about .w300 {
	text-align: center;
}

#about .w300 img {
	width: 150px;
}

#about h3 {
	margin-bottom: 15px;
	padding: 0 0 10px;
	border-bottom: solid 1px #656565;
	text-align: center;
	font-weight: normal;
	font-size: 22px;
	line-height: 1;
}

#about h3 span {
	display: block;
	margin-bottom: 5px;
	font-size: 11px;
	letter-spacing: 1px;
	color: #55a40f;
}

#about p span {
	text-align: left;
	color: #d6083e;
}

#about p small {
	font-size: 16px;
}

/* ---------------------------------------------------------
	CSS Document work
--------------------------------------------------------- */

#work {
	margin: 0 20px 60px;
}

#work .anchor {
	margin-bottom: 30px;
	text-align: center;
	counter-reset: my-counter;
	font-size: 0;
}

#work .anchor li {
	margin: 9px 0;
	text-align: left;
	line-height: 22px;
	position: relative;
}

#work .anchor li:before {
	display: inline-block;
	vertical-align: middle;
	content: counter(my-counter);
	counter-increment: my-counter;
	width: 22px;
	height: 22px;
	-webkit-border-radius: 22px;
	border-radius: 22px;
	border: solid 1px #ccc;
	text-align: center;
	font-size: 13px;
}

#work .anchor li:nth-child(even) {
	width: 300px;
}

#work .anchor a {
	display: inline-block;
	vertical-align: middle;
	width: calc(100% - 30px);
	margin-left: 6px;
	font-size: 13px;
	line-height: 1.3;
	color: #555;
}

#work .section {
	margin-bottom: 40px;
	text-align: left;
}

#work h3 {
	margin-bottom: 15px;
	padding: 0 0 10px;
	border-bottom: solid 1px #656565;
	font-weight: bold;
	font-size: 22px;
	line-height: 1.2;
}

#work p {
	color: #d6083e;
}

#work .clearfix {
	margin-top: 20px;
}

#work .w390 {
	margin-bottom: 15px;
}

#work .w560 {
	margin-bottom: 15px;
}

#work dt {
	font-weight: bold;
	color: #55a40f;
}

#work dt:not(:first-of-type) {
	margin-top: 10px;
}

#work_02 .w390 p {
	margin-top: 10px;
	font-size: 15px;
	line-height: 1.6;
}

#work_03 .clearfix {
	margin-bottom: 15px;
}

#work_03 p span {
	display: inline-block;
	vertical-align: top;
	font-size: 16px;
	line-height: 1.6;
	color: #555;
}

#work_04 .w650 {
	margin-bottom: 15px;
}

#work_04 .w210 ol {
	counter-reset: my-counter;
}

#work_04 .w210 li {
	height: 58px;
	padding: 0 10px 0 38px;
	-webkit-border-radius: 3px;
	border-radius: 3px;
	background: #76b14d;
	line-height: 54px;
	color: #fff;
	position: relative;
}

#work_04 .w210 li:before {
	content: counter(my-counter);
	counter-increment: my-counter;
	width: 20px;
	height: 20px;
	margin-top: -10px;
	-webkit-border-radius: 20px;
	border-radius: 20px;
	background: #fff;
	text-align: center;
	font-weight: bold;
	line-height: 20px;
	color: #76b14d;
	position: absolute;
	top: 50%;
	left: 11px;
}

#work_04 .w210 li:nth-of-type(1):before {
	color: #4a78c7;
}

#work_04 .w210 li:nth-of-type(2):before {
	color: #49bf92;
}

#work_04 .w210 li:nth-of-type(1):after,
#work_04 .w210 li:nth-of-type(2):after {
	content: '';
	width: 0;
	height: 0;
	margin-left: -5px;
	border: solid 10px transparent;
	border-top: solid 10px #4a78c7;
	position: absolute;
	left: 50%;
	bottom: -19px;
}

#work_04 .w210 li:nth-of-type(2):after {
	border-top: solid 10px #49bf92;
}

#work_04 .w210 li:nth-of-type(1) {
	margin-bottom: 20px;
	background: #4a78c7;
}

#work_04 .w210 li:nth-of-type(2) {
	margin-bottom: 20px;
	background: #49bf92;
}

#work_04 .w210 li span {
	display: inline-block;
	vertical-align: middle;
	line-height: 1.3;
}

/* ---------------------------------------------------------
	CSS Document spec
--------------------------------------------------------- */

#spec {
	margin: 0 20px 30px;
	text-align: left;
}

#spec h3 {
	margin-bottom: 5px;
	padding: 0 0 10px;
	border-bottom: solid 1px #656565;
	font-weight: bold;
	font-size: 22px;
	line-height: 1.2;
}

#spec dl {
	padding: 15px 0;
	border-bottom: dotted 1px #b8b8b8;
}

#spec dl:last-of-type {
	border-bottom: 0;
}

#spec dt {
	font-weight: bold;
	color: #55a40f;
}

#spec dd li {
	margin-left: 1em;
	text-indent: -1em;
}

/* ---------------------------------------------------------
	CSS Document setup
--------------------------------------------------------- */

#setup {
	margin: 0 20px 60px;
	text-align: left;
}

#setup h3 {
	padding: 0 0 10px;
	border-bottom: solid 1px #656565;
	font-weight: bold;
	font-size: 22px;
	line-height: 1.2;
}

#setup h3 span {
	font-weight: normal;
	font-size: 15px;
}

#setup dl {
	margin-top: 20px;
}

#setup dt {
	font-weight: bold;
	color: #55a40f;
}

/* ---------------------------------------------------------
	CSS Document mokuji
--------------------------------------------------------- */

#mokuji {
	margin: 0 20px 40px;
	text-align: left;
}

#mokuji h2 span:last-of-type {
	font-weight: normal;
	font-size: 15px;
}

#mokuji table {
	width: 100%;
	margin-bottom: 40px;
}

#mokuji caption {
	padding: 0 0 10px;
	border-bottom: solid 1px #656565;
	text-align: left;
	font-weight: bold;
	font-size: 22px;
	line-height: 1.2;
}

#mokuji th:first-of-type {
	padding: 10px 0 0;
	text-align: left;
	font-weight: bold;
	font-size: 12px;
}

#mokuji th:last-of-type {
	width: 30px;
	padding: 10px 0 0;
	text-align: center;
	font-weight: bold;
	font-size: 12px;
}

#mokuji td {
	padding: 5px 0;
	font-size: 12px;
	line-height: 1;
}

#mokuji td:first-of-type {
	text-align: left;
}

#mokuji td:last-of-type {
	text-align: center;
}

/* ---------------------------------------------------------
	CSS Document banner
--------------------------------------------------------- */

#banner li {
	margin: 0 20px 24px;
}

#banner li:last-of-type {
	margin-bottom: 30px;
}

#banner li a {
	display: block;
	padding: 10px 10px 60px;
	background: #0995e9 url(../images/banner_03.png) no-repeat center 90%;
	background-size: 40px auto;
	box-shadow: 0 4px 0 0 #eee;
	text-decoration: none;
	font-size: 16px;
	line-height: 1.4;
	color: #fff;
}

#banner li span {
	display: block;
	font-size: 26px;
}

#banner li:first-of-type a {
	background-image: url(../images/banner_01.png);
}

#banner li:first-of-type span {
	display: block;
	margin-bottom: 5px;
	padding-bottom: 60px;
	background: url(../images/h_hakoniwa.png) no-repeat bottom;
	background-size: 60px auto;
}

#banner li:last-of-type a {
	font-size: 24px;
	background-image: url(../images/banner_02.png);
}

