@charset "UTF-8";

body {
	font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
}

.bgW {
	background-color: #fff;
}

.bdR {
	border-right: solid #000 1px;
}

.fontRed {
	color: red;
}

.sectionbox {
	margin: 0 auto;
	width: 1080px;
}

.box {
	width: 540px;
}

.pdT7 {
	padding-top: 7px;
}

.pdB5 {
	padding-bottom: 5px;
}

.pdB60 {
	padding-bottom: 60px;
}

.pdT50 {
	padding-top: 50px;
}

.pdT30 {
	padding-top: 30px;
}

.pdT15 {
	padding-top: 15px;
}

.txtL {
	text-align: left;
}

.txtUL {
	border-bottom: solid 1px #000;
}

#contents {
	background-color: #fbfaec;
	font-size: 12px;
	min-width: 1092px;
	text-align: center;
}

#header {
	position: fixed;
	width: 100%;
}

#headSlide {
	position: relative;
}

#headSlide .slideimg {
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

#headSlide #slide04 {
	background: url(../images/bg/header-main-01.jpg) left top no-repeat;
	background-size: cover;
}

#headSlide #slide05 {
	background: url(../images/bg/header-main-02.jpg) left top no-repeat;
	background-size: cover;
}

#headSlide #slide06 {
	background: url(../images/bg/header-main-03.jpg) left top no-repeat;
	background-size: cover;
}

#headSlide #slide01 {
	background: url(../images/bg/header-main-04.jpg) left top no-repeat;
	background-size: cover;
}

#headSlide #slide02 {
	background: url(../images/bg/header-main-05.jpg) left top no-repeat;
	background-size: cover;
}

#headSlide #slide03 {
	background: url(../images/bg/header-main-06.jpg) left top no-repeat;
	background-size: cover;
}

h1#headLogo {
	left: 0;
	position: absolute;
	top: 5%;
	width: 100%;
	z-index: 1;
}

h1#headLogo span {
	background: url(../images/header-logo-text.png) top left no-repeat;
	display: block;
	height: 167px;
	margin: 0 auto;
	text-indent: -9999px;
	width: 562px;
}

#navToggle {
	display: none;
}

#gNav {
	background-color: #044a9f;
}

#gNavList {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	padding: 14px 0;
	width: 1092px;
}

#nav {
	display: flex;
	justify-content: space-around;
}

#nav li {
	border-right: #fff 1px dotted;
}

#nav li:first-child {
	border-left: #fff 1px dotted;
}

#nav li a {
	color: #fff;
	display: block;
	padding: 0 24px;
}

.is-fixed {
	left: 0;
	min-width: 1092px;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 2;
}

#whole {
	left: 0;
	min-width: 1092px;
	position: absolute;
	width: 100%;
	z-index: 2;
}

#concept {
	background: #fff;
	font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	padding-top: 64px;
}

#concept .sectionbox {
	background: url(../images/bg/concept-bg.jpg) center bottom no-repeat;
	height: 100vh;
	margin: 0 auto 32px;
}

#concept h2 {
	padding: 0;
}

#concept h3 {
	padding: 24px 0 40px;
}

#concept p {
	color: #044a9f;
	line-height: 24px;
	margin: 0 0 32px;
}

#work {
	background: #e7f1fa;
	padding: 64px 0 40px;
}

#work h2 {
	padding: 0;
}

#work .work-lists {
	display: flex;
	flex-wrap: wrap;
	padding: 40px 0;
}

#work .work-list {
	width: 31%;
	margin: 0 3.5% 3.5% 0;
}

#work .work-list:nth-child(3n) {
	margin: 0 0 3.5% 0;
}

#work .work-list img {
	border: #fff 2px solid;
	box-sizing: border-box;
	width: 100%;
}

#work .work-list h3 {
	background: #076ac0;
	color: #fff;
	margin: 8px 0 0;
	padding: 4px 0;
}

/**
 * colorbox
 */
#cboxContent,
#cboxLoadedContent {
	background: transparent !important;
}

.popup img {
	box-shadow: 0 -1px 8px -2px #777;
}

.popup .close {
	margin: 64px 0 0;
}

.popup .close-btn {
	background: #076ac0;
	color: #fff;
	display: block;
	margin: auto;
	padding: 8px;
	text-align: center;
	width: 160px;
}

/*colorbox end*/

#work .ufo {
	background: #fff;
	border: #c3d7e9 6px solid;
	margin: 0 auto 32px;
	padding: 24px;
}

#work .ufo h2 {
	border: #076ac0 1px solid;
	color: #076ac0;
	font-size: 22px;
	font-weight: 700;
	margin: 16px auto 32px;
	padding: 12px 24px;
	width: 40%;
}

#work .ufo h2 span {
	color: #000;
	font-size: 28px;
}


#work .ufo .ufo-desc {
	display: flex;
	justify-content: space-between;
	text-align: left;
}

#work .ufo .ufo-desc div {
	width: 48.5%;
}

#work .ufo .ufo-desc div img {
	width: 100%;
}

#work .ufo .ufo-desc .features {
	counter-reset: features;
}

#work .ufo .ufo-desc .features h3 {
	color: #076ac0;
	font-size: 22px;
	margin: 0 0 10px;
}

#work .ufo .ufo-desc .features h3::before {
	background: #076ac0;
	color: #fff;
	content: "0"counter(features);
	counter-increment: features;
	margin: 0 8px 0 0;
	padding: 2px 4px 0;
}

#work .ufo .ufo-desc .features p {
	line-height: 20px;
	margin: 0 0 32px;
}

#work .ufo .ufo-desc .features .btn {
	display: block;
	margin: 12px 0;
}

#work .ufo .ufo-desc-bottom {
	margin: 32px 0 0;
}

#work .ufo .ufo-desc-bottom .difference {
	font-size: 20px;
	font-weight: 700;
	margin: 0 0 16px;
	text-align: left;
}

#work .ufo .ufo-desc-bottom .comparison {
	color: #076ac0;
	font-size: 24px;
	font-weight: 700;
	margin: 0 0 24px;
	text-align: left;
}

#work .uretan {
	position: relative;
}

#work .uretan .uretan-img {
	width: 100%;
}

#work .uretan .uretan-btn {
	bottom: 64px;
	display: block;
	left: 50%;
	position: absolute;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

#footer {
	background: #076ac0;
}

#footer .sectionbox {
	display: flex;
	justify-content: space-around;
	margin: auto;
	padding: 40px 0 0;
}

#footer .sectionbox .access,
#footer .sectionbox .fb {
	max-width: 500px;
	width: 100%;
}

#footer .sectionbox .access h2 {
	margin: 0 0 16px;
}

#footer .sectionbox .access p {
	color: #fff;
	text-align: left;
}

#footer .sectionbox .access p span {
	font-size: 140%;
}

#footer .sectionbox .access p a {
	color: #fff;
}

#footer .sectionbox .map {
	margin: 16px 0 0;
}

#copyright {
	color: #fff;
	font-size: 10px;
	padding: 25px 0;
}

#topcontrol {
	z-index: 3;
}

@media screen and (max-width : 768px) {
	#contents {
		min-width: 100%;
		width: 100%;
	}

	#header {
		position: relative;
	}

	#headSlide {
		min-width: 100%;
		padding-bottom: 62%;
		width: 100%;
		/* 表示画像の高さ ÷ 表示画像の幅 × 100・・・#headSlide内に出力する背景画像の表示高さを可変にしている*/
	}

	#headSlide .slideimg {
		padding-bottom: 62%;
		/* 表示画像の高さ ÷ 表示画像の幅 × 100・・・#headSlide内に出力する背景画像の表示高さを可変にしている*/
	}

	h1#headLogo span {
		background: url(../images/header-logo-text.png) top left no-repeat;
		background-size: 100%;
		width: 50%;
	}

	#whole {
		min-width: 100%;
		position: static;
	}

	.box {
		width: 100%;
	}

	.sectionbox {
		padding: 0 12px;
		width: 100%;
	}

	#concept .sectionbox {
		height: 150vh;
	}

	#concept h3 img {
		width: 80%;
	}

	#concept p {
		text-align: left;
	}

	#concept p br {
		display: none;
	}

	#work .work-lists {
		justify-content: space-between;
	}

	#work .work-list {
		width: 49%;
		margin: 0 0 8%;
	}

	#work .work-list:nth-child(3n) {
		margin: 0 0 8%;
	}

	#work .ufo h2 {
		width: 90%;
	}

	#work .ufo .ufo-desc {
		display: block;
	}

	#work .ufo .ufo-desc div {
		width: 100%;
	}

	#work .ufo .ufo-desc .features {
		margin: 32px 0 0;
	}

	#work .ufo .ufo-desc .features h3 {
		font-size: 18px;
	}

	#work .ufo .ufo-desc-bottom img {
		width: 100%;
	}

	#work .uretan .uretan-btn {
		bottom: 24px;
		width: 72%;
	}

	#work .uretan .uretan-btn img {
		width: 100%;
	}

	.popup img {
		max-width: 96vw;
	}

	#footer .sectionbox {
		display: block;
	}

	#footer .sectionbox .access,
	#footer .sectionbox .fb {
		margin: auto;
		max-width: 500px;
		width: 96%;
	}

	#footer .sectionbox .access h2 img {
		width: 80%;
	}

	#footer .sectionbox .access .spdb {
		display: block;
	}

	#footer .sectionbox .access .map {
		position: relative;
		padding-bottom: 56.25%;
		padding-top: 30px;
		height: 0;
		overflow: hidden;
	}

	#footer .sectionbox .access .map iframe,
	#footer .sectionbox .access .map object,
	#footer .sectionbox .access .map embed {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}

	#footer .sectionbox .fb {
		margin: 32px auto 0;
	}

	/*--- ハンバーガーメニュー ---*/
	#navToggle {
		background-color: #e7f1fa;
		cursor: pointer;
		display: block;
		height: 40px;
		padding-top: 7px;
		position: fixed;
		right: 0;
		top: 0;
		transition: all 0.3s linear 0s;
		width: 40px;
	}

	#navToggle div {
		position: relative;
	}

	#navToggle span {
		display: block;
		font-size: 35px;
	}

	#gNav {
		background-color: none;
	}

	#gNavList {
		background-color: rgba(0, 0, 0, 0.8);
		box-sizing: border-box;
		display: block;
		height: 100%;
		margin: 0;
		padding: 10px 20px;
		position: fixed;
		right: -300px;
		top: 0;
		transition: transform 0.3s linear 0s;
		width: 300px;
		z-index: 1000;
	}

	.openNav #gNavList,
	.openNav #navToggle {
		transform: translateX(-300px);
	}

	#gNavList img {
		width: 80%;
	}

	#navLogo {
		margin: 24px 0;
	}

	#nav {
		display: block;
	}

	#nav li {
		border: none;
		margin: 24px 0;
		padding: 0;
		text-align: center;
	}

	#nav li:first-child {
		border: none;
	}

	#nav a {
		color: #fff;
	}

	#nav a:hover,
	#nav li a:visited,
	#nav li a:active {
		color: #fff;
	}

	#tel {
		margin: 24px 0;
	}

	#topcontrol {
		z-index: 0;
	}
}