@charset "utf-8";

.sp {
	display: none;
}

.tablet {
	display: none;
}
/*MV*/

#mvWrap{
	position: relative;
	width: 100%;
	height: 950px;
    padding-top: 100px;
	overflow: hidden;
	box-sizing: border-box;
}

#mv{
	opacity: 0;
	position: relative;
	width: 100%;
    height: 850px;
	background: url(../img/bg1_slide1.jpg) no-repeat;
	background-position: center center;
	background-size: cover;
}

.mvCopyW{
    position: relative;
	text-align: center;
}
.mvCopy{
    display: inline-block;
    font-size: 10rem;
    color: #fff;
    position: absolute;
	left: 50%;
	transform: translateX(-50%);
    top: 200px;
    line-height: 1.2em;
    white-space: nowrap;
	letter-spacing: 0.1em;
}
.mvCopyS{
    font-size: 3.6rem;
    color: #fff;
    position: absolute;
	left: 50%;
	transform: translateX(-50%);
    top: 470px;
    letter-spacing: 0.17em;
    text-align: center;
}
.mvTxt{
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: #f8ba01;
    color: #fff;
    text-align: center;
    font-size: 2.0rem;
    box-sizing: border-box;
    padding-top: 60px;
    position: absolute;
    top: 355px;
}

/*マウスアイコンアニメーション*/
#scroll{
	background: url(../img/Scroll_bg.png) no-repeat;
	width: 47px;
	height: 48px;
	position: absolute;
	left: 0;
	right: 0;
	bottom:50px;
	margin: auto;
	z-index: 90;
}
.icon-scroll,
.icon-scroll:before {
  position: absolute;
  left: 50%;
}
.icon-scroll {
  width: 47px;
  height: 48px;
}
.icon-scroll:before {
  content: '';
  width: 4px;
  height: 4px;
  background: #1dcd00;
  margin-left: -4px;
  top: 7px;
  border-radius: 2px;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: scroll;
          animation-name: scroll;
}
@-webkit-keyframes scroll {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
}
@keyframes scroll {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
}
/*マウスアイコンアニメーションここまで*/

/*Section01*/

#secNews{
	width: 100%;
	position: relative;
}

.secNewsW{
	padding-top: 80px;
	padding-bottom: 80px;
	position: relative;
	font-weight: 500;
}
.newsL{
	width: 1000px;
	margin: 0 auto;
}
.newsImgs{
	margin-bottom: 60px;
	letter-spacing: -0.4em;
}
.newsImg{
	display: inline-block;
	margin-right: 20px;
}
.newsImg:last-child{
	margin-right: 0;
}
.newsTtl{
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	float: left;
	width: 124px;
	height: 410px;
	box-sizing: border-box;
	border-left: 1px solid rgba(204,204,204,0.5);
	border-right: 1px solid rgba(204,204,204,0.5); 
	position: relative;
	font-size: 2.7rem;
	letter-spacing: 0.3em;
	color: #fff;
	padding: 80px 40px 0 0;
	margin-right: 30px;
}
.newsTtl:before{
	content: "";
	position: absolute;
	width: 114px;
	height: 410px;
	top: 0;
	left: 5px;
	border-left: 3px solid #e6e6e5;
	border-right: 3px solid #e6e6e5;
	box-sizing: border-box;
}

.newsListW{
	height: 410px;
	overflow-x: hidden;
	overflow-y: scroll;
	background: #fff;
	color: #666;
	padding: 30px;
	box-sizing: border-box;
}

.newsLists{
	border-bottom: 1px solid rgba(204,204,204,0.5);
	font-size: 1.6rem;
	width: 763px;
	float: right;
	padding-bottom: 20px;
	margin-bottom: 20px;
}
.newsLists:last-child{
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}

.newsDate{
	display: inline-block;
	vertical-align: top;
}
.newsLabel{
	margin-left: 20px;
	margin-right: 20px;
	display: inline-block;
	color: #fff !important;
	letter-spacing: 0.12em;
	width: 75px;
	text-align: center;
}
.label01{
	background: #666;
}
.label02{
	background: #999;
}
.newsTxt{
	display: inline-block;
	vertical-align: top;
	width: 60%;
}

.newsR{
	float: right;
}
.newsBn{
	display: block;
	margin-bottom: 25px;
}
.newsBn:last-child{
	margin-bottom: 0;
}
#secAbout{
	background: url("../img/concept_bg.jpg") no-repeat;
	background-position: center;
	background-size: cover;
	padding: 60px 0;
}
.secAboutW{
	max-width: 1500px;
	margin: 0 auto;
	display: table;
	overflow-x: hidden;
}

.aboutL{
	display: table-cell;
	width: 53vw;
	min-width: 645px;
	height: 486px;
}
.aboutR{
	display: table-cell;
	vertical-align: middle;
	width: 554px;
	color: #fff;
	padding: 60px;
	background: rgba(0,0,0,0.5);
	box-sizing: border-box;
}
.aboutTtl{
	font-size: 4.2rem;
	letter-spacing: 0.1em;
	line-height: 4.2rem;
	margin-bottom: 30px;
}
.aboutTxt{
	font-size: 1.6rem;
	line-height: 2.8rem;
}

#secService{
    
}
.secServiceW{
	padding-top: 100px;
	padding-bottom: 100px;
    text-align: center;
}
.pickupW{
	margin-bottom: 60px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	position: relative;
}
.serviceTax{
	position: absolute;
	right: 0;
	top: -30px;
}
.pickup{
	width: 380px;
	text-align: left;
}
.pickupTxtW{
	
}
.pickupImg{
}
.pickupImg img{
	width: 100%;
	height: auto;
}
.pickupTxtW{
	margin-top: 20px;
	position: relative;
}
.charge{
	font-size: 1.6rem;
	margin-bottom: 50px;
}
.chargePrice{
	margin-left: 50px;
}
.topMenuW{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.topMenus{
	width: 400px;
	margin-bottom: 50px;
	text-align: left;
	border-left: 1px solid rgba(255,255,255,0.3);
	box-sizing: border-box;
	padding: 0 20px;
}
.topMenus:nth-child(3n){
	border-right: 1px solid rgba(255,255,255,0.3);
}
.topMenus:last-child{
	border-right: 1px solid rgba(255,255,255,0.3);
}
.topMenuTtl{
	font-size: 2rem;
	margin-bottom: 30px;
	text-align: center;
}
.topMenu{
	margin-bottom: 30px;
	position: relative;
	font-size: 1.6rem;
}
.topMenuTxt{
	margin-bottom: 10px;
}
.topMenuCap{
	font-size: 1.2rem;
}
.topMenuPrice{
	position: absolute;
	right: 0;
	top: 0;
}

#secPhoto{
	
}
.secPhotoW{
	
}

.photoW{
	letter-spacing: -0.4em;
}
.photo{
	display: inline-block;
	width: 285px;
	margin-bottom: 30px;
	margin-right: 20px;
}
.photo:nth-child(4n){
	margin-right: 0;
}
.photo img{
	width: 100%;
	height: auto;
}

#secCompany{
	position: relative;
	width: 100%;
}
.secCompanyW{
	box-sizing: border-box;
	width: 1000px;
	margin: 0 auto;
	padding-top: 100px;
	padding-bottom: 100px;
}
.secCompanyTtl{
    position: relative;
}

.about{
	width: 800px;
	margin: 50px auto 0;
}
.aboutTable{
	width: 100%;
}
.aboutTable th{
	border-bottom: 1px solid #fff;
	padding: 10px 0;
	text-align: center;
	font-size: 1.8rem !important;
	color: #fff;
	width: 25%;
}
.aboutTable td{
	border-bottom: 1px solid #333;
	padding: 10px 0 10px 10px;
	text-align: left;
	font-size: 1.8rem !important;
}
.aboutNames{
	position: relative;
}
.aboutName{
	position: absolute;
	left: 230px;
	font-size: 1.8rem;
}
.gMap iframe{
	width: 100%;
	height: 500px;
	filter: grayscale();
}

