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

/*===============================================
●smart.css  画面の横幅が640pxまで
===============================================*/
@media screen and (max-width:640px){

	::selection {background: #000; color: #fff;}
	::-moz-selection {background: #000; color: #fff;}

#wrapper {
	width:100%;
}

.main01,
.header-wrap,
.main-wrap,
.footer,
.copy {
	width:100%;
}

.smt-main,
.main02,
.header {
	width:90%;
	margin:0 auto;
}

.access,
.gallery,
.entry,
.about,
.relay-map {
	width:96%;
	margin:0 auto;
	padding:50px 0;
}

/*=============================================
	ヘッダー
===============================================*/
.logo {
	text-align:center;
	margin-top:20px;
	margin-bottom:20px;
}

/*=============================================
	メイン
===============================================*/
.main01 {
	padding:40px 0 30px 0;
	background-image:url(../images/back.png);
}

.main-title {
	color:#ec1e79;
	font-size:24px;
	font-weight:700;
	text-align:center;
	margin-bottom:20px;
	line-height:1.3em;
}

.smt-main-txt {
	line-height:1.6em;
	text-align:center;
	font-size:14px;
}

.smt-main-img ul{
	text-align:left;
}

.smt-main-txt a {
	color:#000;
	border-bottom:1px solid #A1A1A1;
	text-decoration:none;
}

.smt-main-txt a:hover {
	color:#ec1e79;
	border-bottom:1px solid #ec1e79;
	text-decoration:none;
}

.smt-main-txt .span1{
	display:block;
	font-size:16px;
	font-weight:600;
	margin-bottom:20px;
}

.smt-main-txt .span2{
	display:block;
	margin:20px 0;
}

a.entry-btn {
	display:block;

	color:#ec1e79;
	background:#fff;
	font-size:20px;
	text-align:center;
	font-weight:700;
	text-decoration:none;
	border:3px solid #ec1e79;
	
	width:80%;
	margin:40px auto;
	padding:15px 8px;
	
	/* box-shadow */
	box-shadow:0px 0px 8px -3px #5E5E5E;
	-moz-box-shadow:0px 0px 8px -3px #5E5E5E;
	-webkit-box-shadow:0px 0px 8px -3px #5E5E5E;	
}

.main-photo {
	height:480px;
	background:#6C6C6C;
	border-bottom:4px solid #00c8ff;
	background-image:url(../images/top.jpg);
    background-repeat: no-repeat;
    background-size: cover;
}
.main-photo-logo {
	display:block;
	margin:0 auto;
	position: relative;
	top: 40%;
 }

.main-slider {
	height:200px;
	background:#6C6C6C;
}

/*=============================================
	ピックアップ
===============================================*/

.pickup-wrap {
	background:#00c8ff;
	width:100%;
	padding:40px 0 50px 0;
}

.pickup-box {
	width:95%;
	margin:0 auto;
}

.pickup-box h2 {
	font-size:30px;
	color:#ebff00;
	text-align:center;
	margin-bottom:30px;
}

.pickup-box ul.wrap{
	-webkit-flex-wrap: wrap;          /* Safari etc. */
	-ms-flex-wrap    : wrap;          /* IE10        */
	flex-wrap        : wrap;
    flex-direction: row;            /*横並び・左から右（デフォルト）*/
	width:100%;
	padding:0;
	list-style: none;
	
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
	align-items: flex-start;
	justify-content: center;
}

.pickup-box ul.wrap li.box {
	width:100%;
	margin:0 15px 30px 15px;
}

/*.pickup-box ul.wrap li.box a {
	display:block;
	width:100%;
	height:auto;
}*/

.pickup-top-wrap {
	width:100%;
	height:10px;
	position:relative;
}

.pickup-top {
	position:absolute;
	bottom:0;
}

/*.pickup-wrap:before {
    width: 100%;
    height: 299px;
    position: absolute;
    top: -180px;
    left: 0;
    background: url(../images/pickup-top-img.png) repeat left top;
    background-size: auto;
    content: '';
	z-index:999;
}
*/

/* ------------------------------------------
　モーダルウィンドウ
--------------------------------------------- */
.btn {	/*ボタン*/
	display:block;
	text-align:center;
	text-decoration:none;
	font-size:1em;
	font-weight:bold;
	width:100%;
	height:auto;
	margin:0 auto;
    padding-bottom: 10px;
	letter-spacing:0.4em;

	position: relative;
	background:#fff;
	color: #000;
	-webkit-transition: none;
	transition: none;
	box-shadow: 0 8px 0 #e6e6e6;
}
.btn:hover {
	background-color: #fff;
	box-shadow: 0 8px 0 #e6e6e6;
}
.btn:active {
	top: 8px;
	box-shadow: none;
}

.photoBox img {
	width:100%;
}


.modal-content {
	width: 90%;
	max-width:700px;
	margin: 0 auto;
	padding: 0 0 35px 0;
	position: fixed ;
	display: none ;
	z-index: 9999;
	background: #ededed;
}

.modal-content a {
	color:#000;
}

#modal-overlay {
	z-index: 9997 ;
	display: none ;
	position: fixed ;
	top: 0 ;
	left: 0 ;
	width: 100% ;
	height: 120% ;
	background-color: rgba( 0,0,0, 0.75 ) ;
}

.modal-content img{	/*画像*/
	width:100%;
}

.modal-content .img {
	position: relative;
}

.textBox {
	width:90%;
	margin:22px auto;
	text-align: center;
	font-size:16px;
	color:#000;
	font-weight:bold;
	letter-spacing:0em;
	line-height:1.4em;
}

.modal-content .text{	/*　本文テキスト　*/
	width:80%;
	height:8em;
	font-size:14px;
	line-height:1.5em;
	letter-spacing:0.1em;
    padding: 10px;
	margin:0 auto;
	clear:both;
	overflow: auto;
	background-color: rgba( 255,255,255, 0.5 ) ;
}

.modal-content .text::-webkit-scrollbar{ 
    width: 7px;
}
.modal-content .text::-webkit-scrollbar-thumb{ 
    background: #ec1e79;
    border-radius: 10px;
}
.modal-content .text::-webkit-scrollbar-track-piece:start{
    background: #E5E5E5;
    border-radius: 10px;
}
.modal-content .text::-webkit-scrollbar-track-piece:end{
    background: #fff;
    border-radius: 10px;
}


.modal-content .kome{
	font-size:0.8em;
	color:#9A9A9A;
	line-height:1.8em;
}

.modal-content .data{
	width: 80%;
	font-size:0.92em;
	line-height:1.3em;
	padding:10px;
	margin:0 auto;
	text-align:left;
}

.modal-content .data a{
	color:#ec1e79;
}


.modal-content .button-link {
	position:absolute;
	bottom:17px;
	right:24px;
	font-size:1em;
}

/*=============================================
	グローバルメニュー
===============================================*/
.slicknav_menu {
	border-bottom:3px solid #ec1e79;
}

/*=============================================
	大会概要
===============================================*/
.about {
	padding-bottom:30px;
}

.about-txt {
	font-size:14px;
	line-height:1.6em;
	margin:50px 0;
}
.about-table {
	width:100%;
	border:1px solid #666666;
	margin-bottom:80px;
}

.about-table th,
.about-table td  {
	border:1px solid #666666;
	padding:15px 20px;
 }
.about-table th {
	width:30%;
	vertical-align:middle;
	background:#F8F8F8;
}

.about-table td {
	font-size:14px;
	width:70%;
	vertical-align:middle;
	line-height:1.6em;
}

.about-link {
	color:#000;
	border-bottom:1px solid #A1A1A1;
	text-decoration:none;
}

.about-link:hover {
	color:#ec1e79;
	border-bottom:1px solid #ec1e79;
	text-decoration:none;
}

ul.about-list {
	list-style:none;
}

ol.about-list {
	margin:1em 0 0 1em;
}

.about-list li {
	font-size:14px;
	margin:1em 0;
	
}
.h2-blue {
	width:100px;
	text-align:center;
	font-size:18px;
	color:#fff;
	font-weight:500;
	background:#00c8ff;
	border-radius:10px;
	padding:10px 20px;
}

.h2-blue2 {
	width:160px;
	text-align:center;
	font-size:18px;
	color:#fff;
	font-weight:500;
	background:#00c8ff;
	border-radius:10px;
	padding:10px 20px;
}

.h2-pink {
	width:100px;
	text-align:center;
	font-size:18px;
	color:#fff;
	font-weight:500;
	background:#ec1e79;
	border-radius:10px;
	padding:10px 20px;
}

/*======色分け======*/
.about-a,.about-b,
.about-c,.about-d,
.about-e {
	font-weight:600;
}

.about-a {
	color:#ec1c24;
}
.about-b {
	color:#006837;
}
.about-c {
	color:#92278e;
}
.about-d {
	color:#2e3191;
}
.about-e {
	color:#f78100;
}

/*=============================================
	エントリー
===============================================*/
.entry-txt a{
	text-decoration: none;
	color:#000;
	border-bottom:1px solid #000;
}

.entry-txt a:hover {
	text-decoration: none;
	color:#ec1e79;
	border-bottom:1px solid #ec1e79;
}

.entry-box {
	padding:30px;
	border:1px solid #00c8ff;
}
.entry-bold {	/*太字*/
	font-weight:600;
	font-size:14px;
}

.entry-bold a {
	text-decoration:none;
	color:#000;
	border-bottom:1px solid #000;
}

.entry-txt {
	font-size:14px;
	text-align:center;
	line-height:1.8em;
	margin:50px 0;
}

.entry-day {
	font-size:18px;
	font-weight:600;
	letter-spacing:0.2em;
}

.entry-shime {
	color:#fff;
	font-size:13px;
	font-weight:600;
	padding:4px 12px;
	margin-right:10px;
	background:#ec1e79;
}

.entry-box-txt {
	margin:10px 0 10px 0;
	line-height:2em;
}

a.pdf-btn {
	display:block;

	color:#fff;
	background:#ec1e79;
	font-size:20px;
	text-align:center;
	font-weight:500;
	text-decoration:none;
	border:3px solid #ec1e79;
	
	width:90%;
	margin:30px auto 10px auto;
	padding:15px 0;
	
	/* box-shadow */
	box-shadow:0px 0px 8px -3px #5E5E5E;
	-moz-box-shadow:0px 0px 8px -3px #5E5E5E;
	-webkit-box-shadow:0px 0px 8px -3px #5E5E5E;	
}

.pdf-txt {
	font-size:13px;
	text-align:center;
}

/*=============================================
	ギャラリー
===============================================*/
.movie {
	width:100%;
	height:260px;
	background:#767676;
	margin:50px auto 20px auto;
}

ul.gallery-img {
	margin:0 auto;
}
.gallery-img li {
	width:48%;
    padding:1%;
    float:left;
	margin:0 auto;
	list-style:none;
	text-align:center;
}

.content ul li {
	width:455px;
	height:321px;
	list-style-type:none;
	float:left;
	
	/* box-shadow */
	box-shadow:0px 0px 8px -3px #5E5E5E;
	-moz-box-shadow:0px 0px 8px -3px #5E5E5E;
	-webkit-box-shadow:0px 0px 8px -3px #5E5E5E;	
}


/*=============================================
	コースマップ
===============================================*/
.relay-map-pdf {
	text-align:center;
	margin:30px 0;
}

#map-slide {
	margin-top:50px;
}

/*=============================================
	アクセス
===============================================*/

ul.access-txt {
	font-size:1em;
	padding:20px 30px;
	border:1px solid #00c8ff;
	margin:50px 0;
}

ul.access-txt li{
	list-style-type:none;
	line-height:1.5em;
	margin:15px 0;
}

a.map-btn {
	display:block;

	color:#333333;
	background:#fff;
	font-size:18px;
	text-align:center;
	font-weight:700;
	text-decoration:none;
	border:3px solid #333333;
	
	width:80%;
	margin:0 auto;
	padding:15px 0;
	
	/* box-shadow */
	box-shadow:0px 0px 8px -3px #5E5E5E;
	-moz-box-shadow:0px 0px 8px -3px #5E5E5E;
	-webkit-box-shadow:0px 0px 8px -3px #5E5E5E;	
}

.map {
	text-align:center;
	margin-bottom:50px;
}

/*=============================================
	フッター
===============================================*/
.footer {
	color:#fff;
	background:#3c3c3c;
	border-top:3px solid #00c8ff;
	
	text-align:center;
	padding:30px 0;
}

.footer a {
	color:#fff;
}

.footer-txt {
	font-size:12px;
	line-height:1.8em;
}

.footer-txt span {
	font-size:16px;
}

.copy {
	font-size:12px;
	color:#fff;
	background:#1a1a1a;
	text-align:center;
	padding:15px 0;
}

.copy a {
	color:#fff;
}

/*=============================================
	その他
===============================================*/
.h1-title {
	color:#1a1a1a;
	font-size:24px;
	letter-spacing:0.2em;
	text-align:center;
}

.mt30 {
	margin-top:30px;
}

.mt50 {
	margin-top:50px;
}


.mb30 {
	margin-bottom:30px;
}

.mb15 {
	margin-bottom:15px;
}

.s-left {
	float:left;
}

.s-right {
	float:right;
}

.smt-none {
	display:none;
}

}