@charset "UTF-8";

/*************************************************************
パーパスジャパン
[css/tour.css]
15.11.25
**************************************************************/

/* 目次
-------------------------------------------------------------
1) カラム
2) 受付終了から2枚の写真まで
3) ツアーのポイント  [#point]
4) スケジュール  [#schedule]
5) 旅行代金カレンダー  [#calendar]
6) お問い合わせ  [#otoiawase]
7) サイドカラム  [aside#side]
8）追加
9) スケジュール追加  [#schedule]
-------------------------------------------------------------*/


/* 1) カラム
-------------------------------------------------------------*/
#contents {
	padding-top: 6px;
}

article#main {
	width: 780px;
}

aside#side {
	width: 200px;
}

@media screen and (max-width: 860px) {
	#contents {
		padding-top: 0;
	}

	article#main {
		margin: 0 auto;
		width: 100%;
	}
	article#main.fleft {
		float: none;
	}
	aside#side {
		margin: 0 auto;
		padding-top: 1em;
		width: 100%;
	}
	aside#side.fright {
		float: none;
	}
}

/* 追加　パンくずリスト */
ul.pankuzu {
	margin-bottom: 18px;
}
	
ul.pankuzu li {
	display: inline;
	font-size: 12px;
}

ul.pankuzu li a {
	color:#000;
}

ul.pankuzu li:after {
	content: '\f105';
	font-family: FontAwesome;
	padding-left: 10px;
	padding-right: 6px;
}

ul.pankuzu li:last-child:after {
	content: none;
	padding: 0;
}

@media screen and (max-width: 860px) {
	ul.pankuzu {
		margin-bottom: 10px;
	}
	ul.pankuzu li {
		display: inline;
		font-size: 10px;
	}
}

/* 2) 受付終了から2枚の写真まで
-------------------------------------------------------------*/
/* 受付終了 */
.end {
	line-height: 56px;
	padding-right: 40px;
	margin-bottom: 10px;
	background: url(../images/tour/arrow04.png) no-repeat 740px center;
}

.end p {
	padding-left: 14px;
	border-radius: 4px;
}

.end p i {
	font-size: 40px;

	padding-right: 11px;
}

.end p i,
.end p span {
	vertical-align: middle;
}
@media screen and (max-width: 860px) {
	.end {
		margin: 0 auto;
		width: 100%;
		line-height: 1em;
		padding: 0;
		margin-bottom: 10px;
		background-image: none;
		position: relative;
	}

	.end p {
		padding: 0.5em;
		border-radius: 4px;
	}
	.end p i {
		font-size: 42px;
		padding-right: 0;
		position: absolute;
		top: 5px;
		left: 8px;
	}
	.end p span {
		display: inline-block;
		margin-left: 40px;
		padding: 0 0.5em;
		line-height: 1.6em;
		font-size: 11px;
		transform: none!important;
	}
	.end p span br {
		display: none!important;
	}
}
/* section.wrap */
.wrap {
	padding-right: 40px;
	padding-top: 50px;
}

.wrap:first-child,
.end + .wrap {
	padding-top: 0;
}

@media screen and (max-width: 860px) {
	.wrap {
		padding-right: 0;
		padding-top: 0;
	}
}

/* 国旗 */
img.flag {
	margin-right: 10px;
}
@media screen and (max-width: 860px) {
	img.flag {
		margin-right: 10px;
		width: 50px;
		vertical-align: middle;
	}
	img.flag + span.flagnum.spi {
		display: inline-block;
		line-height: 1em;
		font-size: 13px;
		font-weight: bold;
		vertical-align: middle;
	}
	img.flag + span.flagnum.spi:before {
		content: "コースナンバー：";
		font-weight: normal;
	}
}

/* 印刷ボタン */
p.printBtn a {
	display: block;
	line-height: 30px;
	padding-left: 16px;
	width: 104px;
	border: #b3b3b3 solid 1px;
	border-radius: 4px;
	background: #fff;
	background: -moz-linear-gradient(top, #fff 0%, #ccc 100%);
	background: -webkit-linear-gradient(top, #fff 0%, #ccc 100%);
	background: linear-gradient(to bottom, #fff 0%, #ccc 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#cccccc',GradientType=0 );
}

p.printBtn a i {
	font-size: 20px;
	padding-right: 10px;
}

p.printBtn a i,
p.printBtn a span {
	vertical-align: middle;
}

p.printBtn a:hover {
	text-decoration: none;
}
@media screen and (max-width: 860px) {
	p.printBtn {
		display: none;
	}
}

/* ツアー名 */
#main h3 {
	padding-top: 11px;
	padding-bottom: 14px;
}

/* 2枚の写真 */
.tourPhoto img {
	padding: 6px;
	border: #d9d9d9 solid 1px;
	box-shadow: 0 0 4px #ddd;
}

.tourPhoto img:last-child {
	float: right;
}

@media screen and (max-width: 860px) {
	.tourPhoto {
		text-align: center;
	}
	.tourPhoto img {
		margin: 0 1%;
		padding: 3px;
		width: calc(47% - 6px);
	}

	.tourPhoto img:last-child {
		float: none;
	}
}

/* アンカー　ナビゲーション */
#tour ul.anchor {
	text-align: center;
	font-size: 15px;
	font-weight: bold;
    text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.4);
	margin-bottom: 15px;
}

ul.anchor li,
ul.anchor li a {
	width: 184px;
	line-height: 44px;
	color: #fff;
}

ul.anchor li {
	float: left;
	width: 184px;
	line-height: 44px;
	margin-right: 2px;
	color: #fff;
	background-color: #000;
}

ul.anchor li a {
	display: block;
	background-color: #999;
}

ul.anchor li.last,
ul.anchor li.last a {
	width: 182px;
	margin-right: 0;
}

ul.anchor li.last a {
	background-color: #ffa200;
}

ul.anchor li a:hover {
	text-decoration: none;
	background-color: #000;
}

ul.anchor li i {
	font-size: 16px;
	padding-left: 2px;
	padding-right: 6px;
}

@media screen and (max-width: 860px) {
	#tour ul.anchor {
		padding: 2em 0;
		text-align: center;
		font-size: 12px;
		font-weight: bold;
	    text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.4);
		margin-bottom: 0;
	}
	ul.anchor li,
	ul.anchor li a {
		width: 50%;
		line-height: 3em;
		color: #fff;
	}
	ul.anchor li {
		float: left;
		width: 50%;
		margin-right: 0;
		color: #fff;
		background-color: #000;
	}
	ul.anchor li a {
		display: block;
		padding: 0;
		width: 100%;
		background-color: #999;
	}
	ul.anchor li.last,
	ul.anchor li.last a {
		width: 50%;
		margin-right: 0;
	}
	ul.anchor li.last a {
		width: 100%;
		background-color: #ffa200;
	}
	ul.anchor li a:hover {
		text-decoration: none;
		background-color: #000;
	}
	ul.anchor li i {
		font-size: 16px;
		padding-left: 2px;
		padding-right: 6px;
	}
}

/* 3) ツアーのポイント  [#point]
-------------------------------------------------------------*/
/* フリースペース
スケジュールの詳細と共通スタイル */
.inner .free ul {
	margin-top: 10px;
}

.inner .free,
.inner .free p,
.inner .free li {
	margin-bottom: 18px;
}

.inner .free li {
	font-size: 16px;
	text-indent: -1em;
	padding-left: 1em;
}

.inner .free .tourImage {
	text-align: center;
}

.inner .free .tourImage img {
	margin: 8px 18px 28px 0;
	background-color: #fff;
	padding: 5px;
	border: #d9d9d9 solid 1px;
	box-shadow: 0 0 4px #ddd;
}
@media screen and (max-width: 860px) {
	.inner .free .tourImage img {
		margin: 0 2% 4%;
		padding: 2px;
		width: 80px;
		box-shadow: 0 0 3px #ccc;
	}
	.movie {
		margin: 5% auto;
		padding-top: 56.25%;
		width: 100%;
		position: relative;
	}
	.movie iframe {
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
	}
	.help1 h6 {
		padding: 0.5em 0;
		font-size: 16px!important;
	}
	.help1 {
		margin: 0 auto!important;
		padding: 0.5em;
		width: 90%!important;
		font-size: 15px!important;
	}
	.help1 img {
		display: block;!important
		margin: 0 auto 0.5em!important;
		float: none!important;
		width: 80%!important;
		height: auto!important;
	}
	.spfree {
		margin: 10% auto 0;
		width: 90%;
	}
	.spfree p {
		padding: 0.5em 0 1.5em;
		line-height: 1.6em;
		font-size: 14px;
		letter-spacing: 0.025em;
	}
	.spfree p br {
		display: none;
	}
}
/* デジタルパンフレット */
#point .pamph a {
	display: block;
	width: 300px;
	line-height: 44px;
	padding-left: 28px;
	background: #f0f0f0 url(../images/common/arrow03.png) no-repeat 13px center;
}

/* 表：特徴、出発地、滞在都市、食事回数、最少催行人数 */
#point table {
	width: 740px;
	margin-top: 15px;
	table-layout: fixed;
}

#point th,
#point td {
	border-top: #fff solid 5px;
}

#point th {
	width: 8em;
	padding: 12px;
	background-color: #d6d6d6;
	vertical-align: middle;
	text-align: center;
}

#point th.leftLine {
	border-left: #fff solid 5px;
}

#point td {
	padding: 12px 4px 12px 12px;
	background-color: #f0f0f0;
}

#point td.tenjoin {
	width: 12em
}

@media screen and (max-width: 860px) {
	#point table {
		display: block;
		width: 100%;
		margin-top: 0;
		table-layout: auto;
	}
	#point tbody ,
	#point tr {
		display: block;
	}
	#point th,
	#point td {
		display: block;
		border-top: #fff solid 2px;
	}

	#point th {
		width: auto;
		padding: 0.5em;
		background-color: #d6d6d6;
		vertical-align: middle;
		text-align: center;
	}

	#point th.leftLine {
		border-left: #fff solid 2px;
	}

	#point td {
		padding: 0.5em;
		background-color: #f0f0f0;
	}
	#point td.tenjoin {
		width: auto;
	}
}

/* 特徴 */
#point td.mark {
	padding-bottom: 7px;
}

#point td mark {
	display: inline-block;
	font-size: 13px;
	padding: 5px 8px;
	border-style: solid;
	border-width: 1px;
	border-radius: 4px;
	margin-right: 3px;
	margin-bottom: 6px;
	white-space: nowrap;
}

#point td mark.A {
	color: #e46a38;
	background-color: #fff2e9;
	border-color: #e46a38;
	border-width: 3px;
	padding-top: 3px;
	padding-bottom: 3px;
}
#point td mark.B { color: #30a5c6; border-color: #30a5c6; }
#point td mark.C { color: #d266ae; border-color: #d266ae; }
#point td mark.D { color: #4e9d00; border-color: #4e9d00; }
#point td mark.E { color: #ca4650; border-color: #ca4650; }
#point td mark.F { color: #6573c5; border-color: #6572c5; }

/* 追加アイコン */
#point td mark.themeA,
#point td mark.themeB,
#point td mark.themeC,
#point td mark.themeD,
#point td mark.themeE,
#point td mark.themeF ,
#point td mark.themeG,
#point td mark.themeH,
#point td mark.themeI,
#point td mark.themeJ,
#point td mark.themeK,
#point td mark.themeL,
#point td mark.themeM,
#point td mark.themeN,
#point td mark.themeO,
#point td mark.themeP,
#point td mark.themeQ,
#point td mark.themeR,
#point td mark.themeS,
#point td mark.themeT,
#point td mark.themeU,
#point td mark.themeV,
#point td mark.themeW,
#point td mark.themeX,
#point td mark.themeY,
#point td mark.themeZ {
	color: #fff;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.4);
}

#point td mark.themeA { background-color: #815b4a; border-color: #815b4a; }
#point td mark.themeB { background-color: #df80bd; border-color: #df80bd; }
#point td mark.themeC { background-color: #567fd8; border-color: #567fd8 }
#point td mark.themeD { background-color: #e18d30; border-color: #e18d30; }
#point td mark.themeE { background-color: #cdb630; border-color: #cdb630; }
#point td mark.themeF { background-color: #5d866a; border-color: #5d866a; }
#point td mark.themeG { background-color: #d96e45; border-color: #d96e45; }
#point td mark.themeH { background-color: #97a900; border-color: #97a900; }
#point td mark.themeI { background-color: #b68b4f; border-color: #b68b4f; }
#point td mark.themeJ { background-color: #dc5e79; border-color: #dc5e79; }
#point td mark.themeK { background-color: #a44977; border-color: #a44977; }
#point td mark.themeL { background-color: #374e7e; border-color: #374e7e; }
#point td mark.themeM { background-color: #c2af70; border-color: #c2af70; }
#point td mark.themeN { background-color: #9371bd; border-color: #9371bd; }
#point td mark.themeO { background-color: #68bcd9; border-color: #68bcd9; }
#point td mark.themeP { background-color: #589d56; border-color: #589d56; }
#point td mark.themeQ { background-color: #8699b6; border-color: #8699b6; }
#point td mark.themeR { background-color: #4c6860; border-color: #4c6860; }
#point td mark.themeS { background-color: #c7354a; border-color: #c7354a; }
#point td mark.themeT { background-color: #fccf3e; border-color: #fccf3e; }
#point td mark.themeU { background-color: #3686b2; border-color: #3686b2; }
#point td mark.themeV { background-color: #47a09c; border-color: #47a09c; }
#point td mark.themeW { background-color: #aa818f; border-color: #aa818f; }
#point td mark.themeX { background-color: #f4a682; border-color: #f4a682; }
#point td mark.themeY { background-color: #4c47a7; border-color: #4c47a7; }
#point td mark.themeZ { background-color: #567e9a; border-color: #567e9a; }

/* 4) スケジュール  [#schedule]
-------------------------------------------------------------*/
/* 延泊 */
p.enpaku {
	height:70px;
	padding-top: 11px;
	background: url(../images/tour/balloon.png) no-repeat 0 0;
}
@media screen and (max-width: 860px) {
	p.enpaku {
		margin-bottom: 25px;
		border-radius: 1em;
		border: 3px solid #e46a38;
		height:auto;
		padding: 0.5em;
		background: none;
		background: #fff2e9;
		position: relative;
	}
	p.enpaku:before {
		content: "";
		border: 3px solid #e46a38;
		border-top: 0;
		border-right: 0;
		width: 14px;
		height: 14px;
		background: #fff2e9;
		transform: rotate(-45deg);
		position: absolute;
		bottom: -11px;
		left: 25px;
	}
}
/* スケジュール表 */
table.scheduleTable {
	width: 100%;
	border: #d9d9d9 solid 1px;
	table-layout: fixed;
}

table.scheduleTable thead th { border-left: #bbb dotted 1px; }

table.scheduleTable thead th.num { width: 3.5em; }
table.scheduleTable thead th.city { width: 9.5em; }
table.scheduleTable thead th.time { width: 4.5em; }
table.scheduleTable thead th.meal { width: 5.5em; }

table.scheduleTable tbody{
	border-top: #d9d9d9 solid 1px;
}

/*table.scheduleTable tbody th,
table.scheduleTable td {
	border-top: #d9d9d9 solid 1px;
}
*/
table.scheduleTable tbody th {
	width: 36px;
	text-align: center;
	padding-top: 10px;
	padding-bottom: 10px;
}

table.scheduleTable td {
	border-left: #ccc dotted 1px;
	padding: 10px;
}

/*table.scheduleTable tr:nth-child(even) {
	background-color: #f5f5f5;
}*/

table.scheduleTable .tdeven{
    background: #f5f5f5;
}

#schedule td a:after {
	content: "\f059";
	font-family: FontAwesome;
	padding-left: 2px;
	padding-right: 2px;
}

table.scheduleTable td .pleft1em {
	display: block;
	padding-left: 1em;
}

@media screen and (max-width: 860px) {
	table.scheduleTable {
		table-layout: auto;
		font-size: 13px;
	}
	.spb .tabSchedule {
		display: none;
	}
	.spb .tabSchedule.open {
		display: block;
	}
	table.scheduleTable tbody th {
		width: 36px;
		text-align: center;
		padding: 0.5em 0;
	}
	table.scheduleTable td {
		padding: 0.3em;
	}
	table.scheduleTable th + td +td {
		width: 50%;
	}
/*
	.tabContainer .controls {
		display: none;
	}
*/
	.tabContentsContainer {
		clear: both;
		background: transparent!important;
	}
	p.spschedulebtn {
		display: block!important;
		opacity: 1!important;
		margin: 0.5em auto;
		border-radius: 8px;
		padding: 0.5em;
		background: #d9d9d9;
		cursor: pointer;
		position: relative;
	}
	p.spschedulebtn:after {
		position: absolute;
		content: "\f13a";
		font-family: FontAwesome;
		right: 10px;
		color: #3a65ae;
	}
	p.spschedulebtn.open:after {
		content: "\f139";
	}
}

/* 航空会社、ホテル、備考 */
#schedule .inner section {
	padding-top: 16px;
	padding-bottom: 11px;
	border-top: #ccc dotted 1px;
}

#schedule .inner .scheduleRemark {
	padding-bottom: 0;
}

#schedule .inner .air {
	border-top: none;
	margin-top: 3px;
}

#schedule .inner h4 {
	font-size: 17px;
	line-height: 1.2;
	font-weight: bold;
	border-left: #3a65ae solid 5px;
	padding-left: 10px;
	margin-bottom: 10px;
}

#schedule .inner .air p,
#schedule .inner .hotel table,
#schedule .inner .scheduleRemark .free {
	margin-left: 15px;
}

/* 利用ホテル */
#schedule .inner .hotel th {
	font-weight: bold;
	white-space: nowrap;
	padding-right: 10px;
	border-right: #d9d9d9 solid 1px;
}

#schedule .inner .hotel td {
	display: block;
	padding-left: 10px;
	margin-top: 5px;
	margin-bottom: 5px;
}
@media screen and (max-width: 860px) {
	#schedule .inner .hotel table {
		display: block;
		margin: 0;
		font-size: 14px;
	}
	#schedule .inner .hotel th {
		display: block;
		border: 0;
		border-bottom: 1px solid #d9d9d9;
		white-space: normal;
		padding: 5px;
	}
	#schedule .inner .hotel td {
		display: block;
		padding-left: 0;
		margin-top: 5px;
		margin-bottom: 5px;
	}
}
/* 備考
ツアーのポイントに記述 */

/* 関連ツアー */
#schedule ul.relation {
	padding-top: 10px;
	padding-bottom: 10px;
	padding-right: 5px;
}

#schedule ul.relation li a {
	padding-left: 28px;
	margin-top: 20px;
	background: #f0f0f0 url(../images/common/arrow03.png) no-repeat 13px center;
}

/* 5) 旅行代金カレンダー  [#calendar]
-------------------------------------------------------------*/
/* 出発期間 */
#calendar dl.departure dt {
	border: #999 solid 1px;
	border-radius: 3px;
	padding-left: 9px;
	padding-right: 9px;
	margin-right: 12px;
}

#calendar dl.departure dd {
	padding-top: 1px;
}
@media screen and (max-width: 860px) {
	#calendar dl.departure {
		text-align: center;
	}
	#calendar dl.departure dt {
		float: none;
		display: inline-block;
		margin-right: 0.6em;
		padding: 0 0.3em;
		font-size: 15px;
	}
	#calendar dl.departure dd {
		display: inline-block;
		padding-top: 1px;
	}
}
/* タブ */
.tabContainer {
	margin-top: 15px;
}

.tabContainer .controls li {
	display: inline-block;
	width: 57px;
	line-height: 2.4;
	text-align: center;
	color: #ccc;
	background: #f0f0f0;
	border-radius: 4px 4px 0 0 ;
}

.tabContainer .controls li a {
  display: block;
  background: #999;
  color: #fff;
  border-radius: 4px 4px 0 0 ;
}

.tabContainer .controls li.current a,
.tabContainer .controls li a:hover {
  color: #000;
  background: #d9d9d9;
  text-decoration: none;
}

.tabContainer .tabContentsContainer>* {
  position: relative;
  top: 0;
  left: 0;
}
@media screen and (max-width: 860px) {
	.tabContainer {
		margin: 15px 0 5px;
		overflow: hidden;
	}
	.tabContainer .controls {
		overflow: hidden;
	}
	.tabContainer .tabContentsContainer + .controls {
		padding-top: 1.5%;
	}
	.tabContainer .controls li {
		display: block;
		float: left;
		margin: 0 0.5% 1%;
		width: 15.666%;
		line-height: 1;
		border-radius: 0;
	}

	.tabContainer .controls li a {
	  display: block;
	  padding: 0.5em 0;
	  color: #fff;
	  background: #999;
	  border-radius: 4px;
	}

	.tabContainer .controls li.current a,
	.tabContainer .controls li a:hover {
	  color: #000;
	  background: #d9d9d9;
	  text-decoration: none;
	}

	.tabContainer .tabContentsContainer>* {
	  position: relative;
	  top: 0;
	  left: 0;
	}
}
/* カレンダー */
.tabCalendar {
  overflow: hidden;
  background-color: #d9d9d9;
  line-height: 1.4;
}

.tabCalendar table {
	width: 368px;
	text-align: center;
}

.tabCalendar table:first-child { float: left; }
.tabCalendar table:last-child { float: right; }

.tabCalendar table:first-child th,
.tabCalendar table:first-child td {
	border-left: #d9d9d9 solid 1px;
}

.tabCalendar table:last-child th,
.tabCalendar table:last-child td {
	border-right: #d9d9d9 solid 1px;
}

.tabCalendar th,
.tabCalendar td {
	width: 14.285%;
}

.tabCalendar th {
	font-size: 18px;
	padding-top: 8px;
	padding-bottom: 8px;
}

.tabCalendar td {
	height: 49px;
	background-color: #fff;
	border-bottom: #d9d9d9 solid 1px;
	padding-top: 5px;
}

.tabCalendar tr.week td {
	height: 28px;
	background-color: #f5f5f5;
}

.tabCalendar td:first-child,
.tabCalendar td.holiday { color: #c00; }
.tabCalendar td:last-child { color: #04e; }

.tabCalendar td span {
	display: block;
	font-weight: bold;
	color: #000;
}

@media screen and (max-width: 860px) {
	.tabCalendar table {
		margin: 0 auto 5%;
		width: 90%;
		font-size: 13px;
	}
	.tabCalendar table:first-child { float: none; }
	.tabCalendar table:last-child { float: none; display: none; }
	.tabCalendar th {
		font-size: 16px;
		padding: 0.5em 0;
	}
	.tabCalendar td {
		height: 39px;
		padding: 0.2em 0;
	}
}

/* 料金設定がない月 */
.tabCalendar td.noSetting {
	height: 294px;
	color: #000;
	background-color: #f5f5f5;
}

.tabCalendar td.noSetting p.f18 {
	margin-top: 17px;
	margin-bottom: 17px;
	margin-left: 6px;
}

.tabCalendar td.noSetting dl {
	margin-top: 17px;
	margin-left: 22px;
}

.tabCalendar td.noSetting dt {
	margin-top: 10px;
}

.tabCalendar td.noSetting dd span {
	display: inline;
}

.tabCalendar td.noSetting dd span.f12 {
	font-weight: normal;
}

/* 料金設定もお問い合わせもない月 */
.tabCalendar table.empty {
	height: 364px;
	border-left: #fff solid 1px;
}

.tabCalendar table.empty td {
	border: none;
	background-color: transparent;
}

@media screen and (max-width: 860px) {
	.tabCalendar table.empty {
		display: none;
		height: auto;
		border-left: 0;
	}
}

/* 料金 */
#calendar table.price {
	border: #d9d9d9 solid 1px;
	margin-top: 20px;
	margin-bottom: 20px;
	table-layout: fixed;
}

#calendar table.price tbody th,
#calendar table.price tbody td {
	border-top: #d9d9d9 solid 1px;
	vertical-align: middle;
}

#calendar table.price th,
#calendar table.price td {
	border-left: #d9d9d9 solid 1px;
	padding: 7px 4px;
}

#calendar table.price .bg_bk04 {
	width: 128px;
	border-left: none;
}

#calendar table.price input[type="checkbox"] {
	display: block;
	margin: 2px auto 0;
	background-color: transparent;
}

#calendar table.price thead th { font-weight: bold; }

#calendar .priceA { background-color: #fff89a; }
#calendar .priceB { background-color: #ffa7d7; }
#calendar .priceC { background-color: #95e4c8; }
#calendar .priceD { background-color: #cfc7ff; }
#calendar .priceE { background-color: #fbc3a4; }
#calendar .priceF { background-color: #cdf297; }
#calendar .priceG { background-color: #8db8f8; }
#calendar .priceH { background-color: #eb9195; }
#calendar .priceI { background-color: #85cdeb; }
#calendar .priceJ { background-color: #edac56; }
#calendar .priceK { background-color: #d797f7; }
#calendar .priceL { background-color: #b5c36f; }
#calendar .priceM { background-color: #79afc3; }
#calendar .priceN { background-color: #e3cc5b; }
#calendar .priceO { background-color: #be9f81; }
#calendar .priceP { background-color: #bbbbbb; }
#calendar .priceQ { background-color: #b1a1c2; }
#calendar .priceR { background-color: #c2bb83; }
#calendar .priceS { background-color: #d59aae; }
#calendar .priceT { background-color: #95a5cf; }
#calendar .priceU { background-color: #ffebbb; }
#calendar .priceV { background-color: #ffcfe7; }
#calendar .priceW { background-color: #c2efdf; }
#calendar .priceX { background-color: #fcd4b9; }
#calendar .priceY { background-color: #dcf6b7; }
#calendar .priceZ { background-color: #c4ddfc; }

#calendar table.price td {
	width: 102px;
	vertical-align: middle;
}

/* 備考 */
#calendar .priceRemark { border: #d9d9d9 solid 1px; }
#calendar .priceRemark h4 { border-bottom: #d9d9d9 solid 1px; }

#calendar .priceRemark dl {
	margin: 16px 20px 0;
}

#calendar .priceRemark dt,
#calendar .priceRemark dd {
	display: table-cell;
	width: 136px;
	text-align: center;
}

#calendar .priceRemark ul,
#calendar .priceRemark p {
	margin: 13px 20px;
}

#calendar .priceRemark li {
	text-indent: -1em;
	padding-left: 1em;	
}

@media screen and (max-width: 860px) {
	#calendar .priceRemark p {
		margin: 0;
		padding: 0.5em;
		font-size: 13px;
	}
}
.priceA { background-color: #fff89a; }
.priceB { background-color: #ffa7d7; }
.priceC { background-color: #95e4c8; }
.priceD { background-color: #cfc7ff; }
.priceE { background-color: #fbc3a4; }
.priceF { background-color: #cdf297; }
.priceG { background-color: #8db8f8; }
.priceH { background-color: #eb9195; }
.priceI { background-color: #85cdeb; }
.priceJ { background-color: #edac56; }
.priceK { background-color: #d797f7; }
.priceL { background-color: #b5c36f; }
.priceM { background-color: #79afc3; }
.priceN { background-color: #e3cc5b; }
.priceO { background-color: #be9f81; }
.priceP { background-color: #bbbbbb; }
.priceQ { background-color: #b1a1c2; }
.priceR { background-color: #c2bb83; }
.priceS { background-color: #d59aae; }
.priceT { background-color: #95a5cf; }
.priceU { background-color: #ffebbb; }
.priceV { background-color: #ffcfe7; }
.priceW { background-color: #c2efdf; }
.priceX { background-color: #fcd4b9; }
.priceY { background-color: #dcf6b7; }
.priceZ { background-color: #c4ddfc; }

/* 2017.08.15追加 */
#calendar .postscript {
	background-color: #fff2e9;
	border: #e46a38 solid 1px;
	margin-bottom: 13px;
	padding: 6px;
}


/* 6) お問い合わせ  [#otoiawase]
-------------------------------------------------------------*/
/* 延泊　スケジュール [#schedule] に記述 */

#otoiawase .bg_bk06 {
	padding: 16px 20px 20px;
}

/* 見出し */
#otoiawase h4 {
	margin-bottom: 13px;
}

#otoiawase h4 i,
#otoiawase h4 span {
	vertical-align: middle;
}

#otoiawase h4 i {
	color: #b6b6b6;
	font-size: 40px;
	margin-right: 15px;
}

/* メールでお問い合わせ */
#otoiawase .mail {
	border-bottom: #bbb dotted 1px;
	padding-bottom: 8px;
}

#otoiawase .inner ul {
	margin-top: 17px;
}

#otoiawase .inner li {
	margin-bottom: 10px;
	text-indent: -1em;
	padding-left: 1em;
}

/* 電話でお問い合わせ */
#otoiawase .tel {
	padding-top: 15px;
}

#otoiawase .tel .bg_white {
	border-radius: 8px;
	padding: 13px 20px 13px 30px;
}

#otoiawase .tel .course {
	position: relative;
	margin-top: 17px;
	padding: 20px 0 7px 20px;
	border-radius: 8px;
	background: #4f6081 url(../images/tour/bg_print.png) no-repeat right top;
}

#otoiawase .tel .course dt {
	float: left;
	clear: left;
	width: 94px;
	text-align: center;
	font-size: 12px;
	font-weight: bold;
	color: #4f6081;
	background-color: #fff;
	border-radius: 3px;
	margin-right: 12px;
}

#otoiawase .tel .course dd {
	float: left;
	max-width: 560px;
	color: #fff;
	margin-bottom: 10px;
}

#otoiawase .tel .course p.printBtn {
	position: absolute;
	top: 10px;
	right: 34px;
}
#otoiawase .tel .bg_white dl dd span a {
	color: #000;
	pointer-events: none;
}

@media screen and (max-width: 860px) {
	#otoiawase .bg_bk06 {
	    padding: 0.5em;
	}
	#otoiawase h4 {
		text-align: center;
		margin-bottom: 0.5em;
	}

	#otoiawase h4 i,
	#otoiawase h4 span {
		vertical-align: middle;
	}

	#otoiawase h4 i {
		color: #b6b6b6;
		font-size: 30px;
		margin-right: 15px;
	}
	#otoiawase h4 span {
		font-size: 18px;
	}
	#otoiawase .tel h4 span.f15 {
		display: block;
		font-size: 13px;
	}
	#otoiawase .mail .btn {
		padding-top: 1em;
	}
	#otoiawase .mail .btn p {
		float: none;
		margin: 0 auto 1em;
		width: 80%;
	}
	#otoiawase .tel .bg_white {
		border-radius: 8px;
		padding: 1em;
		text-align: center;
	}
	#otoiawase .tel .bg_white dl {
		display: inline-block;
		float: none;
		text-align: left;
	}
	#otoiawase .tel .bg_white dl.fleft {
		margin-bottom: 5%;
	}
	#otoiawase .tel .bg_white dl dd {
		font-size: 11px;
	}
	#otoiawase .tel .bg_white dl dd span {
	}
	#otoiawase .tel .bg_white dl dd span a {
		color: #3a65ae;
		font-size: 38px;
		pointer-events: auto;
	}
}

/* 7) サイドカラム  [aside#side]
-------------------------------------------------------------*/
aside#side section {
	font-size: 12px;
	line-height: 1.5;
	border: #d9d9d9 solid 1px;
	margin-bottom: 20px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

aside#side h5,
aside#side dl,
aside#side p,
aside#side ul {
	padding-left: 15px;
	padding-right: 15px;
}

/* コースナンバー */
aside#side .courseNum p.bg_orange {
	height: 48px;
	padding-top: 8px;
}

/* お問い合わせ */
aside#side .courseNum p.btn {
	margin-top: 20px;
	margin-bottom: 16px;
}

aside#side .courseNum h5 {
	background: url(../images/tour/bracket.png) no-repeat center center;
}

aside#side .courseNum dt {
	padding-top: 10px;
	font-size: 14px;
}

aside#side .courseNum dt.osaka {
	border-top: #ccc dotted 1px;
}

aside#side .courseNum dd {
	padding-bottom: 10px;
	font-size: 11px;
}

aside#side .courseNum dd span {
	font-size: 21px;
	line-height: 1.2;
	font-weight: bold;
	font-family: Arial, Helvetica, sans-serif;
	letter-spacing: 1px;
}

aside#side .courseNum dd i {
	margin-right: 5px;
}

aside#side .courseNum p small {
	display: block;
	padding-bottom: 10px
}

/* 旅行紀、関連ツアー、希望のツアーが見つからない */
aside#side .item h5 {
	font-size: 14px;
	font-weight: normal;
	text-align: center;
	background-color: #f5f5f5;
	padding-top: 9px;
	padding-bottom: 9px;
}

aside#side .item p {
	padding-top: 15px;
	padding-bottom: 8px;
	border-top: #ccc dotted 1px;
}

aside#side .item.kanren p {
	padding-bottom: 11px;
}

aside#side .item p img {
	margin-bottom: 7px;
}

aside#side .item.ryokoki a,
aside#side .item.kanren li a,
aside#side .item.mitsukaranai li a {
	display: block;
	font-size: 13px;
	padding-left: 12px;
	background: url(../images/common/arrow03.png) no-repeat left 7px;
}

aside#side .item.ryokoki a,
aside#side .item.kanren li a {
	padding-top: 3px;
	padding-bottom: 3px;
}

aside#side .item.ryokoki ul,
aside#side .item.kanren ul {
	border-top: #ccc dotted 1px;
	background-color: #f5f5f5;
	padding-top: 8px;
	padding-bottom: 8px;
}

aside#side .item.mitsukaranai ul {
	padding-left: 0;
	padding-right: 0;
}

aside#side .item.mitsukaranai li {
	padding: 11px 15px;
	border-top: #ccc dotted 1px;
}

aside#side .item.mitsukaranai li a {
	background-position: left center;
	padding-bottom: 3px;
}

@media screen and (max-width: 860px) {
	aside#side .item.mitsukaranai h5 br {
		font-size: 14px;
		font-weight: normal;
		text-align: center;
		background-color: #f5f5f5;
		padding-top: 9px;
		padding-bottom: 9px;
	}
	aside#side .item.mitsukaranai h5 br {
		display: none;
	}

	aside#side .item.ryokoki p ,
	aside#side .item.kanren p {
		padding: 0.5em;
		line-height: 1.4em;
		overflow: hidden;
	}
	aside#side .item.ryokoki p img ,
	aside#side .item.kanren p img {
		float: left;
		margin-bottom: 0;
		margin-right: 0.5em;
		width: 46%;
	}
	aside#side .item.kanren p img {
		width: 20%;
	}
	aside#side .item.ryokoki p a {
		padding: 0;
		text-align: right;
	}
	aside#side .courseNum {
		display: none;
	}
}
/* 8) 追加
-------------------------------------------------------------*/
.orange {
	font-weight: bold;
}
.enpaku.orange {
	font-weight: normal;
}

.printOnly {
	display: none;
}

@media screen and (max-width: 860px) {
	#schedule p.enpaku.orange span ,
	#otoiawase p.enpaku.orange span {
		display: block;
		text-align: center;
		font-size: 14px;
	}
	#schedule p.enpaku.orange strong ,
	#otoiawase p.enpaku.orange strong {
		display: block;
		font-size: 16px;
	}
}

/* 9) スケジュール追加  [#schedule]
-------------------------------------------------------------*/
#schedule .tabContainer,
.tabSchedule {
	border:0 !important;
	padding:0 !important;
	margin:0 !important;
	background: #fff;
}

#schedule .tabContainer .controls li {
	width: 140px;
	font-size: 18px;
	margin-right: 4px;
}
@media screen and (max-width: 860px) {
	#schedule .tabContainer .controls li {
		width: 100px;
		font-size: 14px;
		margin-right: 4px;
	}
}
table.scheduleTable {
	background-color: #fff;
}

table.scheduleTable thead th {
	border:0;
}

@media screen and (max-width: 860px) {
	div.cp {
		margin: 0 auto;
		width: 96%;
	}
	div.cp ul {
	}
	div.cp ul li {
	}
	div.cp ul li figure {
	}
	div.cp ul li figure figcaption {
		padding: 0.5em 0;
		font-size: 14px;
	}
}