@charset "UTF-8";
/* CSS Document */

body {font-family: "Roboto", "Helvetica Neue", Arial, sans-serif;}
body.zh-hant {font-family: "Noto Sans TC", sans-serif;}

#page-top {position: fixed;bottom: 40px;right: 40px;width: 60px; z-index:400;}
@media screen and (max-width: 896px) {
	#page-top {position: fixed;bottom: 5px;right: 5px;width: 30px; z-index:400;}
}

.wpml-ls-legacy-list-horizontal {position: absolute; top: 0; padding: 0!important; border: none!important; left: 220px;}
.wpml-ls-legacy-list-horizontal > ul {display: flex;}
.wpml-ls-legacy-list-horizontal a {color: #FFF; font-weight: 700; background: #A38E5B; padding: 7px 15px 9px!important; border-radius: 0 0 0 8px;}
.wpml-ls-legacy-list-horizontal li:last-child a {border-radius: 0 0 8px 0; border-left: 1px solid #FFF;}
#side .wpml-ls-legacy-list-horizontal {left: 20px;}
#side .wpml-ls-legacy-list-horizontal li:first-child a {border-radius: 8px 0 8px 0;}
@media screen and (max-width: 896px) {
	.wpml-ls-legacy-list-horizontal {left: 110px;}
	.wpml-ls-legacy-list-horizontal a {padding: 5px 10px 7px;}
}

.serif {font-family: "EB Garamond", serif;}
.serif_ch {font-family: "Noto Serif TC", serif;}

.bgWH {background-color: #FFF;}
.bgBR {background-color: #A38E5B;}
.bgBE {background-color: #FBF3E5;}
.bgGR {background-color: #5AAC5B;}
.bgGRY {background-color: #EEEEEE;}
.bgPI {background-color: #D15E67;}
.txtWH {color: #FFF;}
.txtPI {color: #D15E67;}
.txtGR,.txtGR a.ubdr {color: #5AAC5B;}
.txtRD {color: #E5181A;}
.txtYL {color: #FFFF00;}
.txtSKY {color: darkturquoise;}
strong {font-weight: 700;}

.ratioBox {position: relative;width: 100%;height: auto;}
.ratio1-1:before {content: "";display: block;padding-top: 100%; /* 1:1 */}
.ratio2-1:before {content: "";display: block;padding-top: 50%; /* 2:1 */}
.ratio3-2:before {content: "";display: block;padding-top: 66%; /* 3:2 */}
.ratio4-3:before {content: "";display: block;padding-top: 75%; /* 4:3 */}
.ratioInner {position: absolute;top: 0; left: 0;width: 100%;height: 100%;}
.r10 {border-radius: 10px;}
.r20 {border-radius: 20px;}
.rtr20 {border-radius: 0 20px 0 0;}
.rtl20 {border-radius: 20px 0 0 0;}

#header {position: relative; width: 100%;}
#header .logo {width: 200px; position: relative; z-index: 11;}
#header .logo a {background: #FFF; padding: 40px 25px; border-radius: 0 0 20px 0; display: block;}
.headCont {display: block; background: #5AAC5B; color: #FFF; padding: 35px 50px; text-align: center; z-index: 11; position: relative; border-left: 1px solid #5AAC5B;}
.headCont:hover {background: #F2EEE5; color: #5AAC5B;}
.headCont span {padding-left: 40px; background-image: url("../img/rental_car/icon_reserve_wh.svg"); background-repeat: no-repeat; background-position: left center;}
.headCont:hover span {background-image: url("../img/rental_car/icon_reserve_gr.svg");}
.navArea {padding: 20px 40px 0 0;}

#hanburger {display: none;}
.menu_button {width: 55px; height: 55px; position: fixed; top: 0; right: 0; background: #5AAC5B; z-index: 16;}
#hanburger:checked ~ .menu_button {top: 0;}
#hanburger:checked ~ .span2 {display: none;}
#hanburger:checked ~ .span1 {width: 34px; transform: rotate(45deg); top: 27px; right: 11px;}
#hanburger:checked ~ .span3 {width: 34px; transform: rotate(-45deg); top: 27px; right: 11px;}
.global_menu {visibility: hidden; width: 100%; height: 100%; position: fixed; top: 0; left: 0; color: #222; overflow-y: scroll; background: #FFF;}
#hanburger:checked ~ .global_menu {visibility: visible;}
.global_menu a {display: block; width: 100%; padding: 10px;}
.menu {font-size: 16px; font-weight: bold; white-space: nowrap;}
.menu .ib {padding-right: 31px; background: url("../img/cmn/plus.svg") no-repeat right 10px top 15px;}
.menu .pd {display: none;}
.menu:last-child {margin-right: 0px;}
.menu:hover > a {background-color: #EEE;}
#hanburger,.spOnly {display: none;}
@media screen and (max-width: 1040px) {
	#header .logo {width: 180px;}
	.headCont {padding: 35px 30px;}
}
@media screen and (min-width: 990px) {
  .menu_button {display: none;}
  .global_menu {position: inherit; padding: 0; color: #fff; visibility: visible; overflow-y: visible; height: auto; width: auto;}
}
@media screen and (max-width: 990px) {
	.navArea {padding: 10px 70px 0 20px;}
	#gNav {width: calc(100% - 110px);}
	#side,.headCont,.subNav {display: none;}
  #header .spOnly {display: block;}
	#header .logo {width: 110px;}
	#header .logo a {padding: 15px; border-radius: 0 0 10px 0;}
  span.span1,span.span2,span.span3 {width: 29px; height: 1px; background-color: #FFF; right: 13px; transition: .3s; z-index: 100; position: fixed;}
  .span1 {top: 17px;}
  .span2 {top: 27px;}
  .span3 {top: 37px;}
  .menu {display: block;}
  .menu > a {padding: 15px 15px; text-align: left; border-bottom: 1px solid #CCC;}
  .menu > a span {margin-right: 10px; width: 30px!important;}
  .menu > a span img {width: 100%;}
	.menu .ib {background-position: right 15px top 19px; background-size: 15px auto;}
  .global_menu {z-index: 15;}
  .menu .pd {display: inline-block; width: 100%; position: absolute; top: 0; left: 0; height: 100%;}
  .menu_wrap {display: none;}
  #hanburger:checked ~ * .menu_wrap {display: block; opacity: 1; min-height: 100vh; background: rgba(255,255,255,.8); /*position: fixed;*/ top: 0; z-index: 5;}
  #hanburger:checked ~ * .menu {max-height: inherit; overflow-y: visible; padding: 0; margin-left: 0; position: relative;}
  #hanburger:checked ~ * .child_menu {max-height: 0; overflow-y: hidden; visibility: hidden; text-align: left;}
  .menu > label:hover {cursor: pointer; cursor: hand;}
  .menu input[type="checkbox"]:checked ~ .child_menu {max-height: inherit!important; overflow-y: visible; visibility: visible!important;}
}

footer {padding: 90px 0 0; position: relative;}
footer::before {position: absolute; content: ''; width: 100%; height: 10px; top: 0; left: 0; background: #5AAC5B; background: linear-gradient(90deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%);}
footer .logo {width: 110px; margin-right: 30px;}
footer .btnCmn{margin-left: auto; margin-top: auto;}
footer dt {width: 130px;}
footer dd {width: calc(100% - 130px); padding-left: 20px; border-left: 1px solid #222;}
footer .col2 dt {width: 80px;}
footer .col2 dd {width: calc(100% - 80px); padding-left: 20px;}
.mapLink {padding-left: 34px; background: url("../img/rental_car/icon_map.svg") no-repeat left center; line-height: 24px;}
.footCopy {background: #5AAC5B; background: linear-gradient(90deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%); padding: 15px 0;}
.footCopy small {font-size: 16px;}
#ftNavi {display: none;}
@media screen and (max-width: 990px) {
	footer {margin-bottom: 50px; padding: 40px 0;}
	footer .logo {width: 140px; margin: 0 auto 20px;}
	footer dt,footer .col2 dt {width: 100%; font-weight: 700;}
	footer dd,footer .col2 dd {width: 100%; padding-left: 0; border-top: 1px solid #222; padding-top: 10px; border-left: none;}
	footer .jcSb {justify-content: center;}
	footer .fNav {font-size: 12px;}
	footer .fNav ul {margin-left: 20px; margin-right: 20px;}
	footer .fNav ul:first-child {margin-left: 20px;}
	#ftNavi {display: block; background: #5AAC5B; letter-spacing: -.4em; position: fixed; z-index: 5; bottom: 0; width: 100%;}
	#ftNavi ul {text-align: center; font-size: 10px; font-weight: bold;}
	#ftNavi li {letter-spacing: normal; display: inline-block; width: 25%;}
	#ftNavi li a {display: block; padding: 5px 0; color: #FFF; border-left: 1px solid #66BF67; border-right: 1px solid #407641;}
	#ftNavi li:first-child a {border-left: none;}
	#ftNavi li:last-child a {border-right: none;}
	#ftNavi li span {width: 20px; margin: 0 auto 5px; display: block;}
	.footCopy small {font-size: 12px; text-align: center;}
}
@media screen and (max-width: 685px) {
	footer .fNav > ul {width: calc(50% - 40px);}
}
@media screen and (max-width: 530px) {
	footer .fNav > ul {width: calc(50% - 30px);}
	footer .fNav ul {margin-left: 15px; margin-right: 15px;}
	footer .fNav ul:first-child {margin-left: 15px;}
	footer .fNav li {margin-bottom: 5px;}
	footer .fNav li ul li {margin-top: 5px;}
}

.w1920 {width: 100%; max-width: 1920px; padding-left: 0; padding-right: 0;}
.w1680 {width: 100%; max-width: 1680px; padding-left: 0; padding-right: 0;}
.container {width: 100%; max-width: 1212px; padding-left: 0; padding-right: 0;}
.containers {width: calc(100% - 40px); max-width: 888px; padding-left: 0; padding-right: 0;}
.mlr,.container,.containers,.w1920 {margin-left: auto; margin-right: auto;}
.mlr5 {margin-left: 5px; margin-right: 5px;}
.mlr20,.col1,.col2,.col3,.col4,.col5,.col6,.box3,.w46,.w54 {margin-left: 20px; margin-right: 20px;}
.col1 {width: calc(16.6666% - 40px);}
.col2,.box3 {width: calc(33.3333% - 40px);}
.col3 {width: calc(50% - 40px);}
.col4 {width: calc(66.6666% - 40px);}
.col5 {width: calc(83.3333% - 40px);}
.col6 {width: calc(100% - 40px);}
.box4 {width: calc(25% - 30px); margin-left: 15px; margin-right: 15px;}
.w360 {max-width: 360px; width: 100%;}
.w300 {max-width: 300px; width: 100%;}
.w240 {max-width: 240px; width: 100%;}
.w100 {width: 100%;}
.w65 {width: 65%;}
.w50 {width: 50%;}
.w50-20 {width: calc(50% - 20px);}
.w52 {width: 52%;}
.w48 {width: 48%;}
.w35 {width: 35%;}
@media screen and (max-width: 896px) {
  .containers {width: calc(100% - 30px);}
  .mlr20,.col1,.col2,.col3,.col4,.col5,.col6,.box3,.w46,.w54 {margin-left: 15px; margin-right: 15px;}
  .mlr5 {margin-left: 0; margin-right: 0;}
  .col1 {width: calc(16.6666% - 30px);}
  .col2,.box3 {width: calc(33.3333% - 30px);}
  .col3 {width: calc(50% - 30px);}
  .col4 {width: calc(66.6666% - 30px);}
  .col5 {width: calc(83.3333% - 30px);}
  .col6 {width: calc(100% - 30px);}
  .w46 {width: calc(46% - 30px);}
  .w54 {width: calc(54% - 30px);}
	.w50-20 {width: 100%;}
}
@media screen and (max-width: 568px) {
  .col1 {width: calc(33.3333% - 30px);}
  .col2,.col3,.col4,.col5,.col6,.box3,.w46,.w54 {width: calc(100% - 30px);}
  .box4 {width: calc(50% - 7.5px); margin-left: 0; margin-right: 0;}
}

ul.dot {list-style: disc; margin-left: 1.5em;}
ul.num {list-style: decimal; margin-left: 1em;}
ul.num li {margin-bottom: 10px;}
ul.num li:last-child,ul.num2 li {margin-bottom: 0;}
ul.num2 {margin-top: 10px; margin-left: 2em;}
ul.num2 li {counter-increment: cnt; text-indent: -2.5em;}
ul.num2 li::before {content: "（" counter(cnt) "）";}
ul.asterisk {margin-left: 1em;}
ul.asterisk li {list-style-type: none; text-indent: -1em;}
ul.asterisk li:before {display: inline; content: "※";}

table {width: 100%;}
/*table tr:nth-child(odd) {background-color: #FFF;}
table tr:nth-child(even) {background-color: #EEEEEE;}*/
table th,table td {padding: 15px 8px; line-height: 1.5; text-align: center; border: 1px solid #222222; vertical-align: middle;}

@keyframes rotation{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
@keyframes lefttoright{
  from {transform: translateX(-100%);}
  to {transform: translateX(0);}
}
@keyframes loop {
  0% {transform: translateX(100%);}
  to {transform: translateX(-100%);}
}
@keyframes loop2 {
	0% {transform: translateX(0);}
  to {transform: translateX(-200%);}
}
@keyframes loop3 {
  0% {transform: translateX(-100%);}
  to {transform: translateX(100%);}
}
@keyframes loop4 {
	0% {transform: translateX(-200%);}
  to {transform: translateX(0);}
}

.btnCmn {min-width: 250px; display: inline-block;}
.btnCmn a {width: 100%; display: block; border: 1px solid #F2EEE5; background: #F2EEE5; border-radius: 35px; padding: 14px 72px 14px 25px; position: relative;}
.btnCmn a::before,.btnCmn a::after {position: absolute; content: ''; top: 50%; transform: translateY(-50%);}
.btnCmn a::before {width: 42px; height: 42px; border-radius: 50%; background: #2D562E; background: linear-gradient(0deg, rgba(45, 86, 46, 1) 0%, rgba(90, 172, 91, 1) 100%); right: 10px;}
.btnCmn a::after {width: 10px; height: 6px; background: url("../img/rental_car/arrow_right_wh.svg") no-repeat; background-size: cover; right: 26px;}
.btnCmn a:hover {background: #2D562E; background: linear-gradient(0deg, rgba(45, 86, 46, 1) 0%, rgba(90, 172, 91, 1) 100%); color: #FFF;}
.btnCmn a:hover::before {background: #FFF;}
.btnCmn a:hover::after {background: url("../img/rental_car/arrow_right_gr.svg") no-repeat; background-size: cover; right: 26px;}

.ttlBbdr {position: relative; padding-bottom: 30px;}
.ttlBbdr::before {position: absolute; content: ''; width: 150px; height: 4px; border-radius: 2px; background: #5AAC5B; left: 0; bottom: 0;}
.bgBK {background: #222;}
.shdwBox {box-shadow: 0 0 5px rgba(0,0,0,.4);}
.txt36 {font-size: 36px;}
@media screen and (max-width: 990px) {
	.txt36 {font-size: 24px;}
}

#kv,#top01 {margin-top: -85px;}
.zh-hant #kv,.zh-hant #top01 {margin-top: -112px;}
#kv .mainImg {height: 300px;}
#kv .pagettl {position: absolute; width: 100%; text-align: center; padding: 0 20px; top: 50%; transform: translateY(-50%); text-shadow: 2px 2px 2px rgba(0,0,0,.8); z-index: 1;}
#camp01 .pagettl,#camp01 .bread,#kv.campfield .bread {margin-left: 120px; color: #FFF; background: none; position: relative;}
.bread {position: absolute; width: calc(100% - 80px); background: #FFF; bottom: 0; right: 0; padding: 18px 20px; border-radius: 10px 0 0 0; z-index: 1;}
.bread li {margin-right: 32px; position: relative;}
.bread li a {text-decoration: underline;}
.bread li::after {position: absolute; content: ''; background: url("../img/cmn/arrow_gr.svg") no-repeat center; background-size: cover; width: 12px; height: 15px; right: -22px; top: 50%; transform: translateY(-50%);}
.bread li:first-child {padding-left: 25px; background: url("../img/cmn/bread.svg") left center no-repeat; background-size: 19px auto;}
.bread li:last-child {margin-right: 0;}
.bread li:last-child::after {background: none;}
@media screen and (max-width: 1040px) {
	#kv,#top01 {margin-top: -68px;}
	.zh-hant #kv,.zh-hant #top01 {margin-top: -95px;}
}
@media screen and (max-width: 990px) {
	#kv,#top01 {margin-top: -44px;}
	.zh-hant #kv,.zh-hant #top01 {margin-top: -64px;}
	#kv .mainImg {height: 180px;}
}

#top01 .copy {position: absolute; top: 50%; transform: translateY(-50%); z-index: 1; width: 100%;}
#top01 .copy h2 {padding-bottom: 30px;}
#top01 .copy h2::before {position: absolute; content: ''; width: 250px; height: 4px; border-radius: 2px; background: #FFF; box-shadow: 2px 2px 2px rgba(0,0,0,.8); margin: 0 auto; left: 0; right: 0; bottom: 0;}
.txtShdw {text-shadow: 2px 2px 2px rgba(0,0,0,.8);}
#top01 .bgImg {background: #000;}
#top01 .bgImg li {width: calc(100%/3); opacity: .8;}
@media screen and (max-width:850px) {
	#top01 .bgImg li {height: 500px;}
}

#top02 {margin-top: -120px; z-index: 1;}
#top02 .container {padding-top: 220px; position: relative; z-index: 2;}
#top02 .txt {width: 100%;}
#top02 .txt h2 span:first-of-type {margin-right: 40%;}
#top02 .txt .txt16 {margin-right: 32%;}
#top02 .illust {width: 47.8%; margin-left: -55%; margin-top: 120px;}
#top02 .illust h3 {position: absolute; right: 20.5%; bottom: 16%;}
#top02 .topImg,#top02 .btmImg {position: absolute; width: 100%;}
#top02 .topImg {top: 0;}
#top02 .btmImg {bottom: -230px;}
#top02 .topImg li:first-child {width: 23.2%; margin-top: 50px; margin-right: auto;}
#top02 .topImg li:nth-child(2) {width: 35.7%; margin-right: -11.6%;}
#top02 .topImg li:last-child {width: 23.2%; margin-top: 20%;}
#top02 .btmImg {width: 41%; margin-left: 6%;}
#top02 .btmImg li:first-child {width: 46%; margin-left: auto;}
#top02 .btmImg li:nth-child(2) {width: 65.7%; margin-top: -12%;}
#top02 .btmImg li:last-child {width: 46%; margin-left: 46%; margin-top: -17%;}
@media screen and (max-width: 1680px) {
	#top02 .topImg li:first-child img {border-top-left-radius: 0; border-bottom-left-radius: 0;}
	#top02 .topImg li:last-child img {border-top-right-radius: 0; border-bottom-right-radius: 0;}
}
@media screen and (max-width: 1130px) {
	#top02 {margin-top: -80px;}
}
@media screen and (max-width: 850px) {
	#top02 {margin-top: -30px;}
	#top02 .illust h3 {right: 0; bottom: 5%;}
}
@media screen and (max-width: 568px) {
	#top02 .txt .txt16 {margin-right: 0;}
	#top02 .illust {width: 70%; margin-left: auto; margin-right: auto; margin-top: 20px;}
	#top02 .btmImg {position: relative; width: 70%; bottom: 0;}
}

#top03 {background: #5AAC5B; background: linear-gradient(0deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%); padding: 100px 0 60px;}
#top03 .container {z-index: 2;}
#top03 .ttlBbdr::before {background: #FFF; right: 0; left: inherit;}
#top03 .col3 {border-left: 2px solid #FFF; padding-left: 20px;}
#top03 .col3 .txtRight {margin-top: auto;}
#top03 .bgImg {position: absolute; width: 56.25%; right: 0; bottom: 0; mix-blend-mode: multiply;}

#top04 .subImg {position: absolute; width: 31%; bottom: -70px; right: 0;}
#top04 .txt {width: calc(50% - 20px); padding: 40px 50px;}
#top04 .txt dt,#top05 .w50:first-of-type li {display: flex; align-items: center; line-height: 1.2;}
#top04 .txt .icon,#top05 .w50:first-of-type li .icon {width: 30px; margin-right: 10px; display: block;}
#top04 .mainImg {width: calc(50% + 20px);}
#top04 .mainImg img {border-top-left-radius: 0; border-bottom-left-radius: 0;}
@media screen and (max-width: 700px) {
	#top04 .txt,#top04 .mainImg {width: 100%;}
	#top04 .txt {padding: 20px 30px;}
	#top04 .mainImg {height: 300px;}
	#top04 .mainImg img {border-top-right-radius: 0; border-bottom-left-radius: 10px;}
}

#top05 .txt,#top06 .txt {max-width: 680px; width: calc(100% - 160px);}
#top05 .w50:first-of-type {padding: 100px 0; background: url("../img/rental_car/05-01.jpg") no-repeat; background-size: cover; margin-bottom: 120px;}
#top05 .w50:first-of-type .ttlBbdr::before {background: #FFF;}
#top05 .w50:last-of-type {padding: 100px 0 50px; margin-top: 120px;}
#top05 .w50:last-of-type::before,#top05 .w50:last-of-type::after {position: absolute; content: '';}
#top05 .w50:last-of-type::before {width: 102px; height: 102px; background: #5AAC5B; background: linear-gradient(0deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%); top: 150px; left: -51px; border-radius: 50%;}
#top05 .w50:last-of-type::after {width: 24px; height: 15px; background: url("../img/rental_car/arrow_right_wh.svg") no-repeat; top: 195px; left: -12px;}
#top05 .slideArea {margin-top: auto;}
.imgSlide li,.lineupSlide .shdwBox {margin: 0 15px;}
#top05 dt,#top05 dd {margin-bottom: 30px;}
#top05 dt {width: calc(100% - 123px); padding-right: 30px;}
#top05 dd {width: 123px;}
#top05 dt .num {font-size: 50px; margin-right: 20px;}
#top05 dt h3 {width: calc(100% - 70px); line-height: 1.2;}
.zh-hant #top05 dt h3 {width: calc(100% - 90px);}
#top05 dt p {margin-top: 20px;}
@media screen and (max-width: 1024px) {
	#top05 .txt,#top06 .txt {width: calc(100% - 80px);}
	#top05 .w50:last-of-type::before {width: 62px; height: 62px; left: -31px;}
	#top05 .w50:last-of-type::after {top: 175px;}
}
@media screen and (max-width: 850px) {
	#top05 .w50 {width: 100%;}
	#top05 .w50:first-of-type {padding: 50px 0; margin-bottom: 0;}
	#top05 .w50:last-of-type {padding: 50px 0; margin-top: 0;}
	#top05 .txt,#top06 .txt {width: calc(100% - 40px);}
	#top05 .w50:last-of-type::before {left: 50%; transform: translateX(-50%); top: -31px;}
	#top05 .w50:last-of-type::after {left: 50%; transform: translateX(-50%) rotate(90deg); top: -7px;}
}
@media screen and (max-width: 568px) {
	#top05 dt {width: calc(100% - 80px); padding-right: 10px;}
	#top05 dt .num {font-size: 40px;}
	#top05 dd {width: 80px;}
}

.lineupSlide .slick-list {padding: 5px 7%!important;}
.lineupSlide .shdwBox {padding: 0 30px;}
.className > dt {font-size: 50px; font-weight: 500; border-top: 5px solid #222;}
.className > dt span {font-size: 14px; position: absolute; bottom: 3px; right: 0;}
.className > dd {margin-bottom: auto; margin-top: 30px;}
.lineupSlide .thumb {margin-top: -18px;}
.classInfo dt {padding-right: 20px; margin-bottom: 10px;}
.classInfo dd {padding-left: 20px; margin-bottom: 10px; border-left: 1px solid #222;}
.classInfo dt:first-of-type {width: 130px;}
.classInfo dd:first-of-type {width: calc(100% - 130px);}
.zh-hant .classInfo dt:first-of-type {width: 90px;}
.zh-hant .classInfo dd:first-of-type {width: calc(100% - 90px);}
.classPrice {font-size: 30px; font-weight: 700; }
.classPrice dd,.classPrice dt {padding-bottom: 5px; border-bottom: 5px solid #222;}
.classPrice dt {padding: 15px 15px 0 0;}
.classPrice dt,.classPrice dd span {font-size: 55%;}
@media screen and (max-width: 990px) {
	.lineupSlide .shdwBox {padding: 0 20px;}
	.className > dt {font-size: 40px;}
	.className > dt span {font-size: 12px;}
	.classInfo dt:first-of-type,.classInfo dt {width: 100%!important; border-bottom: 1px solid #222;}
	.classInfo dd:first-of-type,.classInfo dd {width: 100%!important; border-left: none; padding-left: 0;}
}

#top06 .container {position: absolute; left: 0; right: 0; top: 50%; transform: translateY(-50%); z-index: 1;}
#top06 .bgSlide {opacity: .4; margin-bottom: 0!important;}
#top06 .routeImg .txt {position: absolute; top: 100px; left: 0; right: 0;}
#top06 .bgImg {width: 100%; height: 50%;}
#top06 .bgBE {padding: 20px 0;}
#top06 .bgBE .start,#top06 .bgBE .end {position: absolute; width: 120px; height: 120px; border-radius: 50%; background: #5AAC5B; background: linear-gradient(0deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%); text-align: center;}
#top06 .bgBE .start {top: 115px; left: -60px;}
#top06 .bgBE .end {bottom: 135px; left: -60px;}
#top06 .bgBE .start::before,#top06 .bgBE .end::before {position: absolute; content: ''; height: 1px; width: 100%; background: #5AAC5B; top: 50%; transform: translateY(-50%); right: -100%;}
#top06 .route02 .bgBE .start::before,#top06 .route02 .bgBE .end::before {left: -100%; right: inherit;}
#top06 .route02 .bgBE .start {right: -60px; left: inherit;}
#top06 .route02 .bgBE .end {right: -60px; left: inherit;}
#top06 .bgBE .start p,#top06 .bgBE .end p {position: absolute; width: 100%; top: 50%; transform: translateY(-50%);}
#top06 .bgBE .start span,#top06 .bgBE .end span {display: block; line-height: 1.2;}
#top06 .bgBE dt,#top06 .bgBE dd {margin-bottom: 30px;}
#top06 .bgBE dt {width: 280px; position: relative;}
#top06 .bgBE dt:not(:last-of-type)::before {position: absolute; content: ''; width: 1px; height: 30px; background: #5AAC5B; left: 25px; bottom: -30px;}
#top06 .route02 .bgBE dt:not(:last-of-type)::before {right: 25px; left: inherit;}
#top06 .bgBE dt p {position: absolute; top: 0; left: 0; border-radius: 10px 0 10px 0; width: 50px; line-height: 50px;}
#top06 .route02 .bgBE dt p {top: 0; left: inherit; right: 0; border-radius: 0 10px 0 10px;}
#top06 .bgBE dd {width: calc(100% - 280px); padding-left: 20px;}
#top06 .route02 .bgBE dd {text-align: right; padding-right: 20px; padding-left: 0;}
.route02 .txtShdw {text-shadow: 2px 2px 2px rgba(255,255,255,.8);}
@media screen and (max-width: 1125px) {
	#top06 .w50 {width: 100%; display: flex; flex-wrap: wrap;}
	#top06 .bgImg {width: 50%; height: 100%;}
	#top06 .routeImg .txt {top: 50%; transform: translateY(-50%);}
}
@media screen and (max-width: 896px) {
	#top06 .bgImg {height: 300px;}
	#top06 .bgBE .start,#top06 .bgBE .end {position: relative; top: inherit; left: inherit; margin-left: 20px;}
	#top06 .bgBE .start {margin-bottom: 30px;}
	#top06 .bgBE .end {bottom: inherit; margin-top: 0;}
	#top06 .bgBE .start::before,#top06 .bgBE .end::before {top: inherit; transform: translateY(0); right: 50%; height: 30px; width: 1px;}
	#top06 .bgBE .start::before {bottom: -30px;}
	#top06 .bgBE .end::before {top: -30px;}
}
@media screen and (max-width: 500px) {
	#top06 .bgBE dt,#top06 .bgBE dd {margin-bottom: 0;}
	#top06 .bgBE dt:not(:last-of-type)::before {content: none;}
	#top06 .bgBE dd:not(:last-of-type)::before {position: absolute; content: ''; width: 1px; height: 30px; background: #5AAC5B; left: 25px; bottom: -30px;}
	#top06 .bgBE dd {width: 100%; padding-left: 0; margin-bottom: 30px; margin-top: 10px; position: relative;}
	#top06 .route02 .bgBE dt {margin-right: auto;}
	#top06 .route02 .bgBE dd {text-align: left; padding-right: 0;}
}

.side {width: 320px; position: sticky; top: 0;}
.faqLink li {margin: 0 0 20px;}
.faqLink li a {display: block; width: 100%; background: #F2EEE5; padding: 20px 40px 20px 25px; border-radius: 32px; position: relative;}
.faqLink li a::before {position: absolute; content: ''; width: 10px; height: 6px; background: url("../img/rental_car/arrow_right_bk.svg") no-repeat; background-size: cover; right: 20px; top: 50%; transform: translateY(-50%);}
.faqLink li a:hover {background: #5AAC5B; background: linear-gradient(90deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%); color: #FFF;}
.faqLink li a:hover::before {background: url("../img/rental_car/arrow_right_wh.svg") no-repeat; background-size: cover; right: 10px;}
.contents {width: calc(100% - 380px); margin-left: auto;}
dl.faq {border: 1px solid #999; border-radius: 10px;}
.faq dt {width: 135px; padding: 20px 20px 20px 30px;}
.faq dd {width: calc(100% - 135px); padding: 20px 30px 20px 20px; position: relative;}
.faq dd::before {position: absolute; content: ''; height: calc(100% - 40px); width: 1px; background: #999; top: 20px; left: 0;}
@media screen and (max-width: 990px) {
	.side,.contents {width: 100%; position: relative;}
	.faqLink {display: flex; flex-wrap: wrap;}
	.faqLink li {margin: 0 10px 20px 0;}
}

#top08 {padding: 80px 0 40px; background: #5AAC5B; background: linear-gradient(90deg, rgba(90, 172, 91, 1) 0%, rgba(45, 86, 46, 1) 100%);}
#top08 dt {padding-right: 20px; margin-right: 20px; border-right: 1px solid #FFF;}
#top08 .col2 {align-content: flex-start;}
#top08 .num {font-size: 50px; width: 50px;}
#top08 .txt {width: calc(100% - 50px); padding-left: 20px;}

#lineup01 li {margin: 0 15px 10px;}
#lineup01 li a {display: block; padding: 5px 30px; border-radius: 25px; border: 1px solid #5AAC5B; color: #5AAC5B;}
#lineup01 li a:hover {background: #5AAC5B; color: #FFF;}

.classDetail .shdwBox {padding: 0 30px 30px;}
.classDetail .w50:first-of-type {width: calc(50% + 20px);}
.classDetail .w50:last-of-type {width: calc(50% - 20px); padding-left: 40px; margin-top: 30px;}
.classDetail .className > dt {font-size: 80px;}
.classDetail .className > dt span {font-size: 20px;}
.capacity dt {padding-right: 20px;}
.capacity dd {padding-left: 20px; border-left: 1px solid #222; margin-right: 30px;}
.classDetail .slick-slider {margin-bottom: 0;}
.modelTtl {padding-bottom: 10px; margin-top: 10px;}
.modelTtl::before {position: absolute; content: ''; bottom: 0; left: 0; width: 80px; height: 1px; background: #222;}
.modelName li {margin: 0 10px 0 0; padding: 0 20px; border-radius: 20px; border: 1px solid #5AAC5B; color: #5AAC5B; cursor: pointer;}
.modelName li:hover,.modelName li.slick-current {background: #5AAC5B; color: #FFF;}
.equipment li:not(:last-child) {margin-right: 20px;}
.equipment li .icon {width: 60px; display: block; margin-left: auto; margin-right: auto;}
.classDetail .classInfo dd .icon {display: inline-block; width: 15px; margin-right: 10px;}
.classDetail .classInfo dt:first-of-type {width: 230px;}
.classDetail .classInfo dd:first-of-type {width: calc(100% - 230px);}
.classDetail .classInfo dt:nth-of-type(2) {width: 260px;}
.classDetail .classInfo dd:nth-of-type(2) {width: calc(100% - 260px);}
.classDetail .classInfo dt:nth-of-type(3) {width: 175px;}
.classDetail .classInfo dd:nth-of-type(3) {width: calc(100% - 175px);}

.zh-hant .classDetail .classInfo dt:first-of-type {width: 110px;}
.zh-hant .classDetail .classInfo dd:first-of-type {width: calc(100% - 110px);}
.zh-hant .classDetail .classInfo dt:nth-of-type(2) {width: 110px;}
.zh-hant .classDetail .classInfo dd:nth-of-type(2) {width: calc(100% - 110px);}
.zh-hant .classDetail .classInfo dt:nth-of-type(3) {width: 110px;}
.zh-hant .classDetail .classInfo dd:nth-of-type(3) {width: calc(100% - 110px);}

.classDetail .classInfo dd:nth-of-type(3) .icon {width: 23px;}
.classDetail .classInfo .comment {margin-left: 10px;}
.classDetail .priceList {margin-top: auto;}
.classDetail .priceList th {font-size: 18px; background: #F2EEE5;}
.classDetail .priceList td {font-size: 24px; font-weight: 700; color: #D15E67;}
.classDetail .priceList td span {font-size: 75%;}
@media screen and (max-width: 990px) {
	.classDetail .w50:first-of-type,.classDetail .w50:last-of-type {width: 100%;}
	.classDetail .w50:last-of-type {padding-left: 0;}
	.classDetail .className > dt {font-size: 60px;}
	.classDetail .className > dt span {font-size: 16px;}
	.classDetail .shdwBox {padding: 0 20px 20px;}
	.capacity dt {padding-right: 10px;}
	.capacity dd {padding-left: 10px; margin-right: 10px;}
	.equipment li .icon {width: 40px;}
	.classDetail .classInfo dt,.classDetail .classInfo dd {width: 100%!important;}
	.classDetail .classInfo dt {border-bottom: 1px solid #222;}
	.classDetail .classInfo dd {border-left: none; padding-left: 0;}
	.classDetail .priceList th {font-size: 14px;}
	.classDetail .priceList td {font-size: 20px;}
}

#insurance01 .box4 {border: 2px solid #5AAC5B;}
.bdrBoxBK,.bdrBoxGR {position: relative;}
.bdrBoxBK::before,.bdrBoxGR::before {position: absolute; content: ''; width: 100%; height: calc(100% - 15px); border: 2px solid #5AAC5B; border-radius: 10px; left: 0; bottom: 0; z-index: -1;}
.bdrBoxBK::before {border: 2px solid #222;}
#insurance01 .box4 .bgGR {padding: 10px 5px; /*flex-grow: 1; display: flex; flex-direction: column;*/}
#insurance01 .compensationDetail,#insurance01 .compensationDesc {padding: 20px; /*flex-grow: 1; display: flex; flex-direction: column;*/}
#insurance01 .compensationDetail {border-bottom: 2px solid #5AAC5B;}
#insurance01 .compensationDetail p {line-height: 1.2;}
#insurance01 .compensationDetail .bgPI {max-width: 200px; padding: 10px 10px; border-radius: 20px; margin-left: auto; margin-right: auto;}
#insurance01 .inner {/*flex-grow: 1;*/}
#insurance01 .bdrBoxBK {padding: 0 30px 20px;}
.ttlAbs {padding: 0 10px; display: inline-block;}
.ttlBbdrGR {position: relative; padding-bottom: 20px; border-bottom: 1px solid #222;}
.ttlBbdrGR span {position: relative; bottom: -15px;}
.ttlBbdrGR::before {position: absolute; content: ''; width: 240px; height: 1px; background: #5AAC5B; bottom: -1px; left: 0;}
#insurance02 .bdrBoxGR::before {height: 100%;}
#insurance02 .bdrBoxGR .inner {padding: 20px 30px;}
#insurance02 .bdrBoxGR h3 {padding: 12px 30px; border-radius: 10px 0 10px 0;}
#insurance02 .bdrBoxGR dl {margin-left: 20px;}
#insurance02 .bdrBoxGR dt,#insurance02 .bdrBoxGR dd {line-height: 1.2;}
#insurance02 .bdrBoxGR dt {margin-right: 10px;}
#insurance03 .bdrBoxGR {padding: 0 30px 20px;}
.insurance {min-width: 800px;}
.insurance th,.insurance td {border: 1px solid #FFF;}
.insurance th {width: 16%;}
.insurance th:last-child {width: 20%;}
.insurance td span {font-size: 70%;}
.insurance .txtSideBdr {position: relative;}
.insurance .txtSideBdr .bgPI {padding: 0 10px; position: relative; z-index: 1; font-size: 100%;}
.insurance .txtSideBdr::before {position: absolute; content: ''; width: 100%; height: 1px; background: #FFF; top: 50%; left: 0;}
@media screen and (max-width: 990px) {
	#insurance01 .box4 {width: calc(50% - 30px);}
	.ttlBbdrGR span {bottom: -10px;}
	#insurance02 .bdrBoxGR dl {width: 100%; margin-top: 20px;}
	#insurance02 .bdrBoxGR .inner {padding: 20px 20px;}
	#insurance03 .bdrBoxGR {padding: 0 20px 20px;}
}
@media screen and (max-width: 568px) {
	#insurance01 .box4 {width: calc(100% - 20px); margin-left: 10px; margin-right: 10px;}
	.ttlBbdrGR span {bottom: 0; float: none; display: block;}
}
