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

/*----------------------------------------------------------

共通css

----------------------------------------------------------*/
/*リセット
-----------------------------*/
html{
	width: 100%;
}
body{
	width: 100%;
	margin: 0;
	padding: 0;
	font-size: 15px;
	min-width: 1100px;
}
body *{
	box-sizing: border-box;
}
.all_wrap{
	overflow: hidden;
}
a{
	color: #2370BF;
}
/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
	background: none;
	width: 100%;
height: 100%;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

/*リセット（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	body{
		font-size: 14px;
		min-width: 100%;
	}
}
/* 表示非表示切り替え
-----------------------------*/
/* SP */
@media screen and (max-width:736px) {
	.-u-SpNonePcBlock {
		display: none;
	}
	.-u-SpNonePcinline {
		display: none;
	}
	.-u-PcNoneSpBlock {
		display: block;
	}
	.-u-PcNoneSpinline {
		display: inline;
	}
}
/* PC */
@media print, screen and (min-width:737px) {
	.-u-SpNonePcBlock {
		display: block;
	}
	.-u-SpNonePcinline {
		display: inline;
	}
	.-u-PcNoneSpBlock {
		display: none;
	}
	.-u-PcNoneSpinline {
		display: none;
	}
}

/*----------------------------------------------------------
　ページトップボタン
----------------------------------------------------------*/
#page_top{
	position: fixed;
	width: 120px;
	height: 120px;
	bottom: 50px;
	right: 50px;
}
#page_top img{
	width: 100%;
	height: auto;
}
/* SP */
@media screen and (max-width:736px) {
	#page_top{
		width: 60px;
		height: 60px;
		bottom: 20px;
		right: 20px;
	}
}

/*----------------------------------------------------------
　ヘッダー
----------------------------------------------------------*/
/*サイトタイトルなど
-----------------------------*/
.header_box_top{
	width: 100%;
	max-width: 1210px;
	min-height: 90px;
	line-height: 90px;
	padding: 0 30px;
	margin: 0 auto;
}
.site_title {
	margin: 0;
	padding: 0;
	float: left;
}
.site_title img{
	width: auto;
	height: 50px;
}
.site_title span{
	padding: 0 10px;
}
.site_title span img{
	width: auto;
	height: 19px;
}
.project_name{
	float: right;
	margin: 0;
	padding: 0;
}
.project_name img{
	height: 50px;
	width: auto;
}
#menu_btn{
	display: none;
}
/*サイトタイトルなど（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	body{
		font-size: 14px;
	}
	.header_box_top{
		width: 100%;
		min-height: 80px;
		line-height: 80px;
		padding: 0 15px;
		margin: 0;
	}
	.site_title img{
		height: 40px;
	}
	.site_title span{
		display: none;
	}
	.project_name{
		display: none;
	}
	#menu_btn{
		display: block;
		width: 50px;
		float: right;
		margin: 0;
		padding: 0;
		cursor: pointer;
	}
	#menu_btn img{
		width: 100%;
		height: auto;
	}
}

/*ナビゲーション
-----------------------------*/
.header_box_bottom{
	padding: 0 30px;
	width: 100%;
	background-color: #666666;
}
.header_nav{
	margin: 0 auto;
	padding: 0;
	list-style: none;
	text-align: center;
	letter-spacing: -.35em;
	display: table;
}
.header_nav li{
	display: table-cell;
	padding: 10px 0;
	text-align: center;
	letter-spacing: normal;
}
.header_nav li a{
	display: block;
	padding: 0 15px;
	text-decoration: none;
	color: #fff;
	line-height: 30px;
	border-left: 1px solid rgba(255,255,255,.5);
}
.header_nav li:first-child a{
	border-left: none;
}
.header_box_bottom .project_name{
	display: none;
}
/*ナビゲーション（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	header{
		position: relative;
	}
	.header_box_bottom{
		padding: 0;
		min-width: 100%;
		position: absolute;
		top: 80px;
		display: none;
		z-index: 9999;
	}
	.header_nav{
		margin: 0;
		padding: 0;
		max-width: 100%;
		display: block;
	}
	.header_nav li{
		display: inline-table;
		padding: 0;
		text-align: center;
		width: 50%;
	}
	.header_nav li a{
		display: block;
		padding: 15px 5px;
		width: 100%;
		line-height: 20px;
		border-left: 1px solid rgba(255,255,255,.5);
		border-bottom: 1px solid rgba(255,255,255,.5);
	}
	.header_nav li:nth-child(odd) a{
		border-left: none;
	}
	/*ナビゲーションが奇数の場合
	.header_nav li:last-child{
		width: 100%;
	}*/
	.header_box_bottom .project_name{
		display: block;
		width: 100%;
		background-color: #fff;
		padding: 15px;
		line-height: 50px;
		text-align: center;
	}
}

/*----------------------------------------------------------
　フッター
----------------------------------------------------------*/
/*窓口・お問い合わせ
-----------------------------*/
.footer_box_top{
	background-color: #666666;
}
.footer_box_top .sec_title{
	color: #fff;
}
.footer_box_top address{
	font-style: normal;
	color: #fff;
	font-size: .95em;
	text-align: center;
}
.footer_box_tel{
}
.address_name{
	margin: 0;
	font-size: 1.5em;
}
.address_tel{
	margin: 2em auto 0;
	padding: 0;
}
.address_tel dt{
	margin: 0 0 1em;
	padding: .2em 2em;
	display: inline-block;
	color: #666666;
	background-color: #fff;
	font-weight: bold;
	border-radius: 4px;
}
.address_tel dd{
	margin: 0;
	padding: 0;
	display: block;
	font-size: 2.3em;
	font-weight: bold;
	line-height: 1em;
}
.address_tel dd small{
	font-size: .5em;
	font-weight: normal;
}
.footer_img_title{
	width: 100%;
	height: auto;
}
.footer_img_tel{
	height: 40px;
	width: auto;
	margin: 0 0 1em;
}
/*窓口・お問い合わせ（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.footer_box_tel{
	}
	.address_name{
		margin: 0 0 30px;
	}
	.address_name img{
		width: 95%;
	}
	.footer_img_tel{
		height: 20px;
	}
}
/*主催
-----------------------------*/
.footer_box_middle{
	width: 100%;
	min-height: 100px;
	line-height: 100px;
	padding: 0 30px;
	text-align: center;
	background-color: #fff;
	border-bottom: 1px solid #ccc;
}
.footer_project_name{
	 margin: 0;
	 padding: 0;
	 font-size: 1.5em;
}
/*主催（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.footer_box_middle{
		min-height: 60px;
		line-height: 60px;
		padding: 0 15px;
	}
	.footer_project_name{
		font-size: 1em;
	}
}
/*コピーライトなど
-----------------------------*/
.footer_box_bottom{
	width: 100%;
	max-width: 1210px;
	min-height: 70px;
	line-height: 70px;
	padding: 0 30px;
	margin: 0 auto;
}
.copyright {
	margin: 0;
	padding: 0;
	float: left;
	display: inline-block;
}
.copyright small{
	font-size: 100%;
}
.sns{
	display: inline-block;
	float: right;
	color: #AA4343;
	font-weight: bold;
	margin: 0;
	padding: 0;
}
.sns br{
	display: none;
}
.sns > img{
	height: 20px;
	width: auto;
}
.sns > a{
	display: inline-block;
}
.sns > a img{
	height: 40px;
	width: auto;
	margin: 0 0 0 1em;
}
/*コピーライトなど（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.footer_box_bottom{
		width: 100%;
		min-height: auto;
		line-height: 40px;
		padding: 0;
		margin: 0;
		text-align: center;
	}
	.copyright {
		margin: 0;
		padding: 0;
		float: none;
		display: block;
	}
	.copyright small{
		font-size: 80%;
	}
	.sns{
		float: none;
		display: block;
		margin: 0;
		padding: 30px 0;
		border-bottom: 1px solid #ccc;
	}
	.sns br{
		display: inline;
	}
	.sns > img{
		display: none;
	}
	.sns > a img{
		height: 40px;
		width: auto;
		margin: 0 .5em;
	}
}

/*----------------------------------------------------------
　共通パーツ 幅
----------------------------------------------------------*/
/*wide100%
-----------------------------*/
.wrap_all{
	width: 100%;
	margin: 0;
	padding: 100px 0 100px;
}
/*wide100%（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.wrap_all{
		padding: 50px 0 50px;
	}
}
/*wide1000px
-----------------------------*/
.wrap_m{
	width: 1000px;
	margin: 0 auto;
	padding: 100px 0 100px;
}
/*wide800px
-----------------------------*/
.wrap_s{
	width: 800px;
	margin: 0 auto;
	padding: 100px 0 100px;
}
/*リセット（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.wrap_m,.wrap_s{
		width: 100%;
		margin: 0 auto;
		padding: 50px 15px 50px;
	}
}

/*----------------------------------------------------------
　共通パーツ 見出しスタイル
----------------------------------------------------------*/
/*ページタイトル
-----------------------------*/
.page_title{
	background-color: #AAAAAA;
	margin: 0;
	padding: 0;
	text-align: center;
	line-height: 200px;
	min-height: 200px;
}
.page_title img{
	height: 102px;
	width: auto;
}
/*ページタイトル（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.page_title{
		line-height: 100px;
		min-height: 100px;
		margin: 0;
	}
	.page_title img{
		height: 51px;
	}
}

/*セクション見だし
-----------------------------*/
.sec_title{
	padding: 0 0 .5em;
	margin: 0 0 .5em;
	width: 100%;
	font-size: 2em;
	text-align: center;
}
/*セクション見だし（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.sec_title{
		margin: 0 0 30px;
	}
}

/*----------------------------------------------------------
　共通パーツ リストスタイル
----------------------------------------------------------*/
/*説明リスト
-----------------------------*/
.dl{
	margin: 0 0 50px;
	padding: 0;
}
.dl dt{
	margin: 0 0 1em;
	padding: 1em 0 0;
	float: left;
	width: 7em;
	clear: both;
	font-weight: bold;
}
.dl dd{
	width: 100%;
	margin: 0;
	padding: 1em 0 1em 10em;
	border-bottom: 1px solid #cccccc;
}
/*説明リスト（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.dl{
		margin: 0 0 50px;
	}
	.dl dt{
		margin: 0 0 1em;
		padding: 1em 0 0;
		float: none;
		width: 100%;
	}
	.dl dd{
		width: 100%;
		margin: 0;
		padding: 0 0 1em 2em;
		border-bottom: 1px solid #cccccc;
	}
}

/*----------------------------------------------------------
　共通パーツ ボタンスタイル
----------------------------------------------------------*/
/*ボタン
-----------------------------*/
.btn{
	text-align: center;
	margin: 50px 0 0;
}
.btn a{
	display: inline-block;
	max-width: 100%;
	min-width: 450px;
	padding: .5em 1em;
	font-size: 1.3333em;
	text-decoration: none;
	background-color: #333333;
	border-radius: 5px;
	color: #fff;
	background-repeat: no-repeat;
	background-size: auto 20px;
	background-position: center right 15px;
}
.btn a + a{
	margin: 0 0 0 50px;
}
.btn a:hover{
	background-color: #000000;
}
/*戻るボタン
-----------------------------*/
.btn_back{
	text-align: center;
	margin: 50px 0 0;
}
.btn_back a{
	display: inline-block;
	max-width: 100%;
	min-width: 450px;
	padding: .5em 3em;
	font-size: 1.3333em;
	text-decoration: none;
	background-color: #333333;
	border-radius: 5px;
	color: #fff;
	background-repeat: no-repeat;
	background-size: auto 20px;
	background-position: center left 15px;
}
.btn_back a:hover{
	background-color: #000000;
}
/*ボタン（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.btn,.btn_back{
		margin: 30px 0 0;
	}
	.btn a + a{
		margin: 15px 0 0;
	}
	.btn a,.btn_back a{
		font-size: 1.2em;
		min-width: 100%;
	}
}

/*----------------------------------------------------------
　共通パーツ テキストスタイル
----------------------------------------------------------*/
/*タイトル下のコピー
-----------------------------*/
.title_under_copy{
	text-align: center;
	color: #707070;
	line-height: 2em;
	margin: 0;
	padding: 0;
}
/*タイトル下のコピー（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.title_under_copy{
		text-align: left;
	}
}

/*----------------------------------------------------------
　共通パーツ カラム
----------------------------------------------------------*/
/*2カラム
-----------------------------*/
.wrap_2colm{
}
.wrap_2colm .colm{
	width: 47%;
	float: left;
}
.wrap_2colm .colm:nth-child(2n){
	float: right;
}

/*2カラム（スマホ）
-----------------------------*/
@media screen and (max-width:736px){
	.wrap_2colm .colm,
	.wrap_2colm .colm:nth-child(2n){
		float: none;
		width: 100%;
	}
	.wrap_2colm .colm + .colm{
		margin-top: 40px;
	}
}

/*----------------------------------------------------------
　共通パーツ ヘッダー(20220128)
----------------------------------------------------------*/
.globalnav-wrap {
	display: flex;
	justify-content: flex-end;
	font-weight: 600;
}
.globalnav {
	position: relative;
    padding: 0;
	margin: 0;
}
.globalnav .header_nav_item {
    position: relative;
    display: inline-block;
    cursor: pointer;
}
.globalnav .header_nav_item a {
    display: block;
	padding: 40px;
    padding-left: clamp(20px,1.75vw,40px);
    padding-right: clamp(20px,1.75vw,40px);
}
.globalnav::after {
	content: "";
	width: 1px;
	height: 40px;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	background: #223355;
}
.globalnav .header_nav_item::after {
	content: "";
	width: 1px;
	height: 40px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	background: #223355;
}
.globalnav .header_nav_item:hover::before,
.globalnav .header_nav_item::before {
	content: "";
	display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	width: 22px;
	height: 10px;
	background-image: url(../img/icon_ao02.png);
	background-size: cover;
	background-repeat: no-repeat;
}
