@charset "UTF-8";

/*common*/
.page-lp-kikin {
	padding-top: 149px;
}

.page-lp-kikin img {
	display: block;
	font-size: unset;
}

.page-lp-kikin div,
.page-lp-kikin p,
.page-lp-kikin h1,
.page-lp-kikin h2,
.page-lp-kikin section,
.page-lp-kikin ul,
.page-lp-kikin li {
	box-sizing: border-box;
}

.page-lp-kikin .section_headline {
	position: relative;
	font-size: 26px;
	text-align: center;
	
	font-weight: 700;
}

.page-lp-kikin .section_headline::after {
	content: '';
	display: block;
	margin: 30px auto 50px;
	width: 50px;
	height: 2px;
	background-color: #4d4d4d;
}

.page-lp-kikin p {
	line-height: 1.6em;
}

.page-lp-kikin .sp,
.page-lp-kikin .tablet {
	display: none;
}

.page-lp-kikin .pc.tablet {
	display: block;
}

.page-lp-kikin .mypage_btn.has-external::after {
	top: 16px;
	right: 6px;
}

.page-lp-kikin .inner {
	margin-left: auto;
	margin-right: auto;
}

.page-lp-kikin .w840 {
	max-width: 840px;
	width: 100%;
}

.page-lp-kikin .w1000 {
	max-width: 1000px;
	width: 100%;
}

.page-lp-kikin .main_wrapper {
	color: #333333;
}

.page-lp-kikin .t_bold {
	
	font-weight: 700;
}

.page-lp-kikin .t_red {
	color: #dd2723;
}

/*maincatch*/
.page-lp-kikin .maincatch {
	position: relative;
	width: 100%;
}

.page-lp-kikin .mv_main {
	overflow: hidden;
	position: relative;
	margin: 0 auto;
	padding: 45px 5vw 0;
	width: 100%;
	background: linear-gradient(#f7f0df, #e5d2b7);
	box-sizing: border-box;
}

.page-lp-kikin .mv_main::before {
	content: '';
	display: block;
	position: absolute;
	bottom: -1px;
	left: -1px;
	width: 101%;
	height: 114px;
	background: url('/kikin/img/kikin_mv_bg_pc.svg') no-repeat;
	background-size: 100% 100%;
	background-position: bottom center;
	z-index: 1;
}

.page-lp-kikin .mv_subtitle {
	font-size: 17px;
	color: #4d4d4d;
	text-align: center;
}

.page-lp-kikin .mv_subtitle .t_bold {
	font-size: 1.12em;
	
	font-weight: 700;
}

.page-lp-kikin .mv_subtitle .t_underline {
	padding-bottom: .3em;
	border-bottom: 2px solid #4d4d4d;
}

.page-lp-kikin .mv_title {
	margin: 30px 0;
	font-size: 27px;
	text-align: center;
	line-height: 1.5em;
}

.page-lp-kikin .mv_title span {
	margin-right: .1em;
	font-size: 1.68em;
	
	font-weight: 700;
	color: #333333;
}

.page-lp-kikin .mv_ribbon {
	width: 100%;
}

.page-lp-kikin .mv_ribbon img {
	margin: 0 auto;
	max-width: 360px;
	width: 80%;
}

.page-lp-kikin .mv_illustration {
	overflow: hidden;
	position: relative;
	margin-top: 15px;
	width: 100%;
	padding: 0 20px;
	z-index: 9;
}

.page-lp-kikin .mv_illustration img {
	margin: 0 auto;
	max-width: 800px;
	width: 100%;
}

.page-lp-kikin .mv_explanation {
	padding: 0 20px;
}

.page-lp-kikin .mv_explanation .inner {
	position: relative;
	padding: 45px;
	background-color: #f2f2f2;
	text-align: center;
}

.page-lp-kikin .mv_explanation_hl {
	margin: 0 0 .5em;
	font-size: 26px;
	
	font-weight: 500;
}

.page-lp-kikin .maincatch::after {
	content: '';
	display: block;
	position: relative;
	margin: 5px auto 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 80px 0 80px;
	border-color: #dd2723 transparent transparent transparent;
}

/* recommend */
.page-lp-kikin .recommend {
	margin: 90px 0;
}

.page-lp-kikin .recommend .inner {
	position: relative;
	max-width: 610px;
	width: 97.5%;
	margin: 0 auto;
}

.page-lp-kikin .recommend .inner p {
	font-size: 24px;
	text-align: center;
	line-height: 1.8em;
	
	font-weight: 500;
}

.page-lp-kikin .recommend .inner p .t_red {
	font-size: 1.1em;
}

.page-lp-kikin .recommend .inner img {
	font-size: 24px;
	text-align: center;
}

.page-lp-kikin .recommend .inner::after {
	content: '';
	display: block;
	position: absolute;
	top: 20px;
	left: 0;
	width: 100%;
	height: 84px;
	background: url('/kikin/img/kikin_recommend_bg.svg') no-repeat;
}

/* voices */
.page-lp-kikin .voices {
	padding: 80px 20px 60px;
	background-color: #f2e7d6;
}

.page-lp-kikin .voices h2 {
	line-height: 1.4em;
}

.page-lp-kikin .voices h2 img {
	display: inline;
	margin-right: .6em;
	height: 1.4em;
	width: auto;
}

.page-lp-kikin .voices ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: stretch;
}

.page-lp-kikin .voices ul li {
	position: relative;
	margin-bottom: 4%;
	width: 32%;
	background-color: #fff;
	border-radius: 10px;
	transition: box-shadow .3s ease-in-out;
}

.page-lp-kikin .voices ul li:hover {
	cursor: pointer;
	z-index: 999;
	box-shadow: 0 6px 20px 6px rgba(155, 98, 98, 0.3);
	-webkit-box-shadow: 0 6px 20px 6px rgba(155, 98, 98, 0.3);
	-moz-box-shadow: 0 6px 20px 6px rgba(155, 98, 98, 0.3);
}

.page-lp-kikin .voices ul li::before {
	content: '';
	display: block;
	width: 100%;
	height: 88px;
	background-color: #f2f2f2;
	border-radius: 10px 10px 0 0;
}

.page-lp-kikin .voices ul li .inner {
	padding: 0 6% 20px;
}

.page-lp-kikin .voice_top img {
	width: 135px;
	margin: -75px auto 0;
}

.page-lp-kikin .voice_top .content {
	margin: 20px 0;
	width: 100%;
}

.page-lp-kikin .voice_top .content .profile {
	display: inline-block;
	padding: .3em .4em .2em;
	font-size: 14px;
	
	font-weight: 500;
	line-height: 1em;
}

.voice_01 .profile {
	background-color: #ceead4;
}

.voice_02 .profile {
	background-color: #cae0e8;
}

.voice_03 .profile {
	background-color: #e7ddf2;
}

.voice_04 .profile {
	background-color: #f9f3d9;
}

.voice_05 .profile {
	background-color: #f4e1ec;
}

.voice_06 .profile {
	background-color: #f4dcde;
}

.page-lp-kikin .voice_top .content .profile span {
	margin-right: .3em;
	font-size: .8em;
	font-weight: 500;
	color: #666666;
}

.page-lp-kikin .voice_top .content .title {
	margin-top: .3em;
	font-size: 18px;
}

.page-lp-kikin .voice_bottom {
	position: relative;
	padding: 6%;
	background-color: #f2f2f2;
	border-radius: 6px;
}

.page-lp-kikin .voice_bottom .content {
	text-align: justify;
	color: #4d4d4d;
}

.page-lp-kikin .voice_bottom .content span {
	
	font-weight: 700;
}

.voice_01 .voice_bottom .content span {
	color: #5ba566;
}

.voice_02 .voice_bottom .content span {
	color: #457199;
}

.voice_03 .voice_bottom .content span {
	color: #6a5e8c;
}

.voice_04 .voice_bottom .content span {
	color: #c99f1b;
}

.voice_05 .voice_bottom .content span {
	color: #934e71;
}

.voice_06 .voice_bottom .content span {
	color: #c1616c;
}

.page-lp-kikin .voice_btn_area {
	margin: 12px 0 4px;
	text-align: right;
}

.page-lp-kikin .voice_btn {
	display: inline;
	padding: .6em .8em;
	font-size: 12px;
	color: #fff;
	background-color: #686160;
	border-radius: 1.9em;
	transition: opacity .2s ease-in-out;
}

.page-lp-kikin .voice_btn:hover {
	opacity: .6;
}

/*cv*/
.page-lp-kikin .cv {
	padding: 60px 2.5vw;
}

.page-lp-kikin .cv_content {
	background: #F5F7F7;
	overflow: hidden;
}

.page-lp-kikin .cv_contact {
	padding-bottom: 40px;
}

.page-lp-kikin .cv_contact .title {
	margin: 40px 0;
	width: 100%;
	text-align: center;
	font-size: 30px;
	
	font-weight: 700;
	color: #333;
}

.page-lp-kikin .cv_contact .title span {
	position: relative;
	top: -2px;
	margin-right: 15px;
	padding: 5px 10px;
	font-size: 24px;
	color: #FFF;
	background: #DD2723;
	border-radius: 3px;
}

.page-lp-kikin .cv_contact .headline {
	margin-bottom: 1em;
	text-align: center;
}

.page-lp-kikin .cv_contact .cv_contact_btn_area {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	margin: 0 auto;
	max-width: 860px;
	width: 90%;
}

.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn {
	transition: opacity .3s ease-in-out;
	width: min(100%, 516px);
}

.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn.mail:hover {
	opacity: .6;
	cursor: pointer;
}

.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn img {
	width: 100%;
	height: auto;
}

.page-lp-kikin .cv_shop {
	padding: 20px;
	background-color: #e6e6e6;
}

.page-lp-kikin .cv_shop_btn_area {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	margin: 0 auto;
	max-width: 860px;
	width: 90%;
}

.page-lp-kikin .cv_shop .headline {
	flex-grow: 1;
	width: 7.5%;
	text-align: center;
	font-size: 16px;
	line-height: 1em;
}

.page-lp-kikin .cv_shop .headline img {
	display: inline;
	height: 1em;
}

.page-lp-kikin .cv_shop_btn {
	margin:0 auto;
	padding: 1.2em 2.5em;
	border-radius: 1.7em;
	color: #fff;
	font-size: 18px;
	
	font-weight: 700;
	line-height: 1em;
	transition: opacity .3s ease-in-out;
}

.page-lp-kikin .cv_shop_btn:hover {
	opacity: .6;
	cursor: pointer;
}

.page-lp-kikin .cv_shop_btn.area {
	background-color: #4d4d4d;
	margin-right: 1em;
}

.page-lp-kikin .cv_shop_btn.reservable {
	background-color: #dd2723;
}

/*column*/
.page-lp-kikin .column {
	margin-bottom: 0 auto 60px;
	padding: 0 2.5vw;
}

.page-lp-kikin .column h2 img {
	width: auto;
	height: 45px;
	margin: 0 auto 15px;
}

.page-lp-kikin .column ul li {
	margin-bottom: 30px;
	/* box-shadow: 0 0 10px #CCC; */
	border-radius: 10px;
	border: 2px solid #e6e6e6;
}

.page-lp-kikin .column ul li a {
	position: relative;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 20px 40px 20px 20px;
	background: #FFF;
	border-radius: 10px;
	transition: box-shadow .2s ease-in-out;
}

.page-lp-kikin .column ul li a::after {
	display: block;
	position: absolute;
	top: calc(50% - 6px);
	right: 20px;
	content: "";
	border-top: solid 4px #CCC;
	border-right: solid 4px #CCC;
	width: 12px;
	height: 12px;
	transform: rotate(45deg);
	transition: border-color .3s ease-in-out;
}

.page-lp-kikin .column ul li a:hover {
	z-index: 999;
	box-shadow: 0 0 20px 6px rgba(179, 111, 111, 0.2);
	-webkit-box-shadow: 0 0 20px 6px rgba(179, 111, 111, 0.2);
	-moz-box-shadow: 0 0 20px 6px rgba(179, 111, 111, 0.2);
}

.page-lp-kikin .column ul li a:hover::after {
	border-color: #DD2723;
}

.page-lp-kikin .column ul li a img {
	width: 300px;
	height: auto;
	margin-right: 20px;
}

.page-lp-kikin .column ul li a .title_lead {
	max-width: 570px;
}

.page-lp-kikin .column ul li a h3 {
	margin: 0 0 15px;
	font-size: 24px;
	color: #0077CC;
	
	font-weight: 700;
	text-decoration: none;
	line-height: 1.6;
}

.page-lp-kikin .column ul li a p {
	font-size: 18px;
	color: #333;
	line-height: 1.6;
}

/*faq*/
.page-lp-kikin .faq {
	padding: 60px 2.5vw 0;
}

.page-lp-kikin .faq h2 img {
	width: auto;
	height: 40px;
	margin: 0 auto 15px;
}

.page-lp-kikin .faq dl {
	margin-bottom: 30px;
	padding: 40px 60px;
	border-radius: 10px;
	background-color: #f4eee6;
	line-height: 1.6;
	color: #333;
}

.page-lp-kikin .faq dl:last-of-type {
	margin-bottom: 0;
}

.page-lp-kikin .faq dl dt {
	position: relative;
	margin-bottom: 20px;
	padding-left: 44px;
}

.page-lp-kikin .faq dl dt::before {
	position: absolute;
	top: -3px;
	left: 0;
	content: "";
	width: 30px;
	height: 30px;
	background: url('/kikin/img/kikin_faq_icon-q.svg') no-repeat;
}

.page-lp-kikin .faq dl dd {
	position: relative;
	padding-left: 44px;
}

.page-lp-kikin .faq dl dd::before {
	position: absolute;
	top: -3px;
	left: 0;
	content: "";
	width: 30px;
	height: 30px;
	background: url('/kikin/img/kikin_faq_icon-a.svg') no-repeat;
}

/*areamodal*/
.area-modal-wrap {
	top: 47%;
	border-radius: 4px;
	box-shadow: 0 11px 15px -7px rgba(0, 0, 0, .2), 0 24px 38px 3px rgba(0, 0, 0, .14), 0 9px 46px 8px rgba(0, 0, 0, .12);
}

.area-modal-wrap .area-wrap .hokkaido {
	top: 0;
}

.area-modal-wrap .area-wrap .kanto {
	top: 140px;
}

.area-modal-wrap .area-wrap .tokai {
	top: 280px;
}

.area-modal-wrap .area-wrap .kansai {
	top: 200px;
}

.area-modal-wrap .area-wrap ul.area li p {
	padding: 5px 0;
}

.area-modal-wrap .area-wrap .area-title h3 {
	font-size: 28px;
}

.area-wrap .mid-headline {
	font-size: 14px;
	font-weight: 700;
	color: #30353a;
	margin-top: 18px;
	margin-bottom: 18px;
}

.area-modal-wrap .area-wrap {
	padding-bottom: 10px;
	margin-bottom: 0;
	background-size: 380px auto;
	background-position: 44% 29%;
}

.area-modal-wrap .area-wrap .area-headline {
	margin-top: 0;
}

/*fixed_menu*/
.fixed_bnnr_wrap_sp {
	display: none;
}

.fixed_bnnr_wrap_pc {
	position: sticky;
	padding: 0 5px;
	z-index: 9999;
	left: 0;
	bottom: 0;
	width: 100%;
	background-color: rgba(0, 0, 0, .7);
}

.fixed_bnnr_wrap_pc .sp,
.fixed_bnnr_wrap_pc .tablet {
	display: none;
}

.fixed_bnnr_wrap_pc .fixed_bnnr-inner {
	width: 100%;
	max-width: 950px;
	height: 70px;
	margin: 0 auto;
	flex-flow: row;
	align-items: center;
	justify-content: center;
}

.fixed_bnnr_wrap_pc .fixed_bnnr-nearby-store {
	position: relative;
	width: 246px;
	height: 50px;
	border: 2px solid #fff;
	background-color: #dd2523;
	border-radius: 30px;
	color: #fff;
	font-size: 14px;
	line-height: 1.3;
	align-items: center;
	justify-content: center;
}

.fixed_bnnr_wrap_pc .fixed_bnnr-mail {
	position: relative;
	width: 220px;
	height: 50px;
	margin-left: 14px;
	border: 2px solid #fff;
	background-color: #333333;
	border-radius: 30px;
	color: #fff;
	font-size: 14px;
	line-height: 1.3;
	align-items: center;
	justify-content: center;
}

.fixed_bnnr_wrap_pc .fixed_bnnr-mail img {
	margin-right: 6px;
}

.fixed_bnnr_wrap_pc .fixed_bnnr-nearby-store i {
	font-size: 24px;
	margin: -6px 0 0 6px;
}

.fixed_bnnr_wrap_pc .footer-label {
	margin: 0 54px 0 18px;
	color: #fff;
	letter-spacing: 0;
	flex-direction: column;
	justify-content: center;
}

.fixed_bnnr_wrap_pc .footer-label .footer-label-top {
	font-size: 16px;
	font-weight: 700;
	margin: 0;
	line-height: 1.5;
}

.fixed_bnnr_wrap_pc .footer-label .footer-label-bottom {
	font-size: 13px;
	margin: 0;
	line-height: 1.5;
}

.fixed_bnnr_wrap_pc .tel_bnnr {
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	height: auto;
	min-height: 0;
}

/* 加入者の声モーダル */
.voice-modal {
	display: none;
	position: fixed;
	top: 0;
	width: 100%;
	height: 100vh;
	
	font-weight: 400;
	font-size: 16px;
	line-height: 1.6em;
	transition: opacity .3s ease-in-out;
	z-index: 99999;
}

.voice-modal div,
.voice-modal p {
	box-sizing: border-box;
}

.vm_bg {
	position: absolute;
	top: 0;
	left: 0;
	height: 100vh;
	width: 100%;
	background: rgba(0, 0, 0, 0.8);
}

.vm_content {
	position: absolute;
	top: 50%;
	left: 50%;
	padding-bottom: 90px;
	width: 800px;
	height: 600px;
	max-width: 95vw;
	max-height: 85vh;
	background: #fff;
	border-radius: 10px;
	transform: translate(-50%, -50%);
	overflow: hidden;
}

.vmc_top {
	width: 100%;
	height: 100%;
	padding: 30px 40px 0;
	overflow-x: hidden;
	overflow-y: scroll;
}

.vmct_li {
	display: none;
	transform: translateX(0);
	transition: opacity .4s ease-in-out, transform .4s ease-in-out;
}

.vmct_li.selected {
	display: block;
}

.vmct_title {
	display: flex;
	width: 100%;
	margin-bottom: 20px;
}

.vmct_title img {
	width: 99px;
}

.vmct_title .content {
	margin: 16px 16px 16px 26px;
}

.vmct_title .content .profile {
	display: inline-block;
	padding: 0.3em 0.4em 0.2em;
	font-size: 14px;
	
	font-weight: 500;
	line-height: 1em;
}

.vmct_title .content .profile span {
	margin-right: 0.3em;
	font-size: .8em;
	font-weight: 400;
	color: #666666;
}

.vmct_title .content .title {
	margin-top: 4px;
	font-size: 22px;
	line-height: 1.6em;
}

.vmct_content {
	padding: 30px 40px;
	background-color: #f2f2f2;
	border-radius: 6px;
	color: #4d4d4d;
}

.vmct_content .title {
	text-align: left;
	line-height: 2em;
}

.vmct_content .title::after {
	content: '';
	display: block;
	position: relative;
	margin: 25px 0;
	width: 40px;
	height: 1px;
	background-color: #4d4d4d;
}

.vmct_content .content {
	font-size: 14px;
	line-height: 2em;
}

.vmct_btn_area {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: nowrap;
	position: relative;
	margin: 20px 0;
	height: 70px;
}

.vmct_btn_area::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 1px;
	height: 40px;
	background-color: #b3b3b3;
	transform: translate(-50%, -50%);
	z-index: 99;
}

.vmct_btn_area a {
	display: block;
	width: 50%;
	height: 100%;
	transition: background-color .2s ease-in-out;
}

.vmct_btn_area a:hover {
	cursor: pointer;
}

.vmct_btn_1:hover {
	background-color: #e1f4e5;
}

.vmct_btn_2:hover {
	background-color: #e6eff4;
}

.vmct_btn_3:hover {
	background-color: #efe8f7;
}

.vmct_btn_4:hover {
	background-color: #f9f6ea;
}

.vmct_btn_5:hover {
	background-color: #f9edf4;
}

.vmct_btn_6:hover {
	background-color: #f7ebec;
}

.vmct_btn {
	display: flex;
	align-items: center;
	width: 100%;
	height: 100%;
	padding: 7px 0;
}

.vmc_back .vmct_btn {
	justify-content: flex-start;
}

.vmc_next .vmct_btn {
	justify-content: flex-end;
}

.vmct_btn img {
	margin: 0 14px;
	width: 50px
}

.vmct_btn p {
	font-size: 14px;
}

.vmc_bottom {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 0 5vw;
	width: 100%;
	height: 90px;
	border-top: 1px solid #b3b3b3;
}

.vmcb_close_btn {
	display: block;
	max-width: 315px;
	width: 100%;
	height: 50px;
	font-size: 14px;
	text-align: center;
	line-height: 50px;
	border: 1px solid #333333;
	border-radius: 25px;
	transition: background-color .2s ease-in-out, color .2s ease-in-out;
}

.vmcb_close_btn:hover {
	background-color: #686160;
	color: #fff;
}

.vm-close:hover {
	cursor: pointer;
}

/* パンくず */
.kikin-breadcrumb__lists {
	display: flex;
	flex-direction: row;
	margin: 0 auto;
	align-items: center;
	font-size: 13px;
}
.kikin-breadcrumb--smt {
	background: #f5f5f5;
	border-top: 1px solid #c3c3c3;
	border-bottom: 1px solid #c3c3c3;
	width: 100%;
	overflow: auto;
	padding: 0 10px;
}
.kikin-breadcrumb--pc {
	display: none;
}
.kikin-breadcrumb--pc .kikin-breadcrumb__lists li:before {
	content: "\03e";
	display: inline-block;
	margin: 0 0.5em;
}
.kikin-breadcrumb--pc .kikin-breadcrumb__lists li:first-child:before {
	content: none;
}
.kikin-breadcrumb--pc .kikin-breadcrumb__lists a {
    color: #0066cc;
}
.kikin-breadcrumb--smt .kikin-breadcrumb__lists,
.kikin-breadcrumb--smt .kikin-breadcrumb__lists a {
	color: #999;
}
.kikin-breadcrumb--smt .kikin-breadcrumb__lists a img {
	width: 2em;
}
.kikin-breadcrumb--smt .kikin-breadcrumb__lists li {
	position: relative;
	padding: 0.75em 1em 0.5em 1.5em;
	overflow: hidden;
	flex-shrink: 0;
}
.kikin-breadcrumb--smt .kikin-breadcrumb__lists li:before {
	content: "";
	display: block;
	width: 2em;
	height: calc(2em * (1.732/2));
	border-bottom: 2px solid #e2e2e2;
	border-right: 2px solid #e2e2e2;
	transform: rotate(-60deg) skewX(-30deg);
	transform-origin: left top;
	position: absolute;
	top: 50%;
	left: -1em;
}
.kikin-breadcrumb--smt .kikin-breadcrumb__lists li:first-child {
	padding-top: 0;
	padding-bottom: 0;
	padding-left: 0;
}
.kikin-breadcrumb--smt .kikin-breadcrumb__lists li:first-child:before {
	content: none;
}
@media screen and (min-width: 768px) {
	.kikin-breadcrumb--smt {
		display: none;
	}
	.kikin-breadcrumb--pc {
		display: block;
	}
	.kikin-breadcrumb__lists {
		max-width: 1280px;
		box-sizing: border-box;
		padding: 1.5em 4% 1em;
	}
}

/* アニメーション */
.fadeout {
	animation: fadeout .3s ease-in-out forwards;
}

.fadein {
	animation: fadein .3s ease-in-out forwards;
}

.fadeout_back {
	animation: fadeout_back .3s ease-in-out forwards;
}

.fadeout_next {
	animation: fadeout_next .3s ease-in-out forwards;
}

.fadein_back {
	animation: fadein_back .3s ease-in-out forwards;
}

.fadein_next {
	animation: fadein_next .3s ease-in-out forwards;
}

@keyframes fadeout {
	0% {
		opacity: 1;
	}

	100% {
		opacity: 0;
	}
}

@keyframes fadein {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

@keyframes fadeout_back {
	0% {
		transform: translateX(0);
		opacity: 1;
	}

	100% {
		transform: translateX(50px);
		opacity: 0;
	}
}

@keyframes fadeout_next {
	0% {
		transform: translateX(0);
		opacity: 1;
	}

	100% {
		transform: translateX(-50px);
		opacity: 0;
	}
}

@keyframes fadein_back {
	0% {
		transform: translateX(-50px);
		opacity: 0;
	}

	100% {
		transform: translateX(0);
		opacity: 1;
	}
}

@keyframes fadein_next {
	0% {
		transform: translateX(50px);
		opacity: 0;
	}

	100% {
		transform: translateX(0);
		opacity: 1;
	}
}

/*=== レスポンシブ ======================================*/

/* tablet, sp共通 */
@media screen and (max-width:950px) {

	/* voices */
	.page-lp-kikin .voices ul li:hover {
		cursor: default;
		box-shadow: none;
		-webkit-box-shadow: none;
		-moz-box-shadow: none;
	}

	.page-lp-kikin .voice_btn:hover {
		opacity: 1;
	}

	/* cv */
	.page-lp-kikin .cv {
		padding: 0;
		border-top: 6px solid #e6e6e6;
		border-bottom: 6px solid #e6e6e6;
	}

	.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn.mail:hover {
		opacity: 1;
		cursor: default;
	}

	.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn.tel:hover {
		opacity: 1;
		cursor: default;
	}

	.page-lp-kikin .cv_shop_btn:hover {
		opacity: 1;
		cursor: default;
	}

	/* column */
	.page-lp-kikin .column {
		margin: 0 auto;
		padding: 10vw 4.5vw 0;
	}

	.page-lp-kikin .column ul li a:hover {
		z-index: 1;
		box-shadow: none;
	}

	.page-lp-kikin .column ul li a:hover::after {
		border-color: none;
	}

	/* faq */
	.page-lp-kikin .faq {
		padding: 10vw 2.5vw;
	}

	/* 加入者の声モーダル */
	.voice-modal .pc {
		display: none;
	}
}

/*tablet*/
@media screen and (min-width:567px) and (max-width:950px) {

	/* common */
	.page-lp-kikin .pc {
		display: none;
	}

	.page-lp-kikin .tablet {
		display: block;
	}

	.page-lp-kikin .pc.tablet {
		display: block;
	}

	/* recommend */
	.page-lp-kikin .recommend .inner::after {
		display: none;
	}

	/* column */
	.page-lp-kikin .column ul li a img {
		max-width: 300px;
		width: 36%;
	}

	.page-lp-kikin .column ul li a p {
		display: none;
	}

	/* cv */
	.page-lp-kikin .cv_shop_btn {
		text-align: center;
		font-size: 16px;
		line-height: 1.4em;
		border-radius: 5px;
	}

	.page-lp-kikin .cv_shop_btn_area {
		max-width: 600px;
	}

	.page-lp-kikin .cv_shop_btn {
		padding: .8em 1.8em;
	}

	/* modal */
	.area-modal-wrap .area-wrap .hokuriku {
		top: 0;
	}

	.area-modal-wrap .area-wrap {
		background-size: 260px auto;
		background-position: 46% 47%;
	}

	/* fixed_bnnr */
	.fixed_bnnr_wrap_pc .fixed_bnnr-nearby-store {
		width: 206px;
		font-size: 12px;
	}

	.fixed_bnnr_wrap_pc .fixed_bnnr-mail {
		width: 186px;
		margin-left: 6px;
		font-size: 12px;
	}

	.fixed_bnnr_wrap_pc .fixed_bnnr-mail img {
		width: 22px;
	}

	.fixed_bnnr_wrap_pc .tel_bnnr {
		width: 250px;
		max-width: 37%;
	}

	.fixed_bnnr_wrap_pc .footer-label {
		margin-left: 8px;
	}

	.fixed_bnnr_wrap_pc .footer-label .footer-label-top {
		font-size: 13px;
	}

	.fixed_bnnr_wrap_pc .footer-label .footer-label-bottom {
		font-size: 10px;
	}

	/* 加入者の声モーダル */
	.vmct_title .content {
		margin: 14px;
	}
}

/* tablet mini */
@media screen and (min-width:567px) and (max-width:767px) {

	/* common */
	.page-lp-kikin {
		padding-top: 0;
		font-size: 14px;
	}

	/* voices */
	.voices ul li {
		width: 49%;
	}

	/* cv */
	.page-lp-kikin .cv_shop_btn_area {
		justify-content: center;
	}

	.page-lp-kikin .cv_shop .headline {
		display: none;
	}

	/*fixed_menu*/
	.fixed_bnnr_wrap_pc .tablet {
		display: block;
	}
}

/* sp */
@media screen and (max-width:566px) {

	/* common */
	.page-lp-kikin {
		padding-top: 0;
		font-size: 14px;
	}

	.page-lp-kikin .footer_sp {
		padding-bottom: 70px;
	}

	.page-lp-kikin .pc {
		display: none;
	}

	.page-lp-kikin .tablet {
		display: none;
	}

	.page-lp-kikin .pc.tablet {
		display: none;
	}

	.page-lp-kikin .sp {
		display: block;
	}

	.page-lp-kikin .section_headline {
		font-size: 19px;
	}

	.page-lp-kikin .section_headline::after {
		margin: 6vw auto 12vw;
		width: 30px;
	}

	/* maincatch */
	.page-lp-kikin .mv_main {
		padding: 30px 0 0;
	}

	.page-lp-kikin .mv_subtitle {
		font-size: 12.8px;
	}

	.page-lp-kikin .mv_title {
		margin: 28px 0 20px;
		font-size: 22px;
	}

	.page-lp-kikin .mv_main::before {
		display: none;
	}

	.page-lp-kikin .mv_illustration {
		position: relative;
		margin-top: 15px;
		max-height: 256px;
		width: 100%;
		height: 68.3vw;
		padding: 0 20px;
		z-index: 9;
	}

	.page-lp-kikin .mv_illustration img {
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		max-height: 256px;
		max-width: 375px;
		width: 100%;
	}

	.page-lp-kikin .mv_illustration::before {
		content: '';
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		max-height: 94px;
		height: 25vw;
		background: url('/kikin/img/kikin_mv_bg_sp.svg') no-repeat;
		background-size: 100% 100%;
		background-position: bottom center;
		z-index: 10;
	}

	.page-lp-kikin .mv_illustration .back {
		z-index: 1;
	}

	.page-lp-kikin .mv_illustration .front {
		z-index: 99;
	}

	.page-lp-kikin .mv_explanation {
		padding: 0 2.5vw;
	}

	.page-lp-kikin .mv_explanation .inner {
		padding: 5vw;
		text-align: left;
		font-size: 12px;
	}

	.page-lp-kikin .mv_explanation_hl {
		font-size: 17px;
	}

	.page-lp-kikin .maincatch::after {
		margin: 10px auto 0;
		border-width: 18px 50px 0 50px;
	}

	/* recommend */
	.page-lp-kikin .recommend {
		margin: 15vw 0;
	}

	.page-lp-kikin .recommend .inner::after {
		display: none;
	}

	.page-lp-kikin .recommend .inner p {
		font-size: 5vw;
	}

	/* voices */
	.page-lp-kikin .voices {
		padding: 8vw 2.5vw;
	}

	.page-lp-kikin .voices ul li {
		width: 100%;
	}

	.page-lp-kikin .voices ul li::before {
		display: none;
	}

	.page-lp-kikin .voices ul li .inner {
		padding: 3vw 5vw 5vw 5vw;
	}

	.page-lp-kikin .voice_top {
		display: flex;
		width: 102%;
		margin: 0 0 2.5vw -2%;
	}

	.page-lp-kikin .voice_top img {
		width: 90px;
		margin: 0;
	}

	.page-lp-kikin .voice_top .content {
		margin: 14px;
	}

	.page-lp-kikin .voice_top .content .title {
		font-size: 16px;
	}

	.page-lp-kikin .voice_top .content .profile {
		font-size: 12px;
	}

	/* cv */
	.page-lp-kikin .cv_content {
		padding: 8vw 0 10vw;
	}

	.page-lp-kikin .cv_contact .title {
		margin: 0 0 5vw;
		font-size: 6vw;
	}

	.page-lp-kikin .cv_contact .title span {
		top: -0.5vw;
		margin-right: 2vw;
		padding: .2em .6em;
		font-size: 4vw;
	}

	.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn {
		width: 100%;
		margin-bottom: 3vw;
	}

	.page-lp-kikin .cv_contact .cv_contact_btn_area .cv_contact_btn:last-of-type {
		margin-bottom: 0;
	}

	.page-lp-kikin .cv_shop {
		padding: 0;
		background-color: transparent;
	}

	.page-lp-kikin .cv_shop_btn {
		margin:0 auto;
		padding: 1.2em 0;
		width: 100%;
		text-align: center;
		font-size: 14px;
		line-height: 1.4em;
		border-radius: 5px;
	}

	.page-lp-kikin .cv_shop_btn.area {
		margin: 0;
	}

	/*column*/
	.page-lp-kikin .column h2 img {
		height: 37px;
	}

	.page-lp-kikin .column ul li {
		margin-bottom: 4.5vw;
		border-radius: 5px;
	}

	.page-lp-kikin .column ul li a {
		position: relative;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		padding: 4vw;
		background: #FFF;
		border-radius: 5px;
	}

	.page-lp-kikin .column ul li a::after {
		display: block;
		position: absolute;
		top: calc(50% - 1.5vw);
		right: 2vw;
		content: "";
		border-top: solid 1vw #CCC;
		border-right: solid 1vw #CCC;
		width: 3vw;
		height: 3vw;
		transform: rotate(45deg);
	}

	.page-lp-kikin .column ul li a img {
		width: 31.5vw;
		height: auto;
		margin-right: 3vw;
	}

	.page-lp-kikin .column ul li a .title_lead {
		max-width: 48vw;
	}

	.page-lp-kikin .column ul li a h3 {
		margin: 0;
		font-size: 4.5vw;
		color: #0077CC;
		
		font-weight: 700;
		text-decoration: none;
		line-height: 1.6;
	}

	.page-lp-kikin .column ul li a p {
		display: none;
	}

	/* faq */
	.page-lp-kikin .faq h2 img {
		height: 27px;
	}

	.page-lp-kikin .faq dl {
		margin-bottom: 5vw;
		padding: 7vw 5vw;
	}

	.page-lp-kikin .faq dl dd p {
		position: relative;
		max-height: 2.8em;
		overflow-y: hidden;
		z-index: 1;
		transition: max-height .3s linear;
	}

	.page-lp-kikin .faq dl dd p::after {
		content: '';
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 1.4em;
		background: linear-gradient(0deg, rgba(244, 238, 230, 1) 0%, rgba(244, 238, 230, 0) 100%);
		z-index: 99;
		transition: opacity .2s linear;
	}

	.page-lp-kikin .faq_moreread_btn {
		position: relative;
		width: 100%;
		margin-top: 1em;
		padding: .8em 0;
		font-size: 12px;
		text-align: center;
		line-height: 1em;
		border: 1px solid #333333;
		border-radius: 1.3em;
		background-color: #fcf9f5;
		z-index: 9;
	}

	.page-lp-kikin .faq_moreread_btn::before {
		content: '';
		display: inline-block;
		position: relative;
		margin: 0 6px 2px 0;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 5.5px 5.5px 0 5.5px;
		border-color: #333333 transparent transparent transparent;
		transition: transform .3s linear;
	}

	.page-lp-kikin .faq .open_accordion dd p {
		max-height: 12em;
	}

	.page-lp-kikin .faq .open_accordion dd p::after {
		opacity: 0;
	}

	.page-lp-kikin .faq .open_accordion .faq_moreread_btn::before {
		transform: rotate(180deg);
	}

	/* 加入者の声モーダル */
	.voice-modal {
		font-size: 14px;
	}

	.vmc_top {
		padding: 3vw 5vw 0;
	}

	.vmct_title {
		margin: 0 0 2.5vw -2%;
	}

	.vmct_title img {
		width: 90px;
	}

	.vmct_title .content {
		margin: 14px;
	}

	.vmct_title .content .profile {
		font-size: 12px;
	}

	.vmct_title .content .title {
		font-size: 16px;
	}

	.vmct_content {
		padding: 6%;
	}

	.vmct_btn_area {
		margin: 3vw 0;
	}

	.vmct_btn img {
		margin: 0 2.5vw;
		width: 32%;
	}

	.vmct_btn p {
		font-size: 12px;
	}

	/*fixed_menu*/
	.fixed_bnnr_wrap_pc {
		display: none;
	}

	.fixed_bnnr_wrap_sp {
		display: flex;
		position: sticky;
		z-index: 99;
		left: 0;
		bottom: -70px;
		padding: 5px;
		width: 100%;
		height: 70px;
		color: #fff;
		font-size: 14px;
		background-color: rgba(0, 0, 0, .7);
		justify-content: space-between;
		align-items: stretch;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-left {
		width: 49%;
		flex-wrap: wrap;
		align-content: flex-end;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-right {
		width: 49%;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-left-top {
		position: relative;
		width: 100%;
		margin-bottom: 1vw;
		font-size: 12px;
		text-align: center;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-left-top img {
		display: inline;
		width: auto;
		height: 12px;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-left-top img.reverse {
		transform: scale(-1, 1);
		filter: FlipH;
		-ms-filter: "FlipH";
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-left-bottom {
		width: 100%;
		justify-content: space-between;
		align-items: stretch;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-mail,
	.fixed_bnnr_wrap_sp .fixed_bnnr-tel {
		width: 100%;
		height: 40px;
		padding: 4px 4px 8px 4px;
		background-color: #333333;
		box-shadow: 0 -5px #111111 inset;
		border: 1px solid #e6e6e6;
		border-radius: 5px;
		color: #fff;
		justify-content: center;
		align-items: center;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-mail img {
		width: 7vw;
		height: auto;
		max-width: 30px;
		margin-right: 2vw;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-tel img {
		width: 5.85vw;
		height: auto;
		max-width: 24px;
		margin-right: 2vw;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-nearby-store {
		width: 100%;
		height: 100%;
		padding: 4px 4px 8px 4px;
		background-color: #dd2523;
		box-shadow: 0 -5px #ad0c0c inset;
		border: 1px solid #e6e6e6;
		border-radius: 5px;
		justify-content: center;
		align-items: center;
		color: #fff;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-nearby-store i {
		font-size: 7vw;
		line-height: 1em;
		margin: -1vw 4vw 0 0;
	}

	.fixed_bnnr_wrap_sp .fixed_bnnr-nearby-store p {
		line-height: 1.24em;
	}
}