@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&family=Sofia+Sans+Extra+Condensed:ital,wght@0,1..1000;1,1..1000&family=Zen+Maru+Gothic&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200..1000;1,200..1000&display=swap');
/*==================================================
cmn
==================================================*/


html {
	overflow: auto;
	font-size: 62.5%;
	background: #1E4994;
}

body {
	overflow: hidden;
	/*font-family: "Nunito","Zen Maru Gothic", serif;*/
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	color: #333;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 2em;
	letter-spacing: 0px;
	position: relative;
	margin: 0px;
	padding: 0px;
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-o-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

header,
nav,
div,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
dl,
dt,
dd,
img,
table,
tr,
td,
th,
input,
textarea,
select,
a,
figure,
span {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	list-style: none;
	margin: 0px;
	padding: 0px;

}

h1,
h2,
h3,
h4,
h5,
h6 {
	line-height: 1.8em;
	font-weight: normal;
}

h2 {
	font-size: 28px;
}

p {
	margin-bottom: 1em;
}

p:last-child {
	margin: 0;
}

a,
input[type="submit"] {
	text-decoration: none;
	color: inherit;
	-webkit-transition:all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
	color: #DD5028;
	outline: none;
	font-weight: bold;
}

a:hover,
input[type="submit"]:hover {
	filter: alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}

a:after {
	font-family: "Font Awesome 5 free";
	margin-left: .5em;
}

a[target="_blank"]:after {
	content: '\f35d';
}

a:before {
	font-family: "Font Awesome 5 free";
	margin-right: .25em;
}

a[href^="mailto:"]:before {
	content: '\f0e0';
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

hr {
	border: none;
	margin: 45px 1em;
	border-bottom: 1px dotted #d0d5df;
}

.hr01 {
	border: none;
	margin: 4em 0;
	border-bottom: 2px solid #b0e3e4;
}

.hr02 {
	margin: 0.5em 1em !important;
	border-bottom: 1px solid #4d77ca !important;
}

.hr03 {
	margin: 0 !important;
	border-bottom: 1px solid #EEE !important;
	margin-bottom: 1.5em !important;
}

.wrap {
	margin: 0 auto;
	padding: 30px 0;
	box-shadow: none;
	width: 100%;
	max-width: 1100px;
	overflow: hidden;
}

.sp {
	display: none;
}

.mb0 {
	margin-bottom: 0em !important;
}

.mb1 {
	margin-bottom: 1em !important;
}

.mb3 {
	margin-bottom: 3em !important;
}

.mb5 {
	margin-bottom: 5em !important;
}

.ml1 {
	margin-left: 1em;
}

.txt-red {
	color: #ff3f3f;
}

.txt-reset {
	color: #333;
	font-weight: normal;
}

.txt-marker {
	background: linear-gradient(transparent 60%, #ffbaba 60%);
	color: #000;
}

.txt-left {
	text-align: left;
}

.txt-110 {
	font-size: 110%;
}

.txt-120 {
	font-size: 120%;
	font-weight: bold;
	margin: 1.5em 0;
}

.outline01 {
	border: 2px solid #966950;
	border-radius: 1em;
	padding: 0.5em 1em;
	margin: 2em 0;
}

.btn01 a {
	display: block;
	background: #DD5028;
	padding: 10px 20px;
	text-align: center;
	border-radius: 10px;
	width: 50%;
	margin: 1em 25%;
	color: #FFF;
}



.btn02 a {
	display: block;
	background: #00b8bf;
	padding: 10px 20px;
	text-align: center;
	border-radius: 5px;
	width: 50%;
	margin: 50px 0;
	color: #FFF;
}


.btn03 {
	text-align: center;
}

.btn03 a {
	display: block;
	background: #ff969c;
	padding: 10px 20px;
	text-align: center;
	border-radius: 5px;
	width: 50%;
	margin: 50px 25% 0 25%;
	color: #FFF;
}

#PageTopBtn {
	position: fixed;
	/*ボタンの配置場所を固定*/
	bottom: 20px;
	/*下からのボタンの配置場所を指定*/
	right: 20px;
	/*右からのボタンの配置場所を指定*/
	font-size: 75%;
}

#PageTopBtn a {
	display: block;
	/*配置の調整*/
	color: #fff;
	/*文字の色*/
	background: #ff969c;
	/*ボタンの背景色*/
	text-align: center;
	/*文字を中央に配置*/
	border-radius: 5px;
	/*ボタンの角を少し丸くする*/
	padding: 10px 10px;
	line-height: 1.5;
	opacity: 0.7;
}

#PageTopBtn a:hover {
	background: #e3343d;
}

.pagetop {
	position: fixed;
	bottom: 25px;
	right: 25px;
	line-height: 1;
	z-index: 999;
	font-size: 400%;
	opacity: 0.7;
}

.vimeo {
	position: relative;
	height: 0;
	padding: 0 0 56.25%;
	overflow: hidden;
	margin-bottom: 3em;
}

.vimeo iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.flex-bnr {
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
	margin-bottom: 2em;
}

.bnr-title {
	margin-top: 1em;
	color: #ff9100;
	font-weight: bold;
}


.flex-bnr li {
	margin-top: 1em;
}

.flex-bnr li img{
	width: 360px;
}

.btngrey {
	background: #999 !important;
}

.caution{
	border: 3px solid #1E4994;
	padding: 1em 2em;
	border-radius: 10px;
	margin-bottom: 1em;
}

.caution h4{
	font-size: 120%;
	font-weight: bold;
	line-height: 2;
	margin-bottom: 1em;
	text-align: center;
}


/*==================================================
head
==================================================*/
#side-box {
	float: none;
	top: 0px;
	left: 0px;
	width: 240px;
	max-height: inherit;
	position: fixed;
	z-index: 9990 !important;
	text-align: center;
	background: #1E4994;
}

#side-box.auto {
	position: absolute;
}

.site-header {
	position: relative;
	z-index: 9990 !important;
}

.site-header h1 {
	width: 100%;
	height: 200px;
	line-height: 0em;
}

.site-header h1 img {
	padding: 30px 0;
}

.site-header h1 a {
	display: block;
}

#gnavi-s,
.button-toggle {
	display: none;
}

.gnavi ul {
	border-top: 0px solid #E0E0E0;
}

.gnavi li {
	border-bottom: 0px solid #E0E0E0;
	position: relative;
	/*font-size: 90%;*/
	font-size: 120%;
	color: #ccc;
	margin: 5px;
	
}

.gnavi li a {
	display: block;
	color: #FFF;
	padding: 9px 20px;
	border-radius: 3px;
	
}

.gnavi li.current a,
.gnavi li a:hover {
	background: #DD5028;
	filter: alpha(opacity=100);
	-moz-opacity: 1;
	opacity: 1;
	color: #fff;
}

.site-header .bnr-nav {
	margin: 0;
}

.site-header .bnr-nav li {
	margin-bottom: 12px;
}

.site-header .bnr-nav a {
	display: block;
	color: #fff;
	padding: 0 !important;
	background: none !important;
}

.site-header .bnr-nav a:hover {
	filter: alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}

.site-header .bnr-nav span {
	display: block;
}

.bnr-nav p{
	margin: 0 !important;
	color: #ffe4ab;
	font-weight: bold;
}

nav .subnavi {
	position: absolute;
	width: 240px;
	background: #1E4994;
	top: -5px;
	left: 235px;
	opacity: 0;
	visibility: hidden;
	transition: .5s;
	font-size: 110%;
}

nav .gnavi-child:hover ul {
	opacity: 1;
	visibility: visible;
}

.line2 {
	line-height: 1.3;
}

.new {
	font-size: 75%;
	background: #F00;
	padding: 2px 4px;
	border-radius: 3px;
	margin-left: 0.5em;
	color: #FFF;
	letter-spacing: 0px;
}

/*.gnavi a[href="#"] {
  color: #BBB !important;
  letter-spacing: -1px;
  padding: 8px 20px;
}
.gnavi a[href="#"]:after {
  content: '準備中';
  font-size: 75%;
  background: #DDD;
  padding: 3px 6px;
  color: #FFF;
}*/

.lang {
	background: #ACE6FF;
	margin: 5px;
	border-radius: 3px;
}

.lang a {
	color: #333 !important;
}

.lang a::before {
	content: '\f0ac';
}

.lang a:hover {
	background: #ACE6FF !important;
	color: #FFF !important;
}

.gnavi hr {

	border: none;
	margin: 0;


}

.bnrlist {
	display: flex;
	justify-content: space-around;
}

.bnrlist li img {
	width: 240px;
	height: auto;
}



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

	.bnrlist li img {
		width: 100%;
		height: auto;
	}
}

.flex-box {
	display: flex;
	justify-content: space-between;

}

.left-box {
	width: 68%;
}

.right-box {
	width: 30%;
}

.flex-box02 {
	display: flex;
}

.flex-box02 li {
	width: 50%;
}

@media screen and (max-width: 1000px) {
	.flex-box {
		display: block;
	}

	.left-box {
		width: 100%;
	}

	.right-box {
		width: 100%;
		margin-top: 2em;
	}
}

/*==================================================
foot
==================================================*/
.site-foot {
	margin-top: 90px;
}

.site-foot.fixed address {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;

}

.site-foot h2 {
	font-size: 24px;
	font-size: 2.4rem;
	color: #666;
	border-bottom: 1px solid #CCC;
	margin-bottom: 30px;
}

.site-foot .en {
	font-size: 21px;
	font-size: 2.1rem;
}

footer .address-list {
	display: flex;
	justify-content: space-around;
	margin: 0 0 30px;
	text-align: center;
}

footer .address-list ul {}

footer .address-list img {
	margin-bottom: 10px;
}

footer .address-list li {
	font-size: 14px;
	vertical-align: top;
}

footer .address-list li:first-child {
	margin-right: 0;
}

footer .address-list li h3 {
	font-weight: bold;
	font-size: 110%;
	margin-bottom: 1em;
}

footer address {
	clear: both;
	font-size: 70%;
	font-style: normal;
	text-align: center;
	color: #666;
	padding: 5px 0;
}

.snsicon{
	display: flex;
	justify-content:center;
	margin-bottom: 15px;
}

.snsicon img{
	height: 40px;
}

.snsicon li{
	margin: 0 1em;
}

/*==================================================
content
==================================================*/
#main {
	display: block;
	float: none;
	width: 100%;
	margin-left: 240px;
	width: auto;
	background: #FFF;
	position: relative;
	overflow: hidden;
}

.main-content {
	/*min-height: 2560px;*/
	padding: 0 40px;

}

section {
	padding: 0;
	position: relative;
	overflow: hidden;
}

.txt-center {
	text-align: center;
}

.txt-small {
	font-size: 80%;
	font-weight: normal;
}

.white-box {
	padding: 3% 0;
}

.white-box.no-pad {
	padding: 0;
}

/*タイトル*/

h2.tit01 {
	font-size: 32px;
	font-size: 3.2rem;
	font-weight: bold;
	color: #666;
	letter-spacing: 4px;
}

h2.tit01::before {
	position: relative;
	content: '';
	display: inline-block;
	width: 38px;
	height: 38px;
	/*background-image: url(img/cmn/title01.png);*/
	background-image: url("../images/title01.png");
	background-size: contain;
	top:7px;
	margin-right: 0.5em;
}

h3.tit01 {
	font-weight: bold;
	font-size: 21px;
	font-size: 2.1rem;
	color: #FFF;
	background: #3d5b91;
	padding: 0.15em 0 0 0.5em;
	margin-bottom: 1em;
	border-radius: 3px;
}

h3.tit02 {
	font-weight: bold;
	font-size: 21px;
	font-size: 2.1rem;
	color: #0088c7;
	border-bottom: 1px dashed #c9c0bc;
	margin-bottom: 0.5em;
}



h3.tit03 {
	font-size: 18px;
	font-size: 1.8rem;
	color: #009e47;
	font-weight: bold;
}

h3.tit04 {
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.5;
	margin: 1em 0;
	padding: 0 0.75em;
	border-radius: 15px;
	color: #FFF;
	background: #00b8bf;
	font-weight: bold;
}

h4.tit01 {
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1;
	margin-bottom: 1em;
	font-weight: bold;
	padding-left: 0.5em;
	color: #13afb4;
	border-left: 1em solid #13afb4;
}

h4.tit02 {
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
}

.list-indent {
	margin-bottom: 2em;
}

.list-indent li {
	list-style: none;
	list-style-position: inside;
	line-height: 1.5;
	text-indent: -1em;
	margin-left: 1em;
	margin-bottom: 0.5em;
}

.list-indent02 {
	margin-bottom: 2em;
}

.list-indent02 li {
	list-style: none;
	list-style-position: inside;
	line-height: 1.5;
	text-indent: -1.5em;
	margin-left: 1.5em;
	margin-bottom: 0.5em;
}

.list-circle {
	margin-bottom: 1em;
}

.list-circle li {
	list-style: disc;
	list-style-position: inside;
	line-height: 1.5;
	text-indent: -1.4em;
	margin-left: 1.5em;
	margin-bottom: 0.5em;
}

.list-circle li .fas {
	margin-left: 1em;
}

.list-decimal {
	margin-bottom: 1em;
}

.list-decimal li {
	list-style: decimal;
	list-style-position: inside;
	text-indent: -1em;
	margin-left: 1em;
	margin-bottom: 0.5em;
}

.list-lower-alpha {
	margin-bottom: 1em;
}

.list-lower-alpha li {
	list-style: lower-alpha;
	list-style-position: inside;
	line-height: 1.5;
	text-indent: -0.9em;
	margin-left: 1em;
	margin-bottom: 0.5em;
}


.list-decimal li .fas {
	margin-left: 1em;
}

.list-decimal02 {
	counter-reset: my-counter;
	margin-bottom: 1em;
}

.list-decimal02 li {
	padding-left: 1.5em;
	position: relative;
	margin-bottom: 0.5em;
}

.list-decimal02 li:before {
	content: counter(my-counter);
	counter-increment: my-counter;
	background-color: #fff;
	border: 1px solid;
	border-radius: 50%;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 1.2em;
	width: 1.2em;
	color: #333;
	font-size: 90%;
	position: absolute;
	top: 0.6em;
	left: 0;
}

.list-alpha {
	margin-bottom: 3em;
}

.list-alpha li {
	list-style-type: upper-alpha;
	list-style-position: inside;
	line-height: 1.5;
	text-indent: -1.1em;
	margin-left: 1em;
	margin-bottom: 0.5em;
}

.dl-list01 {
	margin-bottom: 2em;
	line-height: 1.8;
}

.dl-list01 dt {
	float: left;
	width: 110px;
	font-size: 14px;
	color: #27BDBE;
	text-align: center;
	border: solid 1px #27BDBE;
	border-radius: 30px;
}

.dl-list01 dd {
	margin-left: 130px;
	margin-bottom: 1em;
}


.info02 {
	/*text-align: center;*/
	border: 3px solid #ff9900;
	border-radius: 10px;
	padding: 1em 2em;
	margin-bottom: 1em;
}

.info02 h3 {
	text-align: center;
	font-weight: bold;
	font-size: 18px;
	font-size: 1.8rem;
	margin-bottom: 1em;
}

/*==================================================
index
==================================================*/
.main-img {
	text-align: center;
	background-position: center;
	background-repeat: no-repeat;
	margin-top: 50px;
}

.main-img img {
	max-width: 1100px;
	width: 100%;
	position: relative;
}

.event-detail {
	text-align: center;
	background-color: #ff969c;
}

.event-detail img {
	padding: 5px 0;
	width: 100%;
	max-width: 980px;
}

.news-sec {
	overflow: hidden;
	margin: 0 0 2%;
}

.news-div {
	width: 10.4%;
	display: inline-block;
	vertical-align: top;
	margin-right: 7%;
}

.news-list {
	min-height: 480px;
	display: inline-block;
	width: 100%;
}

.news-list li {
	display: block;
	line-height: 1.8em;
	overflow: hidden;
	border-bottom: 1px dotted #dce2eb;
	padding: 14px 0;
}

.news-list li .data {
	float: left;
	width: 6.5em;
	display: block;
	color: #999;
}

.news-list li .data-en {
	float: left;
	width: 9em;
	display: block;
	color: #999;
}

.news-list li .txt {
	overflow: hidden;
	color: #333;
	display: block;
}

/*==================================================
page
==================================================*/
.page-box{
}

.main-sub {
	padding: 0;
}

.main-sub .tit {
	background: #61ac45;
	padding: 20px 0;
}

.main-sub .page-tit {
	background: url(../img/cmn/main_sub.jpg) no-repeat center;
	background-size: cover;
	color: #fff;
	padding: 60px 0;
}

.main-sub .page-tit h3 {
	font-size: 36px;
	font-size: 3.6rem;
	font-weight: bold;
	letter-spacing: 5px;
}

.table-style01 {
	width: 100%;
	border-collapse: collapse;
}

.table-style01 {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1em;
	line-height: 1.5;
}

.table-style01 th {
	padding: 5px 10px;
	border: 1px solid #b6c0d1;
	vertical-align: middle;
	background-color: #e8f3ff;
	font-size: 90%;
	min-width: 100px;
}

.table-style01 td {
	padding: 5px 10px;
	border: 1px solid #b6c0d1;
	vertical-align: middle;
	text-align: center;
	width: 15.5%;
}

.table-style02 {
	width: 50%;
	border-collapse: collapse;
	line-height: 1.5;
	margin-bottom: 1em;
}

.table-style02 th {
	white-space: nowrap;
	padding: 10px 30px;
	border: 1px solid #f1f3f6;
	vertical-align: top;
	color: #00b8bf;
	min-width: 100px;
}

.table-style02 td {
	padding: 10px 30px;
	border: 1px solid #f1f3f6;
	vertical-align: middle;
	text-align: center;
	min-width: 80px;
}

.table-style03 {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1em;
}

.table-style03 th {
	padding: 5px 20px;
	border: 1px solid #b6c0d1;
	vertical-align: middle;
	background-color: #e8f3ff;
	min-width: 80px;
}

.table-style03 td {
	padding: 5px 20px;
	border: 1px solid #b6c0d1;
	vertical-align: middle;
	min-width: 80px;
	text-align: center;
}

.table-style04 {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1em;
	text-align: center;
	font-size: 80%;
	line-height: 1.5;
}

.table-style04 th {
	padding: 0.5em 2em;
	border: 1px solid #d1c6b6;
	vertical-align: middle;
	background-color: #eee;
}

.table-style04 td {
	padding: 0.5em 2em;
	border: 1px solid #d1c6b6;
	vertical-align: middle;
}

.nowrap {
	white-space: nowrap;
}

.minwidth {
	min-width: 200px !important;
}

.list-disc {
	margin-bottom: 1em;
}

.list-disc li {
	margin-left: 1.5em;
	list-style: disc;
}

.underconstruction {
	font-size: 170%;
	text-align: center;
	min-height: 360px;
	line-height: 360px;
}

/*==================================================
greeting
==================================================*/

.profile {
	font-size: 90%;
	margin: 3em 0 0;
	display: flex;
	justify-content: flex-end;
	align-items: flex-end;
	text-align: right;
}

.profile li {
	display: block;
	vertical-align: bottom;
	margin-bottom: 1em;
}

.profile .name {
	font-weight: bold;
	font-size: 130%;
	margin-left: 1em;
}

.profile .reset {
	margin-left: 0;
}

.profile img {
	margin-left: 2em;
	margin-bottom: 0.5em;
	width: 180px;

}

.greeting p {
	text-indent: 1em;
}

/*==================================================
outline
==================================================*/

.table-overview {
	border-collapse: collapse;
	width: 100%;
}

.table-overview th {
	border-bottom: 1px solid #dce2eb;
	vertical-align: top;
	padding: 30px;
	color: #666;
	white-space: nowrap;
	letter-spacing: 2px;
	font-weight: normal;
}

.table-overview td {
	border-bottom: 1px solid #dce2eb;
	padding: 30px;
	min-width: 480px;
}

/*==================================================
program
==================================================*/

.dl-ws {
	margin-bottom: 2em;
	/*border-bottom: 1px dashed #CCC;*/
	padding-bottom: 1em;
	padding-left: 0.6em;
}

.dl-ws dt {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	line-height: 1.8;
	margin-bottom: 0.5em;
	float: left;
	width: 80px;
	text-align: center;
	background: #ff672b;
	color: #FFF;
	border-radius: 5px;
	font-size: 80%;
	letter-spacing: 1em;
	padding-left: 1em;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.dl-ws dd {
	margin: 0;
	padding: 0;
	line-height: 2;
	margin-bottom: 0.5em;
	margin-left: 90px;
	font-weight: bold;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;

}

.dl-ws span {
	font-size: 90%;
	font-weight: normal;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.dl-wse {
	margin-bottom: 2em;
	/*border-bottom: 1px dashed #CCC;*/
	padding-bottom: 1em;
	padding-left: 0.65em;
}

.dl-wse dt {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	line-height: 1.8;
	margin-bottom: 0.5em;
	float: left;
	width: 140px;
	text-align: center;
	background: #ff672b;
	color: #FFF;
	border-radius: 5px;
	font-size: 80%;
}

.dl-wse dd {
	margin: 0;
	padding: 0;
	line-height: 2;
	margin-bottom: 0.5em;
	margin-left: 150px;
	font-weight: bold;

}

.dl-wse span {
	font-size: 90%;
	font-weight: normal;
}

.time {
	font-size: 110%;
	font-weight: bold;
	color: #666;
	margin-bottom: 0 !important;
}

.protit01 {
	color: #3d5b91;
	font-size: 130%;
	margin: 1em 0;
	font-weight: bold;
	border-bottom: 1px solid #DDD;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.protit02 {
	color: #0088c7;
	font-size: 120%;
	font-weight: bold;
	line-height: 1;
	margin: 1em 0 0.5em 0;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.protit03 {
	color: #000;
	font-size: 110%;
	margin: 0.5em 0;
	margin-left: 0.5em;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.protit04 {
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"
	color: #b31f37;
	font-size: 100%;
	font-weight: bold;
	margin-bottom: 1em;
	margin-left: 130px;
}

.protit04e {
	color: #b31f37;
	font-size: 100%;
	font-weight: bold;
	margin-bottom: 1em;
	margin-left: 160px;
}

.live {
	background: #5e82c5;
	border-radius: 1em;
	padding: 0 0.5em;
	font-size: 80%;
	color: #FFF;
	margin-left: 1em;
}

.ondemand {
	background: #cc5555;
	border-radius: 1em;
	padding: 0 0.5em;
	font-size: 80%;
	color: #FFF;
	margin-left: 1em;
}


.sche-btn {
	margin-bottom: 3em;
	text-align: center;
}

.sche-btn li {
	margin: 2em 4em;
}

.sche-btn li a {
	display: block;
	background: #ff969c;
	padding: 10px 20px;
	text-align: center;
	border-radius: 5px;
	width: 80%;
	margin: 0 10%;
	color: #FFF;
	line-height: 1.5;
}

.sche-btn li p {
	font-size: 90%;
	line-height: 1.5;
}

/*==================================================
coi
==================================================*/

.poster-img{
	float: right;
	max-width: 40%;
	margin-left: 2em;
}

.dl-poster {
	margin-bottom: 0.5em;
	
}
.dl-poster dd{
	margin-left: 1em;
}


.coi-box {
	border: 2px solid #27BDBE;
	border-radius: 5px;
	padding: 20px;
	margin-bottom: 30px;
}

.coi-box p {
	margin-top: -0.5em;
	margin-bottom: -0.5em;
}

.dl-coi {
	margin-left: 2em;
	margin-top: -0.5em;
	margin-bottom: -0.5em;
}

.dl-coi dt,
.dl-coi dd {
	margin-top: -0.5em;
	margin-bottom: -0.5em;
}

.dl-coi dd {
	font-size: 120%;
	font-weight: bold;
}

.dl-coi02 {
	margin-top: -0.5em;
	margin-bottom: 1em;
}

.dl-coi02 dt,
.dl-coi dd {
	margin-top: -0.5em;
	margin-bottom: -0.5em;
}

.dl-coi02 dd {
	font-size: 120%;
	font-weight: bold;
}

/*==================================================
nursery
==================================================*/

.dl-nursery {
	/*border-bottom: 1px dashed #CCC;*/
}

.dl-nursery dt {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	line-height: 1.8;
	margin-bottom: 0.5em;
	float: left;
	width: 140px;
	text-align: center;
	background: #888;
	color: #FFF;
	border-radius: 5px;
	font-size: 80%;
}

.dl-nursery dd {
	margin: 0;
	padding: 0;
	line-height: 2;
	margin-bottom: 0.5em;
	margin-left: 150px;
}

.dl-nursery02 {
	/*border-bottom: 1px dashed #CCC;*/
}

.dl-nursery02 dt {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	line-height: 1.8;
	margin-bottom: 0.5em;
	float: left;
	width: 250px;
	text-align: center;
	background: #888;
	color: #FFF;
	border-radius: 5px;
	font-size: 80%;
}

.dl-nursery02 dd {
	margin: 0;
	padding: 0;
	line-height: 2;
	margin-bottom: 0.5em;
	margin-left: 260px;

}

/*==================================================
ad
==================================================*/
.adbox p {
	margin-left: 0.75em;
}

.adbox h4 {
	margin-left: 0.75em;
}

.adbox ul {
	margin-left: 0.75em;
}

.flex-btn {
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
	margin: 4em 0;
}

.flex-btn li {}

.flex-btn li a {
	background: #DD5028;
	color: #fff;
	font-weight: bold;
	padding: 1em 6em;
	border-radius: 10px;
}

.dl-ad01 {
	margin-bottom: 1em;
	margin-left: 0.5em;
}

.dl-ad01 dt {
	float: left;

	width: 115px;
	text-align-last: justify;
	text-justify: inter-ideograph;
}

.dl-ad01 dd {

	margin-left: 125px;
	font-weight: bold;
}

.dl-ad02 {
	margin-bottom: 1em;
	font-size: 110%;
	margin-left: 0.75em;
}

.dl-ad02 dt {
	float: left;
	margin-bottom: 1em;
	width: 160px;
	text-align-last: justify;
	text-justify: inter-ideograph;
}

.dl-ad02 dd {
	margin-bottom: 1em;
	margin-left: 170px;
	font-weight: bold;
}

/*==================================================
map
==================================================*/

.gmap {
	height: 0;
	overflow: hidden;
	padding-bottom: 56.25%;
	position: relative;
	border-radius: 10px;
}

.gmap iframe {
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}


/*==================================================
registration
==================================================*/
.registration-dl {
	margin-bottom: 30px;
	font-size: 18px;
	font-size: 2.1rem;
	font-weight: bold;
}

.registration-dl dt {
	float: left;
	color: #036eb8;

}

.registration-dl dd {
	margin-left: 8em;
}

.registration-dlen {
	margin-bottom: 30px;
	font-size: 18px;
	font-size: 2.1rem;
	font-weight: bold;
}

.dl-reg {
	margin-bottom: 1em;
}

.dl-reg dt {
	float: left;
	margin-bottom: 2em;
	width: 70px;
}

.dl-reg dd {
	
}

.table-reg {
	width: 100%;
	margin-bottom: 1.5em;
	border: 1px solid #6b82a1;
	border-collapse: collapse;
	line-height: 1.5;
	font-size: 80%;
}

.table-reg th {
	padding: 0.5em 2em;
	background: #e6f1ff;
	border: 1px solid #6b82a1;
}

.table-reg td {
	text-align: center;
	padding: 0.5em 2em;
	border: 1px solid #6b82a1;
}

.table-reg span {
	font-size: 40%;
	font-weight: normal;
}



.reg-btn {
	margin-bottom: 3em;
	text-align: center;
}

.reg-btn li {
	margin: 2em 4em;
}

.reg-btn li a {
	display: block;
	background: #DD5028;
	padding: 10px 20px;
	text-align: center;
	border-radius: 10px;
	width: 80%;
	margin: 50px 10%;
	color: #FFF;
}


.dl-bus {
	margin-bottom: 1em;
}

.dl-bus dt {
	float: left;
	font-weight: bold;
}

.dl-bus dd {
	/*margin-left: 11.5em;*/
	margin-bottom: 1em;
}

.dl-bus02 {
	margin-bottom: 1em;
	color: #df0004;
	font-weight: bold;
	line-height: 1.5;
}

.dl-bus02 dt {
	float: left;
}

.dl-bus02 dd {
	margin-left: 4em;
	margin-bottom: 0.75em;
}

.idimg {
	float: right;
	width: 35%;
}

/*==================================================
abstract
==================================================*/
.abstract .sec {
	margin-bottom: 3em;
}

.abs-date {
	border: 2px solid #EF412A;
	padding: 1.5em;
	text-align: center;
	font-size: 130%;
	font-weight: bold;
	color: #EF412A;
	margin-bottom: 1em;
	border-radius: 10px;
}

.table-abstract {
	width: 100%;
	border-collapse: collapse;
	
}

.table-abstract th {
	text-align: right;
	padding: 5px 10px;
}

.table-abstract td {
	text-align: left;
	padding: 5px 10px;
}

.table-abstract01 {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid #b6c0d1;
}

.table-abstract01 th {
	text-align: center;
	padding: 5px 10px;
	background: #e8f3ff;
	border: 1px solid #b6c0d1;
}

.table-abstract01 td {
	text-align: left;
	padding: 5px 30px;
	border: 1px solid #b6c0d1;
}

.table-abstract02 {
	width: 100%;
	margin-bottom: 1em;
	line-height: 1.5;
	border: 1px solid #21A1D6;
	border-collapse: collapse;
}

.table-abstract02 th {
	white-space: nowrap;
	padding: 1em 2em;
	color: #FFF;
	background: #21A1D6;
}

.table-abstract02 td {
	padding: 1em 2em;
	text-align: center;
}

.abstract-contact {
	text-align: center;
	border: 1px solid #CCC;
	border-radius: 5px;
	padding: 2.5%;
	line-height: 1.5;
}

.table-cat01 {
	width: 100%;
	margin-bottom: 2.5em;
	border: 3px solid #ff969c;
	border-collapse: collapse;
}

.table-cat01 th {
	padding: 0.5em;
	border: 1px solid #DDD;
	text-align: center;
	font-weight: normal;
}

.table-cat01 td {
	padding: 0.5em;
	border: 1px solid #DDD;
}

.table-cat01 tr:nth-child(even) {
	background: #fff5f5;
}

.table-cat02 {
	width: 100%;
	border: 1px solid #DDD;
	border-collapse: collapse;
}

.table-cat02 th {
	padding: 0.5em;
	border: 1px solid #DDD;
	text-align: center;
	font-weight: normal;
	background: #fff5f5;
}

.table-cat02 td {
	padding: 0.5em 1.5em;
	border: 1px solid #DDD;
}

/*==================================================
organizers
==================================================*/
.table-organizers {}

.table-organizers th {
	padding: 5px 10px;
	vertical-align: top;
	white-space: nowrap;
	-moz-text-align-last: justify;
	text-align-last: justify;
}

.table-organizers td {
	padding: 5px 10px;
}

.table-organizers02 {}

.table-organizers02 th {
	text-align: left;
	font-weight: normal;
	border-bottom: 1px solid #036eb8;
	color: #036eb8;

}

.table-organizers02 td {
	min-width: 180px;
	vertical-align: top;
	padding: 10px 0;

}

.org-minwidth {
	min-width: 480px !important;

}

/*==================================================
program
==================================================*/

.date {
	font-size: 80%;
	color: #666;
	font-weight: normal;
	margin-left: 1em;
}


/*==================================================
link
==================================================*/
.list-link {
	margin-bottom: 30px;
}

.list-link li {
	list-style-type: disc;
	list-style-position: inside;
	margin-bottom: 1em;
	border-bottom: 1px dotted #dce2eb;
	padding-bottom: 1em;
}
/*==================================================
foods
==================================================*/

.list-foods{
	display: flex;
	align-items: flex-end;
	margin-bottom: 2em;
}
.list-foods li{
	margin-right: 2em;
}

.list-foods li img{
	max-width: 240px;
	height: auto;
	border-radius: 10px;
}

/*==================================================
sponsor
==================================================*/
.list-sponsors li {
	list-style: inside;
	margin-bottom: 1em;
	padding-bottom: 1em;
}

.list-sponsors li a {
	color: #333;
}

.list-sponsors li a[target="_blank"]:after {
	content: '\f35d';
	color: #EC7077;
}

.list-sponsors li:before {
	border-radius: 50%;
	width: 5px;
	height: 5px;
	display: block;
	position: absolute;
	left: 0;
	top: 0.6em;
	content: "";
	background: #7e6e66;
}

.list-sponsors li::marker {

	color: #7e6e66;
}

.list-sponsors li a:hover {
	background: #ffcfd1;
	border-radius: 5px;
	padding: 0 8px 3px 8px;
	opacity: 1;
}

.list-sponsor {
	font-size: 90%;
	margin-bottom: 30px;
}

.list-sponsor li {
	text-indent: -1em;
	margin-left: 1em;
	line-height: 1.5;
	margin-bottom: 0.75em;
}

.list-sponsor02 {
	font-size: 90%;
	margin-bottom: 30px;
}

.list-sponsor02 li {
	text-indent: -1.75em;
	margin-left: 1.75em;
	line-height: 1.5;
	margin-bottom: 0.75em;
}

.table-sponsor {
	width: 100%;
	border-collapse: collapse;
	font-size: 90%;
	margin-bottom: 3em;
}


.table-sponsor td {
	padding: 10px 20px;
	border: 1px solid #dce2eb;
	vertical-align: middle;
	width: 50%;
}

.table-sponsor tr:nth-child(even) td {
	background: #fff3ee;
  }


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

	.pc {
		display: none;
	}

	.table-overflow {
		overflow-x: scroll;
	}

	.site-header h1 {
		width: auto;
		height: auto;
		padding: 10px 0 10px 2.5%;
		float: left;
		display: inline-block;
	}

	.site-header h1 a {
		display: block;
		line-height: 0;
		width: auto;
		margin: 0;
	}

	.site-header h1 img {
		height: 44px;
		padding: 0;
	}

	.site-title a {
		float: left;
	}

	#side-box {
		border: none;
		width: 100%;
		max-height: inherit;
		position: fixed;
		padding: 0 0;
		background: #1E4994;
	}

	#side-box .navi-box {
		margin: 0;
		text-align: center;
		height: inherit;
		overflow-y: scroll !important;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 100px;
		display: block;
		position: absolute;
		top: 64px;
		left: 0;
		width: 100%;
		background: #1E4994;
	}

	.gnavi .subnavi a {
		line-height: 2em;
	}

	.button-toggle {
		position: absolute;
		top: 20px;
		right: 3.5%;
		display: block;
		z-index: 100;
		line-height: 1em;
	}

	.css-bar {
		display: inline-block;
		position: relative;
		margin: 0;
		padding: 0;
		background: #FFF;
		line-height: 0;
	}

	.css-bar,
	.css-bar:before,
	.css-bar:after {
		width: 30px;
		height: 3px;
	}

	.css-bar:before,
	.css-bar:after {
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		background: #FFF;
	}

	.css-bar:before {
		margin-top: -10px;
	}

	.css-bar:after {
		margin-top: 6px;
	}

	.bnr-nav.pc {
		display: none;
	}

	.bnr-nav.sp {
		display: block;
	}

	#main {
		padding-top: 64px;
		margin-left: 0;
	}

	.main-content {
		padding: 0 3.5%;
	
	}

	.wrap,
	.wrap-s {
		width: 100%;
		max-width: 100%;
		padding: 3.5% 0;
	}

	.main-img{
		margin-top: 3.5%;
	}

	.main-img img {
		margin: 0;
	}

	.idimg2 {
		width: 50%;
		margin: 0 25%;
	}
	.lum-lightbox-inner img {
		max-width: 90vw !important; 
		max-height: 85vh !important; 
	  }
}

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

	/*==================================================
cmn
==================================================*/
	html {
		overflow: auto;
		font-size: 45%;
	}

	body {
		font-size: 13px;
		letter-spacing: 0;
		line-height: 1.8em;
	}

	.button-toggle {
		position: absolute;
		top: 15px;
	}

	.site-header h1 {
		padding: 5px 2.5%;
	}

	.site-header h1 img {
		height: 40px;
	}

	.btn01 a {
		width: 100%;
		margin: 30px 0;
	}

	.btn03 a {
		width: 100%;
		margin: 30px 0 0 0;
	}

	#side-box .navi-box {
		top: 50px;
	}

	.reg-btn li a {

		width: 100%;
		margin: 30px 0;

	}
	h2.tit01::before {
		width: 24px;
		height: 24px;
		background-size: contain;
		top: 4px;
	}

	/*==================================================
foot
==================================================*/
	.site-foot {
		margin-top: 30px;
	}

	footer address {
		line-height: 1.4em;
	}

	.overflow-wrap {
		overflow-x: scroll;
		-webkit-overflow-scrolling: touch;
	}

	footer .address-list {
		display: block;
		width: 100%;
		text-align: center;
	}

	/*==================================================
content
==================================================*/
	#main {
		padding-top: 50px;
	}

	section {
		padding: 0;
	}

	.txt-center {
		text-align: center;
	}

	/*==================================================
index
==================================================*/
	.main-img {}

	.news-list {
		min-height: 240px;
		width: 100%;
	}


	.news-list li {
		padding: 10px 0;
	}

	/*.news-list li:last-child {
	border: none;
}*/
	.news-list li .data {
		float: none;
		width: 100%;
		margin: 0 0 0.2em;
	}

	.news-list li .data-en {
		float: none;
		width: 100%;
		margin: 0 0 0.2em;
	}

	.bnr-box {
		margin: 20px 0;
	}

	/*==================================================
page
==================================================*/



.main-sub .tit {
		padding: 15px 0;
	}

	.main-sub .tit .wrap {
		padding: 0 3.5%;
	}

	.main-sub .tit h2 {
		line-height: 0;
	}

	.main-sub .page-tit {
		padding: 30px 0;
	}

	.main-sub .page-tit h3 {
		font-size: 20px;
		letter-spacing: 1px;
	}

	.table-style01 th,
	.table-style01 td {
		padding: 1.5em 10px;
	}

	.program-container {
		display: block;
	}

	.program-img {
		margin-left: 0;
		width: 100%;
		text-align: center;
	}


	.program-text {
		width: 100%;
	}

	
	/*==================================================
greeting
==================================================*/

	.profile {
		text-align: center;
	}

	.profile img {
		margin-right: 0;
	}

	.table-organizers02 td {
		min-width: 150px;
	}

	.flex-btn {
		margin: 1em 0;
		display: block;
		justify-content: normal;
		flex-wrap: nowrap;
	}

	.flex-btn li:first-child {
		margin-bottom: 1em;
	}

	.flex-btn li a {
		width: 100%;
		display: block;
		text-align: center;
	}

		.table-abstract th{
		display: block;
		width: 100%;
		text-align: center;

	}
		.table-abstract td{
		display: block;
		width: 100%;
		text-align: center;

	}
		/*==================================================
foods
==================================================*/

.list-foods{
	display: block;
}
.list-foods li{
	margin-right: 0em;
	margin-bottom: 4%;
}

.list-foods li img{
	max-width: 100%;
	height: auto;
	border-radius: 10px;
}



}

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

	.program-img {
		margin: 1%;
		width: 100%;
		height: auto;
	}

	.idimg2 {
		width: 80%;
		margin: 0 10%;
	}




}
.prodate {
	font-size: 90%;
	margin-left: 1em;
	border-radius: 2px;
	padding: 0 0.5em;
	font-weight: normal;
	color: #333;
}
.jizen{
	background-color: green;
	color: #FFF;
	border-radius: 5px;
	padding: 0 0.5em;
	font-size: 90%;
	margin-left: 1em;
}
