﻿/*　■■■■■■■■■■■■■■■■■■■■■■■■■　*/
/*　■■■■■■■■■ ページの構造 ■■■■■■■■■　*/
/*　■■■■■■■■■■■■■■■■■■■■■■■■■　*/
/* ------------ ボディ -----------*/
body {
}
/*　■■■■■■■■■ ヘッダ ■■■■■■■■■　*/
header {
	position:relative;
	width: auto;
	height: 80px;
	border-top-width: 5px;
}
/* ------------ タイトル -----------*/
#title {
	width: auto;
	margin: 0 1em;
}
#title .logo {
	margin-right: 10px;
}
#title .logo img {
	width: 40px;
	height: auto;
}
#title .enttl {
	font-size: 10px;
}
#title h1 {
	font-size: 4vw;
}
#title h1 .csfrt {
	display: none;
}
/*　■■■■■■■■■ コンテンツ ■■■■■■■■■　*/
#sec_con {
	display: block;
	padding:0px 0 50px;
	width:100%;
	overflow: hidden;
}
#sec_con .cl {
	order: 2;
	width:100%;
	min-height: 300px;
}
#sec_con .cr {
	order: 1;
	width:100%;
}
#sec_con .cr_ad {
	margin: 0;
	width: auto;
}
/* ------------ index.htmlの開催概要 -----------*/
#sec_con .main {
	background-size: cover;
	width: 100%;
	height: auto;
	aspect-ratio: 800 / 780;
}

dl#tokitokoro {
	font-size: 10px;
	justify-content: center;
	position: absolute;
	left: 10px;
	right: 10px;
}
#theme {
	margin: 0 auto;
	width: 300px;
	position: absolute;
	top: 150px;
	left: 0;
	right: 0;
}
#theme img {
	max-width: 100%;
	height: auto;
}
#kaicho {
	font-size: 10px;
	position: absolute;
	bottom: 30px;
	left: 20px;
	right: 20px;
}
div.web_enter {
	position: absolute;
	bottom: 100px;
	left: 10px;
	right: 10px;
	background: #fff;
	border: solid 2px #000;
	padding: 1.0em 1.0em;
	font-size: 80%;
	line-height: 1.3;
	/*text-align: center;*/
}
div.web_enter  a.btn {
	line-height: 1.0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 110%;
	font-weight: bold;
	min-height: 2.5em;
	min-width: 30%;
	padding: 0.2em 1.2em;
	text-align: center;
	text-overflow: ellipsis;
	vertical-align: bottom;
	white-space: nowrap;
	margin: 0 auto 10px 130px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
/* ------------ サイド -----------*/
.atcl_side {
}
#sec_con article.atcl00 {
	margin: 40px 10px 150px;
	width: auto;
}
.side_instagram {
	margin-left: auto;
	margin-right: auto;
}
/* ------------ ナビ -----------*/
nav.nv_pc {
	display: none;
}
nav.nv_mbile {
}
/* バナー広告 */
.banner {
	margin: 50px 20px;
}
/* ------------ バー -----------*/
.bar {
	width:100%;
}
.bar:after {
	content: "";
	clear: both;
	display: block;
}
.br_temp {
}
.bar span.renew {
	margin:0 5em 0 0;
}
.minibar {
	width:100%;
}
/* 更新情報 */
.news {
	margin:0 0 0 5px;
/*	width:100%;*/
	width: auto;
	height:200px;
}
.news dl {
}
.news dt {
	float:none;
}
.news dd {
	margin:0 0 0 1em;
}
/*　■■■■■■■■■ フッタ ■■■■■■■■■　*/
footer {
	position:fixed;
	bottom:0px;
	right:0px;
	width:100%;
	height:50px;
	background:#DDDDDD;
}
footer .copy {
	display:none;
}
.copy_m {
	display: block;
	margin: 0 0 10px 2.3em;
	margin-top: 50px;
	text-indent: -1.3em;
	font-size: 85%;
	line-height: 110%;
}
/*■■■■スマホメニュー（ハンバーガーメニューとナビゲーションドロワー）■■■■*/
#nv_drwr {
	display: block;
}
/*非表示*/
.nv_none {
  display:none;
}
/*アイコンメニュー*/
footer .mb_menu {
	display:flex;
	text-align: center;
}
footer .mb_menu li {
	padding: 5px 0 0;
	width: 30%;
}
footer .mb_menu li p {
	margin: -10px 0 0;
	font-size: 85%;
}
/*メニューのカバー*/
#nv_tojiru {
	display: none;/*隠す*/
	position: fixed;
	z-index: 99;
	top: 0;/*全体に広げる*/
	left: 0;
	width: 100%;
	height: 100%;
	background: black;
	opacity: 0;
	transition: .3s ease-in-out;
}
/*メニューのコンテンツ*/
#nv_con {
	overflow: auto;
	position: fixed;
	top: 100px;
	left: 0;
	z-index: 9999;
	width: 90%;/**/
	max-width: 200px;/**/
	height: 70%;
	background: #fff;
	transition: .3s ease-in-out;
	-webkit-transform: translateX(-105%);
	transform: translateX(-105%);/*左に隠す*/
	}
/*チェックが入れば表示*/
#nv_in:checked ~ #nv_tojiru {
  display: block;/*カバーを表示*/
  opacity: .5;
}
#nv_in:checked ~ #nv_con {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);/*右へスライド*/
  box-shadow: 6px 0 25px rgba(0,0,0,.15);
}
/*メニューの中身*/
#nv_con {
}
/* ページトップへ */
.page-top {
	z-index: 100;
	position: fixed;
	bottom: -9px;
	right: 60px;
	width:60px;
	height:60px;
	background: #DDDDDD;
	border-radius: 30px;
	text-decoration:none;
}
.top_m {
	scroll-behavior: smooth;
}
/*　■■■■■■■■■ 挨拶 ■■■■■■■■■　*/
#aisatsu {
	margin: 50px 1em 150px;
	width: auto;
}
#aisatsu .kaicho {
	flex-direction: column;
}
#aisatsu .kaicho > * + * {
	margin-top: 20px;
}
/*　■■■■■■■■■ 開催概要 ■■■■■■■■■　*/
#gaiyo {
	margin: 50px 1em 150px;
	width: auto;
}
#gaiyo dt {
	float:none;
}
#gaiyo dd {
	margin: 1em 0 30px 1em;
	padding: 0;
}
/*　■■■ 演題募集 ■■■　*/
#endai {
	margin: 50px 1em 150px;
	width: auto;
}
#endai .poster_presen {
	flex-direction: column;
}
#endai .poster_presen img {
	max-width: 100%;
	height: auto;
}
#endai .coi .link img {
	max-width: 100%;
	height: auto;
}
/*　■■■■■■■■■ 採択演題 ■■■■■■■■■　*/
#saitaku {
	margin: 50px 1em 150px;
	width: auto;
}
#saitaku .session_header {
	flex-direction: column;
}
#saitaku .session_header .sub {
	margin: 0;
}
#saitaku .session_header .kaijo {
	margin: 0;
}
/* #saitaku h3 span.jikan {
	float: none;
	display: block;
	font-size: 80%;
	color: #333;
} */
#saitaku table {
	display: block;
	overflow: auto;
	white-space: nowrap;
	width: 100%;
	-webkit-overflow-scrolling: touch;
}
/*　■■■■■■■■■ プログラム ■■■■■■■■■　*/
#pro {
	margin: 50px 1em 150px;
	width: auto;
}
#pro .heading {
	flex-direction: column;
}
#pro .date_sub {
	justify-content: flex-start;
}
#pro .endai {
	margin-left: 0;
}
#pro .title ~ * {
	margin-left: 1em;
}
#pro .enja {
	grid-template-columns: none;
}
#pro .enja > *:nth-child(n+2) {
	margin-left: 1em;
}
/*　■■■■■■■■■ 参加登録 ■■■■■■■■■　*/
#sanka {
	margin: 50px 1em 150px;
	width: auto;
}
/*　■■■■■■■■■ 参加者 ■■■■■■■■■　*/
#annai {
	margin: 50px 1em 150px;
	width: auto;
}
#annai table.tbl_1,
#annai table.tbl_2 {
	display: block;
	overflow: auto;
	white-space: nowrap;
	width: 100%;
	-webkit-overflow-scrolling: touch;
}
/*　■■■■■■■■■ 問い合わせ ■■■■■■■■■　*/
#toi {
	margin: 50px 1em 150px;
	width: auto;
}
/*　■■■■■■■■■ リンク ■■■■■■■■■　*/
#link {
	margin: 50px 1em 150px;
	width: auto;
}
/*　■■■■■■■■■ 協賛企業の申込 ■■■■■■■■■　*/
#link2 {
	margin: 50px 1em 150px;
	width: auto;
}
/*　■■■■■■■■■ アクセス ■■■■■■■■■　*/
#access {
	margin: 50px 1em 150px;
	width: auto;
}
#access div.map > iframe {
	max-width: 100%;
	height: 360px;
	vertical-align: bottom;
}
