@charset "utf-8";
/* CSS Document */

/*** -----------------------------------------------------------------------------

#home

-----------------------------------------------------------------------------  ***/

/* .visual */
main.main-content section.visual {
	background-size: contain;
	text-align:center;
}
main.main-content section.visual .inner {
	max-width:1200px;
  padding: 0 0 10px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
	position:relative;
}
main.main-content section.visual .inner .content .img-box{
	width:100%;
	position:relative;
	z-index:4;
}
main.main-content section.visual .inner .content .img-box p {
	display:flex;
	flex-wrap: wrap;
	justify-content: center;
	width:100%;
	max-width:1520px;
	padding-left:35px;
	padding-right:722px;
	box-sizing:border-box;
	position: relative;
	margin:0 auto;
	z-index:5;
}
main.main-content section.visual .inner .content .img-box .sp-img{
	display: none;
}
main.main-content section.visual .inner .content .bg {
	display:block;
	width:100%;
	max-width:1520px;
	height:100%;
	padding-left:50%;
	box-sizing: border-box;
	position:absolute;
	top:0;
	left:0;
	right:0;
	margin:0 auto;
	z-index:1;
}
main.main-content section.visual .inner .content .bg:before {
	content:'';
	display:block;
	width:calc(50% - 40px);
	height:100%;
	background:url(../../img/home/mv-img.png)no-repeat top 20px center;
	background-size:contain;
	position:absolute;
	top:0;
	right:0;
}

main.main-content section.visual .catch {
	display: block;
	width:100%;
	padding:0;
	box-sizing:border-box;
	background:#003A77;
	text-align:center;
	position:relative;
	margin-top: -18px;
	z-index: 3;
}
main.main-content section.visual .catch .txt {
	display:inline-block;
	padding:12px;
	box-sizing:border-box;
	text-align:center;
	font-family: 'Noto Serif JP', sans-serif;
	line-height:1.4;
	color:#fff;
	position: relative;
	font-size:45px;
}
main.main-content section.visual .inner .content .img-box .img{
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
}
main.main-content section.visual .inner .content .img-box .img span{
  display: block;
  width: 34%;
  transform: scale(-1,1);
  margin: -30px -4% 18px 0;
}
main.main-content section.visual .inner .content .img-box .img strong{
  display: block;
  width: 70%;
}
/*main.main-content section.visual .inner .content .img-box .img:before {
  content:'';
  display:block;
  width: 25%;
  height: 0;
  padding-top: 14.5%;
  background:url(../../img/home/mv-female.png)no-repeat center bottom;
  background-size:contain;
  position:absolute;
  left:-3%;
  bottom:18px;
  transform: scale(-1,1);
  z-index:6;
}*/

@media (max-width:1650px){
	main.main-content section.visual .catch .txt {
	font-size:45px;
	}
}
@media (max-width:1400px){
	main.main-content section.visual .inner .content .img-box p {
		padding-right: 50%;
	}
	main.main-content section.visual .catch .txt {
		padding:12px;
		font-size:3vw;
		text-align: center;
	}
	main.main-content section.visual .catch .txt:before {
		width:250px;
		right:-10px;
		bottom: 100%;
	}
}
@media (max-width:1150px){
  main.main-content section.visual .inner .content .img-box{
  }
	main.main-content section.visual .catch .txt {
		padding:12px;
		font-size:3vw;
	}
	main.main-content section.visual .catch .txt:before {
		width:200px;
		right:-10px;
	}	
}


@media (max-width:1000px){
	main.main-content section.visual .catch .txt br.pc-none{
		display:block;
	}
}

@media (max-width:800px){
	main.main-content section.visual .inner{
		padding:0 15px;
		position:relative;
	}
  main.main-content section.visual .inner .content .img-box:before{
    display: none;
  }
	main.main-content section.visual .inner:before {
		/*content:'';
		display:block;
		width:140px;
		height:140px;
		background:url(../../img/home/mv-female-sp.png)no-repeat center bottom;
		background-size:contain;
		position:absolute;
		right:0;
		bottom:0;
		z-index:55;*/
		display: none;
	}
	main.main-content section.visual .inner .content .img-box p {
		padding:0 15px;
	}
	main.main-content section.visual .inner .content .img-box .txt{
		padding:15px 20px 25px;
		background:#003A77;
	}
	main.main-content section.visual .inner .content .img-box .sp-img{
		display:block;
		padding-bottom: 10px;
		margin:-20px auto 0;
	}
	main.main-content section.visual .inner .content .img-box .img{
		width:75%;
		max-width:672px;
		position:absolute;
		left:50%;
		transform: translateX(-50%);
		bottom:-14px;
		padding: 0;
	}
  main.main-content section.visual .inner .content .img-box .img span{
    display: none;
  }
  main.main-content section.visual .inner .content .img-box .img strong{
    display: block;
    width: 100%;
  }
	main.main-content section.visual .inner .content .bg {
		display:none;
	}

	main.main-content section.visual .catch {
		margin-top: 0;
	}
	main.main-content section.visual .catch .txt {
		display:block;
		padding:10px;
		box-sizing:border-box;
		text-align:center;
		font-family: 'Noto Serif JP', sans-serif;
		line-height:1.6;
		font-size:4vw;
		font-weight: bold;
		color:#fff;
		position: relative;
	}
	main.main-content section.visual .catch .txt .pc-none {
		display: block;
	}
	main.main-content section.visual .catch .txt:before {
		display:none;
	}
}

@media (max-width:100px) and (min-width: 76px) and (min-height: 1024px){
	main.main-content section.visual img {
		max-width:70%;
	}
	main.main-content section.visual .inner:before {
		width:220px;
		height:220px;
		right:calc(50% - 340px);
	}
	main.main-content section.visual .catch .txt {
		padding:10px;
		text-align:center;
		font-size:30px;
	}
}

@media (max-width:360px) {
	main.main-content section.visual .inner:before {
		width:95px;
		height:100px;
	}
	main.main-content section.visual .catch .txt {
		font-size:14px;
	}
}

/* .pankuzu */
main.main-content .pankuzu .inner {
	padding:10px 20px;
	text-align:left;
}
main.main-content .pankuzu .inner ul li:last-child a{
  pointer-events:none;
}
main.main-content .pankuzu .inner ul li:last-child a:after{
  display:none;
}
@media (max-width:768px){
	main.main-content .pankuzu .inner {
		padding:5px 0 0;
	}
	main.main-content .pankuzu .inner ul {
		padding:0 10px 3px;
	}
}


/* .sec-feat */
main.main-content section.sec-feat .inner {
	max-width:100%;
	padding-left:0;
	padding-right: 0;
	padding-bottom:0;
}

/* .feature4 */
main.main-content section.feature4 .inner {
	max-width:100%;
	padding-left:0;
	padding-right: 0;
}

@media (max-width:768px){
	main.main-content section.feature4 .clm2_box{
		padding-left:20px;
		padding-right:20px;
		box-sizing:border-box;
	}
}

/* .feature5 */
main.main-content section.feature5 .inner{
	max-width: none;
}
main.main-content section.feature5 .inner .img {
	text-align:center;
}
main.main-content section.feature5 .inner .annotation {
	display:block;
	text-align:center;
	font-family: 'Noto Serif JP', sans-serif;
	font-size:18px;
	margin:0 auto 40px;
}
main.main-content section.feature5 .inner > .txt {
	display:block;
	max-width:1000px;
	text-align:left;
	font-size:18px;
	margin:0 auto 80px;
}
main.main-content section.feature5 .link-btn{
	margin:40px auto 100px;
}
main.main-content section.feature5 .consultation_bnr{
	max-width: 1240px;
	margin: 0 auto;
}
@media (max-width:768px){
	main.main-content section.feature5 .section-ttl{
		margin-bottom:0;
	}
	main.main-content section.feature5 .inner .annotation {
		font-size:10px;
		margin-bottom:15px;
	}
	main.main-content section.feature5 .inner > .txt {
		line-height:2;
		font-size:15px;
		margin-bottom:25px;
	}
	main.main-content section.feature5 .link-btn{
		margin:15px auto 50px;
	}
}


/* .const-area */
main.main-content section.const-area {
	background:url(../img/parts/clm2_box/bg-img.png)no-repeat right bottom;
	background-size:50%;
}
main.main-content section.const-area .section-ttl .sp-none{
	display:inline-block;
}
main.main-content section.const-area .clm2_box{
	margin-bottom:50px;
}
main.main-content section.const-area .clm2_box .txt-box{
	align-content:flex-end;
	padding-bottom:30px;
}

@media (max-width:1350px){
	main.main-content section.const-area .clm2_box .txt-box{
		width:calc(50% + 140px);
		align-content:flex-end;
		margin-left:-140px;
	}
}

@media (max-width:1000px){
	main.main-content section.const-area .clm2_box{
		margin-bottom:130px;
	}
	main.main-content section.const-area .clm2_box .txt-box{
		width:calc(50% + 140px);
		padding-bottom:0;
		margin-left:-140px;
	}
}
@media (max-width:950px){
	main.main-content section.const-area .clm2_box .txt-box{
		width:calc(50% + 200px);
		margin-left:-200px;
	}
}
@media (max-width:800px){
	main.main-content section.const-area .clm2_box {
		margin-bottom:170px;
	}
	main.main-content section.const-area .clm2_box .txt-box{
		width:calc(50% + 300px);
		margin-left:-300px;
	}
	main.main-content section .clm2_box .txt{
		margin-bottom:-100px;
	}
}

@media (max-width:768px){
	main.main-content section.const-area {
		background:url(../img/parts/clm2_box/bg-img.png)no-repeat right bottom;
		background-size:100%;
	}
	main.main-content section.const-area .section-ttl {
		margin-bottom:25px;
	}
	main.main-content section.const-area .section-ttl .sp-none{
		display:none;
	}
	main.main-content section.const-area .section-ttl .main .large{
		font-size:38px;
	}
	main.main-content section.const-area .clm2_box .txt {
	    padding:15px;
	    background: #fff;
	    font-size: 14px;
	    line-height: 1.8;
	    box-shadow: 10px 10px 10px rgb(0 0 0 / 10%);
	}
	main.main-content section.const-area .clm2_box{
		margin-bottom: 20px;
	}
	main.main-content section.const-area .clm2_box .txt-box {
		width:100%;
		padding-bottom:0;
		margin-left:0;
	}
}


/* .const-area */
@media (max-width:768px){
	main.main-content section.news-box .section-ttl{
		margin-bottom:0;
	}
}

@media (max-width:768px){
	main.main-content section.bg-cream.sp{
		background-color: #fff;
	}
	main.main-content section.bg-cream .payment{
		background: #F9F4E4;
	}
}


/*** -----------------------------------------------------------------------------

#home.ito

-----------------------------------------------------------------------------  ***/

/* .visual */
.ito main.main-content section.visual .inner .txt-box{
  color: #fff;
}
.ito main.main-content section.visual .inner .txt-box .txt1{
  font-size: 40px;
  line-height: 1.4;
  margin-bottom: 20px;
}
.ito main.main-content section.visual .inner .txt-box .txt2{
  font-size: 26px;
  line-height: 1.6;
}
.ito main.main-content section.visual .inner .price{
  margin: 100px 0 0 auto;
  width: fit-content;
  border-top: solid 2px #004386;
  border-bottom: solid 2px #004386;
  box-sizing: border-box;
  padding: 15px 5px;
}
.ito main.main-content section.visual .inner .price .txt1{
  background-color: #004386;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  padding: 5px 0;
  text-align: center;
  margin-bottom: 10px;
}
.ito main.main-content section.visual .inner .price .txt2{
  color: #004386;
  font-size: 22px;
  line-height: 1;
}
.ito main.main-content section.visual .inner .price .txt2 strong{
  font-size: 56px;
}
.ito main.main-content section.visual .inner .price .txt2 span{
  font-size: 34px;
}
@media (max-width:1080px) {
  .ito main.main-content section.visual .inner .txt-box .txt1{
    font-size: 3.6vw;
  }
  .ito main.main-content section.visual .inner .txt-box .txt2{
    font-size: 2.2vw;
  }
  .ito main.main-content section.visual .inner .price .txt1{
    font-size: 2vw;
    padding: 5px;
  }
  .ito main.main-content section.visual .inner .price .txt2{
    font-size: 2.2vw;
  }
  .ito main.main-content section.visual .inner .price .txt2 strong{
    font-size: 5vw;
  }
  .ito main.main-content section.visual .inner .price .txt2 span{
    font-size: 3vw;
  }
}
@media (max-width:768px) {
	.ito main.main-content section.visual .inner {
	  padding: 0 15px 30px;
	}
  .ito main.main-content section.visual .inner .txt-box{
    text-align: center;
  }
  .ito main.main-content section.visual .inner .txt-box .txt1{
    font-size: 5vw;
    line-height: 1.8;
  }
  .ito main.main-content section.visual .inner .txt-box .txt2{
    font-size: 3.2vw;
  }
  .ito main.main-content section.visual .inner .price{
    margin: 15% 0 0;
    width: 100%;
    text-align: center;
    padding: 2%;
  }
  .ito main.main-content section.visual .inner .price .txt1{
    font-size: 3vw;
    padding: 5px;
  }
  .ito main.main-content section.visual .inner .price .txt2{
    font-size: 3.6vw;
  }
  .ito main.main-content section.visual .inner .price .txt2 strong{
    font-size: 8vw;
  }
  .ito main.main-content section.visual .inner .price .txt2 span{
    font-size: 6vw;
  }
}

/* .about */
.ito main.main-content section.about{
  position: relative;
}
.ito main.main-content section.about:after{
  content: "";
  width: 100%;
  height: 288px;
  background-color: #F9F4E4;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 0;
}
.ito main.main-content section.about .inner {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  position: relative;
  z-index: 2;
  flex-wrap: wrap;
  padding: 100px 20px;
}
.ito main.main-content section.about .inner .txt1{
  max-width: 70px;
  width: 7%;
}
.ito main.main-content section.about .inner .txt2{
  font-family: 'Noto Serif JP', sans-serif;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  line-height: 2.4;
  font-size: 20px;
}
.ito main.main-content section.about .inner .movie {
  width: 70%;
  max-width: 770px;
  height: 0;
  padding-top: 36%;
  margin: 60px 60px 0 0;
  box-shadow: 10px 10px 40px rgb(0 0 0 / 30%);
  position: relative;
}
.ito main.main-content section.about .inner .movie iframe{
  width: 100%;
  height:100%;
  position: absolute;
  top: 0;
  left: 0;
}
@media (max-width:1150px) {
  .ito main.main-content section.about .inner .txt2{
    font-size: 1.7vw;
  }
  .ito main.main-content section.about .inner .movie {
    width: 68%;
    max-width: none;
  }
  .ito main.main-content section.about .inner .movie iframe{
    width: 100%;
    height:100%;
    position: absolute;
    top: 0;
    left: 0;
  }
}
@media (max-width:768px) {
  .ito main.main-content section.about:after{
    width: 100%;
    height: 30%;
  }
  .ito main.main-content section.about .inner {
    display: block;
    padding: 50px 20px;
  }
  .ito main.main-content section.about .inner .txt1{
    max-width: 220px;
    width: 220px;
    margin-left:auto;
    margin-right:auto;
    margin-bottom: 10px;
  }
  .ito main.main-content section.about .inner .txt2{
    -ms-writing-mode: inherit;
    writing-mode: inherit;
    line-height: 1.8;
    font-size: 16px;
  }
  .ito main.main-content section.about .inner .movie {
    width: 100%;
    max-width: none;
    height: 0;
    padding-top: 56%;
    margin: 20px 0 0;
    box-shadow: 5px 5px 20px rgb(0 0 0 / 30%);
  }
  .ito main.main-content section.about .inner .movie iframe{
    width: 100%;
    height:100%;
    position: absolute;
    top: 0;
    left: 0;
  }
}

/* .plan_conts */
.ito main.main-content section.plan_conts{
  margin-bottom: 200px;
}
.ito main.main-content section.plan_conts .content{
  background-color: #fff;
  text-align: center;
  padding: 50px;
  margin: 0 auto 60px;
}
.ito main.main-content section.plan_conts h3{
  font-size: 26px;
  font-weight: bold;
  color: #185192;
  margin: 0 0 30px;
}
.ito main.main-content section.plan_conts .case {
  display: flex;
  justify-content: space-between;
}
.ito main.main-content section.plan_conts .case div {
  width: 49%;
}
.ito main.main-content section.plan_conts .case .case_01 {
  background-color: #ebf1f8;
}
.ito main.main-content section.plan_conts .case .case_02 {
  background-color: #fefbeb;
}
.ito main.main-content section.plan_conts .case div h4 {
  padding: 10px 5px;
  position: relative;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
}
.ito main.main-content section.plan_conts .case div h4 span{
  font-size: 22px;
}
.ito main.main-content section.plan_conts .case .case_01 h4 {
  background-color: #185192;
  color: #fff;
}
.ito main.main-content section.plan_conts .case .case_02 h4 {
  background-color: #FEE33F;
  color: #185192;
}
.ito main.main-content section.plan_conts .case div h4 strong {
  position: relative;
  display: inline-block;
  padding: 0 55px;
}
.ito main.main-content section.plan_conts .case div h4 strong:before,
.ito main.main-content section.plan_conts .case div h4 strong:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 40px;
  height: 1px;
  background-color: #666;
}
.ito main.main-content section.plan_conts .case div h4 strong:before {
  left: 0;
}
.ito main.main-content section.plan_conts .case div h4 strong:after {
  right: 0;
}
.ito main.main-content section.plan_conts .case .case_01 h4 strong:before,
.ito main.main-content section.plan_conts .case .case_01 h4 strong:after{
  background-color: #fff;
}
.ito main.main-content section.plan_conts .case .case_02 h4 strong:before,
.ito main.main-content section.plan_conts .case .case_02 h4 strong:after{
  background-color: #185192;
}
.ito main.main-content section.plan_conts .case div ul {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  padding: 20px;
}
.ito main.main-content section.plan_conts .case div ul li {
  width: calc(100% / 3 - 7px);
  height: 45px;
  margin: 0 10px 10px 0;
  padding: 0 0 0 40px;
  box-sizing: border-box;
  border: solid 1px #333;
  border-radius: 5px;
  display: flex;
  align-items: center;
  font-size: 14px;
  line-height: 1.2;
  text-align: left;
}
.ito main.main-content section.plan_conts .case .case_01 ul li{
  border-color: #185192;
}
.ito main.main-content section.plan_conts .case .case_02 ul li{
  border-color: #FEE33F;
}
.ito main.main-content section.plan_conts .case div ul li:nth-child(3n) {
  margin-right: 0;
}
.ito main.main-content section.plan_conts .case div ul li:nth-child(1) {
  background: url("../../img/ito/icon_plan_s01.svg") left 7px center / 28px auto
    no-repeat #fff;
}
.ito main.main-content section.plan_conts .case div ul li:nth-child(2) {
  background: url("../../img/ito/icon_plan_s02.svg") left 8px center / 22px auto
    no-repeat #fff;
}
.ito main.main-content section.plan_conts .case div ul li:nth-child(3) {
  background: url("../../img/ito/icon_plan_s03.svg") left 7px center / 25px auto
    no-repeat #fff;
}
.ito main.main-content section.plan_conts .case .case_01 ul li:nth-child(4),
.ito main.main-content section.plan_conts .case .case_02 ul li:nth-child(4) {
  background: url("../../img/ito/icon_plan_s05.svg") left 7px center / 26px auto
    no-repeat #fff;
}
.ito main.main-content section.plan_conts .case .case_01 ul li:nth-child(5),
.ito main.main-content section.plan_conts .case .case_02 ul li:nth-child(5) {
  background: url("../../img/ito/icon_plan_s06.svg") left 7px center / 24px auto
    no-repeat #fff;
}
/* .ito main.main-content section.plan_conts .case .case_02 ul li:nth-child(4) {
  background: url("../../img/ito/icon_plan_s04.svg") left 10px center / 20px auto
    no-repeat #fff;
} */
.ito main.main-content section.plan_conts .ceremony-movie{
  margin: 60px auto -150px;
  max-width: 1024px;
  width: 100%;
}
.ito main.main-content section.plan_conts .ceremony-movie .movie {
  width: 100%;
  height: 0;
  padding-top: 56%;
  position: relative;
}
.ito main.main-content section.plan_conts .ceremony-movie .movie iframe{
  width: 100%;
  height:100%;
  position: absolute;
  top: 0;
  left: 0;
}
@media (max-width:1100px) {
  .ito main.main-content section.plan_conts .case div h4 {
    font-size: 1.4vw;
  }
  .ito main.main-content section.plan_conts .case div h4 span{
    font-size: 1.8vw;
  }
  .ito main.main-content section.plan_conts .case div ul li {
    font-size: 1.2vw;
  }
  .ito main.main-content section.plan_conts .annotation {
    font-size: 1.4vw;
    margin-top: 5px;
  }
}
@media (max-width:768px) {
  .ito main.main-content section.plan_conts{
    margin-bottom: 60px;
  }
  .ito main.main-content section.plan_conts .content{
    padding: 15px;
    margin: 0 auto 30px;
  }
  .ito main.main-content section.plan_conts h3{
    font-size: 18px;
    margin: 0 0 10px;
  }
  .ito main.main-content section.plan_conts .flow .img{
    width: 760px;
  }
  .ito main.main-content section.plan_conts .case div h4 {
    font-size: 3vw;
  }
  .ito main.main-content section.plan_conts .case div h4 span{
    font-size: 3.4vw;
  }
  .ito main.main-content section.plan_conts .case div h4 strong {
    padding: 0 13px;
    height: 20px;
  }
  .ito main.main-content section.plan_conts .case .case_01 h4 strong{
    line-height: 20px;
  }
  .ito main.main-content section.plan_conts .case div h4 strong:before,
  .ito main.main-content section.plan_conts .case div h4 strong:after {
    width: 10px;
  }
  .ito main.main-content section.plan_conts .case div ul {
    display: block;
    padding: 10px;
  }
  .ito main.main-content section.plan_conts .case div ul li {
    width: 100%;
    margin: 0 0 10px;
    padding: 0 0 0 40px;
    font-size: 2vw;
  }
  .ito main.main-content section.plan_conts .ceremony-movie{
    margin: 40px auto -70px;
  }
  .ito main.main-content section.plan_conts .annotation {
    font-size: 2vw;
  }
}

/*** -----------------------------------------------------------------------------

#home.tenkousha

-----------------------------------------------------------------------------  ***/

/* .visual */
.tenkousha main.main-content section.visual .inner .content .img-box picture{
	width:90%;
	margin-bottom: 30px;
}
@media (max-width:768px) {
	.tenkousha main.main-content section.visual .inner .content .img-box picture{
		margin-bottom: 10px;
	}
}

/***23.06.22 各ブランドTOPページのMV部分 swiperに変更***/
main.main-content section.visual .swiper_main_block{
  padding-bottom: 50px;
}
main.main-content section.visual .swiper_main_block .swiper-pagination{
  bottom: 25px;
}
main.main-content section.visual .swiper_main_block .swiper-pagination .swiper-pagination-bullet{
  margin: 0 10px;
}
main.main-content section.visual .swiper_main_block .swiper-pagination .swiper-pagination-bullet-active{
  background-color: #000;
}
@media (max-width:768px){
  main.main-content section.visual .swiper_main_block{
    padding-bottom: 30px;
  }
  main.main-content section.visual .swiper_main_block .swiper-pagination{
    bottom: 5px;
  }
}