@charset "UTF-8";
	
/*
	
Description: ニッポンレンタカー ハワイ
Version: 202205

*/


/*------------------------------------------------------------
	【ご利用ガイド】見出し
------------------------------------------------------------*/


h3 {
	background: #f1f1f1;
	line-height: 1.8;
	padding: 5px 10px 5px 20px;
	margin-bottom: 15px;
	position: relative;
}

h3:before {
	content: '';
	display: block;
	background: #ED0000;
	width: 5px;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

h4 {
	font-size: 1.7rem;
	border-bottom: 1px solid #ccc;
	padding-bottom: 15px;
	margin-bottom: 12px;
	color: #f00200;
	text-indent: -0.5em;
}

@media only screen and (min-width: 813px) {
	
	h3 {
		margin-bottom: 25px;
	}
	
	h4 {
		margin-bottom: 15px;
	}
	
}


/*------------------------------------------------------------
	【ご利用ガイド】レイアウト
------------------------------------------------------------*/

.guide-wrap {
	margin-bottom: 40px;
}

.guide-wrap .guide-wrap-inner {
	padding-top: 5px;
	margin-bottom: 30px;
}

@media only screen and (min-width: 813px) {
	
	.guide-wrap {
		margin-bottom: 50px;
	}
	
	.guide-wrap .guide-wrap-inner {
		margin-bottom: 50px;
	}
	
}


/*------------------------------------------------------------
	【ご利用ガイド】リスト
------------------------------------------------------------*/

.guide-page ul li,
.guide-page ol li {
	line-height: 1.8;
	margin-bottom: 5px;
}
	
.guide-page ul li:last-child,
.guide-page ol li:last-child {
	margin-bottom: 0;
}

.guide-page ul li {
	text-indent: -1em;
	padding-left: 1em;
}

.guide-page ol li {
	text-indent: -1.3em;
	padding-left: 1.3em;
}

.guide-page ol li.last {
	margin-top: 15px;
}

@media only screen and (min-width: 813px) {
	
	.guide-page ul li,
	.guide-page ol li {
		line-height: 1.8;
		margin-bottom: 3px;
	}

}


/*------------------------------------------------------------
	【ご利用ガイド】テーブル
------------------------------------------------------------*/

table.guide-basic {
	width: 100%;
	line-height: 1.8;
	margin: 15px 0 10px;
}

@media only screen and (min-width: 813px) {
	
	table.guide-basic {
		margin: 25px 0 60px;
	}
	
}

table.guide-basic caption {
	font-size: 1.5rem;
	font-weight: 600;
	text-align: left;
	margin-bottom: 10px;
}

table.guide-basic caption span {
	color: #f00200;
}

table.guide-basic th {
	display: block;
    background: #767680;
    width: 100%;
	font-weight: 600;
    color: #fff;
	text-align: left;
    border-bottom: 2px solid #fff;
    padding: 15px;
}

table.guide-basic td {
	display: block;
	background: #f1f1f1;
    width: 100%;
    border-bottom: 2px solid #fff;
    padding: 15px;
}

table.guide-basic tr:last-child th,
table.guide-basic tr:last-child td {
	border-bottom: none;
}

@media only screen and (min-width: 813px) {
	
	table.guide-basic th {
		display: table-cell;
		width: 200px;
		vertical-align: middle;
		text-align: center;
	}
	
	table.guide-basic th.align-left {
		text-align: left;
		padding-left: 25px;
	}
	
	table.guide-basic td {
		display: table-cell;
		width: calc(100% - 200px);
		padding: 20px 25px;
	}
	
}

/*キャンセル料*/
table.guide-basic.cancel-info th {
	width: 200%;
}

table.guide-basic.cancel-info td {
	display: table-cell;
	width: 50%;
	font-weight: 600;
	border-left: 2px solid #fff;
}

@media only screen and (min-width: 813px) {
	
	table.guide-basic.cancel-info {
	    table-layout: fixed;
	}
	
	table.guide-basic.cancel-info th {
		width: 200px;
	}
			
	table.guide-basic.cancel-info td {
		width: calc(50% - 100px);
		font-weight: 600;
		border-left: 2px solid #fff;
	}
	
}


/*【保険】搭乗者保険*/
table.guide-basic.insurance-info th {
	display: block;
	width: 100%;
}

table.guide-basic.insurance-info td {
	display: inline-block;
	width: calc(100% / 2);
	font-weight: 600;
	border-right: 2px solid #fff;
}

table.guide-basic.insurance-info td:last-child {
	border-right: none;
}

@media only screen and (min-width: 813px) {
	
	table.guide-basic.insurance-info {
	    table-layout: fixed;
	}
	
	table.guide-basic.insurance-info th {
		display: table-cell;
		width: 200px;
	}
			
	table.guide-basic.insurance-info td {
		display: table-cell;
		width: calc(50% - 100px);
		font-weight: 600;
		border-right: none;
		border-left: 2px solid #fff;
	}
	
}



/*ご返却時のガソリン*/

table.return-info {
	width: 100%;
	margin: 20px 0 20px
}

table.return-info th {
	background: #767680;
	font-weight: bold;
    color: #fff;
	padding: 15px 20px;
}

table.return-info th:first-child {
	border-right: 1px solid #fff;
}

table.return-info td {
	width: calc(100% - 130px);
	font-size: 1.3rem;
	vertical-align: middle;
    padding: 15px;
	border-bottom: 2px solid #eee;
}

table.return-info td:first-child {
    background: #efefef;
    width: 130px;
	font-weight: bold;
	text-align: center;
    padding: 15px 0;
	border-bottom: 2px solid #ddd;
}

table.return-info td:first-child span {
	font-size: 1.2rem;
}

@media only screen and (min-width: 813px) {
	
	table.return-info td {
		width: 50%;
		font-size: 1.4rem;
		padding: 15px 30px;
	}
	
	table.return-info td:first-child {
		width: 50%;
		padding: 15px 20px;
	}
	
	table.return-info td:first-child span {
		font-size: 1.4rem;
	}
	
}


/*------------------------------------------------------------
	【ご利用ガイド】Border-box
------------------------------------------------------------*/

.border-box {
	border: 1px solid #ccc;
	padding: 15px;
	text-align: center;
	margin-top: 15px;
}

.border-box dl dt {
	display: inline-block;
	font-weight: 600;
}

.border-box dl dd {
	display: inline-block;
}

.border-box a {
	font-weight: 600;
}


/*------------------------------------------------------------
	【追加料金】テーブル（スクロール）
------------------------------------------------------------*/

.scroll-holder {
	width: 100%;
	overflow-x: scroll;
	position: relative;
}

.extra-fee {
	background: #f1f1f1;
	width: 460px;
}

@media only screen and (min-width: 813px) {
	
	.extra-fee {
		width: 100%;
		margin-bottom: 20px;
	}
	
}

.extra-fee td {
	vertical-align: middle;
	font-size: 1.3rem;
	line-height: 1.6;
	color: #000;
	padding: 10px;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
}

.extra-fee td:last-child {
	width: 90px;
	font-weight: 600;
	padding: 10px 0;
	text-align: center;
}

@media only screen and (min-width: 813px) {
	
	.extra-fee td {
		font-size: 1.4rem;
		padding: 15px 20px;
	}
	
	.extra-fee td:last-child {
		width: 120px;
	}
	
}

.extra-fee .fld01 {
	background: #767680;
	width: 80px;
	font-weight: 600;
	color: #fff;
	text-align: center;
    padding: 10px 0;
}

.extra-fee td.center {
    width: 110px;
    text-align: center;
    padding: 10px 0;
}

@media only screen and (min-width: 813px) {
	
	.extra-fee .fld01 {
		width: 180px;
	}
	
	.extra-fee td.center {
		width: 150px;
		text-align: center;
	}
	
}


/*------------------------------------------------------------
	【追加料金】横スクロール アイコン
------------------------------------------------------------*/

a.swipe-cursor {
	display: inline-block;
	font-size: 1rem;
	font-weight: 600;
	color: #000;
	text-decoration: none;
	position: relative;
	top: -30px;
	z-index: 100;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	margin-left: 50px;
}

a.swipe-cursor:hover {
	color: #000;
}

a.swipe-cursor span {
	background:url(../img/common/swipe.svg) left center / contain no-repeat;
	position: absolute;
	width: 124px;
	height: 24px;
	top: 0;
	padding-left: 40px;
	-webkit-animation: sdb 3s infinite;
	animation: sdb 3s infinite;
}

@-webkit-keyframes sdb {
	
  0% {
    -webkit-transform: translate(180px, 0);
    opacity: 0;
  }
  20% {
    -webkit-transform: translate(180px, 0);
    opacity: 1;
  }
  90% {
    -webkit-transform: translate(0, 0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  
}

@keyframes sdb {

  0% {
    -webkit-transform: translate(180px, 0);
    opacity: 0;
  }
  20% {
    -webkit-transform: translate(180px, 0);
    opacity: 1;
  }
  90% {
    -webkit-transform: translate(0, 0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  
}	

@media only screen and (min-width: 813px) {
	
	a.swipe-cursor {
		display: none;
	}
	
}


/*------------------------------------------------------------
	【保険】ご注意
------------------------------------------------------------*/

#attention-area {
	background: #F7F7F0;
	padding: 10px;
	color: #000;
}

h5 {
	background: #ED0000;
	width: 100%;
	font-size: 1.6rem;
	line-height: 60px;
	color: #fff;
	text-align: center;
}

#attention-area h3 {
	background: #fff;
	margin-bottom: 15px;
}


@media only screen and (min-width: 813px) {
	
	#attention-area {
		background: #F7F7F0;
		padding: 30px 30px 20px;
		color: #000;
	}
	
	h5 {
		font-size: 2rem;
	}
	
	#attention-area h3 {
		margin-bottom: 20px;
	}

	
}


/*------------------------------------------------------------
	【ドライブ・アドバイス】
------------------------------------------------------------*/

.guide-group {
	margin: 15px 0 5px;
}

.guide-group dt {
	font-size: 1.5rem;
}

@media only screen and (min-width: 813px) {
	
	.guide-group {
		margin: 20px 0 5px;
	}
	
}

figure.one-third-right {
	margin-bottom: 15px;
}

.one-third-right figcaption {
	font-size: 1.2rem;
	margin-top: 5px;
}


@media only screen and (min-width: 813px) {
	
	figure.one-third-right {
		margin-bottom: 0;
	}
	
	.one-third-right figcaption {
		margin-top: 10px;
	}

}

/*------------------------------------------------------------
	【チャイルドシート】
------------------------------------------------------------*/

.child-seat .one-third {
	border: 1px solid #ddd;
	padding: 20px;
	margin-bottom: 20px;
}

.child-seat img {
	width: 100%;
	height: auto;
	margin-bottom: 8px;
}

.child-seat .one-third dl dt {
	font-size: 1.6rem;
	text-align: center;
	font-weight: 600;
	color: #000;
	margin-bottom: 5px;
}

.child-seat .one-third dl dd {
	background: #f1f1f1;
	font-size: 1.3rem;
	padding: 10px 15px;
}

.child-seat .one-third dl dd span {
	font-weight: 600;
}



