@charset "utf-8";
html,body { height:100%; }
/* フォントサイズの基準を10pxに */
html {
  font-size: 10px;
  font-size: 62.5%;
  }

/* body */
body {
  width: 100%;
  margin: auto;
  color: #46413c;
  background-color: #fffff5;
  padding: 0;
  font-family: "ヒラギノ角ゴ Pro W6","ヒラギノ角ゴ","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO","ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro",　sans-serif;  font-size: 1.6rem;
  font-feature-settings: "palt";
  letter-spacing: 0.1em;
}

/* IE11だけに適応 */
_:lang(x)::-ms-backdrop, .selector {
	font-family: "Segoe UI", "メイリオ", Meiryo, sans-serif;
}

/* 太字 */
b, strong, .bold, h2{
	font-family: "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO",　sans-serif;
}

/*clearfix*/
.cf:before,.cf:after {content:""; display:block; overflow:hidden;}
.cf:after {clear:both;}
.cf {zoom:1;}

/*style*/
p{font-size:1.6rem; text-align:justify; text-justify:inter-ideograph; line-height: 1.8; margin:0;}

@media screen and (max-width:960px) {
  p{font-size: 1.6rem;}
}

@media screen and (max-width:560px) {
  p{font-size: 1.4rem;}
}



a{text-decoration: underline; color:#282828; text-decoration: none;}
a:hover{text-decoration: none;}
h2{line-height: 1; font-weight:normal; letter-spacing: 4;}
main{overflow: hidden;}

.widthfix{width:100%; max-width:640px; margin:0 auto;}
img{width:100%; vertical-align: bottom;}



/* ul */
ul,ol{padding:0;}
ol li,ul li{font-size: 1.8rem; padding:0; list-style:none;}

@media screen and (max-width:960px) {
  ol li,ul li{font-size: 1.6rem;}
}

@media screen and (max-width:560px) {
  ol li,ul li{font-size: 1.4rem;}
}

/* テーブルに関して */
table{
  font-size: 1.6rem;
  text-align: center;
}

/* thの下線を1pxに */
.table-bordered thead td, .table-bordered thead th {
  border-bottom-width: 1px;
}
.table thead th {
  vertical-align: bottom;
  border-bottom: 1px solid #dee2e6;
}







/* 共通 */

#kumeisland_marathon_all {
	background-image:url("../img/bg.jpg");
	background-repeat: no-repeat;
	background-color: #169CAF;
	background-position: center 0px;
}


.section__wrap{
  padding:10px 10px 0;
  width: 100%;
  max-width: 930px;
  margin: 0 auto;
}



h3 {
	text-align: center;
	color: #fff;
	font-weight: bold;
	font-size: 35px;
}







@media screen and (max-width:560px) {
	
.section__wrap{
  padding:10px 0px;
  width: 100%;
  margin: 0 auto;
}
	
#kumeisland_marathon_all {
	background-image:url("../img/bg.jpg");
	background-size: 170%;
	background-repeat: no-repeat;
	background-color: #169CAF;	
	background-position: center 0px;
}



}

/* new clearfix */  
.clearfix:after {  
    visibility: hidden;  
    display: block;  
    font-size: 0;  
    content: " ";  
    clear: both;  
    height: 0;  
    }  
* html .clearfix             { zoom: 1; } /* IE6 */  
*:first-child+html .clearfix { zoom: 1; } /* IE7 */  


h2{
  margin:10px auto 30px;
}



.section__image{
  width: 100%;
  max-width: 1000px;
  margin: 0 auto 80px;
}




p span.marker{
  font-size: 2.4rem;
  font-weight: bold;
  color: #ffff00;
  padding: 5px 10px;
  margin: 0 5px;
  background: linear-gradient(transparent 0%, #ff78b7 0%);
}

p span.marker_yerrow{
  font-size: 2.4rem;
  font-weight: bold;
  color: #DC5C1F;
  padding: 5px 10px;
  margin: 0 5px;
  background: linear-gradient(transparent 0%, #F9FF37 0%);
}



@media screen and (max-width:560px) {

  .section__image{
    margin: 0 auto 40px;
  }

  h2{
    margin:0 auto 40px;
  }

  p span.marker{
    font-size: 1.8rem;
  }


}




/* メインビジュアル */


.main_img{
  width: 689px;
	margin: auto;
	padding-top: 20px;
}

.main_txt {
	padding-top: 20px;
	padding-bottom: 20px;
	text-align: center;
	font-size: 120%;
	color: #fff;
}


.tabi_point {
	padding: 30px;
	background-color: #F6FF73;
	border-radius: 20px;
	width: 900px;
	margin: auto;
display: block;
}

.tabi_point_sp {
	display: none;
}

.tourpoint_tit {
	width: 835px;
  margin: 0 auto;
}

.tabi_point li {
	float: left;
}

.tabi_point li p {
	font-size: 70%;
	line-height: 1.5em;
	color: #000000;
	padding: 10px 20px;
	background-color: #fff;
	width: 240px;
	border-radius: 10px;
	height: 140px;
}

.point_img {
	height: 275px;
}

.point_img01,.point_img02,.point_img03 {
	height: 294px;
}

.point_img01 img {
	width: 294px;
}

.point_img02 img {
	width: 305px;
}

.point_img03 img {
	width: 251px;
}

.taikai_shosai {
	background-color: #fff;
	width: 900px;
	border-radius: 20px;
	padding: 30px;
	margin:20px auto;
}

.tshosai {
	text-align: center;
	color: #0090B9;
	font-size: 150%;
	font-weight: bold;
}

.shosai_naiyo dl {
  display: flex;
  flex-wrap: wrap;
}
.shosai_naiyo dt {
  width: 15%;
  padding: 20px;
  background-color: #0090B9;
	color: #fff;
	font-weight: bold;
  margin: 0 0 10px 0;
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.shosai_naiyo dd {
  width: 75%;
  padding: 20px;
  background-color: #fff;
  margin: 0 0 10px 0;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}

.shosai_naiyo a {
	text-decoration: underline;
}

.shosai_naiyo p {
	padding-bottom: 5px;
}

.attention_box {
	padding-bottom: 10px;
	margin: auto;
}


.attention_box p {;
	font-size: 25px;
	color: #ff0041;
	font-weight: bold;
	text-align: center;
}


.taikai_info {
	background-color: #D7D7D7;
	padding: 30px;
}

.info_tit {
	font-size: 110%;
	font-weight: bold;
	width: 840px;
}

.taikai_info p {
	font-size: 100%;
}

.tour_entry {
	background-color: #fff;
	width: 900px;
	border-radius: 20px;
	padding: 30px;
	margin:20px auto 60px;
}

.tour_entry_btn {
	margin-left: 50px;
}

.tour_entry_btn li {
	float: left;
	margin-right: 10px;
}

.tour_entry_btn li a {
	width: 120px;
	font-size: 130%;
}

.sp_br {
	display: none;
}

@media screen and (max-width: 560px) {
	
.sp_br {
	display: block;
}

.main_img{
  width: 80%;
	margin: auto;
	padding-top: 20px;
}

.main_txt {
	font-size: 90%;
		padding: 15px;
}
	
.tabi_point {
	display: none;

}
	
.tabi_point_sp {
	display: block;
	padding: 10px;
	background-color: #F6FF73;
	margin: auto;

}
	
.tabi_point_sp li {
	margin-bottom: 10px;
	}

	.tourpoint_tit {
    width: 330px;
	padding-top: 15px;
}
	
	.point_img_sp {
		width: 150px;
		float: left;
		padding-top: 30px;
	}
	
.point_txt_caych01,.point_txt_caych02,.point_txt_caych03 {
		float: left;
		width: 230px;
	}
	
.point_txt_caych01 img {
		float: left;
		width: 233px;
	}
.point_txt_caych02 img {
		float: left;
		width: 183px;
	}
	
.point_txt_caych03 img {
		float: left;
		width: 181px;
	}
	
.point_txt_caych01 p,.point_txt_caych02 p,.point_txt_caych03 p {
		font-size: 11px;
		line-height: 1.3em;
		background-color: #fff;
		padding: 10px;
		margin:60px 0px 10px 0px;
		
	}
  
.taikai_shosai {
	background-color: #fff;
	width: 100%;
	border-radius: 0px;
	margin: 0px;
	padding: 20px 10px;
		
}
	
	
.tshosai {
	text-align: center;
	color: #0090B9;
	font-size: 120%;
	font-weight: bold;
	padding-top: 20px;
}

.shosai_naiyo dl {
  display: flex;
  flex-wrap: wrap;
}
.shosai_naiyo dt {
  width: 85%;
  padding: 20px;
  background-color: #0090B9;
	color: #fff;
	font-weight: bold;
  margin: 0 0 10px 0;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.shosai_naiyo dd {
  width: 85%;
  padding: 20px;
  background-color: #fff;
  margin: 0 0 10px 0;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}

.shosai_naiyo a {
	text-decoration: underline;
	color: #0E4F83;
	font-size: 90%;
}

.shosai_naiyo p {
	padding-bottom: 5px;
}

.attention_box {
	margin-bottom: 10px;
	padding:0px 10px;
	width: 375px;
}
	

.attention_box p {;
	font-size: 20px;
	color: #ff0041;
	font-weight: bold;
	text-align: center;
}

.taikai_info {
	background-color: #D7D7D7;
	padding: 30px;
	margin: 15px;
	width: 315px;
}

.info_tit {
	font-size: 90%;
	font-weight: bold;
	width: 840px;
}

.taikai_info p {
	font-size: 80%;
}
	

.tour_entry {
	background-color: #fff;
	width:100%;
	border-radius: 0px;
	padding:30px 0px 30px 0px;
	margin:0px;
	border-top: #1C7C91 1px solid;
}

.tour_entry_btn {
	margin-left: 20px;
}

.tour_entry_btn li {
	float: left;
	margin-right: 5px;
	margin-bottom: 5px;
}

.tour_entry_btn li a {
	width: 90px;
	font-size: 130%;
}
	
	
}

/*///////////////パンくず 石垣島/////////////////*/



#breadcrumbs_h {
	color: #fff;
    padding:20px 0px 20px 30px;
    font-size: 12px;
}

#breadcrumbs_h ul {
    margin: 0 auto;
    padding: 0 auto;
    display: flex;
    align-items: center;
}

#breadcrumbs_h li {
    margin: 0 8px 0 0;
    padding: 0;
    font-size: 12px;
    white-space: nowrap;
	color: #fff;
}

#breadcrumbs_h a {
    color: #fff;
    text-decoration: none;
}

#breadcrumbs_h a:hover {
    color: #fff;
    text-decoration: none;
}

#breadcrumbs_h li:not(:first-child):before {
    content: ">";
    margin-right: 8px;
}

/*///////////////パンくず 宮古島/////////////////*/

#breadcrumbs_h_m {
	color: #17548B;
    padding:20px 0px 20px 30px;
    font-size: 12px;
}

#breadcrumbs_h_m ul {
    margin: 0 auto;
    padding: 0 auto;
    display: flex;
    align-items: center;
}

#breadcrumbs_h_m li {
    margin: 0 8px 0 0;
    padding: 0;
    font-size: 12px;
    white-space: nowrap;
	color: #17548B;
}

#breadcrumbs_h_m a {
    color: #17548B;
    text-decoration: none;
}

#breadcrumbs_h_m a:hover {
    color: #17548B;
    text-decoration: none;
}

#breadcrumbs_h_m li:not(:first-child):before {
    content: ">";
    margin-right: 8px;
}

@media screen and (max-width: 560px) {
	#breadcrumbs_h {
		width: 300px;
		font-size: 11px;
	}
	
#breadcrumbs_h li {
	float: left;
}
	
	#breadcrumbs_h li {
    margin: 0 8px 0 0;
    padding: 0;
    font-size: 8px;
    white-space: normal;
	color: #fff;
}
	
#breadcrumbs_h_m {
		width: 300px;
		font-size: 11px;
	}
	
#breadcrumbs_h_m li {
	float: left;
}
	
#breadcrumbs_h_m li {
    margin: 0 8px 0 0;
    padding: 0;
    font-size: 8px;
    white-space: normal;
	color: #17548B;
}
	
}






/* ページTOP */


#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size:15px;
	z-index: 100;
}
#page-top a {
	background:#445289;
	text-decoration: none;
	color: #fff;
	width: 100px;
	padding: 30px 0;
	text-align: center;
	display: block;
	border-radius: 5px;
}
#page-top a:hover {
	text-decoration: none;
	background:#333;
}

@media screen and (max-width: 560px) {
	
	#page-top {
	position: fixed;
	bottom: 20px;
	right: 10px;
	font-size:13px;
}
#page-top a {
	background:#445289;
	text-decoration: none;
	color: #fff;
	width: 100px;
	padding: 20px 0;
	text-align: center;
	display: block;
	border-radius: 5px;
}
#page-top a:hover {
	text-decoration: none;
	background:#333;
}
	
}


/* トップに戻る */
#page__top{
  width: 80px;
  height: 80px;
  margin: 0 20px 20px auto;
  background: #004678;
  opacity: 0.8;
  border-radius: 8px;
  z-index: 4;
}
#page__top a{
  position: relative;
  display: block;
  width: 80px;
  height: 80px;
  line-height: 1;
  text-decoration: none;
}
#page__top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f106';
  font-size: 4rem;
  color: #fff;
  position: absolute;
  width: 40px;
  height: 40px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

/* スマホ用 */
#nav-drawer {
  position: relative;
  text-align: right;
}

/*チェックボックス等は非表示に*/
.nav-unshown {
  display:none;
}




/* フッター */
#footer{
  background-color: #445289;
  padding: 40px 0;
}
#footer .footer__wrap{
  margin: 0 auto;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
	-ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

#footer p{
  padding-right: 20px;
  line-height: 1;
  font-size: 1.4rem;
  color: #fff;
}


.footer__nav{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
	-ms-flex-align: center;
  align-items: center;
}

.footer__nav li{
  margin-left: 10px;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-align: center;
	-ms-flex-align: center;
  align-items: center;
}

.footer__nav li a{
  font-size: 1.4rem;
  color: #fff;
  line-height: 1;
}

.footer__nav li a:hover{
  text-decoration: underline;
}


@media screen and (max-width:960px) {
  #footer p{
    font-size: 1.2rem;
    padding-right: 0;
  }

  .footer__nav li a{
    font-size: 1.2rem;
  }
}

@media screen and (max-width:560px) {
  .footer__nav,
  .footer__wrap{
    -webkit-box-orient: vertical;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: column;
  	flex-direction: column;
  }
  .footer__nav li{
    margin-bottom: 20px;
    margin-left: 0;
  }

  .footer__nav li:last-of-type{
    margin-bottom: 0;
  }

  #footer p{
    margin-bottom: 40px;
  }

}



br.sp{
  display: none;
}

@media screen and (max-width:560px) {
  br.sp{
    display: inline;
  }
}
