button,hr,input{overflow:visible}progress,sub,sup{vertical-align:baseline}[type=checkbox],[type=radio],legend{box-sizing:border-box;padding:0}html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}details,main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:ButtonText dotted 1px}fieldset{padding:.35em .75em .625em}legend{color:inherit;display:table;max-width:100%;white-space:normal}textarea{overflow:auto}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}[hidden],template{display:none}

/* ========================================
	font 
======================================== */
@font-face {
	font-family: 'TTCommons';
	font-style: normal;
	font-weight: 300;
	src: url('fonts/TTCommons-Light.woff') format('woff'), /* woff - Modern Browsers */
		 url('fonts/TTCommons-Light.ttf') format('truetype'), /* truetype - Androd, iOS, safari */
		 url('fonts/TTCommons-Light.eot') format('embedded-opentype'); /* IE9 Compact Modes */
}
@font-face {
	font-family: 'TTCommons';
	font-style: normal;
	font-weight: 400;
	src: url('fonts/TTCommons-Regular.woff') format('woff'), /* woff - Modern Browsers */
		 url('fonts/TTCommons-Regular.ttf') format('truetype'), /* truetype - Androd, iOS, safari */
		 url('fonts/TTCommons-Regular.eot') format('embedded-opentype'); /* IE9 Compact Modes */
}
@font-face {
	font-family: 'TTCommons';
	font-style: normal;
	font-weight: 500;
	src: url('fonts/TTCommons-Medium.woff') format('woff'), /* woff - Modern Browsers */
		 url('fonts/TTCommons-Medium.ttf') format('truetype'), /* truetype - Androd, iOS, safari */
		 url('fonts/TTCommons-Medium.eot') format('embedded-opentype'); /* IE9 Compact Modes */
}
@font-face {
	font-family: 'TTCommons';
	font-style: normal;
	font-weight: 600;
	src: url('fonts/TTCommons-Bold.woff') format('woff'), /* woff - Modern Browsers */
		 url('fonts/TTCommons-Bold.ttf') format('truetype'), /* truetype - Androd, iOS, safari */
		 url('fonts/TTCommons-Bold.eot') format('embedded-opentype'); /* IE9 Compact Modes */
}
@font-face {
	font-family: 'TTCommons';
	font-style: italic;
	font-weight: 400;
	src: url('fonts/TTCommons-RegularItalic.woff') format('woff'), /* woff - Modern Browsers */
		 url('fonts/TTCommons-RegularItalic.ttf') format('truetype'), /* truetype - Androd, iOS, safari */
		 url('fonts/TTCommons-RegularItalic.eot') format('embedded-opentype'); /* IE9 Compact Modes */
}





/* ========================================
	common 
======================================== */
html {
	margin: 0;
	padding: 0;
	height: 100%;
}
body {
	font-size: 14px;
	line-height: 1.75;
	letter-spacing: 0.05em;
	height: 100%;
	font-weight: 400;
	color: #191919;
	background-color: #eff0ec;
	font-family: "TTCommons" ,"Noto Sans JP", sans-serif;
}
.preload {
	-webkit-transition: none !important;
	-moz-transition: none !important;
	-ms-transition: none !important;
	transition: none !important;
}
main {
	padding-top: 150px;
}
main#top {
	padding-top: 90px;
}
#contents {
	height: 100%;
}
@media screen and (max-width:767px) {
	main {
		padding-top: 120px;
	}
	main#top {
		padding-top: 30px;
	}
}

*:focus { 
	outline: none;
}

/* link */
a {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-tap-highlight-color:rgba(0,0,0,0);
	cursor:pointer;
	outline: none;
	text-decoration: none;
	color: #191919;
}
a:hover,
a:active,
a:visited,
a:focus {
	outline: none;
	color: #191919;
}
.link-underline {
	padding-bottom: 0px;
	border-bottom: #000 1px solid;
}
.link-underline__img {
	width: auto;
	height: 9px;
}

/* headline */
h1,h2,h3,h4,h5 {
	line-height: 1.3;
}
h1,h2,h3,h4,h5,p {
	margin: 0;
	padding: 0;
	font-weight: 400;
}
h2 {
	font-size: 21px;
	font-weight: 500;
}

h3 {
	font-size: 21px;
	font-weight: 400;
}
h4 {
	font-size: 18px;
	font-weight: 400;
}
@media screen and (max-width:767px) {
	h2 {
		font-size: 18px;
	}
	h3 {
		font-size: 18px;
	}
	h4 {
		font-size: 16px;
	}
}
/* list */
ul,li {
	padding: 0;
	margin: 0;
}
li {
	list-style: none;
}

table,th,td {
	margin: 0;
	padding: 0;
	border-collapse: collapse;
	border-spacing: 0;	
}
th {
	font-weight: 500;
}
.nolink {
	pointer-events: none;
}
dt {
	font-weight: 400;
}
/* typography (common)
---------------------------------------- */
p {
	color: #191919;
	font-size: 14px;
	hanging-punctuation: allow-end;
	line-height: 1.8;
	letter-spacing: 0.04em;
}
.italic {
	font-style: italic;
}

img {
	vertical-align: middle;
}
hr {
	width: 100%;
	height: 1px;
	background-color: #555;
	margin: 0;
}
small {
	font-size: 10px;
	letter-spacing: 0.05em;
}
ul,li {
	margin: 0;
	padding: 0;
}
.bold {
	font-weight: 600;
}

.br-sp {display: none;}
@media screen and (max-width: 767px) {
  .br-pc {display: none;}
  .br-sp {display: inline-block;}
}

.pc-none {display: none;}
@media screen and (max-width:991px) {
	.sp-none {display: none;}
	.pc-none {display: block;}
}

.pc-img-none {display:none;}
@media screen and (max-width:575px) {
	.sp-img-none {display: none;}
	.pc-img-none {display: block;}
}
.sp-ttl-none {display:block;}
@media screen and (max-width:575px) {
	.sp-ttl-none {display: none;}
}

/* parts btn / line
---------------------------------------- */
.separate-line {
	display: block;
	width: 100%;
	height: 1px;
	background-color: #d9d9d9;
}
.separate-line-white {
	background-color: #fff;
}
.menu-item {
	transition: 0.25s ease-in-out opacity;
	-webkit-transition: 0.25s ease-in-out opacity;
	
}
.menu-item:hover {
	opacity: 0.6;
}
.btn {
	padding-top: 15px;
	padding-bottom: 15px;
}
.btn__txt {
	font-size: 16px;
	font-weight: 400;
}
.btn__txt-ja {
	font-size: 14px;
}
.btn__img {
	display: inline-block;
	position: relative;
	margin-left: 20px;
	vertical-align: baseline;
	overflow: hidden;
	width: 100px;
	height: 8px;
	top: -2px;
}
.btn__img-short {
	width: 36px;
	height: 8px;
}
.btn__img-long {
	width: 100px;
	height: 8px;
}

.btn__img::before,.btn__img::after {
	content: "";
	background-image: url(../images/img_btn-arrow-right-black.png);
	background-size: contain;
	background-position: 0 50%;
	background-repeat: no-repeat;
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	animation-fill-mode: forwards;
	animation-duration: 0.6s;
}
.btn__img-short.btn__img::before,.btn__img-short.btn__img::after {
	background-image: url(../images/img_btn-arrow-right-short-black.png);
	animation-fill-mode: forwards;
	animation-duration: 0.6s;
}
.btn__img-long.btn__img::before,.btn__img-long.btn__img::after {
	background-image: url(../images/img_btn-arrow-right-black.png);
	animation-fill-mode: forwards;
	animation-duration: 1s;
}
.btn-white .btn__img-long.btn__img::before,.btn-white .btn__img-long.btn__img::after {
	background-image: url(../images/img_btn-arrow-right-white.png);
}

.btn__img::after {
  transform: translateX(-100%);
}
.btn:hover .btn__img::before {
  animation-name: RightLeft;
  animation-delay: 0s;
}
.btn:hover .btn__img::after {
  animation-name: LeftRight;
  animation-delay: 0.4s;
}

@keyframes LeftRight {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes RightLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(100%);
  }
}

.btn-wrapper {
	margin-top: 40px;
}
#works .btn-wrapper {
	margin-top: 0;
}
.iframe-wrapper {
	position: relative;
/*
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
*/
	width: 100%;
	height: 0;
	padding-top: 56.25%;
	overflow: hidden;
}
.iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/* loading
---------------------------------------- */
.loading {
	background-color: #676863;
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 999;
}
.loading__logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform:translate(-50%,-50%);
	-webkit-transform:translate(-50%,-50%);
	-ms-transform:translate(-50%,-50%);
}
.loading__logo img {
	width: 100px;
}
/*
.header__ttl.is-fadeout, .header__txt.is-fadeout, .header-top .menu-btn.is-fadeout, .header__pc.is-fadeout {
	transform: translatey(-20px);
	-webkit-transform: translatey(-20px);
	-ms-transform: translatey(-20px);
	-moz-transform: translatey(-20px);
}
*/

@media screen and (max-width:767px) {
	.loading__logo img {
		width: 80px;
	}
}

/* Layout section / module / table
---------------------------------------- */
.section {
	overflow: hidden;
	position: relative;
}
.section__inner {
	padding-top: 120px;
	padding-bottom: 120px;
}
#company .section__inner {
	padding-top: 180px;
}
.header-section {
	overflow: hidden;
	position: relative;
}
/*
.header-section__inner {
	padding-top: 80px;
}
*/
.page-section {
	overflow: hidden;
	position: relative;
}
/*
.page-section__inner {
	padding-bottom: 150px;
}
*/

.header-section {
	margin-bottom: 50px;
}
.page-section__inner {
	padding-top: 100px;
	padding-bottom: 50px;
}
.page-section:last-child .page-section__inner {
	padding-bottom: 150px;
}
.page-header__ttl-wrapper {
	border-bottom: 1px solid #d9d9d9;
}
.module {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}
.module-sm {
	max-width: 870px;
}
#archive-works .module {
	max-width: 1600px;
}
.module__inner {
	padding-left: 10%;
	padding-right: 10%;
}

.header-module .module__inner {
	border-bottom: 1px solid #d9d9d9;
}

.module__left {
	padding-left: 10%;
	float: left;
	width: calc(280px + 10%);
}
.module__right {
	padding-right: 10%;
	float: right;
	width: calc(100% - 280px - 10%);
}


#page-about .module__left {
	padding-left: calc(10% + 60px);
	float: left;
	width: calc(280px + 10%);
}
#page-about .module__right {
	padding-right: calc(10% + 60px);
	float: right;
	width: calc(100% - 280px - 10%);
}

#single-works .module__right {
	
}

.module.module-slider {
	overflow: visible;
}
.module-slider .swiper-wrapper {
	padding-left: 10%;
	padding-right: 10%;
}
#works .module-slider {
	margin-bottom: 40px;
}
.gallery-pc-none {
	display: none;
}
@media screen and (max-width:991px){
	.gallery-pc-none {
		display: block;
	}
	
}
@media screen and (max-width:767px){
	.section__inner {
		padding-top: 90px;
		padding-bottom: 90px;
	}
	#company .section__inner {
		padding-top: 120px;
	}
	#about .section__inner {
		padding-top: 90px;
	}
/*
	.page-section__inner {
		padding-bottom: 60px;
	}
*/
	
	.header-section {
		margin-bottom: 15px;
	}
	.page-section__inner {
		padding-top: 75px;
		padding-bottom: 15px;
	}
	.page-section:last-child .page-section__inner {
		padding-bottom: 90px;
	}
	
/*
	.page-section__inner:last-child {
		padding-bottom: 90px;
	}
*/
	.module__inner {
		padding-left: 5.333%;
		padding-right: 5.333%;
	}
	.module__left {
		padding-left: 5.333%;
		padding-right: 5.333%;
		width: 100%;
		float: none;
	}
	.module__right {
		padding-left: 5.333%;
		padding-right: 5.333%;
		float: none;
		width: 100%;
	}
	#page-about .module__left {
		padding-left: 5.333%;
		padding-right: 5.333%;
		width: 100%;
		float: none;
	}
	#page-about .module__right {
		padding-left: 5.333%;
		padding-right: 5.333%;
		float: none;
		width: 100%;
	}
	
	
	.module-slider .swiper-wrapper {
		padding-left: 5.333%;
		padding-right: 5.333%;
	}
	#works .module-slider {
		margin-bottom: 20px;
	}
}

.table {
	border-top: solid 1px #d9d9d9;
}

.table th, .table td {
	padding-top: 30px;
	padding-bottom: 30px;
	border-bottom: solid 1px #d9d9d9;
}
.table th {
	width: 120px;
	text-align: left;
	vertical-align: top;
}
.table td {
	calc(100% - 120px);
	text-align: left;
	vertical-align: top;
	padding-left: 20px;
}
#single-works .table {
	border-top: none;
}
#single-works .table th ,#single-works .table td {
	padding-top: 10px;
	padding-bottom: 10px;
	font-weight: 400;
}


.main-table {
	border-top: solid 1px #d9d9d9;
}

.main-table th, .main-table td {
	padding-top: 30px;
	padding-bottom: 30px;
	border-bottom: dashed 1px #d9d9d9;
}
.main-table th {
	width: 120px;
	text-align: left;
	vertical-align: top;
}
.main-table td {
	calc(100% - 120px);
	text-align: left;
	vertical-align: top;
	padding-left: 20px;
}
.main-table__header {
	padding-top: 30px;
	padding-bottom: 30px;
	border-bottom: solid 1px #d9d9d9;
	cursor: pointer;
	position: relative;
}
.main-table__header h4,.message-txt__header h4 {
	position: relative;
	top: 3px;
}
.main-table__body {
/*
	opacity: 0;
	display: none;
*/
}
.main-table-open .main-table__body {
	display: block;
/* 	opacity: 1; */
}

.group-table {
	border-bottom: solid 1px #d9d9d9;
}
.group-table__ttl {
	vertical-align: top;
	width: 120px;
	padding-top: 30px;
	padding-bottom: 30px;
}
.group-table__desc {
	calc(100% - 120px);
}

.sub-table th, .sub-table td {
	padding-top: 30px;
	padding-bottom: 30px;
	border-bottom: dashed 1px #d9d9d9;
}
.sub-table th {
	width: 120px;
	text-align: left;
	vertical-align: top;
}
.sub-table td {
	calc(100% - 120px);
	text-align: left;
	vertical-align: top;
	padding-left: 20px;
}
.sub-table:first-child {
	border-bottom: solid 1px #d9d9d9;
}
.sub-table__header {
	padding-top: 30px;
	padding-bottom: 30px;
	cursor: pointer;
}
.sub-table__body {
	display: none;
/*
	opacity: 0;
	display: none;
*/
}
.sub-table-open .sub-table__body {
/* 	opacity: 1; */
}
.sub-table__header_img {
	vertical-align: middle;
	position: relative;
	width: auto;
	height: 8px;
	margin-left: 20px;
	top: -1px;
	transform-origin: center center;
	-webkit-transform-origin: center center;
}
.sub-table-open .sub-table__header_img {
	transform: rotate(180deg);
	-webkit-transform: rotate(180deg);
}
.table-border-none {
	border-bottom: none !important;
}
.table-padding-none {
	padding-top: 0 !important;
}

@media screen and (max-width: 767px) {
	
	.table th {
		display: block;
		width: 100%;
		border-bottom: none;
		padding-top: 15px;
		padding-bottom: 0px;
	}
	.table td {
		display: block;
		width: 100%;
		padding-left: 0;
		padding-top: 0;
		padding-bottom: 15px;
	}
	#single-works .table th {
		padding-top: 20px;
		padding-bottom: 5px;
	}
	#single-works .table td {
		padding-top: 0px;
		padding-bottom: 15px;
	}
	.main-table th {
		display: block;
		width: 100%;
		border-bottom: none;
		padding-top: 15px;
		padding-bottom: 0px;
	}
	.main-table td {
		display: block;
		width: 100%;
		padding-left: 0;
		padding-top: 0;
		padding-bottom: 15px;
	}
	.main-table__header {
		padding-top: 15px;
		padding-bottom: 15px;
	}
	.main-table__header h4,.message-txt__header h4 {
		top: 2px;
	}
	.group-table__ttl {
		text-align: left;
		padding-top: 15px;
		padding-bottom: 0px;
	}
	.sub-table {
		padding-top: 0px;
		padding-bottom: 0px;
		border-bottom: none;
	}
	.sub-table__header {
		padding-top: 15px;
		padding-bottom: 15px;
	}
	.sub-table th {
		display: block;
		width: 100%;
		border-bottom: none;
		padding-top: 15px;
		padding-bottom: 0px;
	}
	.sub-table td {
		display: block;
		width: 100%;
		padding-left: 0;
		padding-top: 0;
		padding-bottom: 15px;
	}
	.sub-table:first-child .sub-table__header {
		padding-top: 15px;
	}
}

@media screen and (max-width: 575px) {
	.group-table__ttl {
		display: block;
	}
	.group-table__desc {
		display: block;
	}
}


.message-txt-wrapper {
	border-top: solid 1px #d9d9d9;
}
.message-txt {
	border-bottom: solid 1px #d9d9d9;
}

.message-txt__header {
	padding-top: 30px;
	padding-bottom: 30px;
	cursor: pointer;
	position: relative;
}
.message-txt__body {
	display: none;
	padding-bottom: 30px;
}
.message-txt-open .message-txt__body {
/* 	opacity: 1; */
}
@media screen and (max-width: 767px) {
	
	.message-txt__header {
		padding-top: 15px;
		padding-bottom: 15px;
	}
}

.header__plus {
	position: absolute;
	top: 27px;
	right: 20px;
	width: 30px;
	height: 30px;
}
.header__plus_line {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	-moz-transform: translate(-50%,-50%);
	display: block;
	transition: linear 0.3s transform;
	transform-origin: center center;
}
.header__plus_line:nth-of-type(1) {
	width: 100%;
	height: 1px;
	background-color: #191919;
}
.header__plus_line:nth-of-type(2) {
	width: 1px;
	height: 100%;
	background-color: #191919;
}
.main-table-open .header__plus_line:nth-of-type(2),.message-txt-open .header__plus_line:nth-of-type(2) {
	transform: translate(-50%,-50%) rotate(90deg);
	-webkit-transform: translate(-50%,-50%) rotate(90deg);
	-ms-transform: translate(-50%,-50%) rotate(90deg);
	-moz-transform: translate(-50%,-50%) rotate(90deg);
}
/*
.main-table-open .header__plus_line:nth-of-type(2) {
	opacity: 0;
}
.message-txt-open .header__plus_line:nth-of-type(2) {
	opacity: 0;
}
*/
@media screen and (max-width: 767px) {
	.header__plus {
		position: absolute;
		top: 15px;
		right: 15px;
		width: 20px;
		height: 20px;
	}
}
#company h3,#message h3 {
	padding-right: 90px;
	margin-top: 8px;
} 

/* Animation heaeder
---------------------------------------- */
.top-header.is-fadeout .header__ttl,.top-header.is-fadeout .header__pc, .top-header.is-fadeout .menu-btn {
	opacity: 0;
	transform: translate(0,-5px);
}
.page-header.is-fadeout .header__ttl,.page-header.is-fadeout .header__pc, .page-header.is-fadeout .menu-btn {
	opacity: 0;
	transform: translate(0,-5px);
}

/* Animation fadeIn
---------------------------------------- */
[data-aos=fade-up] {
	transform: translate3d(0,30px,0);
}
[data-aos=fade-left] {
	transform: translate3d(30px,0,0);
}
[data-aos=fade-right] {
	transform: translate3d(-30px,0,0);
}

/* Layout header / footer
---------------------------------------- */
.header {
	position: fixed;
	width: 100%;
	height: 75px;
	z-index: 10;
}
.top-header {
	background-color: #eff0ec;
	opacity: 1;
	transition: transform ease-in-out 0.3s,opacity ease-in-out 0.3s;
}
.page-header {
	background-color: #eff0ec;
	opacity: 1;
	transition: transform ease-in-out 0.3s,opacity ease-in-out 0.3s;
}
.header__ttl {
	position: absolute;
	top: 30px;
	left: 30px;
	line-height: 1.35;
	transition: 0.8s ease-in-out;
	-webkit-transition: 0.8s ease-in-out;
	z-index: 10;
}
.header__ttl_img {
	width: 60px;
	margin-bottom: 0;
	display:block;
}
.header__pc {
	position: absolute;
	top: 30px;
	right: 30px;
	z-index: 10;
	transition: .8s ease-in-out;
	-webkit-transition: .8s ease-in-out;
	width: 650px;
	height: 60px;
}
.header__pc_menu {
	position: absolute;
	top: -2px;
	right: 40px;
}
.header__pc_menu .header__menu li {
	margin-right: 20px;
    display: inline-block;
    margin-bottom: 0;
    text-align: left;
}
@media screen and (max-width:991px) {
	.header__ttl_img {
		width: 60px;
		margin-bottom: 0;
		display:block;
	}
	.header__pc {
		display: none;
	}
}
@media screen and (max-width:767px) {
	.header__ttl {
		left: 20px;
	}
}

/* menu - SP
---------------------------------------- */
.header__sp {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
	color: #fff;
	pointer-events: none;
	opacity: 0;
}
.header__sp.is-open {
	pointer-events: auto;
	visibility: visible;
}
.header__sp a {
	color: #f1f2ed;
}
.header__sp_inner {
	position: absolute;
	right: 0;
	top: 0;
	width: 400px;
	height: 100%;
	background: rgba(103,104,99,1);
	z-index: 11;
}
@media screen and (max-width:575px) {
	.header__sp_inner {
		width: 100%;
	}
}

.header__sp_bg {
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: 10;
	background: rgba(23,24,21,0.7);
}
.header__sp_ttl {
	position: absolute;
	left: 40px;
	top: 30px;
}
@media screen and (max-width:575px) {
	.header__sp_ttl {
		display: block;
		left: 20px;
	}
	.header__sp_ttl .header__ttl_img {
		width: 60px;
	}
}
.header__sp_menu {
	position: absolute;
	top: 120px;
	left: 40px;
	text-align: left;
	display: block;
}

/* メニュー共通 - .header__menu
---------------------------------------- */
.header__menu {
	text-align: left;
	display: inline-block;
}
@media screen and (max-width:991px) {
	.header__menu {
		display: block;
		margin-bottom: 60px;
	}
}
.menu-item {
	vertical-align: middle;
	display: block;
	position: relative;
	transition: all 0.4s;
	-webkit-transition: all 0.4s;
	line-height: 1;
	padding-left: 6px;
	padding-right: 6px;
	letter-spacing: 0.05em;
	margin-right: 0;
	margin-bottom: 35px;
}
.header__pc .menu-item {
	font-size: 14px;
}
.header__sp .menu-item {
	font-size: 21px;
}

@media screen and (max-width:991px) {
	.menu-item a,
	.menu-item a:visited {
		color: #fff;
	}	
}

/* menu - language
---------------------------------------- */
.header__menu_lang {
	font-size: 10px;
	letter-spacing: 0.05em;
	display: inline-block;
	margin-right: 20px;
	vertical-align: top;
}
@media screen and (max-width:991px) {
	.header__menu_lang {
		display: block;
		margin-right: 6px;
		margin-bottom: 20px;
	}
}

/* menu - sns
---------------------------------------- */
.header__menu_sns {
	margin-top: 10px;
	display: block;
	vertical-align: top;
	margin-left: -15px;
	margin-right: -15px;
}
.header__menu_sns a {
	margin-left: 15px;
	margin-right: 15px;
}

.header__sns_img {
	width: 30px;
	opacity: 1;
}
.menu-btn {
	transition: 0.8s ease-in-out;
	-webkit-transition: 0.8s ease-in-out;
	position: fixed;
	width: 48px;
	height: 48px;
	z-index: 12;
	top: 16px;
	right: 25px;
}
.menu-btn__inner {
	position: absolute;
	top: 15.5px;
	left: 0;
	right: 0;
	width: 27px;
	height: 13px; 
	margin: 0 auto;
}
.menu-btn__line {
	position: absolute;
	width: 100%;
	height: 1px;
	background: #222;
	border-radius: 1px;
	transition: all .3s ease-in-out;
	-webkit-transition: all .3s ease-in-out;
}
.menu-btn__line:nth-of-type(1) {
	top: 0;
}
.menu-btn__line:nth-of-type(2) {
	top: 6px;
}
.menu-btn__line:nth-of-type(3) {
	bottom: 0;
}
.menu-btn.is-change .menu-btn__line {
	background: #fff;
}
.menu-btn.is-change .menu-btn__line:nth-of-type(1) {
	transform: translateY(6px) rotate(45deg);
	-webkit-transform: translateY(6px) rotate(45deg); /* for iOS and Chrome */
	-ms-transform: translateY(6px) rotate(45deg); /* for IE */
	-moz-transform: translateY(6px) rotate(45deg); /* for Firefox */
	transform-origin: center;
	-webkit-transform-origin: center; /* for iOS and Chrome */
	-ms-transform-origin: center; /* for IE */
	-moz-transform-origin: center; /* for Firefox */
}
.menu-btn.is-change .menu-btn__line:nth-of-type(2) {
	opacity: 0;
}
.menu-btn.is-change .menu-btn__line:nth-of-type(3) {
	transform: translateY(-6px) rotate(-45deg);
	-webkit-transform: translateY(-6px) rotate(-45deg); /* for iOS and Chrome */
	-ms-transform: translateY(-6px) rotate(-45deg); /* for IE */
	-moz-transform: translateY(-6px) rotate(-45deg); /* for Firefox */
	transform-origin: center;
	-webkit-transform-origin: center; /* for iOS and Chrome */
	-ms-transform-origin: center; /* for IE */
	-moz-transform-origin: center; /* for Firefox */
}
@media screen and (max-width:767px) {
	.menu-btn {
		right: 15px;
	}
}


.footer {
	position: relative;
	background-color: #676863;
	min-height: 200px;
}
.footer__inner {
	padding-top: 120px;
	padding-bottom: 120px;
}
.footer__logo {
	width: 60px;
	height: auto;
}
.footer__menu_list {
	display: inline-block;
	margin-bottom: 20px;
}
.footer__menu_list:first-child a {
	padding-top: 0;
}
.footer__menu_list a {
	display: inline-block;
	font-size: 18px;
	padding-left: 15px;
	padding-right: 15px;
	color: #f1f2ed;
	transition: 0.3s ease-in-out opacity;
	-webkit-transition: 0.3s ease-in-out opacity;
	line-height: 1;
}
.footer__menu_list a:hover {
	opacity: 0.6;
}
.footer__menu-wrapper {
	overflow: hidden;
	padding-top: 4px;
	margin-bottom: 40px;
	margin-left: -15px;
}
.footer__menu {
/*
	float: left;
	width: 50%;
*/
}
/*
.footer__address {
	float: right;
	width: 50%;
}
.footer__address p {
	font-size:12px;
	color: #f1f2ed;
	line-height: 1.5;
}
.footer__address a {
	font-size:12px;
	color: #f1f2ed;
	transition: 0.3s ease-in-out opacity;
	-webkit-transition: 0.3s ease-in-out opacity;
}
.footer__address a:hover {
	opacity: 0.6;
}
*/

.footer__copy {
	position: relative;
	font-size: 11px;
	color: #f1f2ed;
}

@media screen and (max-width:767px) {
	.footer__inner {
		padding-top: 80px;
		padding-bottom: 80px;
	}
	.footer__logo {
		margin-bottom: 60px;
	}
	.footer__menu-wrapper {
		overflow: hidden;
		padding-left: 0;
		padding-right: 0;
	}
	.footer__menu_list {
		display: block;
		margin-bottom: 5px;
	}
	.footer__menu_list a {
		font-size: 16px;
		padding-top: 10px;
		padding-bottom: 10px;
	}
	.footer__menu {
		float: none;
		width: 100%;
		margin-bottom: 0px;
	}
	.footer__address {
		float: none;
		width: 100%;
	}
	.footer__copy {
		padding-left: 0;
	}
}

/* Typograhy
---------------------------------------- */
.section__ttl {
	font-weight: 400;
	margin-bottom: 40px;
}
.sub-section__ttl {
	margin-top: 28px;
}
.section__ttl_ja {
	font-size: 14px;
	display:block;
	margin-top: 5px;
	color: #8d8d8c;
	letter-spacing: 0;
}
.page-section__ttl {
	font-size: 58px;
	margin-bottom: 30px;
	font-weight: 300;
	line-height: 1;
}
.page-section__ttl {
	display: inline-block;
}

.module__heading {
	margin-bottom: 30px;
}
.module__heading-medium {
	font-size: 16px;
	font-weight: 500;
}
.module__heading-light {
	font-weight: 300;
}

#page-about .module__heading {
	padding-top: 6px;
}
.module__heading-border {
	border-bottom: 1px solid #d9d9d9;
	padding-bottom: 20px;
}
#single-information .module__heading-border {
	margin-bottom: 60px;
}
.module__ttl {
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 30px;
	padding-top: 1px;
}


.about__statement {
	font-size: 58px;
	line-height: 1;
	letter-spacing: 0.025em;
	font-weight: 300;
	display: block;
	margin-bottom: 60px;
}
.about__ttl {
	line-height: 1.8;
	margin-bottom: 40px;
}
.about__txt {
	font-size: 14px;
	margin-bottom: 80px;
}
/*
.about__txt_caption {
	font-size:
}
*/

.about__subttl {
	font-size: 15px;
	font-weight: 400;
	display: block;
	margin-bottom: 15px;
}
.about__subtxt {
	padding-bottom: 20px;
	border-bottom: 1px solid #d9d9d9;
	margin-bottom: 80px;
}
.about__diagram {
	text-align: center;
}
.about__diagram img {
	max-width: 600px;
	margin-bottom: 40px;
	margin-left: auto;
	margin-right: auto;
}
.about__diagram_ttl {
	line-height: 1.6;
/* 	margin-bottom: 20px; */
}
.about__diagram_txt {
	font-size: 13px;
}
.ttl-white {
	color: #fff;
}
.txt-white {
	color: #fff;
}
@media screen and (max-width:767px) {
	.section__ttl {
/* 		font-size: 18px; */
		margin-bottom: 20px;
	}
	.page-section__ttl {
		font-size: 35px;
	}
	.sub-section__ttl {
		margin-top: 0;
	}
	.module__heading-light {
		font-weight: 400;
		font-size: 15px;
	}
/*
	.about__statement {
		font-size: 42px;
	}
*/

	#page-about .module__heading {
		padding-top: 0;
	}
	.about__diagram img {
		max-width: 400px;
		width: calc(100% + 20px);
		position: relative;
		left: -10px;
		margin-bottom: 30px;
	}
	.about__statement {
		font-size: 32px;
		margin-bottom: 30px;
	}
	.about__ttl {
		margin-bottom: 30px;
	}
/*
	.about__txt {
		margin-bottom: 60px;
	}
*/
	.about__subtxt {
		margin-bottom: 40px;
	}
	.about__diagram_ttl {
		margin-bottom: 15px;
	}
	.about__diagram_txt {
		font-size: 12px;
	}
	
	#single-information .module__heading-border {
		margin-bottom: 0px;
	}
}

/* top
---------------------------------------- */
/* bg */
#top {
}

video.w-100 {
	width: 100%;
}
video.h-100 {
	height: 100%;
}
.bg {
	top: 0;
	left: 0;
	width: 100%;
	height: 480px; /* fall back */
	overflow: hidden;
	backface-visibility: "hidden";
	-webkit-backface-visibility: "hidden"; /* for iOS and Chrome */
	z-index:0;
	background-color: #000;
	position: relative;
}
.bg__overlay {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
/*
	z-index: 1;
	opacity: 1;
	background-color: rgba(0,0,0,0.15);
*/
	z-index: 1;
	visibility: hidden;
	-webkit-visibility: hidden;
	visibility: visible;
	-webkit-visibility: visible;
	background-color: rgba(0,0,0,0.15);
	transition-delay: 0;
	transition-duration: 0.5s;
	transition-property: opacity;
}
.bg__overlay.is-active {
	visibility: visible;
	-webkit-visibility: visible;
}
.bg__inner {
	position: relative;
	z-index: 0;
	height: 100%;
}
.bg__inner video {
	opacity: 0;
	transition: ease-in-out 1.6s;
}
.bg__inner video.is-out {
	opacity: 0;
}
.bg__inner video.is-in {
	opacity: 1;
/* 	transition: ease-in-out 2.4s; */
}
.bg__content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	width: 100%;
	text-align: center;
	margin-bottom: 40px;
	color: #fff;
	z-index: 2;
	width: calc(100% - 60px);
}
.bg__content_en {
	font-size: 55px;
	display: block;
	line-height: 1.2;
	margin-bottom: 20px
}
.bg__content_ja {
	font-size: 21px;
	display: block;
}
@media screen and (max-width:767px) {
	.bg {
		height: 360px;
	}
	.bg__content {
		text-align: left;
		left: 5.333%;
		transform: translate(0,-50%);
		-webkit-transform: translate(0,-50%);
		-ms-transform: translate(0,-50%);
	}
	.bg__content_en {
		font-size: 36px;
	}
	.bg__content_ja {
		font-size: 14px;
	}
	
}

.mv__header.is-fadeout {
	opacity: 0;
	transform: translate(0,20px);
}
.mv__content.is-fadeout {
	opacity: 0;
	transform: translate(-10px,0);
}
#mv {
	width: 100%;
	height: 150vh;
}
#mv .swiper-wrapper {
	margin-top: 75px;
	height: calc(100% - 75px);
}
.mv__header {
	position: absolute;
	top: 160px;
	left: 10%;
	z-index: 2;
	width: 80%;
	text-align: left;
	transition: transform ease-in-out 0.6s,opacity ease-in-out 0.3s;
}
.mv__header_ttl {
	width: auto;
	height: 70px;
	margin-bottom: 10px;
	color: #fff;
}
.mv__header_txt {
	display: block;
	font-size: 48px;
	color: #fff;
	font-weight: 300;
	line-height: 1.4;
	letter-spacing: 0.02em;
}
.mv-swiper {
	width: calc(100% - 60px);
	height: 100%;
	margin-left: 30px;
	margin-right: 30px;
}
.mv__slide_bg {
	position: absolute;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	transition: transform 6.8s linear;
	transform-origin: center center;
	transform: scale(1);
}
.swiper-slide-active .mv__slide_bg {
	transform: scale(1.1);
	transition: transform 6.8s linear;
}
/* swiper-slide mv-swiper-slide-1 swiper-slide-duplicate swiper-slide-duplicate-prev */
.swiper-slide-prev .mv__slide_bg,.swiper-slide-duplicate.swiper-slide-duplicate-prev .mv__slide_bg {
	transform: scale(1.1);
/* 	transition: transform 6.8s linear; */
}
.swiper-slide-duplicate.swiper-slide-duplicate-prev .mv__slide_bg {
	transform: scale(1.1) !important;
}


.mv__slide_bg::after {
	content: "";
	display: block;
	background-color: rgba(0,0,0,0.2);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}
.mv-swiper-slide-1 .mv__slide_bg {
	background-image:url(../images/main_pc_01.jpg);
}
.mv-swiper-slide-2 .mv__slide_bg {
	background-image:url(../images/main_pc_02.jpg);
}
.mv-swiper-slide-3 .mv__slide_bg {
	background-image:url(../images/main_pc_03.jpg);
	background-image:url(../images/main_pc_02-2.jpg);
}
.mv-swiper-slide-4 .mv__slide_bg {
	background-image:url(../images/main_pc_04.jpg);
}
.mv-swiper-slide-5 .mv__slide_bg {
	background-image:url(../images/main_pc_05.jpg);
}
.mv__content-wrapper {
	position: absolute;
	bottom: 0;
	left: 0;
	display: block;
	width: 100%;
/* 	height: calc(100% * 2 /3); */
	height: 100%;
	z-index: 2;
}
@media screen and (min-width:768px) {
	.mv__content-wrapper.is-fixed {
		position: fixed;
		left: 30px;
		width: calc(100% - 60px);
	}
}



.mv__content {
	position: absolute;
	z-index: 4;
	left: 10%;
	bottom: 60px;
	transition: transform ease-in-out 0.3s,opacity ease-in-out 0.6s;
}
.mv__content:hover .mv__content_img {
	background-size: 105%;
}
.mv__content_img {
	display: inline-block;
	vertical-align: inherit;
	margin-right: 20px;
	background-image: url(../images/img_mv-thumb.jpg);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 100%;
	width: 100px;
	height: 100px;
	transition: ease-in-out 0.3s background-size;
	-webkit-transition: ease-in-out 0.3s background-size;
}
/*
.mv__content_txt {
	display: inline-block;
	color: #fff;
	line-height: 1.2;
	position: relative;
	top: -10px;
}
*/
/*
.mv__content_cat {
	font-size: 18px;
}
*/
.mv__content_ttl {
	z-index: 1;
	display: inline-block;
	font-size: 21px;
	font-weight: 300;
	color: #fff;
}
.mv__content_arrow {
	display: inline-block;
	width: auto;
	height: 8px;
	margin-left: 10px;
	position: relative;
	top: -1px;
}
@media screen and (max-width:767px) {
	#mv {
		height: 100%;
	}
	.mv__header {
		top: 140px;
		width: calc(100% - 60px);
		left: 30px;
	}
	.mv__header_ttl {
		height: 27px;
	}
	.mv__header_txt {
		font-size: 27px;
	}
	.mv__content-wrapper {
		height: 100%;
		position: absolute !important;
	}
	.mv__content {
		left: 30px;
		bottom: 30px;
	}
	.mv__content_img {
		margin-right: 10px;
		width: 50px;
		height: 50px;
	}
/*
	.mv__content_txt {
		display: inline-block;
		color: #fff;
		line-height: 1.2;
		position: relative;
		top: -5px;
	}
*/
/*
	.mv__content_cat {
		font-size: 14px;
	}
*/
	.mv__content_ttl {
		font-size: 16px;
	}
	.mv__content_arrow {
		margin-left: 5px;
	}
	
	.mv-swiper {
		width: 100%;
		margin-left: 0;
		margin-right: 0;
	}
	.mv-swiper-slide-1 .mv__slide_bg {
		background-image:url(../images/main_sp_01.jpg);
	}
	.mv-swiper-slide-2 .mv__slide_bg {
		background-image:url(../images/main_sp_02.jpg);
	}
	.mv-swiper-slide-3 .mv__slide_bg {
		background-image:url(../images/main_sp_03.jpg);
		background-image:url(../images/main_pc_02-2.jpg);
	}
	.mv-swiper-slide-4 .mv__slide_bg {
		background-image:url(../images/main_sp_04.jpg);
	}
	.mv-swiper-slide-5 .mv__slide_bg {
		background-image:url(../images/main_sp_05.jpg);
	}
	
	
}


/*swiper*/
.works-swiper.swiper-container {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	overflow: visible;
}

.works-swiper .swiper-slide {
	width: 100%;
}
@media screen and (min-width:576px){
	.works-swiper .swiper-slide {
		width: 200px;
	}
}
@media screen and (min-width:768px){
	.works-swiper .swiper-slide {
		width: 250px;
		width: 320px;
	}
}
@media screen and (min-width:992px){
	.works-swiper .swiper-slide {
		width: 300px;
		width: 460px;
	}
}

/*swiper related */
.related-swiper.swiper-container {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	overflow: visible;
}

.related-swiper .swiper-slide {
	width: 100%;
}
@media screen and (min-width:576px){
	.related-swiper .swiper-slide {
		width: 280px;
	}
}
/*
@media screen and (min-width:768px){
	.related-swiper .swiper-slide {
		width: 330px;
	}
}
*/
@media screen and (min-width:992px){
	.related-swiper .swiper-slide {
		width: 320px;
	}
}


.smooth-slider .swiper-wrapper {
	transition-timing-function: linear !important;
	-webkit-transition-timing-function: linear !important;
}
.swiper-pagination-current {
	padding-right: 5px;
}
.swiper-pagination-total {
	padding-left: 5px;
}
.top-swiper-pagination {
	position: absolute;
	top: -45px;
	right: 30px;
	bottom: auto;
	left: auto;
	width: auto;
	display: inline-block;
}

.works-btn-wrapper {
	position: absolute;
	bottom: -2px;
	right: 30px;
	display: inline-block;

}

#gallery .section__inner {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}

.section__bg {
	position: relative;
	top: 0;
	left: 50%;
	width: 960px;
	height: 100%;
	overflow: hidden;
	z-index: 0;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
/*
	position: relative;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	z-index: 0;
*/
}

.gallery-swiper-a {
	position: absolute;
	left: 0;
	top: 0;
	width: 300px;	
	height: 100%;
}
.gallery-swiper-b {
	position: absolute;
	left: calc(300px + 30px);
	bottom: 0;
	width: 300px;	
	height: 100%;
}
.gallery-swiper-c {
	position: absolute;
	left: calc(600px + 60px);
	bottom: 0;
	width: 300px;	
	height: 100%;
}




.gallery-swiper-d {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;	
	height: 100%;
}

.gallery-swiper-a .swiper-slide,.gallery-swiper-b .swiper-slide,.gallery-swiper-c .swiper-slide {
	height:0;
	padding-top:133.333%;
	width: calc(450px * (2 / 3));	
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}
.gallery-swiper-d .swiper-slide {
	height: 400px;
	width: 300px;	
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}
.gallery-swiper-a .swiper-slide-1 {
	background-image: url(../images/img_gallery-slide-a-1.jpg);
}
.gallery-swiper-a .swiper-slide-2 {
	background-image: url(../images/img_gallery-slide-a-2.jpg);
}
.gallery-swiper-a .swiper-slide-3 {
	background-image: url(../images/img_gallery-slide-a-3.jpg);
}
.gallery-swiper-a .swiper-slide-4 {
	background-image: url(../images/img_gallery-slide-a-4.jpg);
}
.gallery-swiper-a .swiper-slide-5 {
	background-image: url(../images/img_gallery-slide-a-5.jpg);
}
.gallery-swiper-a .swiper-slide-6 {
	background-image: url(../images/img_gallery-slide-a-6.jpg);
}

.gallery-swiper-b .swiper-slide-1 {
	background-image: url(../images/img_gallery-slide-a-7.jpg);
}
.gallery-swiper-b .swiper-slide-2 {
	background-image: url(../images/img_gallery-slide-a-8.jpg);
}
.gallery-swiper-b .swiper-slide-3 {
	background-image: url(../images/img_gallery-slide-a-9.jpg);
}
.gallery-swiper-b .swiper-slide-4 {
	background-image: url(../images/img_gallery-slide-a-10.jpg);
}
.gallery-swiper-b .swiper-slide-5 {
	background-image: url(../images/img_gallery-slide-a-11.jpg);
}
.gallery-swiper-b .swiper-slide-6 {
	background-image: url(../images/img_gallery-slide-a-12.jpg);
}

.gallery-swiper-c .swiper-slide-1 {
	background-image: url(../images/img_gallery-slide-a-13.jpg);
}
.gallery-swiper-c .swiper-slide-2 {
	background-image: url(../images/img_gallery-slide-a-14.jpg);
}
.gallery-swiper-c .swiper-slide-3 {
	background-image: url(../images/img_gallery-slide-a-15.jpg);
}
.gallery-swiper-c .swiper-slide-4 {
	background-image: url(../images/img_gallery-slide-a-16.jpg);
}
.gallery-swiper-c .swiper-slide-5 {
	background-image: url(../images/img_gallery-slide-a-17.jpg);
}
.gallery-swiper-c .swiper-slide-6 {
	background-image: url(../images/img_gallery-slide-a-18.jpg);
}

/* gallery-swiper-b だけ JSの制御を完全に奪う */
.gallery-swiper-b .swiper-wrapper {
    display: block !important; /* 横並びを防ぐ */
    animation: infinity-loop-reverse 30s linear infinite !important;
/*
    transform: none !important;
    transition-duration: 0ms !important;
*/
    height: auto !important;
}

.gallery-swiper-b .swiper-slide {
    width: 100% !important; /* 横幅を固定 */
    height: auto !important;
    margin-bottom: 10px; /* 隙間 */
}

@keyframes infinity-loop-reverse {
    0% {
        transform: translateY(-50%); /* スライドが2セットある前提 */
    }
    100% {
        transform: translateY(0%);
    }
}

/*
.gallery-swiper-b .swiper-slide-1 {
	background-image: url(../images/img_gallery-slide-5.jpg);
}
.gallery-swiper-b .swiper-slide-2 {
	background-image: url(../images/img_gallery-slide-6.jpg);
}
.gallery-swiper-b .swiper-slide-3 {
	background-image: url(../images/img_gallery-slide-7.jpg);
}
.gallery-swiper-b .swiper-slide-4 {
	background-image: url(../images/img_gallery-slide-8.jpg);
}
.gallery-swiper-c .swiper-slide-1 {
	background-image: url(../images/img_gallery-slide-1.jpg);
}
.gallery-swiper-c .swiper-slide-2 {
	background-image: url(../images/img_gallery-slide-2.jpg);
}
.gallery-swiper-c .swiper-slide-3 {
	background-image: url(../images/img_gallery-slide-3.jpg);
}
.gallery-swiper-c .swiper-slide-4 {
	background-image: url(../images/img_gallery-slide-4.jpg);
}

.gallery-swiper-d .swiper-slide-1 {
	background-image: url(../images/img_gallery-slide-1.jpg);
}
.gallery-swiper-d .swiper-slide-2 {
	background-image: url(../images/img_gallery-slide-2.jpg);
}
.gallery-swiper-d .swiper-slide-3 {
	background-image: url(../images/img_gallery-slide-3.jpg);
}
.gallery-swiper-d .swiper-slide-4 {
	background-image: url(../images/img_gallery-slide-4.jpg);
}
.gallery-swiper-d .swiper-slide-5 {
	background-image: url(../images/img_gallery-slide-5.jpg);
}
.gallery-swiper-d .swiper-slide-6 {
	background-image: url(../images/img_gallery-slide-6.jpg);
}
.gallery-swiper-d .swiper-slide-7 {
	background-image: url(../images/img_gallery-slide-7.jpg);
}
.gallery-swiper-d .swiper-slide-8 {
	background-image: url(../images/img_gallery-slide-8.jpg);
}
*/

.gallery-swiper {
	
}
@media screen and (max-width:991px) {
	.section__bg {
		right: auto;
		left: 10%;
		transform: translateX(0);
		width: calc(100% - 20%);		
	}
/*
	.section__bg {
		left: 0;
		width: 100%;		
	}
*/
	.gallery-swiper-a {
		width: calc(50% - 10px);	
		height: 100%;
	}
	.gallery-swiper-b {
		left: calc(50% + 10px);
		width: calc(50% - 10px);	
	}
	.gallery-swiper-c {
		display: none;
	}
	.gallery-swiper-a .swiper-slide,.gallery-swiper-b .swiper-slide,.gallery-swiper-c .swiper-slide {
		padding-top:133.333%;
		width: 100%;	
 	}
	
}

@media screen and (max-width:767px) {
	.section__bg {
		left: 5.333%;
		width: calc(100% - 10.666%);		
	}
	#gallery {
		height: 280px !important;
	}
	.gallery-swiper-d .swiper-slide {
		height: 280px;
		width: 210px;	
	}
	
}
/* ABOUT page
---------------------------------------- */
/*diagram*/
.diagram {
	text-align: center;
	padding: 60px;
	background-color: #e6e6e2;
}
.diagram__img {
	max-width: 480px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 60px;
}
.diagram__ttl {
	font-size: 18px;
	font-weight: 500;
}
.diagram__subttl {
	display: block;
	margin-bottom: 20px;
	font-weight: 500;
}
.diagram__txt {
	font-size: 18px;
}
@media screen and (max-width:767px) {
	.diagram {
		position: relative;
		left: -5.333%;
		padding: 30px 40px;
		width: 100vw;
	}
	.diagram__img {
		margin-bottom: 30px;
	}
	
	.diagram__txt {
		font-size: 16px;
	}
}

/*aboutlist*/
.aboutlist-wrapper {
	overflow: hidden;
}
.aboutlist__ttl {
}
@media screen and (max-width:767px) {
	.aboutlist__ttl {
		margin-bottom: 20px;
	}
}

.aboutbox-wrapper {
	
}
.aboutbox {
	display: flex;
	flex-direction: row;
	margin-bottom: 40px;
	border: 1px solid #d5d5d5;
	border-radius: 10px;
	padding: 30px 30px;
	align-content: flex-start;
	flex-wrap: wrap;
	gap: 0;
/* 	justify-content: space-between; */
}
.aboutbox:last-child {
	margin-bottom: 0;
}
.aboutbox__header {
	width: 50px;
	border-right: 1px solid #d5d5d5;
	padding-top: 20px;
}
.aboutbox__main {
	width: calc(100% - 300px);
	padding-right: 30px;
	padding-left: 20px;
	padding-top: 20px;
	padding-bottom: 20px;
}
.aboutbox__footer {
	width: 250px;
}
.aboutbox__img {
	width: 100%;
	max-width: 250px;
/*
	padding-top: 100%;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-image: url(../images/img_about-type-1.jpg);
*/
}
/*
.aboutbox-01 .aboutbox__img {
	background-image: url(../images/img_about-type-1.jpg);
}
.aboutbox-02 .aboutbox__img {
	background-image: url(../images/img_about-type-2.jpg);
}
.aboutbox-03 .aboutbox__img {
	background-image: url(../images/img_about-type-3.jpg);
}
*/

.aboutbox__ttl {
	margin-bottom: 30px;
}
.aboutbox p, .aboutbox li {
}
.aboutbox li {
	position: relative;
	padding-left: 15px;
}
.aboutbox li::before {
	content: "・";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}
@media screen and (max-width:810px) {
	.aboutbox {
		margin-bottom: 40px;
		row-gap: 20px;
	}
	.aboutbox__header {
		width: 100%;
		padding-top: 0;
		padding-bottom: 5px;
		border-right: none;
		border-bottom: 1px solid #d5d5d5;
	}
	.aboutbox__main {
		width: calc(100% - 250px);
		padding-right: 30px;
		padding-left: 0;
		padding-top: 0;
		padding-bottom: 0;
	}
	.aboutbox__footer {
		width: 250px;
	}
/*
	.aboutbox__ttl {
		margin-bottom: 10px;
	}
*/
	
}
@media screen and (max-width:575px) {
	.aboutbox {
		padding: 15px;
		margin-bottom: 40px;
		flex-direction: column;
		row-gap: 40px;
	}
	.aboutbox__header {
		width: 100%;
		padding-bottom: 5px;
		border-right: none;
		border-bottom: 1px solid #d5d5d5;
		order: 0;
	}
	.aboutbox__main {
		width: 100%;
		padding-right: 0;
		padding-left: 0;
		padding-top: 0;
		padding-bottom: 0;
		order: 2;
	}
	.aboutbox__footer {
		width: 100%;
		order: 1;
	}
	.aboutbox__img {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}
}

/* aboutblock */
.aboutbox-wrapper {
	
}
.aboutblock {
	display: flex;
	flex-direction: row;
	margin-bottom: 90px;
	align-content: flex-start;
	flex-wrap: wrap;
	gap: 0;
/* 	justify-content: space-between; */
}
.aboutblock:last-child {
	margin-bottom: 0;
}
.aboutblock__left {
	width: calc(100% - 280px);
	padding-left: 60px;
	order: 2;
}
.aboutblock__right {
	display: flex;
	align-items: flex-start;
	width: 280px;
	padding-right: 60px;
	padding-left: 60px;
	order: 1;
}
.aboutblock__img {
	width: 160px;
}
.aboutblock__ttl {
	padding-bottom:10px;
	border-bottom: 1px solid #d9d9d9;
	margin-bottom: 20px;
}
.aboutblock__ttl_num {
	margin-right: 10px;
	font-size: 24px;
}
.aboutblock__ttl_ja {
	margin-right: 10px;
	font-size: 21px;
}
.aboutblock__ttl_en {
	margin-right: 10px;
	font-size: 14px;
	color: #8d8d8c;
}
.aboutblock__tag-wrapper {
	margin-bottom: 40px;
}
.aboutblock__tag_ttl {
	display: block;
	font-size: 12px;
	font-weight: 600;
	margin-bottom: 10px;
}
.aboutblock__tag_list {
	display: inline-block;
	padding-left: 20px;
	padding-right: 20px;
	background-color: #e3e3df;
	padding-top: 6px;
	padding-bottom: 2px;
	margin-right: 10px;
	margin-bottom: 20px;
	border-radius: 20px;
}
#about-service .module__heading {
	margin-bottom: 40px;
}
.about__inner {
	padding-left: 60px;
	padding-right: 60px;
}
@media screen and (max-width:810px) {
	.aboutblock__left {
		width: calc(100% - 180px);
		padding-left: 40px;
	}
	.aboutblock__right {
		width: 180px;
		padding-right: 40px;
		padding-left: 40px;
	}
	.aboutblock__img {
		width: 120px;
	}
	
	.aboutblock__tag_list {
		margin-bottom: 10px;
	}
}

@media screen and (max-width:575px) {
	.aboutblock {
		position: relative;
		display: block;
		margin-bottom: 60px;
		align-content: inherit;
	}
	.aboutblock__left {
		width: 100%;
		padding-left: 0;
	}
	.aboutblock__right {
		position: absolute;
		top: 0;
		right: 0;
		width: auto;
		padding-right: 0;
		padding-left: 0;
	}
	.aboutblock__ttl {
		margin-top: 8px;
		padding-right: 80px;
	}
	.aboutblock__ttl_num {
		display: block;
		margin-bottom: 5px;
		margin-right: 0;
	}
	.aboutblock__img {
		width: 60px;
	}
	#about-service .module__heading {
		margin-bottom: 20px;
	}
}
/* about
---------------------------------------- */
#about {
	background-color: #eff0ec;
}
/* works
---------------------------------------- */
#works {
	background-color: #eff0ec;
/* 	background-color: #676863; */
/* 	color: #fff !important; */
}
#works .article__body {
/* 	color: #fff !important; */
}
/* gallery
---------------------------------------- */
#gallery {
	height: 400px;
/* 	background-color: #eff0ec; */
	background-color: #676863;
}
/* message
---------------------------------------- */
#message {
	background-color: #eff0ec;
}


/* outline
---------------------------------------- */
#outline {
	background-color: #eff0ec;
}


/* article
---------------------------------------- */
.article__header {
	overflow: hidden;
	margin-bottom: 20px;
}

.article__body {
	
}

.article__header_bg div {
	position: relative;
	padding-top: 133.333%;
	width: 100%;
	height: 0;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	
	transform-origin: center center;
	transform: scale(1);
	transition: ease-in-out 0.4s transform;
}
.archive-item__link:hover .article__header_bg div {
	transform: scale(1.02);
}
.swiper-slide:hover .article__header_bg div {
	transform: scale(1.02);
}


#works .article__header_bg div {
	padding-top: 133.333%;
}
.no-image.article__header_bg div {
	background-color: #ccc;
}
.no-image__txt {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	font-size: 14px;
}
.article__body {
	
}
.article__body_ttl {
	font-size: 21px;
	font-weight: 300;
}
#top .article__body_ttl {
	font-size: 24px;
}
#single-related .article__body_ttl {
	font-size: 24px;
}
.article__body_date {
	
}
.article__body_cat {
	font-size: 13px;
}
.catlist {
}
@media screen and (max-width:767px) {
	.article__header {
		margin-bottom: 20px;
	}
	.article__body_ttl {
	}
	#top .article__body_ttl {
		font-size: 20px;
	}
	#single-related .article__body_ttl {
		font-size: 21px;
	}
}



/* WORKS archive
---------------------------------------- */
.archive-article__header {
}
.archive-item-wrapper {
	display: flex;
	display: -webkit-flex;
	-webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    -webkit-box-align: start;
    -ms-flex-align: start;
    column-gap: 30px;
    row-gap: 60px;
}
.archive-item {
	width: calc(100% / 3 - 20px);
}

.page-menu-wrapper {
	display: inline-block;
	margin-left: 40px;
	margin-bottom: 20px;
}
.page-menu {
	display: inline-block;
	margin-left: 10px;
	margin-right: 10px;
}


@media screen and (max-width:991px) {
	.archive-item-wrapper {
        column-gap: 20px;
/*         row-gap: 30px; */
	}
	.archive-item {
		width: calc(100% / 2 - 10px);
	}
	.page-menu-wrapper {
		display: block;
		margin-left: 0;
	}
}
@media screen and (max-width:575px) {
	.archive-item-wrapper {
        column-gap: 0;
	}
	.archive-item {
		width: 100%;
	}
/*
	.page-menu-wrapper {
		display: block;
		margin-left: 0;
	}
*/
}


/* WORKS single
---------------------------------------- */
.single-header__table dl,.single-header__table dt,.single-header__table dd {
	margin: 0;
	padding: 0;
}
.single-header__table {
	overflow: hidden;
	display: table;
	width:  100%;
}
.single-header__table dl {
	float: left;
	display: inline-block;
	width: 250px;
}
.single-header__table dl.single-header__ttl {
	width: calc(100% - 500px);
	text-align: left;
	vertical-align: top;
}
.single-header__table dt {
	padding-bottom: 10px;
	border-bottom: solid 1px #d9d9d9;
	padding-right: 40px;
}
.single-header__table .single-header__ttl dt {
	border-bottom: solid 1px #d9d9d9;
}
.single-header__table dd {
	padding-top: 20px;
	padding-right: 40px;
	text-align: left;
	vertical-align: top;
}
.single-header__ttl_ja {
	display: block;
/* 	margin-top: 10px; */
	font-size: 14px;
}
.single-header__ttl_en {
	display: block;
	font-size: 48px;
	line-height: 1;
	font-weight: 300;
	margin-bottom: 20px;
}

@media screen and (max-width: 991px) {
	.single-header__table dl {
		width: 150px;
	}
	.single-header__table dl.single-header__ttl {
		width: calc(100% - 300px);
	}
	.single-header__table .single-header__table dt {
		padding-right: 20px;
	}
	.single-header__table .single-header__table dd {
		padding-right: 20px;
	}

	
}

@media screen and (max-width: 767px) {
	.single-header__table dl {
		width: 50%;
	}
	.single-header__table dl.single-header__ttl {
		width: 100%;
		float: none;
	}
	.single-header__table dt {
		padding-top: 15px;
		padding-bottom: 0px;
	}
	.single-header__table dd {
		padding-left: 0;
		padding-right: 0;
		padding-bottom: 15px;
	}
	.single-header__ttl dd {
		padding-bottom: 30px;
	}
	.single-header__table .single-header__cat dd {
		padding-right: 20px;
	}
	.single-header__ttl_en {
		font-size: 44px;
		margin-bottom: 10px;
	}
}
.single-tag-wrapper {
}
.single-tag {
	padding: 5px 20px 3px;
	border: 1px solid #d9d9d9;
	border-radius: 15px;
	font-size: 12px;
	display: inline-block;
	margin-right: 20px;
	font-weight: 600;
}

.module-margin {
	margin-bottom: 100px;
}
.small-margin {
	margin-bottom: 90px;
}
.large-margin {
	margin-bottom: 150px;
}

.module-margin:last-child {
	margin-bottom: 0;
}
.module-margin img {
	margin-bottom: 20px;
}
.comparision-wrapper {
	display: flex;
	display: -webkit-flex;
	-webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    -webkit-box-align: start;
    -ms-flex-align: start;
    column-gap: 20px;
    margin-bottom: 100px;
    max-width: 870px;
    margin-left: auto;
    margin-right: auto;
}
.comparision__left {
	width: calc(50% - 10px);
}
.comparision__right {
	width: calc(50% - 10px);
}
.comparision__bg {
	width: 100%;
	height: 0;
	padding-top: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
}

.overview-wrapper {
	display: flex;
	display: -webkit-flex;
	-webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    -webkit-box-align: start;
    -ms-flex-align: start;
    column-gap: 20px;
    margin-bottom: 100px;
}
.overview__img {
	width: calc(25% - 15px);
}
.overview__img_bg {
	width: 100%;
	height: 0;
	padding-top: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
}
@media screen and (max-width:767px) {
	.overview-wrapper {
	    column-gap: 10px;
	    row-gap: 10px;
	}
	.overview__img {
		width: calc(50% - 5px);
	}
	.small-margin {
		margin-bottom: 60px;
	}
	.large-margin {
		margin-bottom: 120px;
	}
	
}



.gallery-content {
	
}
.gallery-content img {
	width: 100%;
	margin-bottom: 20px;
}

.single-content-wrapper {
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

