@charset "utf-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@600&family=Noto+Serif+JP:wght@400;700&display=swap');

html {
	/*scroll-behavior: smooth;*/
}
body {
	background-attachment: fixed;
	background-size:cover;
}
body a { color:#000;}
body a:hover { text-decoration:none;}

.container {
	-webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.5);
    -moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.5);
    box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.5);
	background: #00459f;
}
.bx-bgpk { background:#ffe1e8;}   

.footer{
    padding: 3em 0 0;
	text-align: center;
}
.footer--logo {
	margin:0 0 2em;
}
.footer--logo ul {
	display:flex;
	justify-content:space-around;
	margin:0 5% 9%;
}
.footer--logo ul li {
	width:26%;
}

.footer p {
    text-align: center;
    font-size: 0.8rem;
    padding-bottom: 1.3em; 
    color: #fff;
}
.footer .footer--logo {
	margin: 6em 26% 1.5em;
    font-size: 0.6em;
}
.footer a {
    color: #fff;
}

.c01 {
	background:#4cd0d2 url("../img/bg_01.jpg") center top no-repeat;
	background-size: cover;
}
.c02 {
	padding-bottom: 3em;
	background:#00459f url("../img/bg_02.jpg") center top no-repeat;
	background-size: 100% auto;
}

@media (min-width: 641px) {
/* PC用 */
	.container {
		width:768px;
		margin:0 auto;
		overflow: hidden; 
	}
    
    .c02 {
		padding-bottom: 18em;
    }
	
	.header img,
	.container img { width:100%; height: auto;}
	
	.footer p.copy{
		font-size: 0.7rem;
	}
}
@media (max-width: 640px) {
/* SP用 */
	.c02 { padding-bottom:7em;}
	.header img,
	.container img { width:100%; height: auto;}
	
	.footer{
		padding: 18px 0 1em;
	}
	
	.footer img {}
}

.scrollanime {
	opacity: 0;
}
.fadeInDown {
	animation-name: fadeInDown;
	animation-delay: 0.7s;
	animation-duration: 0.7s;
	animation-fill-mode: forwards;
}
@keyframes fadeInDown {
	0% {
		opacity: 0;			
	}
	100% {
	opacity: 1;
	transform: translate(0);
	}
}

.updown {
	transform: translateY(-100px);
}
.downup {
	transform: translateY(100px);
}
.slide-right {
	transform: translateX(200px);
}
.slide-left {
	transform: translateX(-200px);
}


/* 
-------------------------------------------------- */
.fx {
	display:flex;
	justify-content: space-between;
}

.cv--area01 .item {
	width:42%;
}
.cv--area01 .txt {
	width:58%;
}

.cv--area02 .item {
	width:47%;
}
.cv--area02 .txt {
	width:53%;
}

.txt .link_btn {
	position: relative;
	display: inline-block;
	margin-right:20%;
}
.cv--area02 .txt .link_btn {
	margin-right:16%;
}
@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* header
-------------------------------------------------- */
@media (min-width: 641px) {
/* PC用 */
	body { 
		position: relative;
		background:url("../img/bg_pc.jpg") center center no-repeat;
		background-attachment: fixed;
		background-size: cover;
	}
	.sp--menubar { display:none;}
	
	.header--wapper {
		position:fixed;
		/*height:70px;
		width:100%;
		background: #fff;*/
	}
	.header h1 {
		position:fixed;
		left:2.5%;
		top:30px;
		width:150px;
	}
	nav {
		display: flex;
		justify-content: flex-end;
		
		position: absolute;
		right:1.25%;
		top:35px;
		transform: translateY(-50%);
	}
	nav ul {
		display:flex;
		justify-content: flex-end;
		padding-right: 0.5em;
	}
	nav ul li {
		font-family: 'Montserrat', sans-serif;
		font-size:13px;
		font-weight: 600;
		letter-spacing: 0.1em;
		padding:0 0.85em;
	}
	nav ul li a {
		text-decoration: none;
	}
	nav .lang {
		padding-left: 0.5em;
		border-left:1px solid #e60e97;
	}
	nav .lang li a { color: #9c9c9c;}
}
@media (max-width: 640px) {
/* SP用 */
	.header h1 {
		position:fixed;
		left:5%;
		top:20px;
		width:25.44%;
		z-index: 11;
	}
	nav { display:none;}
	
	.sp--menubar {
		position: fixed;
		right:0;
		top:0;
		width:16%;
		height:16%;
		background: url("../img/bg_menu@2x.png") right top no-repeat;
		background-size:100% auto;
		z-index: 11;
	}
	.sp--menubar .sp--menuBtn {
		position: absolute;
		right:23%;
		top:15%;
		width:22px;
		height:16px;
	}
	.sp--menubar .sp--menuBtn span {
		position:absolute;
		right:0;
		
		width:24px;
		height:2px;
		background: #231815;
	}
	.sp--menubar .sp--menuBtn span:nth-child(1) {
		top:0;
	}
	.sp--menubar .sp--menuBtn span:nth-child(2) {
		bottom:0;
	}
	.sp--menubar .sp--menuBtn span:nth-child(1) {
		top:50%;
		transform: translateY(-50%);
	}
}



/* buy_btn
-------------------------------------------------- */
.buy_btn {
	position: absolute;
    left: 50%;
    top: calc(100% + 8px);
    transform: translateX(-50%);
    width: 100%;
    padding: 8px 8px 0;
	
    background: #16c228;
    visibility: hidden;
    opacity: 0;
    z-index: 44;
    transition: .5s all;
}
.buy_btn.is--active {
	visibility: visible;
	opacity: 1;
}
.link_btn img:hover { cursor: pointer;}
.buy_btn::before {
	content:'';
	position:absolute;
	top:-10px;
	left:50%;
	transform: translateX(-50%);
	border-bottom:10px solid #16c228;
	border-left:5px solid rgba(0,0,0,0);
	border-right:5px solid rgba(0,0,0,0);
}
.buy_btn li {
	width:100%;
	margin-bottom: 8px;
	background: #fff;
}
.buy_btn li a {
	display: block;	
	padding:15px 30px;
	text-align: center;
}
/*---- anc ----*/
.anc .buy_btn {
	left: 50%;
	transform: translateX(-50%);
	width:80%;
	top:96%;
}
@media (min-width: 641px) {
/* PC用 */
	.buy_btn {
		display:flex;
		justify-content: space-between;
		flex-wrap: wrap;
		top:105%;
	}
	.buy_btn li {
		width:49%;
	}
}
@media (max-width: 640px) {
/* SP用 */
	.buy_btn li a {
		padding:12px 25px;
	}
}

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

@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* sec01
-------------------------------------------------- */
.sec01 {
	background:url("../img/bg_sec_01@2x.jpg") center center no-repeat;
	background-size:auto 100%;
}
.cv--area03 {
	margin:0 4%;
}
.anc {
	position:relative;
}
.anc span {
	display:block;
	margin:0 0 6%;
}
.anc span ul { margin-top:-7.5%;}
@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* sec02
-------------------------------------------------- */
@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* sec03
-------------------------------------------------- */
@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* sec04
-------------------------------------------------- */
.sec04 {
	background:url("../img/bg_sec_04@2x.jpg") center center no-repeat;
	background-size:100% 100%;
}
.sec04 .rose {
	padding-bottom: 25%;
	background:url("../img/bg_sec_04_03@2x.png") center center no-repeat;
	background-size:100% auto;
}
.sec04 .rose .txt01 {
	margin-top:-5%;
}
.sec04 .lav {
	padding-bottom: 10%;
	background:url("../img/bg_sec_04_04@2x.png") center center no-repeat;
	background-size:100% auto;
}
.sec04 .lav .txt01 {
	margin-top:-5%;
}

.sec04 div .fx .item {
	width:48.5%;
}
.sec04 div .fx .txt {
	width:51.5%;
	position: relative;
}
.sec04 div .fx .txt span {
	display: block;
	margin:0 19% 10% 0;
}
@media (min-width: 641px) {
/* PC用 */
	.sec04 .rose .buy_btn li { width:100%;}
	.sec04 .rose .buy_btn li img { width:auto; height:21px;}
}
@media (max-width: 640px) {
/* SP用 */
}


/* sec05
-------------------------------------------------- */
.sec05 {
	background:url("../img/bg_sec_05@2x.jpg") center center no-repeat;
	background-size:100% 100%;
}
.sec05 .txt01 {
	margin-top:-6%;
}
@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* sec06
-------------------------------------------------- */
.sec06 {
	background:url("../img/bg_sec_06@2x.jpg") center center no-repeat;
	background-size:100% 100%;
}
.sec06 .fx .item {
	width:35.4%;
}
.sec06 .fx .txt {
	width:64.5%;
	position: relative;
}
.sec06 .fx .txt span {
	display:block;
	margin-right:20%;
}

.sec06 .oil--jusmine .buy_btn { top: 104%;}
.sec06 .bath--jusmine .buy_btn { top: 73%;}
@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}



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

@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}



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

@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}



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

@media (min-width: 641px) {
/* PC用 */
}
@media (max-width: 640px) {
/* SP用 */
}


/* bottom--banner
-------------------------------------------------- */
.bottom--banner {
	display:block;
	position:fixed;
	bottom:0.5%;
	left:0;
	width:100%;
	z-index: 2;
}
.bottom--banner img {
	width:100%; height: auto;
}
.bottom--banner .rCartBtn {
	width:100%;
	margin: 0 0 0;
	padding:2.8rem;
	border: 0;
	text-indent:-999%;
	background:url("../img/chase_bnr.png") center bottom no-repeat;
	background-size:100% auto;
}

.b--bnr {
	display:flex;
	margin:0 1% 0 2.5%;
}
.b--bnr01 {
	width:96.5%;
	position: absolute;
	left:0;
	top:-103%;
	
	visibility: hidden;
	opacity: 0;
	transition:.2s all;
}
.b--bnr01.is--open {
	visibility: visible;
	opacity: 1;
}
@media (min-width: 641px) {
/* PC用 */
	.bottom--banner {
		width:768px;
		left:50%;
		margin-left:-375px;
	}
	.b--bnr {
		margin-left:1%;
	}
}
@media (max-width: 640px) {
/* SP用 */
	
}





/****************************************************************************
アニメーション
 ****************************************************************************/
.fadeInBottom,
.fadeInBottomLate {
  opacity: 0;
  transform: translateY(40px);
  transition: .7s ease;
}

.fadeInBottom.is-active,
.fadeInBottomLate.is-active {
  opacity: 1;
  transform: translateY(0px);
}

.fadeIn,
.fadeInLate {
  opacity: 0;
  transition: .7s ease;
}

.fadeIn.is-active,
.fadeInLate.is-active {
  opacity: 1;
}

.lineAnime {
  opacity: 0;
}

.lineAnime.is-active {
  opacity: 1;
}

.leftSlide {
  transform: translateX(-51.06667vw);
  transition: .5s ease;
}

.leftSlide.is-active {
  transform: translateX(0);
}

.fadeOrderTitle {
  opacity: 0;
  transform: translateY(20px);
}

.fadeOrderObj {
  opacity: 0;
}

