body {
	color: #353535;
	font-family: "游ゴシック", YuGothic, 'Yu Gothic', '游ゴシック体', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo sans-serif;
    height: 100%;
	line-height: 1.8em;
}

/* ::::::::::::::::::::::::::::::::::
   共通スタイル
::::::::::::::::::::::::::::::::::: */

/* 寄せ_色 */
.alignR { text-align: right; }
.alignL { text-align: left; }

.bold { font-weight: bold; }
.red  { color: #B20000; }
.font_red {
  color: red;
}
/* jumbotron設定 */
.jumbotron_top {
	padding-top: 100px;
	padding-bottom: 30px;
	margin-bottom: 30px;
    color: #FFFFFF;
	background-image: url("../images/top_img.jpg");
	background-size: cover;
	background-position: center 35%;
}
.jumbotron_past {
	padding-top: 100px;
	padding-bottom: 30px;
	margin-bottom: 30px;
    color: #FFFFFF;
	background-image: url("../images/past_img.jpg");
	background-size: cover;
	background-position: center 35%;
}
.jumbotron_kaisetsu {
	padding-top: 100px;
	padding-bottom: 30px;
	margin-bottom: 30px;
    color: #FFFFFF;
	background-image: url("../images/kaisetsu_img.jpg");
	background-size: cover;
	background-position: center 48%;
}
.jumbotron_olympic {
	padding-top: 100px;
	padding-bottom: 30px;
	margin-bottom: 30px;
    color: #FFFFFF;
	background-image: url("../images/olympic_img.jpg");
	background-size: cover;
	background-position: center 15%;
}
.jumbotron_top h1, .jumbotron_past h1, .jumbotron_kaisetsu h1 {
	color: #fff;
	text-align: center;
	font-size: 3rem;
	letter-spacing: .5rem;
	font-family: 'Inter', sans-serif;
	opacity: 0.8;
	text-shadow: 0px 0px 10px #3d3d3d;
}
.jumbotron_olympic h1 {
	color: #fff;
	text-align: center;
	font-size: 2rem;
	font-weight: 500;
	letter-spacing: .5rem;
}
.jumbotron_top .container, .jumbotron_past .container,.jumbotron_kaisetsu .container, .jumbotron_olympic .container {
	max-width: 100%
}

@media screen and (min-width:768px) {
	.jumbotron_top,  .jumbotron_past, .jumbotron_kaisetsu, .jumbotron_olympic {
		padding-top: 150px;
		padding-bottom: 80px
	}
	.jumbotron_top h1, .jumbotron_past h1,.jumbotron_kaisetsu h1, .jumbotron_olympic h1 {
		font-size: 4rem;
	}
}

/* 各でﾃﾞﾊﾞｲｽでの表示切替 */
.sp {display: none;}/*only SP*/
.tab {display: none;}/*only TAB*/
.pc {display: block;}/*only PC*/

@media screen and (max-width: 1199px) {
.sp {display: none;}
.tab {display: none;}
.pc {display: block;}
}

@media screen and (max-width: 991px) {
.sp {display: none;}
.pc {display: none;}
.tab {display: block;}
}

@media screen and (max-width: 767px) {
.tab {display: none;}
.pc {display: none;}
.sp {display: block;}
}

/* 余白の設定 */
.clear{ clear:both; }
.left{ float:left;  }
.right{ float:right; }

.mgB0{   margin-bottom:0px;  }
.mgB5{   margin-bottom:5px;  }
.mgB10{  margin-bottom:10px; }
.mgB15{  margin-bottom:15px; }
.mgB20{  margin-bottom:20px; }
.mgB30{  margin-bottom:30px; }
.mgB40{  margin-bottom:40px; }
.mgB50{  margin-bottom:50px; }
.mgB60{  margin-bottom:60px; }

.mgT0{   margin-top:0px;  }
.mgT5{   margin-top:5px;  }
.mgT10{  margin-top:10px; }
.mgT15{  margin-top:15px; }
.mgT20{  margin-top:20px; }
.mgT30{  margin-top:30px; }
.mgT40{  margin-top:40px; }
.mgT50{  margin-top:50px; }
.mgT60{  margin-top:60px; }

.mgR0{   margin-right:0px;  }
.mgR5{   margin-right:5px;  }
.mgR10{  margin-right:10px; }
.mgR15{  margin-right:15px; }
.mgR20{  margin-right:20px; }
.mgR30{  margin-right:30px; }
.mgR40{  margin-right:40px; }
.mgR50{  margin-right:50px; }
.mgR60{  margin-right:60px; }

.mgL0{   margin-left:0px;  }
.mgL5{   margin-left:5px;  }
.mgL10{  margin-left:10px; }
.mgL15{  margin-left:15px; }
.mgL20{  margin-left:20px; }
.mgL30{  margin-left:30px; }
.mgL40{  margin-left:40px; }
.mgL50{  margin-left:50px; }
.mgL60{  margin-left:60px; }

.pdgB0{   padding-bottom:0px;  }
.pdgB5{   padding-bottom:5px;  }
.pdgB10{  padding-bottom:10px; }
.pdgB15{  padding-bottom:15px; }
.pdgB20{  padding-bottom:20px; }
.pdgB30{  padding-bottom:30px; }
.pdgB40{  padding-bottom:40px; }
.pdgB50{  padding-bottom:50px; }

.pdgT0{   padding-top:0px;  }
.pdgT5{   padding-top:5px;  }
.pdgT10{  padding-top:10px; }
.pdgT15{  padding-top:15px; }
.pdgT20{  padding-top:20px; }
.pdgT30{  padding-top:30px; }
.pdgT40{  padding-top:40px; }
.pdgT50{  padding-top:50px; }

.pdgR0{   padding-right:0px;  }
.pdgR5{   padding-right:5px;  }
.pdgR10{  padding-right:10px; }
.pdgR15{  padding-right:15px; }
.pdgR20{  padding-right:20px; }
.pdgR30{  padding-right:30px; }
.pdgR40{  padding-right:40px; }
.pdgR50{  padding-right:50px; }

.pdgL0{   padding-left:0px;  }
.pdgL5{   padding-left:5px;  }
.pdgL10{  padding-left:10px; }
.pdgL15{  padding-left:15px; }
.pdgL20{  padding-left:20px; }
.pdgL30{  padding-left:30px; }
.pdgL40{  padding-left:40px; }
.pdgL50{  padding-left:50px; }

/* 各ページ_大タイトル */
.topics-sub-title {
	position: relative;
	display: inline-block;
	padding-bottom: 30px;
	margin-bottom: 50px;
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.8em;
	padding-left: 15px;
	padding-right: 15px;
}

.topics-sub-title:after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -5px;/*線の上下位置*/
  display: inline-block;
  width: 60px;/*線の長さ*/
  height: 2px;/*線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: #107B3A;/*線の色*/
  border-radius: 0px;/*線の丸み*/
}

.topics-sub-title span {
	font-size: 70%;
	font-style: normal;
	font-weight: 300;
	letter-spacing: 0.1em;
}

.topics-sub-title span:after {
	content: "\A";
	white-space: pre;	
}

/* 文章_説明 */
.description {
	margin-top: 30px;
	margin-bottom: 50px;
	font-size: 1.1em;
	padding: 0 25px;
}

/* HOVERでｱﾝﾀﾞｰﾗｲﾝが中央からでる */
.cp_link {
	position: relative;
	display: inline-block;
	transition: .3s;
	color: #107B3A !important;
}
.cp_link::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	content: '';
	width: 0;
	height: 1px;
	background-color: #107B3A;
	transition: .3s;
	transform: translateX(-50%);
}
.cp_link:hover::after {
	width: 100%;
}

/* ::::::::::::::::::::::::::::::::::
　　ナビゲーション・バー
::::::::::::::::::::::::::::::::::: */
.nav-games {
    /*background-color: #92ac86;*/
    background-color: rgba(0, 0, 0, .5);
    margin-bottom: 0px;
    border: none;
    border-radius: 0px;
}
.nav-games .navbar-nav > li > a {
    color: #fff;
    font-size: 1.2em;
    font-weight: bold;
    height: 50px;
    line-height: 50px;
    margin-left: 20px;
}
.nav-games .navbar-text {
    color: #fff;
    font-size: 1.4em;
    font-weight: bold;
    height: 50px;
    line-height: 50px;
}

.crane {
    float: left;
    width: 80px;
    height: 80px;
    display: block;
    background-color: #107B3A;
    position: relative;
    transition: all 0.2s cubic-bezier(0.44, 0.07, 0.23, 1.11);
}
.crane img {
    width: 27px;
    height: auto;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
.crane-site {
    text-align: center;
    margin-right: 80px;
    font-size: 1.2em !important; 
}

/* ::::::::::::::::::::::::::::::::::
　　ハンバーガーメニュー
::::::::::::::::::::::::::::::::::: */
* {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
a,
a:visited,
a:hover,
a:active {
text-decoration: none;
color: inherit;
}
/*.cp_fullscreenmenu {
position: fixed;
z-index: 1;
top: 0;
left: 0;
}*/

.cp_fullscreenmenu {
	position: absolute;
	top: 0px;
    right: 80px;
    z-index: 1;
    /*display: inline-block;*/
}

/*menuコンテンツ*/
.cp_fullscreenmenu .menu {
position: fixed;
top: 0;
left: 0;
display: flex;
visibility: hidden;
overflow: hidden;
width: 100%;
height: 100%;
pointer-events: none;
outline: 1px solid transparent;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
align-items: center;
justify-content: center;
}
.cp_fullscreenmenu .menu > div {
display: flex;
overflow: hidden;
width: 200vw;
height: 200vw;
transition: all 0.4s ease;
-webkit-transform: scale(0);
transform: scale(0);
text-align: center;
color: #fefefe;
border-radius: 50%;
background: rgba(16,123,58 ,0.8);
flex: none;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
align-items: center;
justify-content: center;
}
.cp_fullscreenmenu .menu > div > ul {
display: block;
max-height: 100vh;
margin: 0;
padding: 0 1em;
list-style: none;
transition: opacity 0.4s ease;
opacity: 0;
}
.cp_fullscreenmenu .menu > div > ul > li {
font-size: 20px;
display: block;
margin: 1.8em;
padding: 0;
}
.cp_fullscreenmenu .menu > div > ul > li > a {
position: relative;
display: inline;
cursor: pointer;
transition: color 0.4s ease;
}
.cp_fullscreenmenu .menu > div > ul > li > a:hover {
color: #e5e5e5;
}
.cp_fullscreenmenu .menu > div > ul > li > a:hover:after {
width: 100%;
}
.cp_fullscreenmenu .menu > div > ul > li > a:after {
position: absolute;
z-index: 1;
bottom: -0.15em;
left: 0;
width: 0;
height: 2px;
content: '';
transition: width 0.4s ease;
background: #e5e5e5;
}
/*クリックしたらメニューが開閉の動作*/
.cp_fullscreenmenu .toggle {
position: absolute;
z-index: 2;
top: 0;
left: 0;
width: 60px;
height: 60px;
cursor: pointer;
opacity: 0;
}
.cp_fullscreenmenu .toggle:checked + .hamburger > span {
-webkit-transform: rotate(135deg);
transform: rotate(135deg);
}
.cp_fullscreenmenu .toggle:checked + .hamburger > span:before,
.cp_fullscreenmenu .toggle:checked + .hamburger > span:after {
top: 0;
-webkit-transform: rotate(90deg);
transform: rotate(90deg);
}
.cp_fullscreenmenu .toggle:checked + .hamburger > span:after {
opacity: 0;
}
.cp_fullscreenmenu .toggle:checked ~ .menu {
visibility: visible;
pointer-events: auto;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div {
transition-duration: 0.75s;
-webkit-transform: scale(1);
transform: scale(1);
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul {
opacity: 1;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(1) {
transition-delay: 0.4s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(2) {
transition-delay: 0.6s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(3) {
transition-delay: 0.8s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(4) {
transition-delay: 1.0s;
}
.cp_fullscreenmenu .toggle:hover + .hamburger {
box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.1);
}
.cp_fullscreenmenu .toggle:checked:hover + .hamburger > span {
-webkit-transform: rotate(225deg);
transform: rotate(225deg);
}
/*ハンバーガー*/
.cp_fullscreenmenu .hamburger {
position: absolute;
z-index: 1;
top: 0;
left: 0;
display: block;
width: 80px;
height: 80px;
padding: 0.5em 2em;
cursor: pointer;
transition: box-shadow 0.4s ease;
border-radius: 0 0.12em 0.12em 0;
background: rgba(16,123,58 ,0.7);
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
.cp_fullscreenmenu .hamburger > span {
position: relative;
top: 50%;
display: block;
width: 100%;
height: 2px;
transition: all 0.4s ease;
background: #fefefe;
}
.cp_fullscreenmenu .hamburger > span:before,
.cp_fullscreenmenu .hamburger > span:after {
position: absolute;
z-index: 1;
top: -10px;
left: 0;
display: block;
width: 100%;
height: 2px;
content: '';
transition: all 0.4s ease;
background: inherit;
}
.cp_fullscreenmenu .hamburger > span:after {
top: 10px;
}

/* ::::::::::::::::::::::::::::::::::
   結果の一覧
::::::::::::::::::::::::::::::::::: */
/* 競技名 */
.topics-third-title {
	position: relative;
	display: inline-block;
	padding-bottom: 15px;
	margin-bottom: 25px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8em;
	padding-left: 15px;
	padding-right: 15px;
}

.topics-third-title:after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -5px;/*線の上下位置*/
  display: inline-block;
  width: 60px;/*線の長さ*/
  height: 2px;/*線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: #92ac86;/*線の色*/
  border-radius: 0px;/*線の丸み*/
}

.topics-third-title span {
	font-size: 70%;
	font-style: normal;
	font-weight: 300;
	letter-spacing: 0.1em;
}

.topics-third-title span:after {
	content: "\A";
	white-space: pre;	
}

/*一覧表（ｽﾏﾎでの表示）*/
.res-table{
	width:95%;
    margin:2em auto;
	/*border:#6699ff 1.5px solid;*/
}
.res-table th{
    padding:3px;
	display:block;
	/*background-color:#ccddff;*/
	letter-spacing: .2em;
}

.res-table td{
	padding:5px;
	display:block;
	/*text-align:center;*/
	margin-bottom: 15px;
}


/*一覧表（PCでの表示）*/
@media only screen and (min-width: 768px) {

.res-table{
	width:100%;
    margin:5px 0;
	font-size: 1.2em;
	/*font-size:90%;*/
	/*border:#6699ff 1.5px solid;*/
}
.res-table tr{
    border-bottom:#ccc 1px dotted;
	width: 100%;
}
.res-table tr:last-child{
	/*border:none*/
 }
.res-table th{
	width:30%;  
    padding:5px 30px;
	display:table-cell;
	/*border-right:#6699ff 1px solid;*/
	text-align: left;
}

.res-table td{
	width:70%;
    /*padding:0px 50px 5px 10px;*/
	display:table-cell;
	text-align: left;
	line-height: 2.5em;
}
}	

/*非表示分_ｽｸﾛｰﾙして表示*/
.fade_off {
    opacity: 0;
    -webkit-transition: all 5.0s;
    -moz-transition: all 5.0s;
    -o-transition: all 5.0s;
    -ms-transition: all 5.0s;
    transition: all 5.0s;
}

.fade_on {
    opacity: 1;
}

/* ::::::::::::::::::::::::::::::::::
	Timeline（オリンピック・アジア大会）
::::::::::::::::::::::::::::::::::: */

/* Styling */
.timeline {
	margin: 2em auto;
	position: relative;
	max-width: 46em;
	text-align: left;
	list-style: none;
}
.timeline:before {
	background-color: black;
	content: '';
	margin-left: -1px;
	position: absolute;
	top: 0;
	left: 2em;
	width: 2px;
	height: 100%;
}

.timeline-event {
	position: relative;
}
.timeline-event:hover .timeline-event-icon {
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	background-color: #107b3a;
}
.timeline-event:hover .timeline-event-thumbnail {
	-moz-box-shadow: inset 40em 0 0 0 #107b3a;
	-webkit-box-shadow: inset 40em 0 0 0 #107b3a;
	box-shadow: inset 40em 0 0 0 #107b3a;
}

.timeline-event-copy img {
	margin-bottom: 20px;
}
.timeline-event-copy {
	padding: 2em;
	position: relative;
	top: -1.875em;
	left: 4em;
	width: 80%;
}
.timeline-event-copy h3 {
	font-size: 1.75em;
}
.timeline-event-copy h4 {
	font-size: 1.2em;
	margin: 1.2em 0 0.3em 0;
}
.timeline-event-copy strong {
	font-weight: 700;
}
@media only screen and (max-width: 750px) {
.timeline-event-copy {
	padding: 2em;
	position: relative;
	top: -1.875em;
	left: 1.5em;
	width: 95%;
}
}
.timeline-event-icon {
	-moz-transition: -moz-transform 0.2s ease-in;
	-o-transition: -o-transform 0.2s ease-in;
	-webkit-transition: -webkit-transform 0.2s ease-in;
	transition: transform 0.2s ease-in;
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	background-color: black;
	outline: 10px solid white;
	display: block;
	margin: 0.5em 0.5em 0.5em -0.5em;
	position: absolute;
	top: 0;
	left: 2em;
	width: 1em;
	height: 1em;
}
.timeline-event-thumbnail {
	-moz-transition: box-shadow 0.5s ease-in 0.1s;
	-o-transition: box-shadow 0.5s ease-in 0.1s;
	-webkit-transition: box-shadow 0.5s ease-in;
	-webkit-transition-delay: 0.1s;
	transition: box-shadow 0.5s ease-in 0.1s;
	color: white;
	font-size: 0.75em;
	background-color: black;
	-moz-box-shadow: inset 0 0 0 0em #92ac86;
	-webkit-box-shadow: inset 0 0 0 0em #92ac86;
	box-shadow: inset 0 0 0 0em #92ac86;
	display: inline-block;
	margin-bottom: 1.2em;
	padding: 0.25em 1em 0.2em 1em;
}

/* ::::::::::::::::::::::::::::::::::
	結果ページ
::::::::::::::::::::::::::::::::::: */

/*(会員)の文字（PC）*/
.font_small {
    font-size: 12px;
}

/* 表の文字（ｽﾏﾎで小さめに表示） */
@media only screen and (max-width: 750px) {
	.results {
		font-size: 12px;
	}

	.results > tbody > tr > td, .results > tbody > tr > th, .results > tfoot > tr > td, .results > tfoot > tr > th, .results > thead > tr > td, .results > thead > tr > th {
    	padding: 8px 3px;
	}
}

.day_place {
	letter-spacing: .2em;
	border-bottom: 1px solid #ddd;
	text-indent: 1em;
}
.item th {
	background-color: #DFDFD0;
	text-align: center;
	letter-spacing: 3px;	
}
.results {
	text-align: left;
}

/*一覧にもどるボタン*/
a.cp_btn {
	display: inline-block;
	width: 160px;
    padding: .5em 0;
	text-align: center;
	text-decoration: none;
	color: #107B3A;
	border: 2px solid #107B3A;
	transition: .4s;
	font-weight: bold;
}
a.cp_btn:hover {
	background: #107B3A;
	color: #fff;
}

/* ::::::::::::::::::::::::::::::::::
	footerエリア
::::::::::::::::::::::::::::::::::: */
#wrap {
  min-height: 100%;
}
#footer {
    margin-top: 50px;
    background-color: #e9e9e9;
}
.banner_aria {
	padding-top: 30px;
	background: #e9e9e9;
}
.banner_aria p {
	padding: 15px 0;
}
@media screen and (max-width: 767px) {
	.banner_aria img {
        max-width: 280px;
	}
	.banner_aria p {
		padding: 5px 0;
	}
}
.foot-list {
    padding-left: 0px;
}
@media screen and (max-width: 767px) {
    .foot-list {
        padding-left: 10px;
    }
}
.foot-list > li {
    display: inline-block;
    list-style: none;
    padding-top: 10px;
    padding-right: 20px;
    padding-left: 20px;
    padding-bottom: 10px;
    line-height: 20px;
    
}
.foot-list a {
    color: #8f8f8f;
    font-size: 1em;
}
.copyright {
    clear: both;
    display: block;
    font-size: 1em;
    color: #8f8f8f;
    margin: 20px 0;
}

/* pagetopボタン */
#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
}
#page-top a {
    width: 50px;
    padding: 10px 0;
    text-align: center;
    display: block;
}
#page-top a:hover {
    text-decoration: none;
    opacity: 0.5;
}

/* ::::::::::::::::::::::::::::::::::
	まほろばエリア
::::::::::::::::::::::::::::::::::: */

#show .table th,
#show .table td {
  border: 1px solid #ddd;
}

#show .table th {
  width: 25%;
}
#show .table td {
  width: 75%;
}
#show .table td a {
  display: block;
  padding-bottom: 15px;
}
/* GameList
-----------------------------------------------------------------------*/
#gamelist table td {
  padding: 5px;
  border: 1px solid #cccccc;
}

/* Game
-----------------------------------------------------------------------*/
#game .result_table .th_width1 {
  width: 7%;
}

#game .result_table .th_width2 {
  width: 9%;
}

#game .result_table .th_width3 {
  width: 20%;
}

#game .result_table .th_width4 {
  width: 15%;
}

#game .result_table .th_width5 {
  width: 25%;
}

#game .crane_blog_img {
  text-align: center;
}

#game #news_imgbox div {
  text-align: center;
}

#game h2 {
  margin-top: 24px;
  margin-bottom: 0;
}
#game .h4,
#game .h3 {
  margin-top: 0;
  padding-left: 0;
}
#game .h4 small {
  margin-left: 10px;
}
#game table th {
  font-size: 14px;
  text-align: center;
}
  .normal_padding {
    padding: 0 20px;
    margin-bottom: 24px;
  }



