@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400..700&amp;display=swap');
body {
		background: #F2F2F2;
}
.moomin_container {
		overflow: hidden;
}
.moomin_header_logo {
		position: fixed;
		top: 40px;
		left: 40px;
		width: 250px;
		z-index: 10;
}
.moomin_header_logo img {
		width: 100%;
		height: auto;
}
.moomin_header_btn {
		position: fixed;
		top: 20px;
		right: 40px;
		width: 300px;
		height: 80px;
		z-index: 10
}
.moomin_header_btn a {
		display: flex;
		align-items: center;
		width: 300px;
		height: 80px;
		text-decoration: none;
		transition: opacity 0.3s;
}
.moomin_header_btn a::before {
		content: '';
		display: block;
		position: absolute;
		top: 17px;
		left: 0;
		width: 300px;
		height: 53px;
		background: #e48a89;
		border-radius: 60px;
		transform-origin: left center;
		box-sizing: border-box;
}
.moomin_header_btn a::after {
		content: '';
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 80px;
		height: 80px;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: cover;
		background-image: url("https://www.kai-group.com/contents_file/products/brand/select100/special/moomin/images/header_btn_pc.png")
}
@media (hover: hover) {
		.moomin_header_btn a:hover {
				opacity: 0.7;
		}
}
.moomin_header_btn span {
		display: block;
		color: #fff;
		position: absolute;
		left: 65px;
		top: 31px;
		font-size: 16px;
}
/* ============= */
.kv_inner {
		padding-top: 200px;
		max-width: 1100px;
		margin: 0 auto 100px;
		padding-left: 40px;
		padding-right: 40px;
}
.kv_logo {
		max-width: 920px;
		margin: 0 auto 45px;
}
.kv_inner img {
		width: 100%;
		height: auto;
}
.kv_lead {
		text-align: center;
		font-size: 20px;
		letter-spacing: 0.05em;
		line-height: 2.2;
		margin: 0 0 60px;
}
.kv_figure {
		max-width: 1100px;
		margin: 0 auto;
		position: relative;
}
.kv-1 {
		width: 100%;
}
.kv_figure div:not(.kv-1) {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
}
.kv_figure img {
		width: 100%;
		height: auto;
}
@media(max-width: 840px) {
		.kv_inner {
				padding-top: 170px;
		}
		.kv_logo {
				max-width: 700px;
				margin: 0 auto 30px;
		}
		.kv_lead {
				font-size: 18px;
				margin: 0 0 40px;
		}
		.moomin_header_logo {
				position: fixed;
				top: 40px;
				left: 40px;
				width: 260px;
				z-index: 10;
		}
		.moomin_header_btn {
				top: 10px;
				right: 30px;
				width: 260px;
				height: 64px;
		}
		.moomin_header_btn a {
				width: 250px;
				height: 64px;
		}
		.moomin_header_btn a::before {
				top: 14px;
				width: 260px;
				height: 44px;
		}
		.moomin_header_btn a::after {
				width: 64px;
				height: 64px;
		}
		.moomin_header_btn span {
				left: 54px;
				top: 26px;
				font-size: 14px;
		}
}
@media(min-width: 768px) {
		.moomin_header_btn br {
				display: none
		}
}
@media(max-width: 767px) {
		.moomin_header_logo {
				top: 20px;
				left: 20px;
				width: 130px;
		}
		.moomin_header_btn {
				top: 0;
				right: 0;
				width: 200px;
				height: 50px;
		}
		.moomin_header_btn a {
				width: 200px;
				height: 50px;
				background: #e48a89;
				border-radius: 0 0 0 20px;
		}
		.moomin_header_btn a::before {
				display: none;
		}
		.moomin_header_btn a::after {
				width: 60px;
				height: 60px;
				background-size: 60px;
				left: -3px;
				top: -1px;
		}
		.moomin_header_btn span {
				left: inherit;
				top: inherit;
				position: static;
				display: inline-block;
				font-size: 14px;
				padding-left: 50px;
		}
		.kv_inner {
				padding-top: 120px;
				margin: 0 auto 80px;
				padding-left: 0;
				padding-right: 0;
		}
		.kv_logo {
				width: 75vw;
				max-width: 400px;
				margin-bottom: 30px;
		}
		.kv_lead {
				font-size: 14px;
				margin: 0 0 40px;
		}
		.kv_figure {
				padding: 0;
				margin: 0 20px;
				width: auto;
				box-sizing: border-box;
		}
		.kv-7, .kv-8 {
				display: none
		}
}
/* ============= */
.slider_section {
		overflow: hidden
}
.gallerySlider.upper {
		margin-bottom: 16px;
}
.tile {
		width: 300px;
		overflow: hidden;
		border-radius: 6px;
		position: relative;
		margin-right: 16px;
		margin-bottom: 16px;
}
@media(max-width: 1920px) {
		.tile {
				width: 200px;
		}
}
@media(max-width: 767px) {
		.tile {
				width: 110px;
				border-radius: 4px;
				margin-right: 8px;
				margin-bottom: 8px;
		}
}
.tile img {
		width: 100%;
		height: auto;
		transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), filter 0.4s;
}
.tile .thumb_cover {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
		pointer-events: none;
		opacity: 0;
		transition: opacity 0.4s;
		box-sizing: border-box;
		padding: 15px;
}
.thumb_cover p {
		text-align: center;
		line-height: 1.4;
		color: #fff;
		font-size: 16px;
}
@media (hover: hover) {
		.tile a:hover img {
				transform: scale(1.1);
				filter: brightness(70%);
		}
		.tile a:hover .thumb_cover {
				opacity: 1
		}
}
@media(max-width: 767px) {
		.thumb_cover p {
				font-size: 10px;
		}
}
/* ============ */
.introduction_section {
		padding: 70px 20px 50px;
		position: relative;
		z-index: 5;
}
.introduction_inner {
		position: relative;
}
.introduction_figure {
		max-width: 600px;
		margin: 0 auto;
		position: relative;
}
.introduction_figure div {
		position: absolute;
}
.introduction_figure .introduction_figure_bg-1 {
		width: 105px;
		left: -230px;
		bottom: 0
}
.introduction_figure .introduction_figure_bg-2 {
		width: 65px;
		right: -170px;
		top: 38px;
}
.introduction_figure .introduction_figure_bg-3 {
		width: 45px;
		right: -230px;
		top: 138px
}
.introduction_figure img {
		width: 100%;
		height: auto;
}
.introduction_hr {
		position: relative;
		height: 300px;
}
.introduction_hr::before {
		pointer-events: none;
		content: '';
		display: block;
		position: absolute;
		top: -180px;
		left: 0;
		width: 100%;
		background-repeat: no-repeat;
		background-position: center bottom;
		background-size: 2600px;
		background-image: url("https://www.kai-group.com/contents_file/products/brand/select100/special/moomin/images/kv_separate_pc.png");
		height: 350px;
}
@media(max-width: 1440px) {
		.introduction_hr {
				position: relative;
				height: 250px;
		}
		.introduction_hr::before {
				top: -110px;
				background-size: 1440px;
				height: 250px;
		}
}
@media(max-width: 1300px) {
		.introduction_figure .introduction_figure_bg-1 {
				left: -170px;
		}
		.introduction_figure .introduction_figure_bg-2 {
				right: -110px;
		}
		.introduction_figure .introduction_figure_bg-3 {
				right: -170px;
		}
}
@media(max-width: 1100px) {
		.introduction_figure {
				max-width: 540px;
		}
		.introduction_figure .introduction_figure_bg-1 {
				left: -160px;
		}
		.introduction_figure .introduction_figure_bg-2 {
				right: -90px;
		}
		.introduction_figure .introduction_figure_bg-3 {
				right: -150px;
		}
}
@media(max-width: 960px) {
		.introduction_figure .introduction_figure_bg-1 {
				width: 80px;
				left: -110px;
		}
		.introduction_figure .introduction_figure_bg-2 {
				width: 50px;
				right: -70px;
				top: 38px;
		}
		.introduction_figure .introduction_figure_bg-3 {
				width: 32px;
				right: -90px;
				top: 138px
		}
}
@media(min-width: 768px) {
		.introduction_figure_bg-4 {
				display: none
		}
		.sp_introduction_figure {
				display: none
		}
}
@media(max-width: 767px) {
		.introduction_section {
				padding: 0px 20px 90px;
		}
		.introduction_hr {
				height: 12vw;
				position: static;
				margin-bottom: 70px;
		}
		.introduction_hr::before {
				position: static;
				top: inherit;
				left: inherit;
				background-size: 100%;
				height: 12vw;
		}
		.introduction_figure .introduction_figure_bg-1, .introduction_figure .introduction_figure_bg-2, .introduction_figure .introduction_figure_bg-3 {
				display: none
		}
		.sp_introduction_figure {
				position: relative;
				margin-top: 20px;
		}
		.sp_introduction_figure img {
				width: 100%;
				height: auto;
		}
		.sp_introduction_figure div:not(.introduction_figure_bg-1) {
				position: absolute;
				top: 0;
				left: 0;
				width: 100%;
		}
		.introduction_figure_bg-4 {
				position: relative;
				top: 28px;
				z-index: 10
		}
		.introduction_figure_bg-4 img {
				width: 100%;
				height: auto;
		}
}
/* ============ */
.product_section {
		background: #F9E8E8;
}
.product_section.upper {
		padding-bottom: 25px;
}
.product_section.bottom {
		background: #D8ECEE;
		padding: 150px 0 0;
}
.product_section_hr {
		height: 1px;
		position: relative;
		background: #D8ECEE;
		pointer-events: none;
}
.product_section_hr::after {
		content: '';
		display: block;
		position: absolute;
		top: -86px;
		left: 0;
		width: 100%;
		height: 150px;
		background-repeat: repeat-x;
		background-position: center center;
		background-size: 1400px;
		background-image: url("https://www.kai-group.com/contents_file/products/brand/select100/special/moomin/images/separate_hr_pc.png");
		pointer-events: none;
}
@media(max-width: 767px) {
		.product_section.upper {
				padding-bottom: 100px;
		}
		.product_section.bottom {
				padding-top: 100px;
				padding-bottom: 0;
		}
		.product_section_hr::after {
				top: -26px;
				width: 100%;
				height: 50px;
				background-size: 365px;
				background-image: url("https://www.kai-group.com/contents_file/products/brand/select100/special/moomin/images/separate_hr_sp.png");
		}
}
.product_hd_wrap {
		display: flex;
		align-items: center;
		justify-content: center;
		margin: 0 0 80px;
}
.product_hd_col {
		position: relative;
}
.product_hd_col::after {
		content: '';
		display: block;
		position: absolute;
		top: calc(50% - 55px);
		right: -180px;
		width: 145px;
		height: 110px;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 100%;
		background-image: url("https://www.kai-group.com/contents_file/products/brand/select100/special/moomin/images/title_bg_pc.png")
}
.product_hd {
		text-align: center;
		font-family: 'Helvetica LT W01 Roman';
		font-size: 40px;
		font-weight: 500;
		line-height: 1;
		color: #E48A89;
}
.section-1_bg {
		max-width: 1100px;
		margin: -60px auto 60px;
		padding: 0 40px;
		display: flex;
		justify-content: flex-end;
}
.section-1_bg_item {
		width: 90px;
		margin-right: 80px;
}
.section-2_bg {
		max-width: 1100px;
		margin: -60px auto 60px;
		padding: 0 40px;
		display: flex;
		justify-content: flex-start;
}
.section-2_bg_item {
		width: 260px;
		margin-left: 50px;
}
.section-3_bg {
		max-width: 1100px;
		margin: -70px auto 60px;
		padding: 0 40px;
		display: flex;
		justify-content: flex-start;
}
.section-3_bg_item {
		width: 225px;
		margin-left: 60px;
}
.section-1_bg_item img, .section-2_bg_item img, .section-3_bg_item img, .section-4_bg img {
		width: 100%;
		height: auto;
}
.section-4_bg {
		max-width: 1100px;
		margin: -50px auto 60px;
		padding: 0 40px;
		display: flex;
		justify-content: space-between;
}
.section-4_bg_item-1 {
		width: 173px;
		position: relative;
		margin-left: 60px;
}
.section-4_bg_item-1 div:not(.upper) {
		position: absolute;
}
.section-4_bg_item-2 {
		width: 325px;
}
.section-5_bg {
		width: 350px;
		position: relative;
		margin: 0 auto
}
.section-5_bg img {
		width: 100%;
		height: auto;
}
.section-5_bg .section-5_bg-2 {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
}
@media(max-width: 960px) {
		.section-1_bg_item {
				width: 70px;
		}
		.section-2_bg_item {
				width: 210px;
		}
		.section-3_bg_item {
				width: 180px;
		}
		.section-4_bg_item-1 {
				width: 140px;
		}
		.section-4_bg_item-2 {
				width: 260px;
		}
		.section-5_bg {
				width: 280px;
		}
}
@media(max-width: 767px) {
		.product_hd_wrap {
				margin: 0 0 45px;
		}
		.product_hd_col::after {
				top: calc(50% - 30px);
				right: -90px;
				width: 80px;
				height: 60px;
		}
		.product_hd {
				text-align: center;
				font-family: 'Helvetica LT W01 Roman';
				font-size: 40px;
				font-weight: 500;
				line-height: 1;
				color: #E48A89;
		}
		.section-1_bg {
				margin: -40px auto 40px;
				padding: 0 20px;
				display: block;
		}
		.section-1_bg_item {
				width: auto;
				margin-right: 10px;
		}
		.section-2_bg {
				margin: -40px auto 40px;
				padding: 0 20px;
		}
		.section-2_bg_item {
				width: auto;
				margin-left: 10px;
		}
		.section-3_bg {
				margin: -40px auto 30px;
				padding: 0 20px;
		}
		.section-3_bg_item {
				width: auto;
				margin-left: 0;
		}
		.section-4_bg {
				margin: -40px auto 40px;
				padding: 0 20px;
				display: block;
		}
		.section-4_bg_item-1 {
				width: 100%;
				left: inherit;
				position: static;
				margin-left: 0;
				transform: translateX(40px);
		}
		.section-4_bg_item-2 {
				width: 100%;
				position: static;
				padding-top: 30vw;
				transform: translateX(-20px);
		}
		.section-5_bg {
				width: 46vw;
				margin-top: 20vw;
				margin-right: 0;
				margin-left: 20vw;
		}
}
/* ============ */
.footer_bg {
		padding: 60px 40px 0;
}
.footer_bg_figure {
		max-width: 900px;
		margin: 0 auto;
		position: relative;
		top: 120px;
}
.footer_bg_figure img {
		width: 100%;
		height: auto;
}
@media(max-width: 767px) {
		.footer_bg {
				padding: 40px 5px 0 20px;
		}
		.footer_bg_figure {
				top: 13vw;
		}
}
.product_grid_item.item18, .product_grid_item.end {
		margin: 0;
}
.product_grid_item.extra {
		display: flex;
		align-items: flex-end;
}
.product_end_bg {
		position: relative;
		left: 75px;
		margin-bottom: 60px;
		width: 445px;
}
.product_end_bg img {
		width: 100%;
		height: auto;
}
.product_end_bg div:not(.base) {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
}
@media(max-width: 1200px) {
		.product_end_bg {
				left: 0;
		}
}
@media(max-width: 960px) {
		.product_end_bg {
				width: calc(100% + 60px);
				left: inherit;
				right: -20px
		}
}
@media(max-width: 767px) {
		.product_grid_item.extra {
				margin-bottom: 0;
		}
		.product_end_bg {
				width: 100%;
				left: inherit;
				right: inherit;
				margin-bottom: 0;
		}
}
/* ============ */
.footer_dark {
		background: #333;
		color: #fff;
		padding: 200px 20px 50px;
		box-sizing: border-box;
}
.footer_logo {
		width: 259px;
		margin: 0 auto 90px;
}
.footer_logo img {
		width: 100%;
		height: auto;
}
.footer_link {
		display: flex;
		justify-content: space-between;
		max-width: 540px;
		margin: 0 auto 90px;
}
.footer_link li {
		list-style: none;
		width: calc(50% - 12px);
}
.footer_link li a {
		color: #fff;
		display: flex;
		height: 60px;
		justify-content: center;
		align-items: center;
		text-decoration: none;
		box-sizing: border-box;
		border: 1px solid #fff;
		position: relative;
}
.footer_link li a::after {
		content: '';
		display: block;
		position: absolute;
		top: calc(50% - 7px);
		right: 20px;
		width: 11px;
		height: 11px;
		background: url("https://www.kai-group.com/contents_file/products/brand/select100/special/moomin/images/icon_blank.png") no-repeat 0 0;
		background-size: 11px;
}
.footer_link li a span {
		position: relative;
		display: inline-block;
		transform: translateY(-1px);
}
.footer_copyright {
		max-width: 1040px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
		font-size: 12px;
}
.footer_copyright a {
		color: #fff;
		text-decoration: underline;
}
@media (hover: hover) {
		.footer_copyright a:hover {
				color: #fff;
				text-decoration: none;
		}
}
@media(max-width: 767px) {
		.footer_dark {
				padding-top: calc(13vw + 35px);
				padding-bottom: 20px;
		}
		.footer_logo {
				width: 156px;
				margin: 0 auto 35px;
		}
		.footer_link {
				display: block;
				margin: 0 auto 35px;
		}
		.footer_link li {
				width: 100%;
				margin: 0 0 12px;
		}
		.footer_link li a {
				height: 50px;
		}
		.footer_copyright {
				display: block;
		}
		.footer_copyright_about, .footer_copyright_copy {
				line-height: 1.7;
				font-size: 11px;
				text-align: center;
		}
		.footer_copyright_about {
				margin: 0 0 1.5em;
		}
		.footer_copyright_copy {
				font-size: 10px;
		}
}
@media(min-width: 768px) {
		.spObj {
				display: none
		}
}
@media(max-width: 767px) {
		.pcObj {
				display: none
		}
}
@media (min-width: 768px) {
		.mobileBr {
				display: none;
		}
}
/* =================== */
.loop_slider {
		display: flex;
		width: 100%;
		overflow: hidden;
}
.loop_item {
		display: flex;
		width: 2844px;
}
@media(max-width: 1920px) {
		.loop_item {
				width: 1944px;
		}
}
@media(max-width: 767px) {
		.loop_item {
				width: 1062px;
		}
}
.loop_inner:first-child {
		animation: loop 150s linear infinite;
}
.loop_inner:nth-child(2) {
		animation: loop2 150s -100s linear infinite;
}
.loop_inner:last-child {
		animation: loop3 150s -50s linear infinite;
}
.reverse .loop_inner:first-child {
		animation: loop4 150s linear infinite;
}
.reverse .loop_inner:nth-child(2) {
		animation: loop5 150s -100s linear infinite;
}
.reverse .loop_inner:last-child {
		animation: loop6 150s -50s linear infinite;
}
@media(max-width: 767px) {
		.loop_inner:first-child {
				animation: loop 90s linear infinite;
		}
		.loop_inner:nth-child(2) {
				animation: loop2 90s -60s linear infinite;
		}
		.loop_inner:last-child {
				animation: loop3 90s -30s linear infinite;
		}
		.reverse .loop_inner:first-child {
				animation: loop4 90s linear infinite;
		}
		.reverse .loop_inner:nth-child(2) {
				animation: loop5 90s -60s linear infinite;
		}
		.reverse .loop_inner:last-child {
				animation: loop6 90s -30s linear infinite;
		}
}
@keyframes loop {
		0% {
				transform: translateX(200%);
		}
		to {
				transform: translateX(-100%);
		}
}
@keyframes loop2 {
		0% {
				transform: translateX(100%);
		}
		to {
				transform: translateX(-200%);
		}
}
@keyframes loop3 {
		0% {
				transform: translateX(0%);
		}
		to {
				transform: translateX(-300%);
		}
}
@keyframes loop4 {
		0% {
				transform: translateX(-100%);
		}
		to {
				transform: translateX(200%);
		}
}
@keyframes loop5 {
		0% {
				transform: translateX(-200%);
		}
		to {
				transform: translateX(100%);
		}
}
@keyframes loop6 {
		0% {
				transform: translateX(-300%);
		}
		to {
				transform: translateX(0%);
		}
}