:root {
	--black: #231815;
	--logo: #e6160b;
}

/* =============================================
Base Set
============================================= */
html {
	font-size: 62.5%;
}
body {
	font-family:  'Yu Gothic Medium', 'Yu Gothic', '游ゴシック', YuGothic, '游ゴシック体','Noto Sans JP', sans-serif;
	font-feature-settings: "palt" 1;
	font-size: 1.4rem;
	font-weight: normal;
	line-height: 1.5;
}
@media screen and (min-width:500px) {
	body {
		font-size: 2.1rem;
	}
}
body {
	max-width:600px;
	margin: 0 auto;
}
main {
	overflow: hidden;
}

/* ----- Img ----- */
img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
}

/* ----- Link ----- */
a {
	transition: all .3s ease;
}

/* ----- margin ----- */
.mag-t20 {
	margin-top: 20px !important;
}
.mag-t40 {
	margin-top: 40px !important;
}
.mag-t50 {
	margin-top: 50px !important;
}

.mag-b20 {
	margin-bottom: 20px !important;
}
.mag-b30 {
	margin-bottom: 30px !important;
}
.mag-b50 {
	margin-bottom: 50px !important;
}
.mag-b70 {
	margin-bottom: 70px !important;
}
/* -------------------------------------
header
------------------------------------- */
.pg-header {
	position: fixed;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: 99;
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	background-color: #fff;
}

/* -------------------------------------
mv
------------------------------------- */
.mv-cont {
	padding-top: 6rem;
	margin-bottom: 18px;
}
.mv-catch__unit {
	position: relative;
}
.mv-logo {
	width: 34%;
	position: absolute;
	top: 50px;
	left: 0px;
}
.mv-catch {
	width: 100%;
	padding: 16px 0;
	text-align: center;
	background-color: #ae9312;
	position: absolute;
	top: 0;
}
.mv-catch img {
	width: 70%;
	margin: 0 auto;
}
.movie {
	width: 100%;
	aspect-ratio: 1 / 1;
}
.movie iframe {
	width: 100%;
	height: 100%;
	border: none;
}
.movie.movie--wide {
	width: 114%;
	margin: 35px -7% 0;
}
@media screen and (min-width:500px) {
	.mv-cont {
		padding-top: 8rem;
	}
	.movie.movie--wide {
		width: 100%;
		margin: 35px 0 0;
	}
}

.intro-catch {
	font-size: 1.7rem;
	font-weight: bold;
	width: 13em;
	margin: 28px auto 20px;
	text-align: center;
	position: relative;
}
.intro-catch::before,
.intro-catch:after {
	content: "";
	display: block;
	width: 0;
	height: 50px;
	position: absolute;
	bottom: 0;
	border-left: 1px solid #000;
}
.intro-catch::before {
	left: -18px;
	transform: rotate(-28deg);
}
.intro-catch::after {
	right: -18px;
	transform: rotate(28deg);
}
.intro-product {
	font-size: 2.0rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 20px;
}
@media screen and (min-width:500px) {
	.intro-catch {
		font-size: 2.0rem;
	}
	.intro-txt {
		font-size: 1.7rem;
		margin-bottom: 20px;
	}
	.intro-product {
		font-size: 2.4rem;
	}
}

/* -------------------------------------
Common
------------------------------------- */
.section-ttl {
	position: relative;
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	z-index: 1;
}
.center-txt {
	text-align: center;
}
.box-txt {
	padding: 0 6% 24px;
	letter-spacing: 0.05rem;
}
.va-super {
	vertical-align: text-top;
	font-size: 1.0rem;
}
.note {
	font-size: 1.0rem;
	margin-top: 18px;
}
.note--left-mrg {
	margin-left: 6%;
}
.note-indent {
	text-indent: -1.8em;
	margin-left: 1.8em;
	display: inline-block;
}
.box-txt.note {
	padding-top: 20px;
	margin: 24px auto 0;
	position: relative;
}
.box-txt.note::before {
	content: "";
	display: block;
	width: 40%;
	height: 0;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	border-top: 1px dashed var(--black);
}
.note-padding {
	padding: 0 6%;
}
@media screen and (min-width:500px) {
	.note{
		font-size: 1.5rem;
	}
}


/* ---Animate.css--- */
.invisible {
	visibility: hidden;
}
.kirari-anime {
	overflow: hidden;
	position: relative;
}
.kirari-anime:before {
  position: absolute;
  content: '';
  display: inline-block;
  top: 0px;
  left: -100px;
  width: 100%;
  height: 100%;
	background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 1) 55%,
    rgba(255, 255, 255, 0) 100%
  );
	transform: skewX(60deg);
	animation: kiran 3.5s ease-in-out infinite;
}
@keyframes kiran {
	0%   { left: -50%; opacity: 0; }
  10%  { left: -50%; opacity: 0; }
  40%  { left: 120%; opacity: 1; }
  100% { left: 120%; opacity: 0; }
}


/* slick スクロール時にautoplayとめない */
.mv-img,
.story-img,
.feature-visual {
	pointer-events: none;
}


/* ---btn--- */
.btn {
	display: block;
	width: 255px;
	margin: 0 auto 20px;
	position: relative;
	z-index: 1;
}
.btn + .btn {
	margin-top: 20px;
}
.btn::before {
	content: "";
	display: block;
	width: 79px;
	height: 50px;
	position: absolute;
	top: 0;
	left: 0;
	background-image:url(../img/btn_search.png);
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 1;
}
.btn-buy.btn::before {
	background-image:url(../img/btn_buy.png);
}
.btn-free.btn::before {
	background-image:url(../img/btn_free.png);
	width: 90px;
}
.btn__round {
	display: block;
	border-radius: 10px;
	background-color: #fff;
	border: 1px solid var(--black);
	padding: 4px 0 4px 35%;
	font-size: 1.6rem;
	line-height: 1.25;
	font-weight: bold;
	position: relative;
}
.btn-free .btn__round {
	padding-left: 40%;
}
@media screen and (min-width:500px) {
	.btn {
		width: 320px;
		margin: 0 auto 20px;
	}
	.btn + .btn {
		margin-top: 24px;
	}
	.btn::before {
		width: 91px;
		height: 58px;
	}
	.btn-free.btn::before {
		width: 105px;
	}
	.btn__round {
		padding: 8px 0 8px 35%;
	}
}


/* -------------------------------------
about-bitte
------------------------------------- */
.about-bitte {
	padding-top: 35px;
	position: relative;
}
.about-bitte .section-ttl {
	position: absolute;
  top: 75px;
  left: 50%;
	transform: translateX(-50%);
}
.about-cont {
	position: relative;
}
.about-cont .box-txt {
	background-color: #8AC5DD;
	background: linear-gradient(to bottom, #8AC5DD calc(100% - 50px), #D3E3EB 100%);
	padding: 64px 9%;
}
/* story-cont */
.story-ttl {
	width: 85%;
	min-width: 168px;
	position: absolute;
	top: -60px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}
.story-txt.box-txt {
	margin: 0px auto;
	line-height: 2;
}
@media screen and (min-width:500px) {
	.story-ttl {
		top: -95px;
	}
	.about-cont .box-txt {
		padding: 90px 9% 64px;
	}
}


/* -------------------------------------
feature-bitte
------------------------------------- */
/* common */
.features {
	background-color: #D3E3EB;
}
.feature-sec {
	padding: 50px 0 0px;
	position: relative;
}
#for-baby.feature-sec {
	margin-top: -1px;
	margin-bottom: 60px;
}
#for-us.feature-sec {
	background-color: #B4CEDD;
}
#for-all.feature-sec {
	background-color: #E1E5E7;
}
.feature-ttl {
  width: 50%;
	margin: 0 auto 15px;
}
.feature-sec.is-show::before {
  content: '';
  display: block;
  width: 1px;
  height: 50px;
  position: absolute;
	top: 0;
	left: 50%;
	background: #000;
	opacity: 0;
	animation: scrollbar .9s ease-in-out .2s forwards;
}
@keyframes scrollbar {
  0% {
		opacity: 0;
		height: 0;
  }
  100% {
		opacity: 1;
		height: 50px;
  }
}
.feature-question,
.feature-answer {
	text-align: center;
	margin: 0 10% 30px;
}
.feature-question {
	padding: 15px;
	font-size: 1.6rem;
  font-weight: bold;
	line-height: 1.75;
	border-top: solid 1px #000;
	border-bottom: solid 1px #000;
	position: relative;
}
.feature-question::before,
.feature-question::after {
  content: '';
  display: block;
  width: 1px;
  height: 33%;
  position: absolute;
	background: #000;
}
.feature-question::before {
	bottom: 0px;
  left: 0px;
}
.feature-question::after {
	top: 0px;
  right: 0px;
}
.feature-answer {
	font-size: 2rem;
	font-size: 2.8rem;
  font-weight: bold;
	background-color: #FFF000;
	padding: 8px 0px;
	position: relative;
  letter-spacing: 0.2rem;
}
.feature-answer .answer__small {
	font-size: 2.3rem;
}
.feature-answer::before {
  content: '';
  display: block;
  width: 1px;
  height: 30px;
  position: absolute;
	top: -30px;
	left: 50%;
	background: #000;
	opacity: 0;
}
.feature-answer.is-show::before {
	animation: scrollbar2 1s ease-in-out 1.3s forwards;
}
.feature-answer::after {
  content: '';
  display: block;
  width: 1px;
  height: 30px;
  position: absolute;
	top: 59px;
	left: 50%;
	background: #000;
	opacity: 0;
}
.feature-answer.is-show::after {
	animation: scrollbar2 1s ease-in-out 1.9s forwards;
}
@keyframes scrollbar2 {
  0% {
		opacity: 0;
		height: 0;
  }
  100% {
		opacity: 1;
		height: 30px;
  }
}
#for-all .feature-cont {
	position: relative;
}
#for-all .feature-cont::after {
  content: '';
  display: block;
  width: 126px;
  height: 190px;
  position: absolute;
  bottom: 0px;
  right: 15px;
	background-image: url(../img/all_img_visual03.webp);
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 2;
}
#for-all .feature-visual {
	margin-bottom: 30px;
}
#for-all .feature-visual.visual--irregular {
	margin-bottom: -50px;
}
.feature-box__catch {
	font-size: 2rem;
	font-weight: bold;
	letter-spacing: 0.1rem;
	border-bottom: solid 1px #000;
	margin: 0 6% 16px;
	padding-left: 40px;
	position: relative;
}
.feature-box__catch::before {
  content: '';
  display: block;
  position: absolute;
  top: 0px;
  left: 0px;
	background-size: contain;
	background-repeat: no-repeat;
	margin-top: 3px;
	z-index: 5;
}
.accordion-item--01 .feature-box__catch::before {
	width: 12px;
  height: 21px;
	background-image: url(../img/catch_number_01.webp);
}
.accordion-item--03 .feature-box__catch::before {
	width: 27px;
  height: 20px;
	background-image: url(../img/catch_number_02.webp);
}
.accordion-item--04 .feature-box__catch::before {
	width: 19px;
  height: 25px;
	background-image: url(../img/catch_number_03.webp);
}
.accordion-item--05 .feature-box__catch::before {
	width: 23px;
  height: 27px;
	background-image: url(../img/catch_number_04.webp);
}
.feature-box {
	background: #fff;
	margin: 0px 6% 10px;
	padding: 28px 5.333%;
	border-radius: 7.5px;
}
#for-all .feature-box {
	position: relative;
  z-index: 1;
}
#for-baby .feature-box.white-box--01 {
	position: relative;
}
.feature-box__figure--01 {
	width: 60%;
	position: absolute;
	top: 150px;
	left: 0px;
}
.feature-box__figure--02 {
	margin-top: 55px;
}
.feature-box__figure--03 {
	margin-top: 28px;
}
.feature-box__figure--04 {
	margin-top: 33px;
}
.feature-box__inner {
	position: relative;
}
.accordion-item--02 .feature-box__figure,
.accordion-item--05 .feature-box__figure {
	width: 64%;
	margin: 0 auto;
}
.feature-catch--gold {
	color: #fff;
	font-size: 2rem;
	width: 60%;
	height: 100px;
  font-weight: bold;
	text-align: center;
	background-color: #ae9312;
	border-radius: 50%;
	margin: 0 auto -68px;
	padding-top: 12px;
  letter-spacing: 0.1rem;
	position: relative;
}
.feature-catch__wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-bottom: 20px;
}
.feature-catch {
	display: inline-block;
	font-weight: bold;
	font-size: 1.8rem;
	margin-right: 12px;
}
.feature-catch span {
	border: solid 1px #000;
	padding: 5px 12px;
	border-radius: 5px;
}
.catch--new {
	width: 100px;
}
.feature-box__ttl {
	text-align: center;
	font-size: 1.8rem;
	background-color: var(--black);
	color: #fff;
	font-weight: bold;
	margin-bottom: 20px;
	padding: 4px 0;
}
.feature-box__ttl.ttl--left {
	text-align: left;
	padding-left: 20px;
	position: relative;
}
.feature-box__ttl .box-ttl--sub {
	font-size: 1.4rem;
	margin-left: 16px;
	padding: 2px 6px;
	color: #000;
	background: #fff;
	border-radius: 1.5px;
	position: absolute;
	top: 50%;
  transform: translateY(-50%);
	right: 5px;
}
.feature-box__figure + .feature-box__figure {
	margin-top: 10px;
}
.feature-box__txt + .feature-box__figure,
.feature-box__figure + .feature-box__txt,
.feature-figure + .feature-box {
	margin-top: 14px;
}
.feature-list__item + .feature-list__item {
	margin-top: 30px;
}
.feature-movie {
	position: relative;
	width:100%;
	padding-top: 56.25%;
	cursor: pointer;
	cursor: hand;
	margin-top: 20px;
}
.feature-movie iframe {
	width:100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
#for-all .movie {
	width: calc(100% + 30%);
  margin: 0 -15% 25px;
	height: 100%;
}
.feature-point__wrap.us__white-box--02 {
	display: flex;
	justify-content: space-between;
	margin-top: 12px;
	gap: 10px;
}
.feature-point__box.us__white-box--02 {
	display: flex;
	align-items: center;
	gap: 5px;
}
.feature-point__img.us__white-box--06 {
	margin-top: 16px;
}
.feature-point__img.us__white-box--07 {
	width: 48%;
	margin: 16px auto 0;
}
.feature-point__txt {
	font-size: 1.2rem;
}

@media screen and (max-width: 370px) {
	#for-us .feature-question,
	#for-us .feature-answer {
		margin: 0 11px 30px;
	}
	.feature-box__ttl.ttl--left {
		font-size: 1.5rem;
		padding-left: 10px;
	}
}
@media screen and (min-width:500px) {
	.feature-question {
		font-size: 2.4rem;
	}
	.feature-box__ttl.ttl--left {
		padding-left: 10px;
	}
	.feature-box__catch {
		font-size: 3rem;
		padding-left: 60px;
	}
	.feature-box__catch::before {
		margin-top: 5px;
	}
	.feature-catch--gold {
		font-size: 3rem;
		width: 65%;
		height: 190px;
		margin: 0 auto -140px;
		padding-top: 25px;
	}
	.accordion-item--01 .feature-box__catch::before {
		width: 16px;
		height: 27px;
	}
	.accordion-item--03 .feature-box__catch::before {
		width: 35px;
		height: 26px;
	}
	.accordion-item--04 .feature-box__catch::before {
		width: 28px;
		height: 32px;
	}
	.accordion-item--05 .feature-box__catch::before {
		width: 30px;
		height: 35px;
	}
	.feature-box__ttl {
		font-size: 2.7rem;
	}
	.feature-box__ttl .box-ttl--sub {
		font-size: 2.1rem;
	}
	.feature-point__txt {
		font-size: 1.5rem;
	}
	.feature-box__figure--01 {
		top: 170px;
	}
	#for-all .feature-cont::after {
		width: 189px;
		height: 285px;
	}
}
@media screen and (min-width:600px) {
	.feature-box__ttl.ttl--left {
		padding-left: 50px;
	}
}


/* ---accordion-SET--- */
.feature-point__secondary-catch {
	text-align: center;
	position: relative;
	margin: 0 auto;
	width: 100%;
}
.feature-point__secondary-catch.catch-14 {
	max-width: 16em;
}
.feature-point__secondary-catch::before,
.feature-point__secondary-catch:after {
	content: "";
	display: block;
	width: 0;
	height: 20px;
	position: absolute;
	bottom: 0;
	border-left: 1px solid #000;
}
.feature-point__secondary-catch::before {
	left: 5px;
	transform: rotate(-35deg);
}
.feature-point__secondary-catch::after {
	right: 5px;
	transform: rotate(35deg);
}
.accordion-item--02 .feature-box__ttl.ttl--left {
	padding-left: 34px;
}
.accordion-item--02 .feature-point__secondary-catch::before {
	left: -5px;
}
.accordion-item--02 .feature-point__secondary-catch::after {
	right: -5px;
}

@media screen and (max-width:320px) {
	.feature-point__secondary-catch {
		font-size: 1.2rem;
	}
}
@media screen and (min-width:500px) {
	.feature-point__secondary-catch {
		font-size: 1.8rem;
	}
	.accordion-item--02 .feature-box__ttl.ttl--left {
		padding-left: 60px;
	}
}


/* アコーディオン */
.accordion-label {
	cursor: pointer;
}
.accordion-body {
	height: 0;
	opacity: 0;
	transition: .5s;
	visibility: hidden;
}
.accordion-check {
	opacity: 0;
	display: none;
}
.accordion-btn {
	display: block;
	width: 68%;
	max-width: 320px;
	margin: 0 auto;
}
.accordion-btn--catch {
	font-weight: bold;
	margin-bottom: 10px;
}
.accordion-check:checked + .accordion-label + .accordion-body {
	height: 100%;
	opacity: 1;
	visibility: visible;
	overflow: visible;
	background: #D3E3EB;
	padding: 30px 0 24px;
	border-radius: 10px 0 10px 10px;
}
.accordion-btn span {
	transition: .5s ease-in;
}
.accordion-btn .is-open {
	display: block;
	line-height: 40px;
	text-align: center;
	width: 100%;
	height: 50px;
	background: #fff;
	border: 1px solid var(--black);
	border-radius: 10px;
	padding: 0 20px;
	box-sizing: border-box;
}
.accordion-btn .is-open img {
	margin-top: 15px;
}
.accordion-btn .is-close {
	opacity: 0;
	visibility: hidden;
	display: none;
	line-height: 40px;
	text-align: center;
	width: 100%;
	height: 40px;
	border-radius: 10px 10px 0 0;
	padding: 0 20px;
	box-sizing: border-box;
	font-weight: bold;
	color: #fff;
}
.accordion-btn .is-close span {
	color: #fff;
}
.accordion-btn .is-close {
	background-color: #8ac5dd;
}
.accordion-check:checked + .accordion-label .is-close {
	opacity: 1;
	visibility: visible;
	display: block;
}
.accordion-check:checked + .accordion-label .is-open {
	opacity: 0;
	visibility: hidden;
	display: none;
}
.accordion-body .feature-box__ttl {
	margin-top: 10px;
}
.accordion-body .feature-box .note {
	margin-top: 6px;
}
@media screen and (max-width:320px) {
	.accordion-btn .is-open,
	.accordion-btn .is-close {
		font-size: 1.2rem;
	}
}


/* -------------------------------------
share-area
------------------------------------- */
.share-area {
	background: var(--logo);
	padding-bottom: 24px;
}
.share-area .center-txt {
	color: #fff;
	font-size: 1.5rem;
	font-weight: bold;
	padding: 10px 10px 20px;
}
@media screen and (max-width:320px) {
	.share-area .center-txt{
		font-size: 1.4rem;
	}
}
@media screen and (min-width:500px) {
	.share-area {
		padding-bottom: 40px;
	}
	.share-area .center-txt {
		font-size: 2.0rem;
		line-height: 1.75;
		padding-bottom: 30px;
	}
}


/* -------------------------------------
Product-wrap
------------------------------------- */
#bitte-lineup {
	padding-top: 120px;
	padding-bottom: 20px;
	position: relative;
}
#bitte-lineup .section-ttl {
	position: absolute;
  top: 45px;
  left: 50%;
	transform: translateX(-50%);
}
#product-wrap {
	padding-bottom: 24px;
}

.thumbnail-list {
	display: flex;
	justify-content: center;
	padding: 24px 8% 24px;
	gap: 18px;
}
.thumbnail-item {
	width: calc(100%/3);
	position: relative;
	cursor: pointer;
	cursor: hand;
}
.thumbnail-item:after {
	content: "";
	background-color: rgba(255, 255, 255, 0.50);
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 1;
	transition: 0.3s opacity linear;
}
.thumbnail-item.thumbnail-current:after {
	opacity: 0;
}
.product-info {
	padding: 10px 6% 20px;
}
.product-strong {
	display: block;
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 4px;
}
.product-strong:first-of-type {
	border-bottom: 1px solid var(--black);
	padding-bottom: 4px;
}
.product-info .annotation {
	padding-top: 6px;
}
.pad-left {
	display: block;
	padding-left: 52px;
}
@media screen and (min-width:500px) {
.product-strong {
		font-size: 2.7rem;
	}
}
@media screen and (min-width:600px) {
	#product-wrap{
		padding-bottom: 40px;
	}
	.pad-left{
		display: block;
		padding-left: 60px;
	}
}


/* -------------------------------------
Fixed-menu
------------------------------------- */
#sp-fixed-menu {
	display: none;
	position: fixed;
	max-width: 600px;
	width: 100%;
	bottom: 0;
	z-index: 99;
	background-color: #fff;
}
.footer-btn-area {
	display: flex;
	border-top: 4px solid #fff ;
}
.footer-btn-items:not(:last-of-type) {
	width: calc(84% / 3);
}
.footer-btn-items:last-of-type {
	width: 16%;
}


/* -------------------------------------
Footer
------------------------------------- */
@media screen and (min-width:600px) {
	.footer-wrap {
		padding-bottom: 70px;
	}
}
@media screen and (max-width: 767px) {
	.footer-wrap {
		padding-bottom: 70px;
	}
	.footer-wrap iframe {
		min-height: 330px;
	}
}
@media screen and (max-width: 340px) {
	.footer-wrap iframe {
		min-height: 380px;
	}
}