	/* -----------------------
		common
	----------------------- */
	.body {
		overflow-x: clip;
	}
	.lp_wrap {
		width: 100%;
		max-width: 750px;
		margin: 0 auto;
		box-shadow: 0 0 10px 2px #d6d6d6;
		position: relative;
		background-color: #fff;
	}

	.lp_wrap img {
		max-width: 100%;
		width: 100%;
		vertical-align: bottom;
	}
	.lp_wrap .ttl-box span {
		display: block;
	}
	.lp_wrap .grid-box {
		display: grid;
	}
	.lp_wrap .box {
		position: relative;
	}
	/* slick-reset */
	.lp_wrap .slider {
		display: none;
	}
	.lp_wrap .slider.slick-initialized {
		display: block;
		margin-bottom: 0;
	}
	.lp_wrap .slider .slick-arrow {
		cursor: pointer;
	}
	.lp_wrap .slider .slick-list {
		cursor: grab;
	}
	.lp_wrap .slider .slick-list:active {
		cursor: grabbing;
	}
	.lp_wrap .slider .slick-dots li * {
		display: none;
	}
	video {
		filter: drop-shadow(0px 0px rgb(255,255,255));
		outline: none;
		border: none;
	}
	.top {
		position: absolute;
		top: 0;
	}
	.bottom {
		position: absolute;
		bottom: 0;
	}
	.up{
		position: relative;
		z-index: 2;
	}
	.note {
		font-size: 14px;
		color: #fff;
		text-align: right;
	}

	/* animations */
	.fadeInUp.trigger {
		transition: all 0.5s 0s ease;
		opacity: 0;
		transform: scale(1, 1) translateY(20px);
		transition-delay: .05s;
	}
	.fadeInUp.trigger.move {
		opacity: 1;
		transform: scale(1, 1) translateY(0);
	}
	.fadeInDown.trigger {
		transition: all 0.5s 0s ease;
		opacity: 0;
		transform: scale(1, 1) translateY(-20px);
		transition-delay: .05s;
	}
	.fadeInDown.trigger.move {
		opacity: 1;
		transform: scale(1, 1) translateY(0);
	}
	.unmaskLeft.trigger {
		clip-path: inset(0 100% 0 0);
		transition: all 0.5s 0s ease;
		transition-delay: .05s;
	}
	.unmaskLeft.trigger.move {
		clip-path: inset(0);
	}
	.unmaskLeft02.trigger {
		clip-path: inset(0);
		transition: all 0.5s 0s ease;
		transition-delay: .05s;
	}
	.unmaskLeft02.trigger.move {
		clip-path: inset(0 100% 0 0);
	}
	.unmaskRight02.trigger {
		clip-path: inset(0);
		transition: all 0.5s 0s ease;
		transition-delay: .05s;
	}
	.unmaskRight02.trigger.move {
		clip-path: inset(0 0 0 100%);
	}
	.unmaskDown.trigger {
		clip-path: inset(0 0 100% 0);
		transition: all 0.5s 0s ease;
		transition-delay: .05s;
	}
	.unmaskDown.trigger.move {
		clip-path: inset(0);
	}
	.unmaskUp.trigger {
		clip-path: inset(100% 0 0 0);
		transition: all 0.5s 0s ease;
		transition-delay: .05s;
	}
	.unmaskUp.trigger.move {
		clip-path: inset(0);
	}
	.fadeInLeft.trigger {
		transition: all 0.5s 0s ease;
		opacity: 0;
		transform: scale(1, 1) translateX(20px);
		transition-delay: .05s;
	}
	.fadeInLeft.trigger.move {
		opacity: 1;
		transform: scale(1, 1) translateX(0);
	}
	.fadeInRight.trigger {
		transition: all 0.5s 0s ease;
		opacity: 0;
		transform: scale(1, 1) translateX(-20px);
		transition-delay: .05s;
	}
	.fadeInRight.trigger.move {
		opacity: 1;
		transform: scale(1, 1) translateX(0);
	}

	.popInUp.trigger {
		transition: opacity 0.5s ease, transform 0.5s ease;
		opacity: 0;
		transform: translateY(20px) scale(0.65);
		transition-delay: .05s;
	}

	.popInUp.trigger.move {
		opacity: 1;
		transform: translateY(0) scale(1);
	}

	.fadeIn.trigger {
		opacity: 0;
		transition: opacity 0.5s ease;
	}

	.fadeIn.trigger.move {
		opacity: 1;
	}
	
	.scaleUp.trigger {
		transition: all 0.5s 0s ease;
		opacity: 0;
		transform: scale(0, 0);
		transform-origin: 50% 50%;
		transition-delay: .05s;
	}
	.scaleUp.trigger.move {
		opacity: 1;
		transform: scale(1, 1);
	}
	.scaleZoom {
		opacity: 0;
		transform: scale(0,0);
		transform-origin: 50% 50%;
			transition: opacity 0.5s ease 0.15s, transform 0.5s ease 0.15s;
	}
	.scaleZoom.trigger.move,
	.trigger.move .scaleZoom {
	opacity: 1;
	animation: scaleAnimation 1s ease forwards;
}
	@keyframes scaleAnimation {
			0% {
					transform: scale(1);
			}
			50% {
					transform: scale(1.3);
			}
			100% {
					transform: scale(1);
			}
	}
	
	.rotate {
			animation: rotate360 8s linear infinite;
	}
	@keyframes rotate360 {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

	.delay-1.trigger { transition-delay: 0.2s !important; }
	.delay-2.trigger { transition-delay: 0.4s !important; }
	.delay-3.trigger { transition-delay: 0.6s !important; }
	.delay-4.trigger { transition-delay: 0.8s !important; }
	.delay-5.trigger { transition-delay: 1.0s !important; }
	.delay-6.trigger { transition-delay: 1.2s !important; }

	.shine::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: linear-gradient(45deg, rgba(255, 255, 255, 0) 35%, rgba(255, 255, 255, 0.3) 45%, rgba(255, 255, 255, 0.8) 49%, rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 0.8) 51%, rgba(255, 255, 255, 0.3) 55%, rgba(255, 255, 255, 0) 65%);
		background-repeat: no-repeat;
		background-size: 200% 100%;
		animation: shine 2.5s infinite;
		pointer-events: none;
		mask-repeat: no-repeat;
		mask-position: center;
		mask-size: contain;
		mix-blend-mode: overlay;
	}

	@keyframes shine {
		0% {
			background-position: 200% -200%;
		}

		100% {
			background-position: -200% 200%;
		}
		
	}

	.floaty {
		opacity: 1;
		animation: floatAlways 3s ease-in-out infinite;
	}

	@keyframes floatAlways {
		0%   { transform: translateY(0); }
		50%  { transform: translateY(-8px); }
		100% { transform: translateY(0); }
	}

	/* -----------------------
		fv
	----------------------- */
	.fv{
		width: min(calc(750 / 750 * 100vw), 750px);
		height: min(calc(1200 / 750 * 100vw), 1200px);
	}
	.fv video{
		width: min(calc(750 / 750 * 100vw), 750px);
		height: auto;
		object-fit: cover;
	}

	/* -----------------------
		aspect
	----------------------- */
	.aspect {
		position: relative;
	}
	.aspect h2 {
		padding-top: min(calc(95 / 750 * 100vw), 95px);
		margin-bottom: min(calc(68 / 750 * 100vw), 68px);
	}
	.aspect .aspect_icon {
		width: 100%;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.aspect_icon li {
		position: relative;
		width: min(calc(261 / 750 * 100vw), 261px);
		list-style: none;
		text-align: center;
		margin: 0 auto;
	}
	.aspect_icon li>p:nth-of-type(1) img {
		display: block;
		width: min(calc(261 / 750 * 100vw), 261px);
		margin: 0 auto;
	}
	.aspect_icon li:nth-child(3) {
		width: 100%;
		margin-top: min(calc(120 / 750 * 100vw), 120px);
		margin-bottom: min(calc(78 / 750 * 100vw), 78px);
		display: flex;
		justify-content: center;
	}
	.aspect_icon .circle {
		position: absolute;
		top: 50%;
		left: 50%;
		width: min(calc(317 / 750 * 100vw), 317px);
		transform: translate(-50%, -50%);
		z-index: 2;
	}

	/* -----------------------
		citric
	----------------------- */
	.citric {
		position: relative;
	}
	.citric .citric_title01 {
		position: absolute;
		top: max(calc(-164 / 750 * 100vw), -164px);
	}
	.citric .citric_title02 {
		margin-top: min(calc(160 / 750 * 100vw), 160px);
	}
	.citric_video {
		position: sticky;
		top: 0;
		height: min(calc(1340 / 750 * 100vw), 1340px);
		z-index: 0;
	}
	.citric_video video {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.citric_parallax {
		position: relative;
		z-index: 2;
		margin-top: calc(-1 * min(calc(1340 / 750 * 100vw), 1340px));
	}
	.citric_content {
		position: relative;
	}

	/* -----------------------
		cta
	----------------------- */
	.cta {
		position: relative;
	}
	.cta .cta_tokuten {
		position: relative;
	}
	.cta .cta_tokuten .tokuten_bg {
		position: absolute;
		top: 0;
	}
	.cta .cv_icon01 {
		position: absolute;
		width: min(calc(149 / 750 * 100vw), 149px);
		left: min(calc(10 / 750 * 100vw), 10px);
		top: min(calc(84 / 750 * 100vw), 84px);
	}
	.cta .cv_icon02 {
		position: absolute;
		width: min(calc(134 / 750 * 100vw), 134px);
		right: min(calc(33 / 750 * 100vw), 33px);
		bottom: min(calc(30 / 750 * 100vw), 30px);
	}
	.cta .btn {
		width: min(calc(664/ 750 * 100vw), 664px);
		/* display: block; */
		margin: 0 auto;
		text-align: center;
		left: 50%;
		transform: translateX(-50%);
	}
	.cta .btn img {
		animation: updown 1s ease forwards infinite;
	}
	@keyframes updown {
		0% {
			transform: translateY(-5%);
		}

		50% {
			transform: translateY(5%);
		}

		100% {
			transform: translateY(-5%);
		}
	}

	/* -----------------------
		demo
	----------------------- */
	.demo {
		position: relative;
	}
	.demo .demo_txt {
		position: relative;
	}

	/* -----------------------
		develop
	----------------------- */
	.develop {
		position: relative;
		height: min(calc(1400 / 750 * 100vw), 1400px);
	}
	.develop video {
		height: min(calc(1400 / 750 * 100vw), 1400px);
	}

	/* -----------------------
		develop_aori
	----------------------- */
	.develop_aori {
		position: relative;
	}
	.develop_aori .develop_aori_waku {
		width: min(calc(750/ 750 *100vw), 750px);
		margin: min(calc(30/ 750 *100vw), 30px) auto 0;
		text-align: center;
	}
	.develop_aori .develop_aori_waku img {
		width: min(calc(705/ 750 *100vw), 705px);
	}
	.develop_aori .develop_icon {
		position: absolute;
		width: min(calc(492/ 750 *100vw), 492px);
		top: min(calc(110/ 750 *100vw), 110px);
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		display: flex;
		justify-content: space-between;
	}
	.develop_aori .develop_icon li {
		width: min(calc(175/ 750 *100vw), 175px);
	}

	/* -----------------------
		doctor
	----------------------- */
	.doctor {
		position: relative;
	}

	/* -----------------------
		how
	----------------------- */
	.how {
		position: relative;
	}
	.how .how_wrap {
		width: min(calc(750 / 750 * 100vw), 750px);
	}
	.how .slick-dotted.slick-slider {
		margin-bottom: min(calc(142 / 750 * 100vw), 142px);
	}
	.how .howto_slide_content {
		width: min(calc(750 / 750 * 100vw), 750px);
		position: relative;
		z-index: 2;
	}
	.how .howto_slide .how_slide_pic {
		position: absolute;
		top: min(calc(80 / 750 * 100vw), 80px);
		left: 50%;
		transform: translateX(-50%);
		width: min(calc(500 / 750 * 100vw), 500px);
		aspect-ratio: 5 / 6;
		height: auto;
		border-top-left-radius: 50% 41%;
		border-top-right-radius: 50% 41%;
		overflow: hidden;
		z-index: -1;
	}
	.how .howto_slide .how_slide_pic img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
		transform: scale(1.2);
		transform-origin: center center;
		transition: transform 1s ease;
	}
	.how .howto_slide .slick-center .how_slide_pic img {
		transform: scale(1);
	}
	.howto_slide .slick-dots {
		bottom: -8.5%;
	}
	.howto_slide .slick-dots li {
		width: min(calc(11 / 750 * 100vw), 11px);
		height: min(calc(11 / 750 * 100vw), 11px);
		margin: 0% 1%;
		aspect-ratio: 1 / 1;
		box-sizing: border-box;
		background-color: #fff;
		border-radius: 50%;
		transition: 0.2s;
	}
	.howto_slide .slick-dots li button {
		width: auto;
	}
	.howto_slide .slick-dots li.slick-active {
		background-color: #bf0c0c;
	}

	/* -----------------------
		howto_aori
	----------------------- */
	.howto_aori {
		position: relative;
	}

	/* -----------------------
		intro
	----------------------- */
	.intro {
		position: relative;
	}
	.intro .intro_ttl {
		margin-bottom: min(calc(242/ 750 * 100vw), 242px);
	}
	.intro .product {
		display: flex;
		justify-content: center;
	}
	.intro .product p {
		width: min(calc(375/ 750 * 100vw), 375px);
		z-index: 2;
	}
	.intro .product_03 {
		margin-top: max(calc(-41/ 750 * 100vw), -41px);
	}
	.intro .intro_img {
		margin-top: max(calc(-33/ 750 * 100vw), -33px);
	}
	.intro .intro_04 {
		top: min(calc(33/ 750 * 100vw), 33px);
	}
	.intro_content {
		position: relative;
	}
	.intro .intro_tokkyo {
		position: absolute;
		bottom: max(calc(-100 / 750 * 100vw), -100px);
	}
	.intro_video {
		position: sticky;
		top: 0;
		height: min(calc(1400 / 750 * 100vw), 1400px);
		z-index: 1;
		overflow: hidden;
	}
	.intro_video video {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.intro_parallax {
		position: relative;
		z-index: 2;
		margin-top: max(calc(-1260 / 750 * 100vw), -1260px);
	}
	.intro02 .bg{
		position: absolute;
		bottom: 0;
		z-index: 0;
	}

	/* -----------------------
		material
	----------------------- */
	.material {
		position: relative;
	}
	.material .material_video video {
		position: absolute;
		width: min(calc(750 / 750 * 100vw), 750px);
		height: auto;
		object-fit: cover;
		z-index: 0;
	}
	.material .content {
		position: relative;
		z-index: 1;
		width: 100%;
	}
	.material .content img {
		display: block;
		max-width: 100%;
		height: auto;
	}
	.material .slick-dotted.slick-slider {
		margin-bottom: 0;
	}
	.material_slide .slick-dots {
		bottom: 3.5%;
	}
	.material_slide .slick-dots li {
		width: min(calc(11 / 750 * 100vw), 11px);
		height: min(calc(11 / 750 * 100vw), 11px);
		margin: 0% 1%;
		aspect-ratio: 1 / 1;
		box-sizing: border-box;
		background-color: #fff;
		border-radius: 50%;
		transition: 0.2s;
	}
	.material_slide .slick-dots li button {
		width: auto;
	}
	.material_slide .slick-dots li.slick-active {
		background-color: #bf0c0c;
	}
	.material_slide,
	.material_slide .slick-list{
		width: min(calc(750 / 750 * 100vw), 750px);
		padding: 0;
	}
	.material_slide .slick-next,
	.material_slide .slick-next:hover,
	.material_slide .slick-next:focus {
		background: url(//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/sns_slider_arrow_next.png) no-repeat center/ contain;
		right:  min(calc(20 / 750 * 100vw), 20px);
	}
	.material_slide .slick-prev,
	.material_slide .slick-prev:hover,
	.material_slide .slick-prev:focus {
		background: url(//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/sns_slider_arrow_prev.png) no-repeat center/ contain;
		left:  min(calc(20 / 750 * 100vw), 20px);
	}
	.slick-prev:hover::before, .slick-prev:focus::before, .slick-next:hover::before, .slick-next:focus::before {
		opacity: 1;
	}
	.material_slide .slick-arrow {
		position: absolute;
		width: min(calc(66 / 750 * 100vw), 66px);
		height: min(calc(66 / 750 * 100vw), 66px);
		top: 44.8%;
		z-index: 4;
	}
	.slick-arrow::before {
		content: none;
	}
	.slick-prev::before, 
	.slick-next::before{
		display: none;
	}
	.material_slide .prev {
		left: 8%;
	}
	.material_slide .next {
		right: 8%;
	}

	/* -----------------------
		nayami
	----------------------- */
	.nayami {
		position: relative;
		z-index: 1;
		background: url(//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/worrie_bg.png) no-repeat bottom center;
	}
	.nayami-sticky {
		position: sticky;
		top: 0;
	}
	.nayami-images {
		position: relative;
		width: 100%;
	}
	.nayami-item {
		position: absolute;
		inset: 0;
		width: 100%;
		margin: 0;
		opacity: 0;
		pointer-events: none;
		transition: opacity .35s ease;
	}
	.nayami-item.is-active {
		opacity: 1;
		pointer-events: auto;
		z-index: 2;
	}
	.nayami-item:first-child {
		position: relative;
		opacity: 1;
		pointer-events: auto;
	}
	.nayami-item .top,
	.nayami-item .nayami-main {
		margin: 0;
	}
	.nayami-item .top img,
	.nayami-item .nayami-main img {
		display: block;
		width: 100%;
		height: auto;
	}

	/* -----------------------
		point
	----------------------- */
	.point {
		position: relative;
		z-index: 1;
	}
	.point .bg {
		position: absolute;
		top: 0;
		z-index: -1;
	}
	.point .point02_nutrition_05 {
		margin-top: max(calc(-30/750 * 100vw), -30px);
		margin-bottom: max(calc(-33/750 * 100vw), -33px);
	}
	.point .point02_text02 {
		margin-top: min(calc(42/750 * 100vw), 42px);
	}
	.point .point02_bg {
		top: max(calc(-170/750 * 100vw), -170px);
	}
	.scaleUp.trigger.point01_graph {
		position: absolute;
		top: min(calc(55/750 * 100vw), 55px);
		transition: all 1.5s 0s ease;
		transition-delay: 0.09s;
	}
	.point .graph_popup.trigger{
		z-index: 2;
		transition-delay: 1.2s!important;
	}

	/* -----------------------
		recommend
	----------------------- */
	.recommend {
		position: relative;
	}

	/* -----------------------
		sensation
	----------------------- */
	.sensation {
		position: relative;
		background: url(//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/sensation_bg.png) no-repeat center top min(calc(1720/ 800 * 100vw), 1720px) / 100%;
	}
	.sensation .rltv-box>p:not(:first-child) {
		position: absolute;
		top: 0;
	}
	.sensation .sensation_video {
		display: block;
		width: min(calc(631 / 800 * 100vw), 631px);
		height: min(calc(1011 / 800 * 100vw), 1011px);
		border-radius: 999px;
		margin: max(calc(-50 / 800 * 100vw), -50px) auto max(calc(-120 / 800 * 100vw), -120px);
		z-index: -1;
	}
	.sensation .sensation_10,
	.sensation .sensation_03,
	.sensation .sensation_05 {
		position: relative;
		z-index: 2;
	}
	.sensation .premium_plate {
		position: absolute;
		top: 0;
	}
	.sensation .premium_plate.shine::after {
		mask-image: url('//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/premium_plate.png');
	}

	/* -----------------------
		sns
	----------------------- */
	.slick-dots li button::before {
		display: none;
	}
	.sns {
		position: relative;
		background: #000;
	}
	.sns .bg {
		margin-top: max(calc(-200 / 750 * 100vw), -200px);
	}
	.sns_slide {
		margin-top: min(calc(75 / 750 * 100vw), 75px);
	}
	.sns h2 {
		margin-top: min(calc(200 / 750 * 100vw), 200px);
	}
	.sns .sns_wrap {
		width: min(calc(750 / 750 * 100vw), 750px);
	}
	.sns_slide .slick-arrow {
		position: absolute;
		width: min(calc(66 / 750 * 100vw), 66px);
		height: min(calc(66 / 750 * 100vw), 66px);
		top: 44.8%;
		z-index: 4;
	}
	.sns_slide .prev {
		left: 8%;
	}
	.sns_slide .next {
		right: 8%;
	}
	.sns_slide .slick-slide {
		position: relative;
		clip-path: inset(0px round min(calc(70 / 750 * 100vw), 70px));
		width: min(calc(463 / 750 * 100vw), 463px);
	}
	.sns_slide .slick-slide img {
		display: block;
		filter: blur(6px);
		transform: scale(0.8);
		transform-origin: center center;
	}
	.sns_slide .slick-slide.slick-center img,
	.sns_slide .slick-slide.is-next-center img,
	.sns_slide .slick-slide.is-clone-center img {
		filter: blur(0);
		transform: scale(1);
	}
	.sns_slide .slick-dots {
		top: max(calc(-43 / 750 * 100vw), -43px);
		height: 1.7%;
	}
	.sns_slide .slick-dots li {
		width: min(calc(17 / 750 * 100vw), 17px);
		height: min(calc(17 / 750 * 100vw), 17px);
		margin: 0% 2%;
		aspect-ratio: 1 / 1;
		box-sizing: border-box;
		background-color: #fff;
		border-radius: 50%;
		transition: 0.2s;
	}
	.sns_slide .slick-dots li button {
		width: auto;
	}
	.sns_slide .slick-dots li.slick-active {
		background-color: #bf0c0c;
	}
	.sns .note {
		padding-top: 10%;
		width: 90%;
		margin: 0 auto;
	}
	/* -----------------------
		voice
	----------------------- */
	.voice {
		position: relative;
	}
	.voice .voice_slide {
		width: min(calc(750 / 750 * 100vw), 750px);
		margin: 0 auto;
		padding-bottom: min(calc(165 / 750 * 100vw), 165px);
	}
	.voice .voice_slide .slide_item {
		margin: 0 min(calc(40 / 750 * 100vw), 40px) 0 0;
	}
	.voice .voice_slide .slide_item img {
		width: min(calc(500 / 750 * 100vw), 500px);
	}
	.voice .slick-dots {
		width: min(calc(750 / 750 * 100vw), 750px);
		bottom: min(calc(125/ 750 * 100vw), 125px);
		left: 50%;
		transform: translateX(-50%);
		text-align: center;
	}
	.voice .slick-dots li {
		margin: 0 min(calc(12 / 750 * 100vw), 12px) 0 0;
		width: min(calc(86 / 750 * 100vw), 86px);
		height: min(calc(7 / 750 * 100vw), 7px);
	}
	.voice .slick-dots li button {
		content: "";
		padding: 3px;
		width: min(calc(86 / 750 * 100vw), 86px);
		height: min(calc(7 / 750 * 100vw), 7px);
		display: inline-block;
		text-align: center;
		line-height: 1;
		background: #fff;
	}
	.voice .slick-dots li.slick-active button {
		background: #dc4622;
		opacity: 1;
	}
	.voice .note {
		position: absolute;
		bottom: 20px;
		right: 20px;
	}

	/* -----------------------
	vitabrid
	----------------------- */
	.vitabrid {
		position: relative;
	}

	/* -----------------------
	aori
	----------------------- */
	.aori {
		position: relative;
	}

	/* -----------------------
		faq
	----------------------- */
	.faq .acc-box {
		position: relative;
		width: min(calc(670 / 750 * 100vw), 670px);
		margin: 0 auto min(calc(96 / 750 * 100vw), 96px);
	}

	/* Q */
	.faq dt.ttl {
		position: relative;
		display: grid;
		grid-template-columns: min(calc(42 / 750 * 100vw), 42px) 1fr;
		column-gap: min(calc(30 / 750 * 100vw), 30px);
		align-items: center;
		font-size: min(calc(30 / 750 * 100vw), 30px);
		font-weight: 600;
		line-height: 1.2;
		letter-spacing: 0.1em;
		padding: 0 min(calc(70 / 750 * 100vw), 70px) min(calc(30 / 750 * 100vw), 30px) 0;
		margin-bottom: min(calc(30 / 750 * 100vw), 30px);
		border-bottom: #333 solid 1px;
		cursor: pointer;
	}
	.faq dt.ttl span {
		display: block;
		width: min(calc(42 / 750 * 100vw), 42px);
		height: min(calc(37 / 750 * 100vw), 37px);
		background: url(//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/faq_q.png) no-repeat center top / contain;
		flex-shrink: 0;
	}

	/* A */
	.faq dd.text {
		margin: 0;
		display: grid;
		grid-template-columns: min(calc(42 / 750 * 100vw), 42px) 1fr;
		column-gap: min(calc(30 / 750 * 100vw), 30px);
		align-items: start;
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		transition: max-height 0.3s ease, opacity 0.3s ease;
		font-size: min(calc(30 / 750 * 100vw), 30px);
		line-height: 1.35;
		letter-spacing: 0.1em;
	}
	.faq dd.text.open {
		max-height: 500px;
		opacity: 1;
	}
	.faq dd.text span {
		display: block;
		width: min(calc(42 / 750 * 100vw), 42px);
		height: min(calc(37 / 750 * 100vw), 37px);
		background: url(//images.vitabrid.co.jp/sp/imgs/lp/juso/v1/faq_a.png) no-repeat center top / contain;
		flex-shrink: 0;
	}
	.faq dt.ttl::before,
	.faq dt.ttl::after {
		content: "";
		position: absolute;
		top: 0.8em;
		right: min(calc(20 / 750 * 100vw), 20px);
		width: min(calc(18 / 750 * 100vw), 18px);
		height: min(calc(4 / 750 * 100vw), 4px);
		background: #1a1311;
		transition: transform 0.3s ease;
	}
	.faq dt.ttl::after {
		transform: rotate(90deg);
	}
	.faq dt.ttl.open::after {
		transform: rotate(0);
	}

	/* -----------------------
		kettei
	----------------------- */
	.kettei{
		position: relative;
	}
	.kettei h2{
		padding-top: min(calc(80/ 750 * 100vw),80px);
	}

	/* -----------------------
		worrie
	----------------------- */
	.worrie {
		position: relative;
	}
	.worrie .arrow {
		position: absolute;
		top: max(calc(-150 / 750 * 100vw), -150px);
		left: 50%;
		width: min(calc(10 / 750 * 100vw), 10px);
		transform: translateX(-50%);
		z-index: 2;
		animation: updown 1s ease forwards infinite;
	}
	.worrie .worrie_02_image {
		position: absolute;
		width: min(calc(262 / 750 * 100vw), 262px);
		top: 35%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
	.worrie .worrie_sanka {
		display: flex;
		flex-wrap: wrap;
	}
	.worrie .worrie_sanka li {
		margin: 0 auto;
	}
	.worrie .worrie_sanka li:nth-of-type(1) {
		width: min(calc(340 / 750 * 100vw), 340px);
		margin-top: min(calc(20 / 750 * 100vw), 20px);
		margin-left: min(calc(35 / 750 * 100vw), 35px);
		margin-right: 0;
	}
	.worrie .worrie_sanka li:nth-of-type(2) {
		width: min(calc(320 / 750 * 100vw), 320px);
		margin-right: min(calc(32 / 750 * 100vw), 32px);
	}
	.worrie .worrie_sanka li:nth-of-type(3) {
		width: min(calc(399 / 750 * 100vw), 399px);
		margin-top: max(calc(-22 / 750 * 100vw), -22px);
	}

/*----------------------------common*/
.kanyo dl {
	align-items: stretch;
}
.gatt .tbl {
	background: var(--WhitE);
}

/*ispecS*/
.ispec h4{
	padding: 1% 3%;
	text-decoration: underline;
	font-size: 1em;
	text-align: left;
	border-right: 1px solid #aaa;
	border-bottom: 1px solid #aaa;
	background: #eee;
}
.ispec .brB {
	margin-left: 10px;
	padding: 5px;
	border: 1px solid #999;
}
.ispec .box{
	display: none;
}
.ispec .compo{
	display: block;
	margin: 0 0 15px 5px;
	width: 380px;
	padding: 0;
	border: 1px solid #ccc;
	background: #fff;
}

.ibuy{
	margin: 100px auto 0;
	width: 1200px;
	font-family:"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",var(--Fyg);
}
#ibuy .box1{
	padding-bottom: 50px;
	border-bottom: 1px dashed #aaa;
}
#ibuy .box2{
	margin-top: 50px;
}
#ibuy h2{
	font-size: 1.8em;
	letter-spacing: 2px;
	background: #ddd;
	text-align: center;
}
#ibuy h3{
	margin-top: 5px;
	padding-bottom: 5px;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}
#ibuy h4{
	font-weight: bold;
	text-align: center;
	padding-bottom: 5px;
}
#ibuy ul{
	display: flex;
	justify-content: space-between;
	padding: 10px 20px 0;
}
#ibuy .itemli{
	padding: 0 20px;
	width: 232px;
	border-right: 1px dotted #ccc;
}
#ibuy .itemli:last-of-type{
	border-right: 0;
}
#ibuy .itemli div{
	margin-bottom: 10px;
	padding: 0 25px;
	text-align: center;
}
#ibuy label{
	font-size: 18px;
	display: block;
}
#ibuy div:last-of-type label{
	margin-bottom: 0;
}
#ibuy img{
	margin: 10px auto;
	display: block;
	width: 130px;
}
#ibuy .itemli input:checked + label{
	background: #fffbd1;
	border: 2px solid #000;
}
#ibuy .itemli input[type="checkbox"] {
	border: 1px solid #aaaaaa;
	vertical-align: sub;
	-webkit-appearance: none;
	position: relative;
	margin-right: 5px;
	-webkit-border-radius: 3px;
	border-radius: 3px;
	-webkit-box-sizing: border-box;
	width: 20px;
	height: 20px;
	background: #e2e2e2;
	background: -webkit-gradient\( linear, left top, left bottom, color-stop(0.00, #ffffff), color-stop(1.00, #e2e2e2);
}
#ibuy .itemli input[type="checkbox"]:checked{
	background: #e30200;
}
#ibuy .itemli input[type="checkbox"]:checked:before {
	content: "";
	position: absolute;
	left: -1px;
	top: 14px;
	display: block;
	width: 10px;
	height: 4px;
	background: #ffffff;
	-webkit-transform: rotate(45deg);
	-webkit-transform-origin: right center;
}
#ibuy .itemli input[type="checkbox"]:checked:after {
	display: block;
	position: absolute;
	left: 7px;
	top: 14px;
	content: "";
	width: 16px;
	height: 4px;
	background: #ffffff;
	-webkit-transform: rotate(-53deg);
	-webkit-transform-origin: left center;
}
#ibuy select{
	margin-top: 10px;
	padding: 2px 5px;
	width: 100%;
	display: inline-block;
	border: 1px solid #ccc;
	font-size: 0.8em;
}
#ibuy .ctaBtn{
	margin-top: 30px;
	padding-bottom: 50px;
	text-align: center;
}
.compo dl{
	width: auto;
}
.compo2{
	display: flex;
}
.compo2 dl{
	margin-bottom: 10px;
	background: #fff;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	border-left: 1px solid #ccc;
}
.compo2 dl:last-of-type{
	border-right: 1px solid #ccc;
}
.compo2 dt,.compo2 dd{
	margin: 0;
	padding: 5px 3px;
}
.compo2 dt{
	background: #e1e1e1;
	height: 22px;
}
.compo2 dt:before{
	content: none;
}
.compo2 dd{
	height: 80px;
}