@charset "utf-8";

/* -------------------------------------------------
	#fv
------------------------------------------------- */

#fv {
	position: relative;
}
#fv .fv-slider {
	position: relative;
	z-index: 2;
}
#fv .fv-slider::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 30%;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 100%);
    pointer-events: none;
    z-index: 1;
}
#fv .fv-slider img {
	width: 100%;
}
#fv .group {
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
}
#fv .group {
	height: 100%;
	z-index: 4;
}
#fv h1 {
	width: calc(534 var(--pcp));
	height: calc(265 var(--pcv));
	padding-top: calc(49 var(--pcv));
	position: absolute;
	left: 0;
	top: calc(260 var(--pcv));
	transform: translateY(-50%);
	background: rgba(242,127,47,0.9);
}
#fv h1 .text {
	width: calc(345 var(--pcv));
	margin-left: calc(120 var(--pcv));
}
#fv h1 .logo {
	width: calc(411 var(--pcv));
	margin: calc(21 var(--pcv)) 0 0 calc(87 var(--pcv));
}
#fv .copy {
	width: calc(388 var(--pcp));
	position: absolute;
	left: calc(98 var(--pcp));
	top: calc(508 var(--pcv));
	transform: translateY(-50%);
}
#fv .copy li {
	width: calc(147 / 324 * 100%);
}
#fv .copy li img {
	width: 100%;
}

#fv .slick-dots {
	width: 100%;
	display: flex;
	justify-content: center;
	gap: 0 16px;
	position: absolute;
	left: 0;
	bottom: 22px;
	z-index: 10;
}
#fv .slick-dots li {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: #fff;
	overflow: hidden;
}
#fv .slick-dots li.slick-active {
	background: #F40000;
}
#fv .slick-dots li button {
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

@media screen and (max-width:767px) {
	#fv {
		width: 100%;
		overflow: hidden;
	}
	#fv h1 {
		width: 100%;
		height: calc(172 var(--spv));
		padding-top: calc(29 var(--spv));
		top: 0;
		transform: translateY(0);
	}
	#fv h1 .text {
		width: calc(295 var(--spp));
		margin-left: 0;
		position: absolute;
		left: 50%;
		top: calc(118 var(--spv));
		transform: translateX(-50%);
	}
	#fv h1 .logo {
		width: calc(249 var(--spp));
		margin: 0 auto;
		display: block;
	}
	#fv .copy {
		width: calc(273 var(--spp));
		left: 50%;
		transform: translateX(-50%);
		top: auto;
		bottom: calc(40 var(--spv));
	}
	#fv .copy li {
		width: calc(113 / 250 * 100%);
	}
	
	#fv .slick-dots {
		bottom: 21px;
	}
}

/* -------------------------------------------------
	#lead
------------------------------------------------- */

#lead {
	margin-top: 72px;
	text-align: center;
}
#lead .title img {
	width: 329px;
}
#lead .desc {
	margin-top: 35px;
}
#lead .desc p {
	font-size: 20px;
	line-height: calc(38 / 20);
	color: #4E4E4E;
	font-weight: bold;
}
#lead .desc p + p {
	margin-top: 1.4em;
}

@media screen and (max-width:767px) {
	#lead {
		margin-top: 57px;
	}
	#lead .title img {
		width: 238px;
	}
	#lead .desc {
		margin-top: 43px;
	}
	#lead .desc p {
		font-size: 18px;
		line-height: calc(29 / 20);
		text-align: left;
	}
	#lead .desc p + p {
		margin-top: 1.4em;
	}
}

/* -------------------------------------------------
	.bg-forest
------------------------------------------------- */

.bg-forest {
	position: relative;
	overflow: hidden;
}
.bg-forest > section,
.bg-forest > div {
	position: relative;
	z-index: 4;
}
.bg-forest::before {
	width: 100%;
	content: "";
	display: block;
	position: absolute;
	z-index: 2;
}

@media print, screen and (min-width:768px) {
	.bg-forest {
		padding-bottom: 88px;
		background: url("../img/bg_01.jpg") no-repeat center bottom / 1576px auto;
	}
	.bg-forest::before {
		height: 346px;
		bottom: -13px;
		background: linear-gradient(180deg, transparent 0%, #fff 100%);
	}
}

@media print, screen and (min-width:1590px) {
	.bg-forest {
		background-size: 100% auto;
		background-position: center 326px;
	}
}

@media screen and (max-width:767px) {
	.bg-forest {
		padding-bottom: 30px;
		background: url("../img/bg_01_sp.jpg") no-repeat center bottom / 100% auto;
	}
	.bg-forest::before {
		height: 328px;
		bottom: 0;
		background: linear-gradient(transparent 0%, #fff 76.5%);
	}
}

/* -------------------------------------------------
	#basic-info
------------------------------------------------- */

#basic-info {
	margin-top: 68px;
}
#basic-info .col2 {
	background: rgba(255,255,255,0.8);
	border-radius: 14px;
}
#basic-info .title {
	padding: 0 10px;
	text-align: center;
	font-weight: bold;
}
#basic-info .title .small {
	font-size: 18px;
	line-height: 1.3;
	display: block;
}
#basic-info .title .large {
	margin-top: 0.2em;
	font-size: 26px;
	line-height: 1.3;
	display: block;
}
#basic-info .texts dl {
	display: flex;
	flex-wrap: wrap;
}
#basic-info .texts dl dt,
#basic-info .texts dl dd {
	padding: 9px 0 7px;
	font-size: 18px;
	line-height: calc(30 / 18);
}
#basic-info .texts dl dt {
	width: 5em;
	font-weight: bold;
}
#basic-info .texts dl dd {
	width: calc(100% - 5em);
}
#basic-info .texts dl dt:not(:first-of-type),
#basic-info .texts dl dd:not(:first-of-type) {
	border-top: solid 2px #fff;
}

#basic-info .btn {
	width: 348px;
	height: 46px;
	padding: 13px 0 0 58px;
	margin: -23px 0 0 calc(100% - 324px);
	border: solid 3px #179183;
	display: block;
	font-size: 16px;
	position: relative;
	background: #fff;
	transition:
		color 0.2s ease-out,
		background 0.2s ease-out;
}
#basic-info .btn .arrow {
	width: 29px;
	position: absolute;
	right: 14px;
	top: 14px;
	transition: opacity 0.2s ease-out;
}
#basic-info .btn .arrow.wt {
	opacity: 0;
}

@media print, screen and (min-width:768px) {
	#basic-info .col2 {
		padding: 20px 0 12px;
		display: flex;
		align-items: center;
	}
	#basic-info .left {
		width: calc(381 / 1020 * 100%);
		text-align: center;
	}
	#basic-info .texts {
		width: calc(609 / 1020 * 100%);
		padding: 4px 0 24px calc(45 / 1020 * 100%);;
		border-left: solid 1px #707070;
	}
	
	#basic-info .btn:hover {
		color: #fff;
		background: #68B42E;
	}
	#basic-info .btn:hover .arrow.wt {
		opacity: 1;
	}
	#basic-info .btn:hover .arrow.color {
		opacity: 0;
	}
}

@media screen and (max-width:767px) {
	#basic-info {
		margin-top: 200px;
	}
	#basic-info .col2 {
		padding: 37px 0 51px;
	}
	#basic-info .left {
		
	}
	#basic-info .title {
		padding: 0;
	}
	#basic-info .title .small {
		font-size: 16px;
	}
	#basic-info .title .large {
		margin-top: 0.3em;
		font-size: 22px;
	}
	#basic-info .texts dl {
		margin-top: 15px;
	}
	#basic-info .texts dl dt,
	#basic-info .texts dl dd {
		padding: 8px 0 7px;
		font-size: 16px;
		line-height: calc(24 / 16);
	}
	#basic-info .texts dl dt {
		width: 6em;
		padding-left: 1em;
	}
	#basic-info .texts dl dd {
		width: calc(100% - 6em);
		padding-right: 0.8em;
	}

	#basic-info .btn {
		width: 295px;
		padding: 13px 0 0 22px;
		margin: -23px auto 0;
	}
	#basic-info .btn .arrow {
		width: 23px;
	}
}

/* -------------------------------------------------
	#basic-info > .buttons
------------------------------------------------- */

#basic-info .buttons li a {
	width: 100%;
	height: 72px;
	padding-top: 4px;
	border: solid 2px #fff;
	border-radius: 36px;
	font-size: 18px;
	font-weight: bold;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	position: relative;
	text-indent: -1em;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.3);
	transition: background 0.2s ease-out;
}
#basic-info .buttons li a.reserve {
	background: #E33939;
}
#basic-info .buttons li a.line {
	background: #00AF3C;
}
#basic-info .buttons li a .arrow {
	width: 29px;
	position: absolute;
	right: 34px;
	top: 25px;
}

@media print, screen and (min-width:768px) {
	#basic-info .buttons {
		max-width: 845px;
		width: 96%;
		margin: 38px auto 0;
		display: flex;
		justify-content: space-between;
	}
	#basic-info .buttons li {
		width: calc(411 / 845 * 100%);
	}
	#basic-info .buttons li a:hover {
		background: #589496;
	}
}

@media screen and (max-width:767px) {
	#basic-info .buttons {
		margin-top: 45px;
	}
	#basic-info .buttons li + li {
		margin-top: 25px;
	}
	#basic-info .buttons li a.line {
		justify-content: flex-start;
		padding-left: 3.5em;
	}
	#basic-info .buttons li a .arrow {
		width: 24px;
		right: 34px;
	}
}

/* -------------------------------------------------
	#inner-links
------------------------------------------------- */

#inner-links {
	margin-top: 70px;
}
#inner-links ul {
	display: flex;
	flex-wrap: wrap;
}
#inner-links ul li {
	font-size: 16px;
}
#inner-links ul li a {
	height: 68px;
	padding-top: 2px;
	border: solid 3px #F27F22;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	color: #1A1311;
	transition: background 0.2s ease-out;
}

@media print, screen and (min-width:768px) {
	#inner-links ul {
		gap: 12px calc(12 / 1020 * 100%);
	}
	#inner-links ul li {
		width: calc(246 / 1020 * 100%);
		font-weight: bold;
	}
	#inner-links ul li a:hover {
		background: #FFD964;
	}
}

@media screen and (max-width:767px) {
	#inner-links {
		margin-top: 45px;
		text-align: center;
	}
	#inner-links::after {
		width: 27px;
		height: 23px;
		margin-top: 12px;
		content: "";
		display: inline-block;
		background: url("../../../shared/img/arrow_07.svg") no-repeat 0 0 / 100% auto;
	}
	#inner-links ul {
		gap: 6px 0;
		justify-content: space-between;
	}
	#inner-links ul li {
		width: calc(247 / 505 * 100%);
		font-size: 15px;
	}
	#inner-links ul li a {
		height: 36px;
		padding-top: 2px;
		border-width: 2px;
	}
}

/* -------------------------------------------------
	#information
------------------------------------------------- */

#information .white-box {
	padding: 34px calc(87 / 1020 * 100%) 31px;
	background: #fff;
	border-radius: 23px;
	box-shadow: 0 6px 6px 0 rgba(0,0,0,0.2);
}

#information .lead {
	margin-bottom: 49px;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.3;
}
#information .lead .icons {
	vertical-align: middle;
	display: inline-block;
}
#information .lead a {
	margin-left: 15px;
	display: inline-block;
	vertical-align: middle;
}
#information .lead img {
	width: 37px;
}

#information .news li {
	padding: 2px 0 1px;
	font-size: 18px;
	line-height: calc(30 / 18);
	border-left: solid 7px #FF6534;
}
#information .news li + li {
	margin-top: 12px;
}
#information .news li .date {
	display: block;
	font-size: 16px;
}
#information .news li .title {
	display: block;
	font-weight: bold;
}

#information .accordion {
	display: none;
}

#information .more {
	margin-top: 28px;
	border-top: solid 6px #B14435;
}
#information .more button {
	margin: 19px auto 0;
	cursor: pointer;
	background: transparent;
	border: none;
	display: block;
}
#information .more.on button {
	transform: rotateX(180deg);
}
#information .more button img {
	width: 100%;
}

@media print, screen and (min-width:768px) {
	#information {
		padding-bottom: 81px;
		background: url("../../../shared/img/bg_04.png") no-repeat fixed center center / cover;
	}
	
	#information .lead a:hover {
		opacity: 0.7;
	}
	
	#information .news li {
		display: flex;
	}
	#information .news li .date {
		width: 210px;
		padding: 2px 0 0 25px;
	}
	#information .news li .title {
		width: calc(100% - 178px);
	}
	#information .news li .title a:hover {
		color: #FF7600;
	}
	
	#information .accordion .news {
		padding-top: 16px;
	}
}

@media screen and (max-width:767px) {
	#information {
		padding-bottom: 68px;
		background: url(../../../shared/img/bg_04_sp.png) no-repeat fixed center center / cover;
	}
	
	#information .white-box {
		padding: 28px calc(12 / 334 * 100%) 34px;
		border-radius: 20px;
		box-shadow: none;
		border: solid 2px #B9B9B9;
	}

	#information .lead {
		margin-bottom: 26px;
		font-size: 16px;
		line-height: calc(24 / 16);
		text-align: center;
	}
	#information .lead .icons {
		margin-top: 0.6em;
		display: block;
	}
	#information .lead a {
		margin-left: 0;
	}
	#information .lead a + a {
		margin-left: 15px;
	}
	
	#information .news li {
		padding-left: 11px;
		line-height: 1.4;
		border-left-width: 5px;
	}
	#information .news li + li {
		margin-top: 16px;
	}
	#information .news li .title {
		margin-top: 4px;
		font-size: 16px;
	}
	
	#information .accordion .news {
		padding-top: 16px;
	}

	#information .more {
		margin-top: 18px;
		border-top-width: 5px;
	}
	#information .more button {
		width: 22px;
		margin: 8px auto 0;
	}
}

/* -------------------------------------------------
	.slider-type1
------------------------------------------------- */

.slide-wrap1 {
	width: 672px;
	max-width: 100%;
	margin: 0 auto;
	position: relative;
}
.slide-wrap1 p.cs-terop{
	color:#fff;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.8);
	position: absolute;
	top: 20px;
	left: 20px;
	z-index:2;
}
.slider-type1 .slick-arrow {
	cursor: pointer;
	border: none;
	overflow: hidden;
	text-indent: 100px;
	position: absolute;
	top: 50%;
	z-index: 10;
}
.slider-type1 .slick-dots {
	width: 100%;
	display: flex;
	justify-content: center;
	gap: 0 8px;
	position: absolute;
	bottom: 23px;
	z-index: 10;
}
.slider-type1 .slick-dots li {
	width: 15px;
	height: 15px;
	background: #fff;
	border-radius: 50%;
	overflow: hidden;
}
.slider-type1 .slick-dots li.slick-active {
	background: #FF0000;
}
.slider-type1 .slick-dots li button {
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

@media print, screen and (min-width:768px) {
	.slider-type1 .slick-arrow {
		width: 24px;
		height: 45px;
		background: url("../../../shared/img/arrow_09.svg") no-repeat 0 0 / 100% auto;
	}
	.slider-type1 .slick-arrow.slick-prev {
		left: -48px;
		transform: rotateY(180deg) translateY(-50%);
	}
	.slider-type1 .slick-arrow.slick-next {
		right: -48px;
		transform: translateY(-50%);
	}
	
	.slider-type1 .slick-arrow:hover,
	.slider-type1 .slick-dots li:hover {
		opacity: 0.7;
	}
}

@media print, screen and (min-width:768px) and (max-width:800px) {
	.slider-type1 .slick-arrow.slick-prev {
		left: -29px;
	}
	.slider-type1 .slick-arrow.slick-next {
		right: -29px;
	}
}

@media screen and (max-width:767px) {
	.slider-type1 .slide-wrap1 {
		overflow: hidden;
	}
	
	.slider-type1 .slick-arrow {
		width: calc(33 var(--spv));
		height: calc(40 var(--spv));
		background: url("../../../shared/img/arrow_10.svg") no-repeat 0 0 / 100% auto;
	}
	.slider-type1 .slick-arrow.slick-prev {
		left: 0;
		transform: translate(-62%,-50%) rotateY(180deg);
	}
	.slider-type1 .slick-arrow.slick-next {
		right: 0;
		transform: translate(62%,-50%);
	}
	
	.slider-type1 .slick-dots {
		gap: 0 5px;
		bottom: 13px;
	}
	.slider-type1 .slick-dots li {
		width: 9px;
		height: 9px;
	}
}

/* -------------------------------------------------
	#scene
------------------------------------------------- */

@media print, screen and (min-width:768px) {
	#scene {
		padding-bottom: 81px;
		background: url(../../../shared/img/bg_04.png) no-repeat fixed center center / cover;
	}
}

@media screen and (max-width:767px) {
	#scene {
		width: 100%;
		overflow: hidden;
		padding-bottom: 68px;
		background: url(../../../shared/img/bg_04_sp.png) no-repeat fixed center center / cover;
	}
}

/* -------------------------------------------------
	#course
------------------------------------------------- */

#course {
	width: 100%;
	overflow: hidden;
}
#course .courses li button {
	width: 237px;
	height: 77px;
	background: #fff;
	border-radius: 8px;
	position: relative;
	display: block;
	text-align: left;
	cursor: pointer;
	color: #000;
}
#course .courses li:nth-child(1) button { border: solid 3px #20992A; }
#course .courses li:nth-child(2) button { border: solid 3px #20992A; }
#course .courses li:nth-child(3) button { border: solid 3px #0092E5; }
#course .courses li:nth-child(4) button { border: solid 3px #DC000C; }
#course .courses li:nth-child(5) button { border: solid 3px #DC000C; }

#course .courses li.bt1.current button {
	background: #99f6a1;
}
#course .courses li.bt2.current button {
	background: #99e7f6;
}
#course .courses li.bt3.current button {
	background: #ffb9b9;
}
#course .courses li button .num {
	font-family: Roboto , 'Albert Sans';
	font-weight: 400;
	position: absolute;
	left: 13px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 50px;
}
#course .courses li button .course {
	margin-left: 68px;
	display: block;
	font-size: 20px;
}
#course .courses li button .lv {
	margin: 0.4em 0 0 56px;
	font-size: 14px;
	display: block;
}
#course .courses li button .lv .leaf {
	margin-left: 11px;
	display: inline-block;
}
#course .courses li button .lv .leaf img {
	width: 14px;
	transform: translateY(-1px);
}
#course .courses li button .lv .leaf img + img {
	margin-left: 6px;
}

#course .right .course {
	height: 0;
	overflow: hidden;
	position: relative;
	z-index: 2;
	opacity: 0;
}
#course .right .course.current {
	height: auto;
	overflow: visible;
	z-index: 4;
	opacity: 1;
}

@media print, screen and (min-width:768px) {
	#course .pic1 {
		width: 96%;
		max-width: 1323px;
		margin: 0 auto;
		display: block;
	}
	#course .col2 {
		width: 96%;
		max-width: 1323px;
		margin: 21px auto 0;
		display: flex;
		align-items: flex-start;
	}
	#course .col2 .left {
		width: 277px;
		margin-left: 71px;
	}
	#course .courses li {
		position: relative;
	}
	#course .courses li + li {
		margin-top: 10px;
	}
	#course .courses li.bt1 button:hover {
		background: #99f6a1;
	}
	#course .courses li.bt2 button:hover {
		background: #99e7f6;
	}
	#course .courses li.bt3 button:hover {
		background: #ffb9b9;
	}
	#course .courses li.current::after {
		width: 0;
		height: 0;
		content: "";
		display: block;
		border-width: 13px 0 13px 20px;
		border-style: solid;
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
	}
	#course .courses li.bt1.current::after {
		border-color: transparent transparent transparent #20992A;
	}
	#course .courses li.bt2.current::after {
		border-color: transparent transparent transparent #0092E5;
	}
	#course .courses li.bt3.current::after {
		border-color: transparent transparent transparent #DC000C;
	}
	#course .col2 .right {
		margin-left: 107px;
	}
}

@media print, screen and (min-width:768px) and (max-width:1400px) {
	#course .col2 .left {
		margin-left: 5.6%;
	}
	#course .col2 .right {
		width: calc(86% - 277px);
		margin: 0 4% 0 4.2%;
	}
	#course .slick-arrow.slick-prev {
		left: 5px;
	}
	#course .slick-arrow.slick-next {
		right: 5px;
	}
}

@media screen and (max-width:767px) {
	#course .courses {
		margin-top: 21px;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		gap: 11px 0;
	}
	
	#course .left::after {
		width: 0;
		height: 0;
		margin: 15px auto 6px;
		content: "";
		display: block;
		border-width: 16px 13px 0 13px;
		border-color: #F27F22 transparent transparent transparent;
		border-style: solid;
	}
	
	#course .courses {
		max-width: 334px;
		margin-left: auto;
		margin-right: auto;
	}
	#course .courses li:nth-child(1) {
		margin-left: calc(86 / 334 * 100%);
	}
	#course .courses li:nth-child(1) ~ li {
		width: calc(162 / 334 * 100%);
	}
	#course .courses li button {
		width: 162px;
		height: 52px;
		border-radius: 6px;
	}

	#course .courses li button .num {
		left: 12px;
		font-size: 30px;
	}
	#course .courses li button .course {
		margin-left: 40px;
		font-size: 15px;
	}
	#course .courses li button .lv {
		margin: 0 0 0 40px;
		font-size: 13px;
	}
	#course .courses li button .lv .leaf {
		margin-left: 6px;
	}
	#course .courses li button .lv .leaf img {
		width: 11px;
	transform: translateY(0);
	}
	#course .courses li button .lv .leaf img + img {
		margin-left: 3px;
	}
	
	#course .right {
		width: 100%;
		overflow: hidden;
	}
}

/* -------------------------------------------------
	#facility
------------------------------------------------- */

#facility {
	margin-top: 111px;
}
#facility .info {
	display: flex;
	gap: 25px calc(24 / 1020 * 100%);
	flex-wrap: wrap;
}
#facility .info li {
	width: calc(237 / 1020 * 100%);
	height: 140px;
	padding-top: 91px;
	text-align: center;
	border-radius: 14px;
	font-size: 18px;
	font-weight: bold;
}
#facility .info li.p {
	background: #fff url("../../../shared/img/ico_06.svg") no-repeat center 41px / 48px auto;
}
#facility .info li.rental {
	background: #fff url("../../../shared/img/ico_07.svg") no-repeat center 35px / 45px auto;
}
#facility .info li.wash {
	background: #fff url("../../../shared/img/ico_08.svg") no-repeat center 37px / 37px auto;
}
#facility .info li.rest {
	background: #fff url("../../../shared/img/ico_09.svg") no-repeat center 32px / 40px auto;
}
#facility .info li.locker {
	background: #fff url("../../../shared/img/ico_10.svg") no-repeat center 34px / 37px auto;
}
#facility .info li.food {
	background: #fff url("../../../shared/img/ico_11.svg") no-repeat center 34px / 37px auto;
}
#facility .info li.wifi {
	background: #fff url("../../../shared/img/ico_12.svg") no-repeat center 37px / 45px auto;
}
#facility .info li.ins {
	background: #fff url("../../../shared/img/ico_13.svg") no-repeat center 32px / 34px auto;
}

@media print, screen and (min-width:768px) {
	#facility {
		padding-bottom: 190px;
		background: url("../../../shared/img/bg_05.png") no-repeat fixed center center / cover;
	}
}

@media screen and (max-width:767px) {
	#facility {
		margin-top: 68px;
		padding-bottom: 140px;
		background: url("../../../shared/img/bg_05_sp.png") no-repeat fixed center center / cover;
	}
	#facility .info {
		justify-content: space-between;
		gap: calc(11 var(--spv)) 0;
	}
	#facility .info li {
		width: calc(162 / 334 * 100%);
		padding-top: 96px;
		font-size: 16px;
	}
}

/* -------------------------------------------------
	#price
------------------------------------------------- */

#price {
	position: relative;
}
#price::before {
	width: 100%;
	display: block;
	content: "";
	position: absolute;
	left: 0;
	top: 0;
}
#price .bg-color {
	background: #A74130;
}

#price .h-type1 {
	padding: 0;
	background: transparent;
}

@media print, screen and (min-width:768px) {
	#price {
		margin-top: -4.2vw;
		padding-top: 7vw;
	}
	#price::before {
		height: 7vw;
		background: url("../../../shared/img/bg_02.svg") no-repeat center top / 100% auto;
	}
	#price .bg-color {
		padding-bottom: 121px;
	}
}

@media screen and (max-width:767px) {
	#price {
		margin-top: -12vw;
		padding-top: 29.6vw;
	}
	#price::before {
		height: 29.6vw;
		background: url("../../../shared/img/bg_02_sp.svg") no-repeat center top / 100% auto;
	}
	#price .bg-color {
		padding-bottom: 74px;
	}
}

/* -------------------------------------------------
	#price > .white-upper
------------------------------------------------- */

#price .white-upper {
	padding: 68px calc(58 var(--pcp)) 52px;
	background: #fff;
	border-radius: 42px;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
}

#price .white-upper .tab {
	width: 580px;
	margin: 0 auto 51px;
	display: flex;
	border-radius: 6px;
	overflow: hidden;
}
#price .white-upper .tab li {
	width: 50%;
}
#price .white-upper .tab li button {
	width: 100%;
	height: 57px;
	background: #D8D2CE;
	border: none;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 20px;
	color: #393939;
	cursor: pointer;
}
#price .white-upper .tab li button.on {
	background: #FFC406;
	color: #000000;
	font-weight: bold;
}

#price .white-upper .tab-cont:not(.on) {
	display: none;
}

#price .white-upper .tab-cont > section + section {
	margin-top: 35px;
}

#price .white-upper .headline {
	margin-bottom: 0.7em;
	font-size: 22px;
	line-height: 1.3;
	font-weight: bold;
	text-align: center;
}
#price .white-upper .headline.color {
	color: #EA580C;
}

#price .white-upper .notes {
	margin-top: 8px;
}
#price .white-upper .notes li,
#price .bottom-box3 .notes li{
	font-size: 15px;
	line-height: calc(24 / 15);
	text-indent: -1em;
	margin-left: 1em;
}

@media print, screen and (min-width:768px) {
	#price .white-upper {
		width: 96%;
		max-width: 1136px;
		margin: 60px auto 0;
	}
}

@media screen and (max-width:767px) {
	#price .white-upper {
		padding: 28px calc(13 / 334 * 100%) 36px;
		border-radius: 15px;
	}

	#price .white-upper .tab {
		width: 100%;
		margin: 0 auto 45px;
	}
	#price .white-upper .tab li button {
		width: 100%;
		height: 60px;
		font-size: 15px;
		line-height: 1.4;
	}

	#price .white-upper .tab-cont > section + section {
		margin-top: 42px;
	}

	#price .white-upper .headline {
		font-size: 18px;
	}
	
	#price .white-upper .notes {
		margin-top: 0.8em;
	}
	#price .white-upper .notes li,
	#price .bottom-box3 .notes li {
		font-size: 14px;
		line-height: calc(22 / 14);
	}

}

/*注釈*/
.notes,
.notes ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.notes {
  font-size: 14px;
  line-height: 1.6;
}
.notes > li {
  padding-left: 1em;
  text-indent: -1em;
  margin-bottom: 2px;
}
.notes li ul {
  margin-top: 4px;
  text-indent: 0;
}
.notes li ul li {
  position: relative;
/*  padding-left: 1em;*/
  margin-bottom: 2px;
}
.notes li ul li::before {
  content: "・";
  position: absolute;
  left: 0;
}

@media screen and (max-width: 768px) {
  .notes {
    font-size: 13px;
  }
}

/* -------------------------------------------------
	#price テーブル1
------------------------------------------------- */

.price-table-container {
	width: 1020px;
	margin: 40px auto;
	font-family: "Meiryo", "メイリオ", sans-serif;
	color: #333;
}

.price-table {
	width: 100%;
	border-collapse: collapse;
	border: 3px solid #f05a28;
	border-radius: 8px;
}

.price-table th, 
.price-table .label-time,
.price-table .label-car {
	font-size: 18px;
	font-weight: normal;
}
.price-table .label-daytype{
	font-size: 18px;
	font-weight: bold;
}
.price-table th, .price-table td {
	border: 1px solid #fbd9c5;
	padding: 14px 15px 12px;
	text-align: center;
	vertical-align: middle;
}

/* ヘッダー部分 */
.price-table thead th {
	background-color: #fff6ed;
}
.label-car, .label-time {
	color: #f05a28;
}
.price-table tbody th {
	background-color: #fff;
	line-height: 1.4;
}
.price-table td {
	font-family: "Roboto", sans-serif;
	font-size: 1.3em;
	font-weight: bold;
	width: 23%;
	letter-spacing: 0.05em;
}
.price-table tbody tr:nth-child(even) {
	background-color: #fffcfb;
}

@media screen and (min-width:768px) {
	.price-table tbody th.tbl-l2{
		padding: 1.2em 0 .8em;
	}
}

@media screen and (max-width:767px) {
	.price-table th, 
	.price-table .label-time,
	.price-table .label-car {
		font-size: 12px;
	}
	.price-table .label-car {
		width:45%;
	}
	.price-table .label-daytype{
		font-size: 13px;
	}
	.price-table th, .price-table td {
		padding: 8px 6px;
	}
	.price-table td {
		font-size: 13px;
	}
}

/* -------------------------------------------------
	#price テーブル2
------------------------------------------------- */

.price-table2 {
	width: 100%;
	border-collapse: separate; 
	border-spacing: 0;
	border: 2px solid #d1d5db;
	border-radius: 8px;
	overflow: hidden;
}
.price-table2 th, 
.price-table2 .label-time,
.price-table2 .label-category {
	font-size: 18px;
	font-weight: normal;
}
.price-table2 .label-daytype {
	font-size: 18px;
	font-weight: bold;
}
.price-table2 th, .price-table2 td {
	border-bottom: 1px solid #d1d5db;
	border-right: 1px solid #d1d5db;
	padding: 18px 15px;
	text-align: center;
	vertical-align: middle;
}
.price-table2 th:last-child, 
.price-table2 td:last-child {
	border-right: none;
}
.price-table2 tbody tr:last-child th,
.price-table2 tbody tr:last-child td {
	border-bottom: none;
}
.price-table2 thead th {
	background-color: #f1f5f9;
	color: #333;
}
.price-table2 tbody th {
	background-color: #fff;
}

.price-table2 td {
	font-family: "Roboto", sans-serif;
}

@media print, screen and (min-width:768px) {
	.price-table2 td {
		font-size: 1.3em;
		font-weight: bold;
		width: 23%;
		letter-spacing: 0.05em;
	}
}

@media screen and (max-width:767px) {
	.price-table2 th, 
	.price-table2 .label-time,
	.price-table2 .label-category {
		font-size: 13px;
	}
	.price-table2 .label-daytype {
		font-size: 14px;
	}
	.price-table2 th, .price-table2 td {
		padding: 8px 6px;
	}
	.price-table2 td {
			font-family: "Roboto", sans-serif;
			font-size: 13px;
			font-weight: bold;
			letter-spacing: 0.05em;
	}
}

/* -------------------------------------------------
	#price テーブル3
------------------------------------------------- */

.price-table3 {
	width: 100%;
	border-collapse: separate; 
	border-spacing: 0;
	border: 2px solid #d1d5db;
	border-radius: 8px;
	overflow: hidden;
}

.price-table3 th, 
.price-table3 .label-time,
.price-table3 .label-car {
	font-size: 18px;
	font-weight: normal;
}
.price-table3 .label-daytype {
	font-size: 18px;
	font-weight: bold;
}
.price-table3 th, .price-table3 td {
	border-bottom: 1px solid #d1d5db;
	border-right: 1px solid #d1d5db;
	padding: 18px 15px;
	text-align: center;
	vertical-align: middle;
}
.price-table3 th:last-child, 
.price-table3 td:last-child {
	border-right: none;
}

.price-table3 tbody tr:last-child th,
.price-table3 tbody tr:last-child td {
	border-bottom: none;
}
.price-table3 thead th {
	background-color: #f1f5f9;
	color: #333;
}
.price-table3 tbody th {
	background-color: #fff;
}

.price-table3 td:not(.text-parkset) {
	font-family: "Roboto", sans-serif;
}

@media print, screen and (min-width:768px) {
	.price-table3 tbody th {
		line-height: 1.4;
	}
	.price-table3 td {
		font-size: 1.3em;
		font-weight: bold;
		width: 23%;
		letter-spacing: 0.05em;
	}
	.text-parkset {
		font-size: 18px!important;
	}
}

@media screen and (max-width:767px) {
	.price-table3 th, 
	.price-table3 .label-time,
	.price-table3 .label-category {
	font-size: 12px;
	}
	.price-table3 .label-daytype {
		font-size: 13px;
	}
	.price-table3 th, .price-table3 td {
		padding: 8px 6px;
		line-height: 1.4;
	}
	.price-table3 td {
		font-family: "Roboto", sans-serif;
		font-size: 13px;
		font-weight: bold;
		letter-spacing: 0.05em;
	}
	.price-table3 .label-car {
    font-size: 13px;
	}
}

/* -------------------------------------------------
	#price > .bottom-box1
------------------------------------------------- */

#price .bottom-box1 {
	width: 546px;
	margin: 56px auto 0;
	padding: 40px 50px 43px;
	background: #fff;
	border-radius: 42px;
	box-shadow: 2px 3px 6px 0 rgba(0,0,0,0.2);
}
#price .bottom-box1 .title-h {
	padding-left: 105px;
	position: relative;
}
#price .bottom-box1 .title-h .ex {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: #A74130;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 22px;
	font-weight: bold;
	color: #fff;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	padding-top:3px;
}
#price .bottom-box1 .title-h .title {
	font-size: 22px;
	font-weight: bold;
	display: block;
}
#price .bottom-box1 .title-h .note {
	margin-top: 0.9em;
	font-size: 15px;
	display: block;
}

#price .bottom-box1 .texts {
	margin-top: 35px;
	padding: 39px 37px 40px;
	background: #F27F22;
	border-radius: 25px;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
}
#price .bottom-box1 .texts .sub-title {
	margin-bottom: 30px;
	font-size: 18px;
	letter-spacing: 0.17em;
	color: #E6E6E6;
	font-family: 'Albert Sans';
	font-weight: 700;
	text-align: center;
}
#price .bottom-box1 .texts .item {
	font-size: 18px;
	line-height: calc(32 / 18);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	color: #fff;
}
#price .bottom-box1 .texts .item .text1 {
	width: 6em;
	display: inline-block;
}
#price .bottom-box1 .texts .item .text2 {
	width: 8em;
	display: inline-block;
}
#price .bottom-box1 .texts .item .text3 {
	text-align: right;
	display: inline-block;
	font-family: "Roboto", sans-serif;
}
#price .bottom-box1 .texts .all {
	margin-top: 14px;
	padding-top: 20px;
	font-size: 18px;
	line-height: calc(32 / 18);
	color: #fff;
	border-top: solid 1px #D9D9D9;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
#price .bottom-box1 .texts .all .text1 {
	display: inline-block;
}
#price .bottom-box1 .texts .all .text3 {
	font-size: 30px;
	line-height: 1;
	font-family: "Roboto", sans-serif;
}

@media screen and (max-width:767px) {
	#price .bottom-box1 {
		width: 100%;
		margin: 42px auto 0;
		padding: 24px 13px 19px;
		border-radius: 13px;
	}
	#price .bottom-box1 .title-h {
		padding-left: 73px;
	}
	#price .bottom-box1 .title-h .ex {
		width: 58px;
		height: 58px;
		font-size: 18px;
	}
	#price .bottom-box1 .title-h .title {
		font-size: 16px;
	}
	#price .bottom-box1 .title-h .note {
		font-size: 14px;
	}

	#price .bottom-box1 .texts {
		margin-top: 26px;
		padding: 22px 16px 24px;
		border-radius: 18px;
	}
	#price .bottom-box1 .texts .sub-title {
		margin-bottom: 22px;
		font-size: 15px;
	}
	#price .bottom-box1 .texts .item {
		font-size: 14px;
		line-height: calc(32 / 14);
	}
	#price .bottom-box1 .texts .all {
		margin-top: 7px;
		padding-top: 9px;
		font-size: 14px;
		line-height: calc(32 / 14);
	}
	#price .bottom-box1 .texts .all .text3 {
		font-size: 24px;
	}
}

/* -------------------------------------------------
	#price > .bottom-col2
------------------------------------------------- */

/*#price .bottom-col2 > section {
	padding: 40px calc(55 / 1136 * 100%) 35px;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
	background: #fff;
	border-radius: 42px;
}*/
#price .bottom-box2 {
	width: 546px;
	margin: 56px auto 0;
    padding: 40px 50px 43px;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
	background: #fff;
	border-radius: 42px;
}
#price .bottom-col2 .bottom-box3 {
	padding: 40px calc(40 / 1136 * 100%) 35px;
}
#price .bottom-box2 .title {
	padding-top: 90px;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	background: url("../../../shared/img/ico_24.svg") no-repeat center top / 41px auto;
}
#price .bottom-box2 .desc {
	margin-top: 1em;
	font-size: 18px;
	line-height: calc(30 / 18);
}
#price .bottom-box3 {
	width: 870px;
    max-width: 100%;
	margin: 56px auto 0;
    padding: 40px 50px 32px;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
	background: #fff;
	border-radius: 42px;
}

#price .bottom-box3 .title {
	font-size: 20px;
	font-weight: bold;
}
#price .bottom-box3 ul {
	margin-top: 18px;
}
#price .bottom-box3 ul li {
	font-size: 18px;
	line-height: calc(30 / 18);
	text-indent: -1em;
	margin-left: 1em;
}
#price .bottom-box3 ul li ul{
	margin-top: 5px;
	padding-left:0!important;
}
#price .bottom-box3 .notes li ul li::before {
	display:none;
}

@media print, screen and (min-width:768px) {
	#price .bottom-col2 {
		width: 96%;
		max-width: 1136px;
		margin: 71px auto 0;
		display: flex;
		justify-content: space-between;
	}
	#price .bottom-col2 > section {
		width: calc(556 / 1136 * 100%);
	}
}

@media screen and (max-width:767px) {
	#price .bottom-col2 > section {
		padding: 23px calc(18 var(--spv)) 21px;
		box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
		border-radius: 17px;
	}
	#price .bottom-col2 > section.bottom-box3 {
		padding-top: 29px;
	}

	#price .bottom-box2 {
		width: 100%;
		margin-top: 42px;
		padding: 30px 40px;
	}
	#price .bottom-box2 .title {
		padding-top: 66px;
		font-size: 18px;
		background-size: 30px auto;
	}
	#price .bottom-box2 .desc {
		margin-top: 1em;
		font-size: 15px;
		line-height: calc(25 / 15);
	}

	#price .bottom-box3 {
		margin-top: 28px;
		padding: 40px 30px 30px 10px;
	}
	#price .bottom-box3 .title {
		font-size: 18px;
		text-align: center;
	}
	#price .bottom-box3 ul {
		margin-top: 20px;
	}
	#price .bottom-box3 ul li {
		font-size: 15px;
		line-height: calc(25 / 15);
	}
	#price .bottom-box3 .notes li ul{
	display:none;
	}
}

/* -------------------------------------------------
	#access
------------------------------------------------- */

#access .map-wrap {
	overflow: hidden;
}
#access iframe {
	width: 100%;
	border: none;
}

#access .info li {
	position: relative;
}
#access .info li::before {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 0.8em;
	transform: translateY(-50%);
}
#access .info li.address::before {
	width: 25px;
	height: 32px;
	background: url("../../../shared/img/ico_14.svg") no-repeat 0 0 / 100% auto;
	left: 1px;
}
#access .info li.car::before {
	width: 24px;
	height: 22px;
	background: url("../../../shared/img/ico_15.svg") no-repeat 0 0 / 100% auto;
}

@media print, screen and (min-width:768px) {
	#access iframe {
		height: calc(582px + 59px);
		margin-top: -59px;
	}
	
	#access .info {
		margin-top: 33px;
		position: relative;
		display: flex;
		gap: 0 60px;
	}
	#access .info li {
		padding-left: 36px;
		font-size: 18px;
		line-height: calc(30 / 18);
	}
}

@media screen and (max-width:767px) {
	#access .map-wrap {
		position: relative;
	}
	#access .spacer {
		width: 100%;
		position: relative;
		z-index: 2;
	}
	#access iframe {
		width: 100%;
		height: calc(100% + 59px);
		
		position: absolute;
		left: 0;
		top: -59px;
		z-index: 4;
	}
	
	#access .info {
		margin-top: 31px;
	}
	#access .info li {
		padding-left: 45px;
		font-size: 16px;
		line-height: calc(26 / 16);
	}
	#access .info li.address {
		padding-bottom: 16px;
		margin-bottom: 15px;
		border-bottom: solid 1px #707070;
	}
}

/* -------------------------------------------------
	#bike
------------------------------------------------- */

#bike {
	margin-top: 3px;
}
#bike .lead {
	margin-top: 30px;
	font-size: 18px;
	text-align: center;
}
#bike .lead::before {
	width: 22px;
	height: 24px;
	margin-right: 12px;
	background: url("../../../shared/img/ico_23.svg") no-repeat 0 0 / 100% auto;
	content: "";
	display: inline-block;
	vertical-align: -6px;
}

#bike .bikes {
	margin-top: 70px;
	display: flex;
	flex-wrap: wrap;
}
#bike .bikes.modal-text {
	margin-top: 20px;
}
#bike .more .bikes {
	margin-top: 0;
	border-top: solid 80px #fff;
}
#bike .bikes li button {
	background: transparent;
	border: none;
	cursor: pointer;
}
#bike .bikes li button img {
	width: 100%;
	transition: opacity 0.2s ease-out;
}
#bike .bikes li button .cate {
	padding-top: 0.6em;
	border-top: solid 1px #C3C3C3;
	font-size: 14px;
	line-height: 1.4;
	color: #000000;
	transition: color 0.2s ease-out;
}
#bike .bikes li button .cate span{
	display: block;
}
#bike .bikes li button .title {
	padding-top: 5px;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.3;
	color: #000000;
	transition: color 0.2s ease-out;
}
#bike .bikes li button .desc {
	display: none;
}

#bike .more {
	display: none;
}

#bike .btn {
	width: 273px;
	height: 49px;
	margin: 58px auto 0;
	padding-top: 2px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 18px;
	font-weight: bold;
	color: #4D4D4D;
	border: solid 2px #F27F22;
	border-radius: 25px;
	transition: background 0.2s ease-out;
}
#bike .btn::before {
	content: "さらに見る";
}
#bike .btn.on::before {
	content: "戻す";
}
#bike .bikes.modal-text li {
	width: 100%;
}

@media print, screen and (min-width:768px) {
	#bike .bikes {
		gap: 60px calc(24 / 1368 * 100%);
	}
	#bike .bikes li {
		width: calc(324 / 1368 * 100%);
	}
	
	#bike .bikes li button:hover img {
		opacity: 0.6;
	}
	#bike .bikes li button:hover .title {
		color: #E56600;
	}
	
	#bike .btn:hover {
		background: #FFD964;
	}
}

@media screen and (max-width:767px) {
	#bike {
		margin-top: 2px;
	}
	#bike .lead {
		margin-top: 20px;
		font-size: 15px;
	}
	#bike .lead::before {
		margin: 0 auto 0.5em;
		display: block;
		vertical-align: 0;
	}

	#bike .bikes {
		margin-top: 35px;
		justify-content: space-between;
		gap: 20px 0;
	}
	#bike .more .bikes {
		margin-top: 0;
		border-top: solid 20px #fff;
	}
	#bike .bikes li {
		width: calc(162 / 334 * 100%);
	}
	#bike .bikes li button img {
		width: 100%;
		transition: opacity 0.2s ease-out;
	}
	#bike .bikes li button .title {
		font-size: 14px;
		line-height: calc(20 / 14);
	}

	#bike .btn {
		margin: 58px auto 0;
	}
	#bike .btn::before {
		content: "さらに見る";
	}
	#bike .btn.on::before {
		content: "戻す";
	}
}

/* -------------------------------------------------
	バイクモーダル
------------------------------------------------- */

#bike-modal-base,
#bike-modal-cont {
	position: fixed;
	left: 0;
	top: 0;
	display: none;
}

#bike-modal-base {
	width: 100%;
	height: 100vh;
	background: #000;
	opacity: 0.6;
	z-index: 200;
}
#bike-modal-cont {
	width: 96%;
	max-width: 846px;
	max-height: 90vh;
	background: #FFE79B;
	z-index: 210;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}
#bike-modal-cont .scroll-box {
	max-height: 90vh;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
#bike-modal-cont .inner {
	width: calc(800 / 845 * 100%);
	padding: 30px 0 35px;
	margin: 0 auto;
}
#bike-modal-cont img {
	width: 100%;
}
#bike-modal-cont .cate {
	margin: 1.4em 0 0;
	font-size: 16px;
	line-height: 1.4;
	text-align: center;
}
#bike-modal-cont .cate span{
	display:block;
}
#bike-modal-cont .title {
	margin: .3em 0 1em;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
#bike-modal-cont .desc {
	font-size: 16px;
	line-height: calc(24 / 16);
}
#bike-modal-cont .close {
	width: 37px;
	height: 37px;
	border: none;
	cursor: pointer;
	display: block;
	background: url("../../../shared/img/close_02.svg") no-repeat 0 0 / 100% auto;
	position: absolute;
	right: -50px;
	top: -30px;
}

@media print, screen and (min-width:768px) {
	#bike-modal-cont .title br {
		display: none !important;
	}
	#bike-modal-cont .close:hover {
		opacity: 0.7;
	}
}

@media screen and (max-width:767px) {
	#bike-modal-cont {
		width: calc(334 / 375 * 100%);
		max-height: 82vh;
	}
	#bike-modal-cont .scroll-box {
		max-height: 82vh;
	}
	#bike-modal-cont .inner {
		width: calc(301 / 334 * 100%);
		padding: 24px 0 22px;
	}
	#bike-modal-cont .title {
		margin: 1em 0 0.5em;
		font-size: 16px;
		line-height: calc(30 / 16);
	}
	#bike-modal-cont .desc {
		font-size: 15px;
		line-height: calc(24 / 15);
	}
	#bike-modal-cont .close {
		width: 29px;
		height: 29px;
		right: 0;
		top: -47px;
	}
}



/* -------------------------------------------------
	テキストモーダルリンク
------------------------------------------------- */
.js-size-trigger {
    display: flex;
    justify-content: center; 
    align-items: center;
    width: 100%;
    background: none;
    border: none;
}

.modal-Link-text {
    color: #2e38b9;
    font-size: 20px;
    cursor: pointer;
    margin: 0;
}
.modal-Link-text::after {
    content: "";
    display: inline-block;
    width: 18px;
    height: 18px;
    margin-left: 8px;
    background: url(/shared/img/arrow_11.svg) no-repeat center center / contain;
}
.modal-Link-text:hover {
    color:#E85400;
}
.modal-Link-text:hover::after {
    transform: translateX(3px);
    transition: transform 0.2s ease;
}

/* モーダルが開く前のコンテンツは隠す */
.js-size-trigger .modal-table-content {
	display: none;
}

#bike-modal-cont:has(.modal-table-content) {
	background: #fff !important;
	max-width: 500px !important;
}
#bike-modal-cont .modal-table-title {
	color: #F27F22;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 20px;
	display: block;
}
#bike-modal-cont .size-table {
	width: 100% !important;
	border-collapse: collapse;
	margin: 0 auto;
	table-layout: fixed;
}
#bike-modal-cont .size-table th,
#bike-modal-cont .size-table td {
	border: 1px solid #333;
	padding: 10px 5px;
	text-align: center;
	font-size: 16px;
}
#bike-modal-cont .size-table th {
	background-color: #8b8b8b;
	color: #fff;
}
#bike-modal-cont:has(.modal-table-content) .close {
	opacity: 1;
}
#bike-modal-cont .modal-Link-text {
    display: none !important;
}

@media screen and (max-width: 767px) {
	#bike-modal-cont:has(.modal-table-content) {
		width: 90% !important;
	}
	#bike-modal-cont .modal-table-title {
		font-size: 16px;
		line-height: 1.4;
	}
	#bike-modal-cont .size-table th,
	#bike-modal-cont .size-table td {
		font-size: 14px;
		padding: 8px 2px;
	}
	.modal-Link-text {
    font-size: 16px;
	}
}

/* -------------------------------------------------
	#program
------------------------------------------------- */

#program {
	margin-top: 78px;
}
#program .white-box {
	padding: 45px 0 50px;
	background: #fff;
	border-radius: 23px;
	box-shadow: 0 6px 6px rgba(0,0,0,0.2);
}
#program .programs li .title {
	text-align: center;
	font-size: 22px;
	font-weight: bold;
}
#program .programs li .desc {
	margin-top: 0.8em;
	text-align: center;
	font-size: 16px;
	line-height: calc(24 / 16);
}
#program .programs li .card {
	margin-top: 18px;
	padding-bottom: 28px;
	background: #fff;
	border-radius: 19px;
	overflow: hidden;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
}
#program .programs li .card .group1 {
	width: calc(273 / 323 * 100%);
	margin: 18px auto 0;
}
#program .programs li .card .pic {
	width: 100%;
}
#program .programs li .card .price {
	font-size: 22px;
	font-family: Roboto , 'Albert Sans';
	font-weight: 700;
}
#program .programs li .card .price .small {
	font-size: 16px;
	vertical-align: baseline;
}
#program .programs li .card .btn {
	width: 100%;
	height: 49px;
	margin-top: 18px;
	padding-top: 2px;
	border-radius: 25px;
	background: #E33939;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 18px;
	font-weight: bold;
	color: #fff;
	transition:
		color 0.2s ease-out,
		background 0.2s ease-out;
}

#program .about {
	width: 783px;
	max-width: 100%;
	margin: 41px auto 0;
	padding: 22px 4% 17px;
	background: #fff;
	border-radius: 23px;
	box-shadow: 0 6px 6px rgba(0,0,0,0.2);
}
#program .about .title {
	font-size: 16px;
	font-weight: bold;
}
#program .about .desc {
	margin-top: 11px;
}
#program .about .desc li {
	font-size: 16px;
	line-height: calc(26 / 16);
	text-indent: -1em;
	margin-left: 1em;
}

@media print, screen and (min-width:1395px) {
	#program .programs li .desc.txt-l2 {
	margin-bottom:2.5em;
	}
}

@media print, screen and (min-width:768px) {
	#program {
		padding-bottom: 82px;
		background: url("../../../shared/img/bg_05.png") no-repeat fixed center center / cover;
	}
	#program .programs {
		width: calc(1079 / 1194 * 100%);
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
	}
	#program .programs li {
		/*width: calc(323 / 1079 * 100%);*/
		width: calc(340 / 1079 * 100%);
	}
	
	#program .programs li .card .btn:hover {
		background: #589496;
	}
}

@media screen and (max-width:767px) {
	#program {
		margin-top: 74px;
		padding-bottom: 68px;
		background: url("../../../shared/img/bg_05_sp.png") no-repeat fixed center center / cover;
	}
	#program .white-box {
		padding: 38px 0 40px;
		border-radius: 11px;
		box-shadow: 2 3px 6px rgba(0,0,0,0.2);
	}
	#program .programs {
		width: calc(305 / 334 * 100%);
		margin: 0 auto;
	}
	#program .programs li + li {
		margin-top: 52px;
	}
	#program .programs li .title {
		font-size: 20px;
	}
	#program .programs li .desc {
		font-size: 15px;
		line-height: calc(24 / 15);
	}
	#program .programs li .card {
		margin-top: 16px;
		border-radius: 18px;
	}
	#program .programs li .card .group1 {
		width: calc(273 / 305 * 100%);
		margin: 16px auto 0;
	}
	#program .programs li .card .price {
		font-size: 20px;
	}
	#program .programs li .card .price .small {
		font-size: 15px;
	}
	#program .programs li .card .btn {
		height: 41px;
		border-radius: 21px;
		font-size: 16px;
	}

	#program .about {
		margin: 39px auto 0;
		padding: 37px 5% 26px;
		border-radius: 11px;
		box-shadow: 2px 3px 6px rgba(0,0,0,0.2);
	}
	#program .about .title {
		font-size: 16px;
		font-weight: bold;
		text-align: center;
	}
	#program .about .desc {
		margin-top: 16px;
	}
	#program .about .desc li {
		font-size: 16px;
		line-height: calc(24 / 16);
	}
	#program .about .desc li + li {
		margin-top: 0.6em;
	}
}

/* -------------------------------------------------
	#bottom-btn
------------------------------------------------- */

#bottom-btn {
	margin-top: 110px;
}
#bottom-btn p {
	font-size: 33px;
	font-weight: bold;
	text-align: center;
	color: #E33939;
}
#bottom-btn a {
	width: 411px;
	max-width: 100%;
	height: 86px;
	margin: 45px auto 0;
	padding-top: 7px;
	background: #E33939;
	border-radius: 43px;
	font-size: 22px;
	font-weight: bold;
	color: #fff;
	box-shadow: 2px 3px 6px rgba(0,0,0,0.3);
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	transition:
		color 0.2s ease-out,
		background 0.2s ease-out;
}
#bottom-btn a .arrow {
	width: 29px;
	position: absolute;
	right: 30px;
	top: 33px;
	transition: opacity 0.2s ease-out;
}

@media print, screen and (min-width:768px) {
	#bottom-btn a:hover {
		background: #589496;
	}
}

@media screen and (max-width:767px) {
	#bottom-btn {
		margin-top: 64px;
	}
	#bottom-btn p {
		font-size: 23px;
	}
	#bottom-btn a {
		height: 69px;
		margin: 27px auto 0;
		border-radius: 35px;
		font-size: 20px;
	}
	#bottom-btn a .arrow {
		width: 24px;
		right: 22px;
		top: 25px;
	}
}

/* -------------------------------------------------
	#line
------------------------------------------------- */

#line {
	width: 78px;
	display: block;
	position: fixed;
	right: 0;
	top: 80px;
	z-index: 50;
	transform: translateX(100%);
	transition: transform 0.2s ease-out;
}
#line.on {
	transform: translateX(0);
}
#line img {
	width: 100%;
}

@media screen and (max-width:767px) {
	#line {
		width: 164px;
		top: auto;
		bottom: 0;
		z-index: 50;
		transform: translate(0,100%);
	}
	#line.on {
		transform: translate(0,0);
	}
}

/* -------------------------------------------------
	footer
------------------------------------------------- */

@media print, screen and (min-width:768px) {
	footer {
	}
}

@media screen and (max-width:767px) {
	footer {
		margin-top: 76px;
	}
}

/* -------------------------------------------------
	ADD
------------------------------------------------- */
#basic-info .texts dd a{
	color:#2e38b9;
}
#basic-info .texts dd a {
    color: #2e38b9;
    display: inline-flex;
    align-items: center;
}

#basic-info .texts dd a::after {
    content: "";
    display: inline-block;
    width: 18px;
    height: 18px;
    margin-left: 8px;
    background: url("/shared/img/arrow_11.svg") no-repeat center center / contain;
}

#basic-info .texts dd a:hover {
    color:#E85400;
}
#basic-info .texts dd a:hover::after {
    transform: translateX(3px);
    transition: transform 0.2s ease;
}
#basic-info .buttons li a:hover .arrow{
    transform: translateX(4px);
    transition: transform 0.2s ease;
}
#bottom-btn a:hover .arrow {
    transform: translateX(4px);
    transition: transform 0.2s ease;
}

/* -------------------------------------------------
	ボタンOFF対応
------------------------------------------------- */

#basic-info .buttons li .reserve.off-gray {
    background: #b4b4b4;
}
#basic-info .buttons li div {
    width: 100%;
    height: 72px;
    padding-top: 4px;
    border: solid 2px #fff;
    border-radius: 36px;
    font-size: 18px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    position: relative;
    text-indent: -1em;
    box-shadow: 2px 3px 6px rgba(0, 0, 0, 0.3);
    transition: background 0.2s ease-out;
}
#basic-info .buttons li .arrow {
    width: 29px;
    position: absolute;
    right: 34px;
    top: 25px;
}
/*4/25以降もComingSoonある場合は下記残す*/
#program .programs li .card .btn.off-gray {
	background: #b4b4b4;
}
#bottom-btn .off-gray {
    width: 411px;
    max-width: 100%;
    height: 86px;
    margin: 45px auto 0;
    padding-top: 7px;
    background: #b4b4b4;
    border-radius: 43px;
    font-size: 22px;
    font-weight: bold;
    color: #fff;
    box-shadow: 2px 3px 6px rgba(0, 0, 0, 0.3);
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    transition: color 0.2s ease-out, background 0.2s ease-out;
}
#bottom-btn .arrow {
    width: 29px;
    position: absolute;
    right: 30px;
    top: 33px;
}
@media screen and (max-width:767px) {
#basic-info .buttons li .arrow {
    width: 24px;
}
}