@charset "utf-8";

.visual--title {
	background: url(../imgs/img-mv.jpg) no-repeat center center;
	background-size: cover;
}

@media screen and (max-width: 736px) {
	.visual--title .caption {
	}
}

.page-mv__img {
	position: relative;
}

.page-mv .txt {
	text-align: center;
}

.page-mv .txt {
	font-size: 24px;
	line-height: calc(56/24);
}

.page-mv .txt strong {
	font-weight: normal;
	font-size: 36px;
}

.page-mv .txt span {
	font-size: 22px;
}

@media screen and (max-width: 736px) {
	.page-mv .txt {
		font-size: 18px;
	}

	.page-mv .txt strong {
		font-size: 24px;
	}

	.page-mv .txt span {
		font-size: 16px;
	}
}

.p-headline--h {
	font-size: 20px;
	line-height: calc(24/20);
	text-align: center;
}

.p-headline--h::before,
.p-headline--h::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
}

.p-headline--h::before {
	margin-top: calc((1 - (24/20)) * 0.5em);
}

.p-headline--h::after {
	margin-bottom: calc((1 - (24/20)) * 0.5em);
}


.p-text-01 {
	font-size: 16px;
	line-height: calc(30/16);
}

.p-text-02 {
	font-size: 14px;
	line-height: calc(24/14);
}

.p-text-03 {
	font-size: 14px;
	letter-spacing: .06em;
	line-height: calc(18/14);
}

.p-text-03.srt {
	letter-spacing: 0;
}

.p-text-01::before,
.p-text-01::after,
.p-text-02::before,
.p-text-02::after,
.p-text-03::before,
.p-text-03::after {
	content: '';
	display: block;
	height: 0;
	width: 0;
}

.p-text-01::before {
	margin-top: calc((1 - (30/16)) * 0.5em);
}

.p-text-01::after {
	margin-bottom: calc((1 - (30/16)) * 0.5em);
}

.p-text-02::before {
	margin-top: calc((1 - (24/14)) * 0.5em);
}

.p-text-02::after {
	margin-bottom: calc((1 - (24/14)) * 0.5em);
}

.p-text-03::before {
	margin-top: calc((1 - (18/14)) * 0.5em);
}

.p-text-03::after {
	margin-bottom: calc((1 - (18/14)) * 0.5em);
}

.p-acTxt {
	text-align: center;
}

.figure+.p-headline--h {
	margin-top: 30px;
}

.p-headline--h+.p-text-02 {
	margin-top: 20px;
}

@media only screen and (max-width: 736px) {
	.p-headline--h {
		padding-bottom: 8px;
		font-size: 14px;
	}

	.p-text-01 {
		font-size: 14px;
	}

	.p-text-02 {
		font-size: 12px;
	}

	.p-text-03 {
		font-size: 12px;
	}

	.p-acTxt {
		text-align: left;
	}
}

.p-box-a {
	margin-top: 80px;
	padding: 60px 50px 70px;
	border: solid 1px #c4a446;
}

.p-box-a .inner {
	/*
		max-width: 540px;
		margin-left: auto;
		margin-right: auto;
*/
}

.p-box-a .inner .p-text {
	font-size: 20px;
	text-align: center;
}

.p-img--logo {
	margin-top: 20px;
	text-align: center;
}

.p-box-a .inner .p-text-01 {
	margin-top: 10px;
	letter-spacing: -.02em;
}


.p-icon {
	text-align: center;
}

.p-icon+.p-text-03 {
	margin-top: 15px;
	text-align: center;
}

@media only screen and (max-width: 736px) {
	.p-box-a {
		margin-top: 60px;
		padding: 40px 20px;
	}

	.p-box-a .inner .p-text {
		font-size: 16px;
	}

	.p-img--logo {
		margin-top: 0;
	}

	.p-box-a .inner .p-text-01 {
		letter-spacing: .06em;
	}
}

.clm2>div {
	width: calc(460/1000*100%);
}

.clm2>div .figure {
	max-width: 450px;
	margin-left: auto;
	margin-right: auto;
}

.clm2>div:nth-child(n+3) {
	margin-top: 60px;
}

.clm2>div.clm--company {
	width: calc(280/540*100%);
	font-size: 20px;
	line-height: 1;
}

.clm2>div.clm--company .c-name {
	margin-top: 40px;
	font-size: 24px;
}

.clm2>div.clm--logo {
	width: calc(238/540*100%);
}

.clm2 .clm3_inner {
	justify-content: flex-start;
}

.clm2 .clm3_inner>div {
	width: calc(142/460*100%);
	margin-right: calc(17/460*100%);
}

.clm2 .clm3_inner>div:nth-child(3n) {
	margin-right: 0;
}

.clm2 .clm3_inner>div:nth-child(n+4) {
	margin-top: 30px;
}

@media only screen and (max-width: 736px) {
	.clm2>div {
		width: 100%;
	}

	.clm2>div:nth-child(n+2) {
		margin-top: 60px;
	}

	.clm2>div.clm--company {
		width: 100%;
		margin-top: 40px;
		font-size: 16px;
	}

	.clm2>div.clm--company .c-name {
		margin-top: 20px;
		font-size: 20px;
	}

	.clm2>div.clm--logo {
		width: 100%;
		max-width: 238px;
		margin-left: auto;
		margin-right: auto;
	}

	.clm2 .clm3_inner {
		justify-content: space-between;
	}

	.clm2 .clm3_inner>div {
		width: 48%;
		margin-right: 0;
	}

	.clm2 .clm3_inner>div:nth-child(n+3) {
		margin-top: 20px;
	}
}

.p-mw560 {
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}

.p-mw560 .caption {
	margin-top: 30px;
	text-align: right;
}

.p-mw680 {
	max-width: 680px;
	margin-left: auto;
	margin-right: auto;
}

@media only screen and (max-width: 736px) {}

.headline--01+.heading--medium {
	margin-top: 120px;
}

@media only screen and (max-width: 736px) {
	.headline--01+.heading--medium {
		margin-top: 60px;
	}
}

.section--01 {
	padding-top: 80px;
	padding-bottom: 90px;
}

.section--01 .heading--medium+.p-mw680 {
	margin-top: 70px;
}

@media only screen and (max-width: 736px) {
	.section--01 {
		padding-top: 60px;
		padding-bottom: 50px;
	}

	.section--01 .heading--medium+.p-mw680 {
		margin-top: 40px;
	}
}

.section--02 {
	padding-top: 65px;
	padding-bottom: 65px;
	background: rgba(73, 195, 209, .05);
}

.section--02 .p-zu {
	max-width: 526px;
	margin-left: auto;
	margin-right: auto;
}

@media only screen and (max-width: 736px) {
	.section--02 {
		padding-top: 40px;
		padding-bottom: 40px;
	}
}

.section--03 {
	padding-top: 80px;
	padding-bottom: 90px;
}

.section--03 .p-text-02+.p-clmn {
	margin-top: 40px;
}

.section--03 .movieArea+.wrap {
	margin-top: 60px;
}

@media only screen and (max-width: 736px) {
	.section--03 {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.section--03 .clm3_inner {
		justify-content: center;
	}

	.section--03 .clm3_inner>div:nth-child(2n) {
		margin-left: 4%;
	}
}

.movieArea {
	margin-top: 60px;
}

.movieArea__inner {
	display: block;
	width: 100%;
	position: relative;
}

.movieArea__inner>div {
	top: 0;
}

@media screen and (max-width: 736px) {
	.movieArea__inner {
		margin-left: -20px;
		margin-right: -20px;
		width: calc(100% + 40px);
	}
}

.heading01 {
  display: flex;
  align-items: flex-start;
  justify-content: left;
  margin-bottom: 33px;
}

@media only screen and (max-width: 736px) {
  .heading01 {
    margin-bottom: calc(40/750*100vw);
  }
}

.heading01__txt--en {
  font-size: 38px;
  line-height: 33px;
  letter-spacing: 0.05em;
  font-family: 'Cormorant', serif;
  width: auto;
  text-align: center;
  margin-left: 10px;
}

@media only screen and (max-width: 736px) {
  .heading01__txt--en {
    font-size: 24px;
    line-height: 1;
  }
}

.heading01__txt--ja {
  font-size: 22px;
  letter-spacing: 0.12em;
  border-left: 1px solid #7f7f7f;
  margin-left: 30px;
  padding-left: 30px;
}

@media only screen and (max-width: 736px) {
  .heading01__txt--ja {
    font-size: 16px;
    margin-left: calc(30/750*100vw);
    padding-left: calc(30/750*100vw);
  }
}

.movieArea__txtWrap {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	width: 100%;
	margin-bottom: 30px;
}

.movieArea__head {
	font-size: 38px;
	line-height: 1;
}

.movieArea__txt {
	font-size: 22px;
	letter-spacing: 0.19em;
	line-height: 1;
}

.movieArea__txt::before {
	content: '';
	display: inline-block;
	width: 1px;
	height: 1em;
	background-color: #474747;
	vertical-align: middle;
	margin-right: 2em;
}

@media screen and (max-width: 736px) {
	.movieArea__txtWrap {
		flex-direction: column;
		justify-content: center;
		align-items: flex-start;
		margin-bottom: 20px;
	}

	.movieArea__head {
		font-size: 26px;
		line-height: 1.6;
		margin-bottom: 20px;
	}

	.movieArea__head::after {
		content: '';
		display: block;
		width: 100%;
		height: 1px;
		background-color: #474747;
		background-size: 100%;
	}

	.movieArea__txt {
		font-size: 16px;
		letter-spacing: 0.19em;
		line-height: 1.4;
	}

	.movieArea__txt::before {
		display: none;
	}
}

.movieArea__inner::before {
	content: '';
	display: block;
	padding-top: 56.25%;
}

.movieArea__inner iframe {
	top: 0;
	left: 0;
}

.movieCol {
	margin-top: 40px;
	display: flex;
	align-items: center;
	justify-content: space-around;
  }
  @media screen and (max-width: 736px) {
	.movieCol {
	  margin-top: 30px;
	}
  }
  .movieColItem {
	position: relative;
  }
  .movieColItemBtn {
	display: block;
	width: 100%;
	height: 100%;
	transition-duration: 0.3s;
  }
  .movieColItemBtn:hover {
	opacity: 0.8;
  }
  .movieColItemCap {
	position: absolute;
	top: 10px;
	right: 10px;
	color: #fff;
	text-shadow: 0 0 3px #000, 2px 2px 3px #000, -2px 2px 3px #000, -2px -2px 3px #000, 2px -2px 3px #000;
  }

  .playerBox {
	display: none;
	position: fixed;
	z-index: 9999999;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0, 0, 0, 0.7);
	box-sizing: border-box;
	padding: 10%;
	text-align: center;
  }

  @media screen and (max-width: 736px) {
	.playerBox {
	  display: none;
	  -webkit-box-align: center;
	  -webkit-align-items: center;
	  -ms-flex-align: center;
	  align-items: center;
	}
  }
  .playerBoxInner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	max-width: 960px;
	height: calc(680 / 960 * 100%);
	z-index: 10;
  }

  @media screen and (max-width: 736px) {
	.playerBoxInner {
	  width: 90%;
	  height: calc(380/750*100vw);
	}
  }
  .playerBox .btn-close {
	position: absolute;
	width: 40px;
	height: 40px;
	right: 0;
	top: -50px;
	z-index: 1;
	color: #fff;
	cursor: pointer;
	-webkit-transition: 0.4s;
	transition: 0.4s;
	display: inline-block;
  }

  .playerBox .btn-close:before {
	position: absolute;
	top: 50%;
	right: 10%;
	content: "";
	background: #fff;
	display: inline-block;
	height: 1px;
	width: 40px;
	transform: translateY(-50%) rotate(45deg);
  }
  @media screen and (max-width: 736px) {
	.playerBox .btn-close:before {
	  top: 10%;
	}
  }

  .playerBox .btn-close:after {
	position: absolute;
	top: 50%;
	right: 10%;
	content: "";
	background: #fff;
	display: inline-block;
	height: 1px;
	width: 40px;
	transform: translateY(-50%) rotate(-45deg);
  }
  @media screen and (max-width: 736px) {
	.playerBox .btn-close:after {
	  top: 10%;
	}
  }

  .playerBox iframe {
	position: relative !important;
  }

  .playerBox.hidden iframe {
	display: none;
  }

.service-caption {
	margin-top: 40px;
}