@charset "utf-8";
/* CSS Document */

/* base
-----------------------------------------------*/
/* ========== universal reset ========== */
/* ========== base style ========== */

/* common parts
-----------------------------------------------*/
/* ========== text ========== */
/* ========== border ========== */
/* ========== float ========== */
/* ========== display ========== */
/* ========== position ========== */
/* ========== overflow ========== */
/* ========== width ========== */
/* ========== margin ========== */
/* ========== background ========== */
/* ========== modal ========== */
/* ========== device displaying ========== */
/* ========== animation for ScrollTrigger.min.js  ========== */

/* other style
-----------------------------------------------*/



/* base
-----------------------------------------------*/
/* ========== universal reset ========== */
/**
* html5doctor.com Reset Stylesheet v1.6.1 (http://html5doctor.com/html-5-reset-stylesheet/)
* Richard Clark (http://richclarkdesign.com)
* http://cssreset.com
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
button, input, select, textarea,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
margin:0;
padding:0;
border:0;
outline:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
body { line-height:1; }
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
display:block;
}
nav ul { list-style:none; }
blockquote, q {
quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content:'';
content:none;
}
a {
margin:0;
padding:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}


/* ========== base style ========== */
* { box-sizing: border-box; }

html { height: 100%; }

body {
height: 100%;
min-height: 100%;
background: #e2ecf0;
color: #221815;
font-size: 12px;
font-family: fot-cezanne-pron, sans-serif;
font-style: normal;
font-weight: 500;
font-feature-settings: "palt";
}
@media (max-width:374px){
	body {
	font-size: 3.2vw;
	}
}

a:link,
a:visited {
color: #221815;
text-decoration: none;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
}

a:hover,
a:hover img,
button:hover img {
opacity: 0.70;
filter: alpha(opacity=70);
}

div,p,h1,h2,h3,h4,h5,h6,li,dt,dd,th,td {
line-height: 100%;
font-family: fot-cezanne-pron, sans-serif;
font-style: normal;
font-weight: 500;
font-feature-settings: "palt";
letter-spacing: 0.1em;
}

div, article { box-sizing: border-box; }

ol, ul { list-style:none; }

img, video {
width: 100%;
display: block;
margin-left: auto;
margin-right: auto;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
}



/* common parts
-----------------------------------------------*/
/* ========== text ========== */
/* align */
.al_left { text-align: left; }
.al_center { text-align: center; }
.al_right { text-align: right; }

/* size */
.fs10 { font-size: 10px; }
.fs11 { font-size: 11px; }
.fs12 { font-size: 12px; }
.fs13 { font-size: 13px; }
.fs14 { font-size: 14px; }
.fs15 { font-size: 15px; }
.fs16 { font-size: 16px; }
.fs17 { font-size: 17px; }
.fs18 { font-size: 18px; }
@media (max-width:374px){
	.fs10 { font-size: 2.67vw; }
	.fs11 { font-size: 2.93vw; }
	.fs12 { font-size: 3.2vw; }
	.fs13 { font-size: 3.47vw; }
	.fs14 { font-size: 3.73vw; }
	.fs15 { font-size: 4vw; }
	.fs16 { font-size: 4.27vw; }
	.fs17 { font-size: 4.53vw; }
	.fs18 { font-size: 4.8vw; }
}

/* weight */
.fw400 { font-weight: 400 !important; }
.fw500 { font-weight: 500 !important; }
.fw700 { font-weight: 700 !important; }

/* line height */
.lh130 { line-height: 130%; }
.lh140 { line-height: 140%; }
.lh150 { line-height: 150%; }
.lh160 { line-height: 160%; }
.lh170 { line-height: 170%; }
.lh180 { line-height: 180%; }
.lh190 { line-height: 190%; }
.lh200 { line-height: 200%; }
.lh210 { line-height: 210%; }


/* ========== float ========== */
/* clearfix */
.clearfix:before,
.clearfix:after {
display: table;
content: " ";
}
.clearfix:after { clear: both; }

/* float */
.float_left { float: left; }
.float_right { float: right; }


/* ========== display ========== */
.disp_block { display: block !important;}
.disp_iblock { display: inline-block !important;}
.disp_inline { display: inline !important;}
.disp_none { display: none;}
.disp_flex { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-start; }


/* ========== position ========== */
.posi_relative { position: relative !important; }
.posi_absolute { position: absolute !important; }
.posi_fixed { position: fixed !important; }


/* ========== overflow ========== */
.overflow_hidden { overflow: hidden !important; }


/* ========== margin ========== */
/* margin-auto */
.mx_auto { margin-left: auto; margin-right: auto; }


/* ========== device displaying ========== */
.sp_none{ display: none; }
@media (min-width:768px){.sp_none{display: block;} .tab_none { display: none; }}
.sp_only{ display: block; }
@media (min-width:768px){.sp_only{display: none;}}
.spc_none{ display: block; }
@media (min-width:991px){.s-pc_none{display: none;}}
.spc_above{ display: block; }
@media (max-width:992px){.s-pc_above{ display:none;}}
.pc_none{ display: block; }
@media (min-width:1199px){.pc_none{display: block;}}
.pc_only{ display: none; }
@media (min-width:1200px){.pc_none{display: none;}
.pc_only{display: block;}
.tab_none{ display: block; }
}


/* ========== animation for ScrollTrigger.min.js  ========== */
.invisible {
transition: opacity 1s ease;
opacity: 0.0;
}
.visible {
transition: opacity 1s ease;
opacity: 1.0;
}


/* other style
-----------------------------------------------*/
.allwrapper { /* Xscroll bar hidden */
width: 100%;
overflow: hidden;
}
.ff_midashigo {
font-family: a-otf-midashi-go-mb31-pr6n, sans-serif;
font-style: normal;
font-weight: 600;
}

.header {
padding: 6.5vw 0 3.33vw
}
.header .logo01 {
width: 76.8vw;
}
.header .logo02 {
margin-top: 8vw;
width: 36vw;
}
@media (min-width:768px){
	.header {
	padding: 50px 0 30px;
	}
	.header .logo01 {
	width: 326px;
	}
	.header .logo02 {
	margin-top: 47px;
	width: 200px;
	}
}

.mv {
width: 100%;
height: 100vw;
}
.mv a:hover {
background: #000;
opacity: 1;
filter: alpha(opacity=100);
}
.mv_img {
animation-delay: 0.75s;
}
.mv h1 {
top: 34.67vw;
left: 36.67vw;
width: 26.66vw;
animation-delay: 1.5s;
}
@media (min-width:768px){
	.mv {
	height: 66.6vw;
	}
	.mv h1 {
	width: 10vw;
	top: 29.5vw;
	left: 45vw;
	}
}

.intro {
padding-top: 50px;
}
.intro h2 {
width: 87.46vw;
}
.intro .textbox {
margin-top: 40px;
}
.intro p {
margin-bottom: 1.76em;
text-align: center;
font-family: a-otf-midashi-go-mb31-pr6n, sans-serif;
font-style: normal;
font-weight: 600;
font-size: 13px;
letter-spacing: 0.075em;
line-height: 176%;
}
.intro p:last-child {
margin-bottom: 0;
}
.intro .check {
width: 92vw;
margin-top: 40px;
padding: 20px 0 20px 6.65vw;
background: #fff;
} 
.intro .check dt {
position: relative;
padding-left: 20px;
font-family: aktiv-grotesk, sans-serif;
font-style: normal;
font-weight: 700;
font-size: 16px;
white-space:nowrap;
overflow: hidden;
letter-spacing: 0.075em;
border-right: .1em solid black;
}
.intro .check dt::before {
content: "";
position: absolute;
left: 0;
top: 0;
display: block;
width: 14px;
height: 14px;
background: url("../images/intro-check.png") 0 0 / 100% auto no-repeat;
}
@-webkit-keyframes blink-caret { from, to { border-color: transparent } 50% { border-color: black } } 
@-moz-keyframes blink-caret { from, to { border-color: transparent } 50% { border-color: black } }

.intro .check01 { width: 7.3em; }
@-webkit-keyframes typing01 { from { width: 0 } to { width: 7.3em; } } 
@-moz-keyframes typing01 { from { width: 0 } to { width: 7.3em; } } 
.intro .typing_animation01 { -webkit-animation: typing01 1.4s steps(9, end),  blink-caret 1s step-end infinite; -moz-animation: typing01 1.4s steps(9, end),  blink-caret 1s step-end infinite; }

.intro .check02 { width: 9.8em; }
@-webkit-keyframes typing02 { from { width: 0 } to { width: 9.8em; } } 
@-moz-keyframes typing02 { from { width: 0 } to { width: 9.8em; } } 
.intro .typing_animation02 { -webkit-animation: typing02 1.7s steps(12, end),  blink-caret 1s step-end infinite; -moz-animation: typing02 1.7s steps(12, end),  blink-caret 1s step-end infinite; }

.intro .check03 { width: 10.3em; }
@-webkit-keyframes typing03 { from { width: 0 } to { width: 10.3em; } } 
@-moz-keyframes typing03 { from { width: 0 } to { width: 10.3em; } } 
.intro .typing_animation03 { -webkit-animation: typing03 1.9s steps(14, end),  blink-caret 1s step-end infinite; -moz-animation: typing03 1.9s steps(14, end),  blink-caret 1s step-end infinite; }

.intro .check04 { width: 9.3em; }
@-webkit-keyframes typing04 { from { width: 0 } to { width: 9.3em; } } 
@-moz-keyframes typing04 { from { width: 0 } to { width: 9.3em; } } 
.intro .typing_animation04 { -webkit-animation: typing04 1.6s steps(11, end),  blink-caret 1s step-end infinite; -moz-animation: typing03 1.6s steps(11, end),  blink-caret 1s step-end infinite; }

.intro .check dd {
margin: 2.5vw 0 5.33vw;
animation-delay: 0.5s;
}
.intro .check dl:last-child dd:last-child {
margin-bottom: 0;
}
@media (max-width:374px){
	.intro p {
	font-size: 3.47vw;
	}
}
@media (min-width:768px){
	.intro h2 {
	width: 362px;
	}
	.intro p {
	margin-bottom: 1.7em;
	font-size: 14px;
	line-height: 170%;
	}
	.pc_box {
	width: 710px;
	}
	.intro .check {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
	margin-top: 50px;
	padding: 20px;
	}
	.intro .check dl {
	width: 300px;
	}
	.intro .check dt {
	font-size: 18px;
	}
	.intro .check dd {
	margin: 10px 0 20px;
	}
	.intro .check dd:last-child {
	margin-bottom: 0;
	}
}
@media (min-width:800px){
	.pc_box {
	width: 750px;
	}
	.intro .check dl {
	width: 335px;
	}
}

.standard {
margin-top: 60px;
}
.standard h3 {
width: 37.6vw;
max-width: 140px;
}
.standard ul {
width: 100%;
margin-top: 20px;
}
.standard li {
width: 47.2vw;
}
.standard li:nth-child(2) {
animation-delay: 0.3s;
}
.standard a {
display: block;
}
.standard a:hover {
background: #000;
opacity: 1;
filter: alpha(opacity=100);
}
@media (min-width:768px){
	.standard {
	width: 710px;
	}
	.standard h3 {
	max-width: 213px;
	}
	.standard ul {
	margin-top: 37px;
	}
	.standard li {
	width: 335px;
	}
}

.seasonal {
margin-top: 22px;
}
.seasonal h3 {
width: 37.6vw;
max-width: 140px;
}
.seasonal ul {
width: 100%;
margin-top: 20px;
}
.seasonal li {
width: 31.73vw;
}
.seasonal li:nth-child(2) {
animation-delay: 0.3s;
}
.seasonal li:nth-child(3) {
animation-delay: 0.6s;
}
.seasonal a {
display: block;
opacity: 1;
filter: alpha(opacity=100);
}
.seasonal a:hover {
background: #000;
}
@media (min-width:768px){
	.seasonal {
	width: 710px;
	margin-top: 50px;
	}
	.seasonal h3 {
	max-width: 213px;
	}
	.seasonal ul {
	margin-top: 37px;
	}
	.seasonal li {
	width: 225px;
	}
}

.hello {
width: 94.4vw;
margin-top: 25px;
padding: 32px 2.67vw 50px;
background: #fff;
}
.hello.coco {
margin-top: 75px;
}
.hello h2 {
margin-top: 25px;
}
.hello .inner {
margin-top: 33px;
}
.hello .imgbox {
margin-top: 25px;
}
.hello .imgbox li {
width: 44vw;
margin-top: 1.33vw;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
}
.hello .imgbox li:nth-child(2) {
animation-delay: 0.2s;
}
.hello .imgbox li:nth-child(3) {
animation-delay: 0.4s;
}
.hello .imgbox li:nth-child(4) {
animation-delay: 0.6s;
}
.hello a:hover .imgbox li {
background: #000;
}
.hello .credit {
margin-top: 15px;
}
.hello .credit a {
text-decoration: underline !important;
}
a.buy {
margin-top: 15px;
background: #fff;
color: #000;
border: 1px solid #000;
line-height: 30px;
}
a:hover.buy {
background: #000;
color: #fff;
border: 1px solid #000;
}
@media (min-width:768px){
	.hello {
	width: 100%;
	margin-top: 50px;
	padding: 30px 25px 55px;
	}
	.hello .name {
	width: 354px;
	margin: 0 auto;
	}
	.hello .inner {
	display: flex;
	justify-content: space-between;
	}
	.hello .movie,
	.hello .detail {
	width: 320px;
	}
	.hello .movie {
	margin: 0;
	}
	.hello .imgbox {
	margin-top: 0;
	}
	.hello .imgbox li {
	width: 154px;
	margin-top: 0;
	}
	.hello .imgbox li:nth-child(3),
	.hello .imgbox li:nth-child(4) {
	margin-top: 10px;
	}
	.hello .credit {
	text-align: left;
	}
}
@media (min-width:800px){
	.hello {
	padding: 30px 27px 55px;
	}
	.hello .movie,
	.hello .detail {
	width: 335px;
	}
	.hello .imgbox li {
	width: 165px;
	}
	.hello .imgbox li:nth-child(3),
	.hello .imgbox li:nth-child(4) {
	margin-top: 5px;
	}
}

.outro {
width: 94.4vw;
margin-top: 75px;
}
.outro figure {
margin-bottom: 20px;
}
.outro_credit {
letter-spacing: 0;
}
.attention {
margin-top: 75px;
}
@media (min-width:768px){
	.outro {
	width: 475px;
	}
	.outro figure {
	margin-bottom: 35px;
	}
}

.banner {
width: 100%;
margin-top: 90px;
}
.banner_box {
padding: 0 7px;
}
.slick-dotted.slick-slider {
padding-bottom: 27px;
margin-bottom: 0;
}
.slick-dots {
width: 150px;
bottom: 0;
left: calc(50% - 75px);
z-index: 2;
}
.slick-dots li {
width: auto;
height: auto;
}
.slick-dots li button {
width: 8px;
height: 8px;
padding: 0;
border-radius: 50%;
background: #fff;
}
.slick-dots li.slick-active button {
background: #9ebbc6;
}
.slick-dots li button:before {
content: none;
}
.slide-arrow {
position: absolute;
bottom: -3px;
width: 8px;
margin: 0;
z-index: 3;
cursor: pointer;
}
.prev-arrow {
left: calc(50% - 90px);
}
.next-arrow {
right: calc(50% - 90px);
}
@media (min-width:760px){
	.banner {
	width: 100%;
	}
	.slick-dotted.slick-slider {
	padding-bottom: 40px;
	}
}
@media (min-width:1000px){
	.banner {
	width: 1000px;
	}
	.banner_box {
	padding: 0 10px;
	}
}


.footer {
margin-top: 100px;
padding-bottom: 35px;
background: #fff;
}
.footer * {
color: #5a5a5a !important;
letter-spacing: 0;
}
.help {
background: #f6f6f6;
padding: 40px 0 45px;
}
.help h4 {
font-size: 22px;
}
.help h4 span {
display: block;
margin-top: 10px;
}
.help ul {
justify-content: center;
width: 285px;
margin-top: 30px;
}
.help li {
width: 50%;
font-size: 17px;
text-align: center;
}
.help li:nth-of-type(n + 3) {
margin-top: 25px;
}
.sns {
margin-top: 10px;
padding: 40px 0;
background: #f6f6f6;
}
.sns h4 {
font-size: 18px;
}
.sns ul {
width: 170px;
margin-top: 25px;
}
.sns li {
width: 30px;
}
.onlinestore {
margin-top: 10px;
padding: 35px 0 50px;
background: #f6f6f6;
}
.onlinestore * {
letter-spacing: 0.05em;
}
.onlinestore h4 {
font-size: 18px;
}
.onlinestore ul {
margin-top: 30px;
}
.onlinestore li {
margin-top: 15px;
text-align: center;
font-size: 14px;
}
.onlinestore li:first-child {
margin-top: 0;
}
.onlinestore li a {
letter-spacing: 0 !important;
}
.footerlink {
justify-content: center;
padding-top: 15px;
}
.footerlink li {
margin-bottom: 10px;
padding: 0 12px;
font-size: 10px;
border-right: 1px solid #333;;
}
.footerlink li a {
letter-spacing: 0;
}
.footer_logo {
width: 160px;
margin-top: 40px;
}
.copy {
margin-top: 20px;
}
@media (min-width:1200px){
	.footer {
	width: 100%;
	padding-bottom: 70px;
	border-top: 1px solid #c9c9c9;
	}
	.lifeandbeauty {
	width: 735px;
	padding: 25px 0;
	}
	.footer * {
	color: #5a5a5a !important;
	letter-spacing: 0;
	}
	.footer_sec01 {
	background: #ececec;
	}
	.footer_sec01 .inner {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	width: 1200px;
	padding: 30px 0;
	}
	.help {
	width: 50%;
	padding: 60px 0 60px 80px;
	background: none;
	border-left: 1px solid #ccc;
	}
	.help h4 {
	font-size: 27px;
	text-align: left;
	}
	.help h4 br {
	display: none;
	}
	.help h4 span {
	display: inline;
	margin: 0 0 0 30px;
	font-size: 14px;
	}
	.help ul {
	justify-content: flex-start;
	width: 100%;
	margin: 30px 0 0 0;
	}
	.help li {
	width: auto;
	margin-right: 20px;
	padding-right: 20px;
	text-align: left;
	border-right: 1px solid #000;
	font-size: 16px;
	}
	.help li:nth-of-type(n + 3) {
	margin: 0;
	border-right: none;
	}
	.sns {
	display: flex;
	align-items: center;
	width: 50%;
	margin-top: 0;
	padding: 0 60px 0 80px;
	background: none;
	}
	.sns h4 {
	width: 160px;
	font-size: 15px;
	text-align: left;
	}
	.sns ul {
	width: auto;
	margin: 0;
	}
	.sns li {
	width: 50px;
	margin-right: 22px;
	}
	.onlinestore {
	margin-top: 0;
	padding: 40px 0;
	background: #ececec;
	border-top: 1px solid #ddd;
	}
	.onlinestore .inner {
	display: flex;
	justify-content: center;
	width: 1200px;
	}
	.onlinestore h4 {
	margin-right: 30px;
	font-size: 16px;
	font-weight: 700;
	}
	.onlinestore ul {
	display: flex;
	margin-top: 0;
	}
	.onlinestore li {
	margin: 0 15px 0 0;
	padding-right: 15px;
	text-align: left;
	font-size: 12px;
	border-right: 1px solid #000;
	}
	.onlinestore li:last-child {
	margin: 0;
	padding: 0;
	border-right: none;
	}
	.footerlink {
	padding-top: 50px;
	}
	.footerlink li {
	margin: 0 20px 0 0;
	padding: 0 20px 0 0;
	font-size: 12px;
	border-right: 1px solid #333;;
	}
	.footer_logo {
	width: 220px;
	margin-top: 55px;
	}
	.copy {
	margin-top: 40px;
	font-size: 12px;
	}
}

img[src^="https://jun.click.zetacx.net"],
img[src^="https://zetaclick.junonline.jp"],
img[src^="https://dev.tag.zetacx.net"] {
  position: absolute;
  width: 0;
  height: 0;
}

