@charset "utf-8";
/* CSS Document  2020 iot_bz_ss 2020.11.20*/



/*------------------------------------------------------------
base
-------------------------------------------------------------*/


html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, h7, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
}

body{
	font-family: 'M PLUS 1', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-style: normal;
	color:#333;
	font-size:18px;
}

@media
only screen and (max-width : 786px){
	body{
    font-size: 90%;
  }
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  font-size:18px;
  line-height:1.8em;}
@media
only screen and (max-width : 786px){
	html{
    font-size: 15px!important;
  }
}
 

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style:none;
}

table{
    border-collapse: collapse; 
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}

sup{
font-size: 65%;
vertical-align: top;
position: relative;
top: -0.1em;
}

.clearfix:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.clearboth{
	clear:both;
}

.inline_block {  
	display: inline-block;  
	*display: inline;  
	*zoom: 1;  
}

.sup{
	font-size: 75.5%;
vertical-align: top;
position: relative;
top: -0.1em;
}

.dnone{display: none;}

.overfh{
overflow: hidden;
}

/* 個別パーツ*/

img, canvas, iframe, video, svg  {
	max-width:100%;
	height: auto;
	vertical-align: middle;
	-ms-interpolation-mode: bicubic;
	border: 0;
    z-index: 2;
}


a img	{border: none;}



/*a,a:hover {
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	transition: 0.7s;
}*/

a img:hover {
	filter: alpha(opacity=70);
	-moz-opacity:0.70;
	opacity:0.70;
}

.border_non{
	border:none !important;}
	
.border_nonB{
	border-bottom:none!important;}

.border_box{
border: 1px solid #cccccc;
}

.border_box_bottom{
border-bottom: 1px solid #cccccc;
}

hr.border_box_bottom{
border-bottom: 1px solid #cccccc;
margin: 10px 0 ;
}

.text-shadow{
	text-shadow: 1px 1px 3px #000;
}

.box-shadow01 {
	-moz-box-shadow: 1px 1px 3px #000;
	-webkit-box-shadow: 1px 1px 3px #000;
	box-shadow: 1px 1px 3px #000;
}

.box-shadow02{/* 影内側*/
	-moz-box-shadow: inset 1px 1px 3px #000;
	-webkit-box-shadow: inset 1px 1px 3px #000;
	box-shadow: inset 1px 1px 3px #000;
}

.radius {
	border-radius: 8px; 
	-webkit-border-radius: 8px;
	-moz-border-radius: 8px; 
}

.transition {
	-webkit-transition: 1.5s;
	-moz-transition: 1.5s;
	-o-transition: 1.5s;
	transition: 1.5s;
}

.alpha {
	filter: alpha(opacity=25);
	-moz-opacity:0.25;
	opacity:0.25;
}

.bg-alpha {
	background-color:rgba(255,255,255,0.2);
}

.gradient {
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#ffffff', endColorstr = '#000000');
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr = '#ffffff', endColorstr = '#000000')";
	background-image: -moz-linear-gradient(top, #ffffff, #000000);
	background-image: -ms-linear-gradient(top, #ffffff, #000000);
	background-image: -o-linear-gradient(top, #ffffff, #000000);
	background-image: -webkit-gradient(linear, center top, center bottom, from(#ffffff), to(#000000));
	background-image: -webkit-linear-gradient(top, #ffffff, #000000);
	background-image: linear-gradient(top, #ffffff, #000000);
}

.leftbox{
	float:left;
}

.rightbox{
	float:right;
}


.nojustify{ text-align:left !important;}


/*---リンク色 ----*/
a:link {
    color: #352b5e;
    text-decoration: none;
}
a:visited {
    color: #352b5e;
    text-decoration: none;
}
a:hover {
    color: #352b5e;
    text-decoration: underline;
	
}


/* 点滅 */
.blinking{
	-webkit-animation:blink 1.5s ease-in-out infinite alternate;
    -moz-animation:blink 1.5s ease-in-out infinite alternate;
    animation:blink 1.5s ease-in-out infinite alternate;
}
/* .0% {opacity:1;} */

/* 幅 */
.w125{width:145px;}
.w70{width:70px;}
.w300{width:270px;}
.w500{width:500px!important;}
.w600{width:600px;}
.w650{width:650px;}
.w700{width:700px;}

.w50per{width:50%!important;}
.w47per{width:47%!important;}


/*------------------------------------------------------------
margin・・・周りのブロックからの距離
-------------------------------------------------------------*/

.m0{ margin: 0!important; }/*周りからのmarginを0に*/
.m0-t{ margin-top: 0!important; }/*上からのmarginを0に*/
.m0-r{ margin-right: 0!important; }/*右からのmarginを0に*/
.m0-b{ margin-bottom: 0!important; }/*下からのmarginを0に*/
.m0-l{ margin-left: 0!important; }/*左からのmarginを0に*/

.m5{ margin: 5px!important; }
.m5-t{ margin-top: 5px!important; }
.m5-r{ margin-right: 5px!important; }
.m5-b{ margin-bottom: 5px!important; }
.m5-l{ margin-left: 5px!important; }

.m10{ margin: 10px!important; }
.m10-t{ margin-top: 10px!important; }
.m10-r{ margin-right: 10px!important; }
.m10-b{ margin-bottom: 10px!important; }
.m10-l{ margin-left: 10px!important; }

.m15{ margin: 15px!important; }
.m15-t{ margin-top: 15px!important; }
.m15-r{ margin-right: 15px!important; }
.m15-b{ margin-bottom: 15px!important; }
.m15-l{ margin-left: 15px!important; }

.m20{ margin: 20px!important; }
.m20-t{ margin-top: 20px!important; }
.m20-r{ margin-right: 20px!important; }
.m20-b{ margin-bottom: 20px!important; }
.m20-l{ margin-left: 20px!important; }

.m25{ margin: 25px!important; }
.m25-t{ margin-top: 25px!important; }
.m25-r{ margin-right: 25px!important; }
.m25-b{ margin-bottom: 25px!important; }
.m25-l{ margin-left: 25px!important; }

.m30{ margin: 30px!important; }
.m30-t{ margin-top: 30px!important; }
.m30-r{ margin-right: 30px!important; }
.m30-b{ margin-bottom: 30px!important; }
.m30-l{ margin-left: 30px!important; }

.m35-b{ margin-bottom: 35px!important; }

.m40{ margin: 40px!important; }
.m40-t{ margin-top: 40px!important; }
.m40-r{ margin-right: 40px!important; }
.m40-b{ margin-bottom: 40px!important; }
.m40-l{ margin-left: 40px!important; }

.m45{ margin: 45px!important; }
.m45-t{ margin-top: 45px!important; }
.m45-r{ margin-right: 45px!important; }
.m45-b{ margin-bottom: 45px!important; }
.m45-l{ margin-left: 45px!important; }

.m50{ margin: 50px!important; }
.m50-t{ margin-top: 50px; }
.m50-r{ margin-right: 50px!important; }
.m50-b{ margin-bottom: 50px!important; }
.m50-l{ margin-left: 50px!important; }

.m60{ margin: 60px!important; }
.m60-t{ margin-top: 60px!important; }
.m60-r{ margin-right: 60px!important; }
.m60-b{ margin-bottom: 60px!important; }
.m60-l{ margin-left: 60px!important; }

.m70{ margin: 70px!important; }
.m70-t{ margin-top: 70px!important; }
.m70-r{ margin-right: 70px!important; }
.m70-b{ margin-bottom: 70px!important; }
.m70-l{ margin-left: 70px!important; }

.m80{ margin: 80px!important; }
.m80-t{ margin-top: 80px!important; }
.m80-r{ margin-right: 80px!important; }
.m80-b{ margin-bottom: 80px!important; }
.m80-l{ margin-left: 80px!important; }

.m90{ margin: 90px!important; }
.m90-t{ margin-top: 90px!important; }
.m90-r{ margin-right: 90px!important; }
.m90-b{ margin-bottom: 90px!important; }
.m90-l{ margin-left: 90px!important; }

.m100{ margin: 100px!important; }
.m100-t{ margin-top: 100px!important; }
.m100-r{ margin-right: 100px!important; }
.m100-b{ margin-bottom: 100px!important; }
.m100-l{ margin-left: 100px!important; }

.m120-t{ margin-top: 120px!important; }
.m130-t{ margin-top: 130px!important; }
.m140-t{ margin-top: 140px!important; }

.m150{ margin: 150px!important; }
.m150-t{ margin-top: 150px!important; }
.m150-r{ margin-right: 150px!important; }
.m150-b{ margin-bottom: 150px!important; }
.m150-l{ margin-left: 150px!important; }

.m250-b{ margin-bottom: 250px!important; }


/*------------------------------------------------------------
padding・・・周りのブロックからの距離（padding）
-------------------------------------------------------------*/

.p0{ padding: 0!important; }
.p0-t{ padding-top: 0!important; }
.p0-r{ padding-right: 0!important; }
.p0-b{ padding-bottom: 0!important; }
.p0-l{ padding-left: 0!important; }

.p5{ padding: 5px!important; }
.p5-t{ padding-top: 5px!important; }
.p5-r{ padding-right: 5px!important; }
.p5-b{ padding-bottom: 5px!important; }
.p5-l{ padding-left: 5px!important; }

.p10{ padding: 10px!important; }
.p10-t{ padding-top: 10px!important; }
.p10-r{ padding-right: 10px!important; }
.p10-b{ padding-bottom: 10px!important; }
.p10-l{ padding-left: 10px!important; }

.p15{ padding: 15px!important; }
.p15-t{ padding-top: 15px!important; }
.p15-r{ padding-right: 15px!important; }
.p15-b{ padding-bottom: 15px!important; }
.p15-l{ padding-left: 15px!important; }

.p20{ padding: 20px!important; }
.p20-t{ padding-top: 20px!important; }
.p20-r{ padding-right: 20px!important; }
.p20-b{ padding-bottom: 20px!important; }
.p20-l{ padding-left: 20px!important; }

.p25{ padding: 25px!important; }
.p25-t{ padding-top: 25px!important; }
.p25-r{ padding-right: 25px!important; }
.p25-b{ padding-bottom: 25px!important; }
.p25-l{ padding-left: 25px!important; }

.p30{ padding: 30px!important; }
.p30-t{ padding-top: 30px!important; }
.p30-r{ padding-right: 30px!important; }
.p30-b{ padding-bottom: 30px!important; }
.p30-l{ padding-left: 30px!important; }

.p40{ padding: 40px!important; }
.p40-t{ padding-top: 40px!important; }
.p40-r{ padding-right: 40px!important; }
.p40-b{ padding-bottom: 40px!important; }
.p40-l{ padding-left: 40px!important; }

.p50{ padding: 50px!important; }
.p50-t{ padding-top: 50px!important; }
.p50-r{ padding-right: 50px!important; }
.p50-b{ padding-bottom: 50px!important; }
.p50-l{ padding-left: 50px!important; }

.p60{ padding: 60px!important; }
.p60-t{ padding-top: 60px!important; }
.p60-r{ padding-right: 60px!important; }
.p60-b{ padding-bottom: 60px!important; }
.p60-l{ padding-left: 60px!important; }

.p70{ padding: 70px!important; }
.p70-t{ padding-top: 70px!important; }
.p70-r{ padding-right: 70px!important; }
.p70-b{ padding-bottom: 70px!important; }
.p70-l{ padding-left: 70px!important; }

.p80{ padding: 80px!important; }
.p80-t{ padding-top: 80px!important; }
.p80-r{ padding-right: 80px!important; }
.p80-b{ padding-bottom: 80px!important; }
.p80-l{ padding-left: 80px!important; }

.p90{ padding: 90px!important; }
.p90-t{ padding-top: 90px!important; }
.p90-r{ padding-right: 90px!important; }
.p90-b{ padding-bottom: 90px!important; }
.p90-l{ padding-left: 90px!important; }

.p100{ padding: 100px!important; }
.p100-t{ padding-top: 100px!important; }
.p100-r{ padding-right: 100px!important; }
.p100-b{ padding-bottom: 100px!important; }
.p100-l{ padding-left: 100px!important; }

.p250-b{ padding-bottom: 250px!important; }

/*------------------------------------------------------------
font-size・・・フォントサイズの設定
-------------------------------------------------------------*/

.b{ font-weight: bold!important; }/*太字*/
.normal{ font-weight: normal!important; }/*太字を解除*/

.big{ font-size: 1.2em!important; }
.big2{ font-size: 1.5em!important; }
.big3{ font-size: 1.8em!important; }
.small{ font-size: 0.8em!important; }

.f06em{ font-size: 0.6em!important; }
.f07em{ font-size: 0.7em!important; }
.f08em{ font-size: 0.8em!important; }
.f09em{ font-size: 0.9em!important; }
.f10em{ font-size: 1.0em!important; }
.f11em{ font-size: 1.1em!important; }
.f12em{ font-size: 1.2em!important; }
.f13em{ font-size: 1.3em!important; }
.f14em{ font-size: 1.4em!important; }
.f15em{ font-size: 1.5em; }
.f16em{ font-size: 1.6em; }
.f17em{ font-size: 1.7em; }
.f18em{ font-size: 1.8em; }
.f19em{ font-size: 1.9em; }
.f20em{ font-size: 2.0em; }
.f21em{ font-size: 2.1em; }
.f22em{ font-size: 2.2em; }
.f23em{ font-size: 2.3em; }
.f24em{ font-size: 2.4em; }

.lh12em{ line-height: 1.2em !important;}
.lh14em{ line-height: 1.4em!important;}
.lh16em{ line-height: 1.6em!important;}
.lh2em{ line-height: 2em!important;}

.fnt_green{ color:#5e8e25!important;}
.fnt_blue{ color:rgba(0,130,181,1)!important;}
.fnt_dblue{ color:rgba(2,103,143,1.00)!important;}
.fnt_pink{ color:#d81f64;}
.fnt_lpink{ color:rgba(192,14,83,0.3);}

.fnt_greenB{ color:#5e8e25; font-weight:bold;}
.fnt_blueB{ color:rgba(0,130,181,1);font-weight:bold;}
.fnt_pinkB{ color:#dd007f;font-weight:bold;}
.fnt-AI{ color: rgba(250,134,4,1.00)!important;}

.white{ color: #ffffff;}
.red{color:#d60a00 !important;}
.green{color:#006837;}
.white{color:#fff;}
.black{ color:#000!important;}
.gray{ color:#999;}
.brown{ color:#9B5A13!important;}

.dorenge{ color: #E7410B;}
.orenge{ color: #E7410B;}
.purple{ color: #9E6DAB;}
.dpurple{ color: #693584!important;}
.blue{ color: #008cc6;}
.dblue{ color: #352b5e;}
.white{color:#fff;}
.black{ color:#000!important;}
.gray{ color:#999 !important;;}
.dred{color:#B60046 !important;}

.fnt_kon{ color:rgba(0,44,125,1.00)!important;}

/*--背景色--*/
.bg_white{ background:#fff!important;}
.bg_blue{ background: rgba(41,171,226,1.00);}
.bg_orenge{ background:#ed6c00!important;}
.bg_blue{ background:  rgba(41,171,226,1.00);}
.bgc_red00{ background: #B31114;}

.bgc_red{ background: #dd007f;}
.bgc_blue{ background: #00a9e4!important;}
.bgc_green{ background:rgba(0,159,185,1.00)!important;}
.bgc_lgreen{ background:rgba(0,159,185,0.1);}
.bgc_lgreen_02{ background-color: rgba(146, 168, 36, 0.5);}
.bgc_orenge{background: rgba(244,159,1,1);}
.bgc_pink{ background: #E6003E!important;}
.bgc_lpink{ background: rgba(192,14,83,0.15);}
.bgc_dpink{ background: rgba(192,14,83,1.00)!important;}
.bgc_gray{ background: #cdcdcd!important;}
.bgc_lgray{ background: #eee;}
.bgc_purple{ background: rgba(105,53,132,1.00);}
.bgc_lpurple{ background: rgba(105,53,132,0.3);}
.bgc_beige{ background: rgba(241,222,194,1.00);}

.bgc_gold {
    background: #7d6014;
    background: -moz-linear-gradient(left, #7d6014 0%, #b28500 11%, #b28500 89%, #7d6014 100%);
    background: -webkit-linear-gradient(left, #7d6014 0%,#b28500 11%,#b28500 89%,#7d6014 100%);
    background: linear-gradient(to right, #7d6014 0%,#c5580f 11%,#a0592a 89%,#7d6014 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#7d6014', endColorstr='#7d6014',GradientType=1 );
}

.bgc_topgold {
    background: #e6b422;
    /* background: -moz-linear-gradient(left, #7d6014 0%, #b28500 11%, #b28500 89%, #7d6014 100%); */
    /* background: -webkit-linear-gradient(left, #7d6014 0%,#b28500 11%,#b28500 89%,#7d6014 100%); */
    background: linear-gradient(to right, #7d6014 0%,#be951b 11%,#e6b422 89%,#7d6014 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#7d6014', endColorstr='#7d6014',GradientType=1 );
    /* background: #e6b422; */
    /* background: -moz-linear-gradient(0deg, rgba(113,65,5,1) 0%, rgba(144,68,5,1) 28%, rgba(196,73,4,1) 100%); */
    /* background: -webkit-linear-gradient(0deg, rgba(113,65,5,1) 0%, rgba(144,68,5,1) 28%, rgba(196,73,4,1) 100%); */
    /* background: linear-gradient(0deg, #7d6014 0%, #a98519 28%, #e6b422 100%); */
    /* filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#714105",endColorstr="#c44904",GradientType=1); */
    }





.bgc_lorenge{
background-color: rgba(246,214,154,0.7);
}
.bgc_lblue{ background: rgba(0,130,181,0.5);}
.bgc_dblue{ background: rgba(0,44,125,1.00)!important;}
.bgc_lyellow{ background: rgba(253,249,199,1.00) !important}

.bgc_manegi{ background: #003592!important;}
.bgc_kokyaku{ background: #84488F!important;}
.bgc_shakai{ background: #00A93A!important;}
.bgc_tolance{ background: #C80053!important;}
.bgc_newno{ background: #BB8600!important;}
.bgc_sasutena{ background: #009E9F!important;}
.bgc_ss_com_mocashi01{ background: #009E9F;}
.bgc_ITsho {
    background: #A0A0A0;
    background: -moz-linear-gradient(left, #717271 0%, #A0A0A0 11%, #A0A0A0 89%, #717271 100%);
    background: -webkit-linear-gradient(left, #717271 0%,#A0A0A0 11%,#A0A0A0 89%,#717271 100%);
    background: linear-gradient(to right, #717271 0%,#A0A0A0 11%,#A0A0A00 89%,#717271 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#717271', endColorstr='#717271',GradientType=1 );
}
.bgc_ITsyo {
    background-color: #C17C62 !important;
}

.bgc_thinnavy { background: #352b5e1c !important;}
.bgc_navy {
    background: #352b5e !important;
}
.bgc_dgreen {
    background: #0c6451 !important;
}

.bgc_ma {
    background: #83128f !important;
}
.bgc_it {
    background: #13b639 !important;
}

.bgc_sy {
    background: #ff9100 !important;
}

.bgc_ko {
    background: #0b84b7 !important;
}

.bgc_to {
    background: #a71139 !important;
}

.bgc_op {
    background: #c8930a !important;
}

.bgc_sa  {
    background: rgb(20, 175, 162) !important;
}

.lineh{line-height:1.3em;}

.pink_line{
background: linear-gradient(transparent 60%, rgba(255,255,102,0.6) 60%);
font-weight: bold;}


.bgc_gra_green {
    background: linear-gradient(90deg, #412fa8 0%, #008cc6 100%);
}
.bgc_gra_blue {
    background: linear-gradient(90deg, #412fa8 0%, #009e83 100%);
}
.bgc_gra_pink {
    background: linear-gradient(90deg, #412fa8 0%, #d81f64 100%);
}


/*------------------------------------------------------------
align・・・文字の横位置
-------------------------------------------------------------*/

.al-c{ text-align: center!important; }/*中央寄せ*/
.al-r{ text-align: right!important; }/*右寄せ*/
.al-l{ text-align: left !important; }/*左寄せ*/

/* Rules for sizing the icon. */
.material-icons.md-14 { font-size: 14px; }
.material-icons.md-18 { font-size: 18px; }
.material-icons.md-24 { font-size: 24px; }
.material-icons.md-36 { font-size: 36px; }
.material-icons.md-48 { font-size: 48px; }

/*flex*/
.flex-container{
display: -moz-box;
display: -ms-box;
display: -webkit-flexbox;
display: -moz-flexbox;
display: -ms-flexbox;
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: flex;
-webkit-box-lines: multiple;
-moz-box-lines: multiple;
-webkit-flex-wrap: wrap;
-moz-flex-wrap: wrap;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
flex-direction: row;            /*横並び・左から右（デフォルト）*/
}

.sp-bt { justify-content: space-between;}

.flexbox-vertical-center {
    display: flex; /* 子要素をflexboxで揃える */
    flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center;  /* 子要素をflexboxにより中央に配置する */
}

.flexbox-end-end {
 display: flex;
 align-items: flex-end;
 justify-content: flex-end;
}

.flex-2com,
.flex-3com{
display: flex;
justify-content: space-between;
}

.flex-2com div{
width: calc(96% / 2);
}

.flex-2com-1com{
display: flex;
justify-content: space-between;
}
.flex-2com-1com .flex-2com-1com--2com{
width: 66%;
}

.flex-2com-1com .flex-2com-1com--1com{
width: calc(96% / 3);
}

.flex-3com .flex-3com_inner{
width: calc(95% / 3);
}



.flex-4 {
    width: calc(100% / 4);
}

.flex-3 {
    width: calc(100% / 3);
}

.flex-2com {
    width: calc(100% / 2);
}

.flex_2 {
    width: calc(100% / 2);
}

@media
only screen and (max-width : 768px){
    .flex_2 {
        width: 100%;
    }
}


.z-index10{
    z-index: 100;
}

.flex {
    display: flex;
    gap: 0 2%;
}

.flex-center {
    display: flex;
    justify-content: center;
}

.flex-column {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}

.fd-c {
flex-direction: column;
}

.nowrap {
    white-space: nowrap;
}


/*--注釈--*/
.note{ font-size:0.8em; padding-left:1em; text-indent:-1em; line-height: 1.3em;}

/* ------ アンカーリンクの調整------ */
.anchor{
  display: block;
   margin-top:-100px;
   padding-top:100px;
  }
  
.secreen_sp {display:none;}
@media
only screen and (max-width : 786px){
	.secreen_sp {display: block;}
}


.is-pc {
    display:  block !important;
}

.is-sp {
    display: none !important;
}

.is-intb {
    display:  block !important;
}


@media
only screen and (max-width : 768px){
    .is-pc {
        display:  none !important;
    }
    
    .is-sp {
        display: block !important;
    }
}

@media
only screen and (max-width : 450px){
    .is-intb {
        display:  none !important;
    }
}


/* --- wrapper --- */

#wrapper{
	width:100%;
	z-index:0;
	position:relative;
}

#top{display:block !important;}


#container{
	width: 100% !important;
	position:relative;
	padding:0!important;
	margin:0!important;
    z-index: 1;
    padding-top: 100px;
    margin-top: -100px;
}


h2{
	font-size:1.6em ;
	font-weight:bold;
	margin-bottom:30px ;
	text-align:left;
}

.head_text {
	position: relative;
	padding-top: 5px;
    text-align: center;
    left: 50%;
    right: 50%;
    width: max-content;
    transform: translate(-50%, -50%);
}

.head_text span {
	position: relative;
	z-index: 1;
}

/* .head_text::before {
	content: attr(data-en);
	position: absolute;
	top: -20px;
	left: 0;
	color: rgba(0,159,185,0.3);
	font-size: 20px;
	font-weight:bold;
	font-style: italic;
} */


h2.line_before span {
	display: flex;
	align-items: center;
	color: rgba(108,10,110,0.8);
	font-size: 18px;
	text-transform: uppercase;
}

h2.line_before span::before {
	content: '';
	display: inline-block;
	margin-right: 20px;
	width: 30px;
	height: 1px;
	background-color: rgba(108,10,110,0.8);
}

h2 span.sab-title{
font-size: 0.6em;
line-height: 1.5;
display: block;
color: rgba(231,65,11,0.5);
}

h2 span.ss{
color: rgba(111,56,133,0.7);
}

h3{
    font-weight: bold;
	margin: 0px auto 20px auto;
    font-size: 1.3em;
}

h3.bk_ss_box{
/* background: rgba(192,14,83,1.00); */
color: #ffffff;
padding: 8px 15px;
}
h3.bk_prog_box{
background: #352b5e;
color: #fff;
padding: 8px 15px;
}

.bottom-border{
padding-bottom: 10px;
line-height: 1.6em;
}

.bottom-border::after {
    content: '';
    display: block;
    width: 40px;
    height: 2px;
    background-color: rgba(108,10,110,0.8);
}


.head-border {
    position: relative;
    display: inline-block;
    padding: 0 55px;
}

.head-border:before,
.head-border:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 50px;
    height: 1px;
    background-color: #666;
}

.head-border:before {
    left: 0;
}

.head-border:after {
    right: 0;
}

.head-border02{
    display: flex;
    align-items: center;
    text-transform: uppercase;
}

.head-border02::before {
    content: '';
    display: inline-block;
    margin-right: 10px;
    width: 8px;
    height: 30px;
    background-color: #d81f64;
}

.head-border02_ss:before{
 background-color: rgba(192,14,83,1.00)!important;
}

.head-border03{
    display: flex;
    align-items: center;
    text-transform: uppercase;
}

.head-border03::before {
    content: '';
    display: inline-block;
    margin-right: 10px;
    width: 20px;
    height: 2px;
    background-color: rgba(108,10,110,0.8);
}

	
h4{	font-size:1em;
	font-weight:bold;
	margin-bottom:0.5em;
	text-align:left;
	}

/* @media
only screen and (max-width : 786px){
	h2{ margin-bottom:20px!important;}
} */

.style01{
	font-weight:bold;
	border-bottom:2px solid #008C22;
	padding-bottom:0.3em;
}

.style02{
	font-weight:bold;
	color:#008C8C;
	border-bottom:2px solid #008C8C;
	padding:0 0.8em 0.3em 0.8em ;
}

.style02a{
	font-weight:bold;
	color:#008C8C;
	font-size:1.5em;
	font-weight:bold;
	text-align:center;
	margin-bottom:0.2em;
}

.style02b{
	font-weight:bold;
	color:#fff;
	font-size:1em;
	text-align:center;
	line-height:2em;
	height:2em;
	background-color:#0079AF;
		border-radius: 20px; 
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	padding:0.2em 1em;
}


.style03{
	font-weight:bold;
	color:#1B99C1;
	border-bottom:2px solid #1B99C1;
	padding:0 0.8em 0.3em 0.8em ;
}

.style04{
	font-weight:bold;
	color:#333333;
	border-bottom:2px solid #333333;
	padding:0 0.8em 0.3em 0.8em ;
}
	
.contents{
	width:95%;
    max-width: 1280px;
	margin:0 auto;
	padding:70px 0;
    z-index: 10;
    }

 .contents_1000{
        width: 1000px;;
        margin:0 auto;
        padding:70px 0;
        z-index: 10;
        }
    
.contents_800{
	width:800px;
}

/* .contents_1000{
	width:1000px;
} */

.contents_1100{
	width:1100px;
}

.contents_1200{
	width:  1200px;
}
    
	
@media
only screen and (max-width : 786px){
	.contents{ width:95% !important;
        /* padding:70px 0 !important; */
    }
    .contents_800,
    .contents_1000,
    .contents_1100,
    .contents_1200{
	width:90%;
}
}

	

#header{
	width:100%;
	margin:0;
	overflow:hidden;
	z-index:999;
	background-color:000;
	opacity:0.8;
	position:static !important;
}



#header .head_in{
	width:1100px;
	margin:0 auto;
	height:55px;
	overflow:hidden;
   display: flex; /* 子要素をflexboxで揃える */
    flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */}

#header .head_in .logobox{
	width:256px;
	padding:10px 100px 5px 7px;
	margin:0;
}
@media
only screen and (min-width : 787px){
.screen_sp{ display:none!important;}
}

@media
only screen and (max-width : 786px){
	.screen_pc{ display:none;}
	
}
	
@media
only screen and (max-width : 786px){
	#header .head_in{
	width:100%;
	padding:10px;
	height:auto;
	text-align:center;
	}
#header .head_in .logobox{ float:none; width: max-height:30px; text-align:center; margin:0 auto;}
}
	
#header .head_in h1{
	float:right;
	text-align: right;
	line-height:55px;
	font-size:0.9em;
	font-weight:bold;
	margin-right:1em;}
@media
only screen and (max-width : 786px){
	#header .head_in h1{ float:none; line-height:1.2em; text-align:center; margin-right:0; font-size:0.9em;}
}
	
	
#header .head_in h1 a{
	color:#000;
	font-weight:bold;}
	
#header .head_in h1 a:hover{
	color:#999;
	font-weight:bold;
	text-decoration:none;}

	
#header .head_in .orderbox{
	float:right;
	width:160px;
	height:48px;
	line-height:48px;
	text-align:center;
	color:#FFF;
	font-weight:bold;
	font-size:0.9em;
	vertical-align:middle;
	display:block;
}
	
#header .head_in .orderbox a{
	color:#fff;
	text-decoration:none;
	background-color:#BF0C20;
		display:block;
	}
	
#header .head_in .orderbox a:hover{
	background-color:#D53B32;
	display:block;
}

#header .head_in .orderbox img{
	margin-bottom:7px;}


#gnavi  {
	width:700px;
	background-color:#000;
}
#gnavi .menu {
	margin:0px auto;;
display: flex;
justify-content: space-between;
height:55px;
}

#gnavi .menu ul{
	padding:0;
	width:100%;
	
}
#gnavi .menu li {
	font-size:0.7em;
padding: 15px 0;
text-align: center;
transition: all .3s ease-in-out;
width:25%;
position: relative;
height:55px;
display:flex;
 flex-direction: column;
 color:#fff;
}


#gnavi .menu li:hover {
background: #6CC1C6;
color:#fff;
}
#gnavi .menu li a {
color: #666;
font-weight:bold;
border-left: solid 1px #666;
display:block;
position: relative;
z-index: 1;
}

#gnavi .menu li:last-child a{
	color: #666;
font-weight:bold;

display:block;
position: relative;
z-index: 1;
border-right: solid 1px #666;	
}

#gnavi .menu a:hover,
#gnavi .menu li:last-child a:hover {
color: #fff;
text-decoration:none;
display:block;
}


.top_inner{ margin: 0 auto; text-align: center;position: relative; }
.top_inner blockquote{
width: 500px;
/* margin: 0 auto 0 0; */
}

.top_inner p{
font-size: 0.8em;
text-align: left;
line-height: 1.5em;
margin: 20px auto 0 auto;
width: 40%;
position: absolute;
bottom: 50px;
}

.top_inner h2{text-align: center; margin-bottom: 0;}
@media
only screen and (max-width : 786px){
.top_inner{display: block;}
/* .top_inner blockquote{
width: auto;
margin: 0 auto;
margin-left: auto;
} */
}
@media
only screen and (max-width : 450px){
    .top_inner{display: block;}
    .top_inner blockquote{
    width: auto;
    margin: 0 auto;
    }
}

#top_main .contents{
padding: 50px 0;
width: 1080px;
}

@media
only screen and (max-width : 786px){
#top_main .contents{
padding: 30px 0 10px 0!important;
}
}

#top_main .contents_ss{
padding: 40px 0 50px 0;
}


#top_main .days_box{
display: flex;
align-content: center;
justify-content: space-between;
width: 800px;
margin: 0 auto 30px auto;
}

#top_main .days_box_w700{
width: 700px;
}

#top_main .top_innar .days_box_sp{
text-align: center;
margin: 0 auto;

}

#top_main .days_box figure{
margin: 0 10px;
}

#top_main .top_rightbox{
   width : 320px;
}


/* 
@media
only screen and (max-width : 450px){
#top_main .top_rightbox{
   width : 90%;
   margin:-100px auto 0 auto;
}
} */

.top_slider .slick-slide {
  width: 300px;
  height: 315px;
  margin: 0 40px;
  position: relative;
  overflow: hidden;
}
.top_slider .slick-slide img {
  display: block;
  margin: 0 auto;
/*  width: 100%;
  height: 100%;
  object-fit: cover;*/
}
.top_slider .slick-slide a img:hover{
	filter: alpha(opacity=90);
	-moz-opacity:0.90;
	opacity:0.90;
}


.slider-2.slick-arrow {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: #fff;
  cursor: pointer;
  border: none;
  outline: none;
  font-size: 0;
  position: absolute;
  top: 180px;
  z-index: 1;
  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));
}
.slider-2 .slick-arrow::before {
  content: '';
  display: block;
  width: 12px;
  height: 12px;
  border: 1px solid #09000d;
  border-width: 3px 3px 0 0;
  position: absolute;
  top: 24px;
  transform: rotate(45deg);
}
.slider-2 .slick-next {
  right: 0;
}
.slider-2 .slick-prev {
  left: 0;
}
.slider-2 .slick-next::before {
  left: 20px;
}
.slider-2 .slick-prev::before {
  border-width: 0 0 3px 3px;
  right: 22px;
}
.dots-2 .slick-dots {
  text-align: center;
  bottom: 0;
}

/* .slick-dots {
  bottom: 0!important;
} */

.slick-prev {
    left: 0px!important;
    z-index: 100;
}

.slick-next {
    right: 0px!important;
    z-index: 100;
}

.dots-2 .slick-dots li {
  display: inline-block;
}

.dots-2 .slick-dots button {
  display: block;
  width: 10px;
  height: 10px;
  margin: 6px;
  font-size: 0;
  padding: 0;
  border: 0;
  outline: none;
  cursor: pointer;
  background: #bcbcbc;
  border-radius: 50%;
}
.top_slider .slick-dots .slick-active button:before{
  opacity:1;
  color: #ffffff;
}

.top_slider .slick-dots li button:before{
     opacity:.5;
  color: #ffffff;
}



@media
only screen and (max-width : 786px){
	#top_main { text-align: center; margin-top: 65px;}
	.top_inner{ padding:0px; }
	.top_innar h2{ margin: 0 auto 20px auto !important;}
	.top_innar .arrow,#top_main .innar .main_img{ display: none;}
#top_main .days_box{ width: auto; flex-wrap: wrap; margin: 0 auto 15px auto;}
#top_main .days_box figure{ width: calc( 90% / 2 );margin: 5px;}
#top_main .days_box figure:first-child{ width: 100%;}
#top_main .days_box_w700 figure:first-child{ width: calc( 90% / 2 );}
#top_main .days_box_w700{ width: 100%;}

}


@media
only screen and (max-width : 786px){
	#top_main .contents h1{ margin:0 auto;}
	#top_main .contents h1 img{ width:100%;}
}




/* --- 背景 --- */
.bk_bgimg {
    background: url("../img/bk_img.jpg") no-repeat center center;
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
    position: relative;
    z-index: 1;
}
/* .bk_bgimg:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: rgba(0,159,185,0.7);
} */

.bk_bgimg_ss {
    background: url("../img/bk_img.jpg") no-repeat center center;
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
    position: relative;
    z-index: 1;
}
.bk_bgimg_ss:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    /* background: rgb(134 208 196 / 50%); */
    background: rgb(175 153 218 / 50%);
}




.bk_bgimg_top {
    background: url("../img/bk_img.jpg") no-repeat top center ,#352b5e;
    z-index: 1;
    background-size: cover;
}

.bk_bgimg_top_ss {
    background: url("../img/bk_com_img.jpg") no-repeat top center,#352b5e ;
    z-index: 1;
}

@media
only screen and (max-width : 786px){
.bk_bgimg_top {
    background: url("../img/bk_img.jpg") no-repeat center top;
background-size: cover;
}

.bk_bgimg_top_ss {
    background: url("../img/bk_img.jpg") no-repeat top center;
background-size: cover;
}
}



#point .contents{ 
width:860px;
z-index: 100;
position: relative;
}

.point_box {
  padding: 10px 30px 30px 30px;
 background: rgba(255,255,255,0.7);
 margin-bottom: 15px;
 position: relative;
 margin: 50px auto;
}

.point_box:before{
		width: calc(100% - 20px);
		height: 0;
		display: block;
		position: absolute;
		left: 0;
		content: "";
	}
.point_box:before{
		border-bottom: solid 20px rgba(255,255,255,0.7);
		border-right: solid 20px transparent;
		bottom: 100%;
	}

.point_box dl{
display: flex;
margin: 0;
padding: 0;
width: 100%;
}

.point_box dl dt{
 display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 60px;
  font-size: 2.5em;
  color: #E7410B;
  font-weight: bold;
  margin-top: -20px;
  margin-right: 20px;
}

.point_box_ss dl dt{
color: #693584;
}




.point_box dl dt p{
font-size: 0.3em;
}

.point_box dl dd{
width: calc(100% - 80px);
}

.point_box dl dd p{
font-weight: bold;
}

.point_box dl dd p.text_medachi{
font-size: 1.4em;
  display: flex;
  align-items: center; /* 垂直中心 */
}
.point_box dl dd p.text_medachi:before {
  border-top: 1px solid;
  content: "";
 width: 2em; /* 線の長さ */
 margin-right: 0.5em;
}

.text_medachi:after {
  margin-right: 2em;
}

.point_box dl dd .kichou_box{
width: auto!important;
}

.point_box dl dd .kichou_box p{
font-size: 0.8em;
line-height: 1.5em;
text-align: right;
}

.point_box dl dd .kichou_box figure{

width: 150px;
margin-left: 15px;
}

.kichou_box_in{
  display:flex;/* ここは子要素divの上下左右を決めるための指定*/
  align-items: flex-end; /* 垂直方向の指定*/
  justify-content: flex-end;
  float: right;
  width: 100%!important;
}



@media
only screen and (max-width : 786px){
.point_box {
  padding: 15px 30px 15px 15px;
  }
.point_box dl{ display: block;}
.point_box dl dt{ margin-bottom: 10px;}
.point_box dl dd {
    width: 100%; overflow: hidden;
}
.point_box dl dd .flex-2com{ display: block;}
.point_box dl dd .kichou_box.first_box,
.point_box dl dd .kichou_box{ width: 100%; margin-top: 10px;}
}

#gaiyou .contents{ 
z-index: 100;
position: relative;
}


#gaiyou .copy{ margin-bottom:30px; text-align:center;}

#gaiyou dl{ line-height: 1.5em;}

#gaiyou dl dt{ 
width:20%;; 
text-align:center; 
color:#fff; 
background: #352b5e;
padding:0.2em 0;
margin-bottom:0.5em;
font-weight: bold;
}

#gaiyou dl dd{
	margin-left:0.5em;
font-weight:bold;
margin-bottom:0.5em;
background: #fff;
border-bottom: 1px solid rgba(199,199,199,0.9);
width: 75%;
padding: 0.2em 10px;
}

table.order_gaiyou{
width: 100%;
}

table.order_gaiyou th{
font-weight: bold;
}

table.order_gaiyou td{
text-align: center;
}

table.order_gaiyou td,
table.order_gaiyou th{
padding: 5px 10px;
font-size: 0.9em;
}

table.order_gaiyou td,
table.order_gaiyou th{
border-bottom: 1px solid rgba(121,121,121,1.00);
}
table.order_gaiyou td:last-child {
white-space: nowrap;
}

table.order_gaiyou tr:nth-child(1) td{
font-weight: bold;
}

.icon_code{
	padding:3px 8px;
	background-color:#C90306;
	color:#fff;
	font-weight:bold;
	line-height:1.3em;
	display: inline-block;
	text-align:center;
}
/* .code_time{
    font-weight: bold;
    background: #EAB284;
    color: #fff;
    padding: 0.2em 0.5em;
    display: inline-block;
    font-size: 0.8em;
    line-height: 1em;
    margin-left: 1em;
} */
.code10 {
    background-color: rgba(0,159,185,1.00);
    color: #fff;
    display: inline-block;
    border-radius: 4px;
    padding: 5px 0.5em;
    margin-bottom: 2px;
    line-height: 1;
    border: transparent 1px solid;
    font-size: 0.75em;
    text-align: center;
    font-weight: bold;
}

#gaiyou dl dd ul.dot li{
margin-right: 1em;
font-weight: bold;
margin-left: 10px;
}

.gaiyou_img{
position: absolute;
right: -30px;
bottom: 35px;
width: 300px;
}
.gaiyou_img img{
border: 1px solid rgba(199,198,198,1.00);
}

.gaiyou_img figcaption{
font-size: 0.8em;
text-align: center;
}

@media
only screen and (max-width : 786px){
#gaiyou dl dt{ 
width: 100%;
margin-bottom: 0;
float:none;
	}
#gaiyou dl dd{
			margin-left:0;
			padding:10px;
			height:auto;
			font-weight: normal;
            width: 100%;}
            
#gaiyou  dl {
margin-bottom: 0;

}
}
#gaiyou ul li{
	padding-left: 1.3em;
text-indent: -1.3em;
}

#gaiyou ul li::before {
    content: "●";
    margin-right: 0.3em;
    color: #6195C6;
    display: inline;
}

/*トップページプログラム--*/

#top_program .contents{
position: relative;
z-index: 100;
}

@media
only screen and (max-width : 786px){
#top_program .contents .m50-b{
    margin-bottom: 10px!important; 
}
}

#top_program h2{
color: #ffffff;
}

#top_program .head_text::before,
#contact .head_text::before {
    content: attr(data-en);
    position: absolute;
    top: -20px;
    left: 0;
    color: rgba(219,245,250,0.8);
    font-size: 16px;
    font-weight: bold;
    font-style: italic;
}

#top_program .flex-3com_inner{
background: #ffffffdb;
box-shadow: 0 3px 6px 0 rgb(0 0 0 / 16%);
position: relative;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
}

#top_program a{
color: #333;
text-decoration: none;
overflow: hidden;
}

#top_program .flex-3com_inner .btn_detail{
    margin-top: auto;
    margin-bottom: 10px;
}

#top_program .flex-3com_inner .btn_detail a {
    line-height: 1.2em;
    font-size: 0.7em;
    text-align: center;
    font-weight: normal;
}


.top_program_com__link::before {
content: "";
position: absolute;
top: -1px;
left: -1px;
right: -1px;
bottom: -1px;
}


#top_program .flex-3com_inner h5{
display: flex;
align-items: center;
flex-direction: column;
justify-content: center;
padding: 10px;
font-weight: bold;
line-height: 1.2em;
text-align: center;
color: #FFFFFF;
min-height: 2.5em;
}

#top_program .flex-3com_inner h5 span{
display: block;
font-size: 0.8em;
font-weight: bold;
}

#top_program .flex-3com_inner .flex-3com_inner_in{
padding: 15px;
}

#top_program .flex-3com_inner ul.dot li{
text-indent: -1.2em;
padding-left: 1em;
font-size: 0.9em;
line-height: 1.4em;
margin-bottom: 10px;
font-weight: bold;
}

#top_program .flex-3com_inner ul.dot li:before{
/* color: rgba(0,159,185,0.5); */
color: rgba(192,14,83,0.3);
}

#top_program .flex-3com_inner ul.day2_b li:before{
color: rgba(0,44,125,0.3);
}
#top_program .flex-3com_inner ul.ss_b li:before{

color: rgba(0,159,185,0.5);
}

@media
only screen and (max-width : 786px){
#top_program .flex-3com{ display: block;}
#top_program .flex-3com_inner { width: auto; margin-bottom: 20px;}
}



#program .col4 .program_com {
width: 100%;
}

#program .col3 .colum{
width: calc(96% / 3);
display: block;
}

#program .col4 .colum{
width: calc(96% / 4);
display: block;
}

#program .royouiki_box{
padding-top: 30px;
position: relative;
}

.royouiki_box h5{
position: absolute;
top: 0;
right: 0;
width: 49.5%;
text-align: center;
font-weight: bold;
background: rgba(59,92,144,1.00);
color: #ffffff;
border-radius: 5px;
}

@media
only screen and (max-width : 786px){
.royouiki_box h5{
position: static;
top: auto;
right: auto;
width: 100%;
margin-top: 30px;
}
}

.royouiki_box .program_com{
display: flex;
    flex-wrap: wrap;
    flex-direction: column;
}

#program .royouiki_box .colum{
display: flex;
}

.royouiki_box .program_com p.copy{
padding: 15px 15px 15px 15px;
}

.royouiki_box .program_com h4{
margin: 0px 15px 5px 15px!important;
}

.royouiki_box .program_com ul{
margin: 0px 15px 15px 15px;
}

.royouiki_box .program_com ul li{
font-size: 0.8em;
line-height: 1.5em;
}

.royouiki_box .program_com .btn_detail {
    margin-top: auto;
    font-size: 0.7em;
    margin-bottom: 10px;
}

@media
only screen and (max-width : 786px){
#program .col3 .colum,
#program .col4 .colum{
width: 94%;
display: block;
}
}

.code03 {
    background-color:#D80003;
    display: inline-block;
    padding: 5px 7px;
    line-height: 1;
    border: transparent 1px solid;
	width:10em;
	text-align:center;
		border-radius:5px;
		font-size:0.9em;
		font-weight:bold;
		color:#fff;
}

#program .flex-container{
justify-content: space-between;
}

 #program .program_com{
 padding: 10px 0 10px 0;
 width: calc(98%/2);
 margin-top:10px;
 position: relative;
 }
  #program .program_com_100p{
 width: 100%;
 }
 
  #program .program_com .innar{
  	padding: 10px 20px 10px 20px;
  }
 
#program .program_com .icon_se {
    display: block;
    padding: 8px 0 8px 20px;
    font-size: 0.8em;
    color: #fff;
    border-radius: 0 5px 5px 0;
    font-weight: bold;
    vertical-align: middle;
    width: auto;
    margin-right: 20px;
}

#program .program_com .icon_se_flex {
    padding: 8px 0 8px 20px;
    font-size: 0.8em;
    color: #fff;
    border-radius: 0 5px 5px 0;
    font-weight: bold;
    width: auto;
    margin-right: 20px;
    display: flex;
    align-items: center;
}

#program .program_com .icon_se_flex p{
font-weight: bold;
margin-right: 0.5em;
font-size: 1em;
}

#program .program_com .icon_se_title {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 3px 10px 3px 10px;
    font-size: 0.8em;
    color: #fff;
    border-radius: 0 5px 5px 0;
    width: calc(95% - 20px);
    font-weight: bold;
    line-height: 1.1em;
    height: 50px;
    vertical-align: middle;
    white-space: normal;
    text-align: left;
}

#program .program_com .icon_se_title .small{
	font-size: 0.75em!important;
}
  
 #program .program_com .icon_se_w90{
    width: calc(96% - 10px);
    }
    
#program .program_com .icon_se_w90_auto{
    width: 90%;
    min-height: 2em;
    }
    
@media
only screen and (max-width : 786px){
#program .program_com{
width: 100%;
  }
#program .program_com .icon_se,
#program .program_com .icon_se_title{
    width: auto;
}
}
  
   #program .program_com .title{
  display: block;
  padding: 3px 10px;
  font-size: 0.8em;
  color: #333;
  border-radius: 5px;
  font-weight: bold;
  margin:15px 20px 0 20px;
  }
  
#program .program_com .icon_free{
display: inline-block;
  padding: 3px 5px;
  font-size: 0.95em;
  color: #666;
  margin-left: 0.8em;
  background: #fff;
  line-height: 1em;
}

#program .program_com .icon_free2{
display: inline-block;
  padding: 3px 5px;
  font-size: 0.95em;
  color:#E70307;
  margin-left: 0.8em;
  background:#fff;
  line-height: 1em;
}
  
   #program .program_com .rogo{
   position: absolute;
   top: 20px;
   right: 20px;
   width: 240px;
   text-align: right;
   }
   
    #program .program_com .rogo2{
   position: absolute;
   top: 10px;
   right: 20px;
   width: 200px;
   text-align: right;
   }
   
 #program .program_com .rogo3{
   position: absolute;
   top: 0px;
   right: 5px;
   width: 200px;
   text-align: right;
   }
   
#program .program_com .rogo img,
#program .program_com .rogo2 img,
#program .program_com .rogo3 img{
   vertical-align: top;
   }
  
  #program .program_com h3{
	    font-size: 1em;
    font-weight: bold;
    color: #1E6E99;
    margin-bottom: 10px;
    line-height: 1.3em;
	margin: 5px auto 10px auto;
	}

#program .program_com h3.mb_adjustment{
	margin-bottom: 60px;
}

#program .program_com .program_com_buttom{
display: flex;
justify-content: space-between;
}

#program .program_com .program_com_buttom .koushi_3cel{
width: 100%;
display: flex;
justify-content: space-between;
}

#program .program_com .program_com_buttom .koushi_3cel_inner{
width: calc(96% / 4);
}

#program .program_com .program_com_buttom .photo_box img {
    width: 70px;
    margin-left: 10px;
}

@media
only screen and (max-width : 786px){
#program .royouiki_box{
padding-top: 0;
}
#program .program_com .program_com_buttom,
.flexbox-end-end{
display: block;
}
.flexbox-end-end{
display: block;
margin: 0 auto;
text-align: center;
}
#program .program_com .program_com_buttom .koushi_3cel{
width: 100%;
display: block;
justify-content: space-between;
margin-bottom: 10px;
}

#program .program_com .program_com_buttom .koushi_3cel_inner{
width: auto;
overflow: hidden;
margin-bottom: 10px;
}
	#program .program_com h3.mb_adjustment{
	margin-bottom: 10px;
}
}

  #program .program_com h4{
	font-size: 0.9em;
	font-weight: bold;
	margin-bottom: 10px;
	line-height: 1.3em;
	}
	
 #program .program_com p{
  font-size: 0.8em;
  line-height: 1.3em;
 }
 
 #program .program_com .photo_box figure{
 float: right;
 }

 #program .program_com .photo_box img{
width: 90px;
margin-left: 20px;
}

#program .program_com .photo_box .caption {
  line-height: 1.2em;
  font-size: 0.8em;
  text-align: right;

}

#program .program_com .program_com_buttom .photo_box .caption {
  line-height: 1.2em;
  font-size: 0.75em;
  text-align: right;

}

.flex_end{
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

 #program .program_com .com_name{
 font-weight: bold;
 color: #a61c24;
 font-size: 1.1em;
 }
 
 
.program_box .time{ width:150px; text-align:center; font-weight:bold; padding:20px 0 0 0;}
.program_box .theme {
    overflow: hidden;
	display:block;
	width:700px;
	position:relative;
	margin:20px auto;
}

.program_box .inner{ border-left:1px solid #999; padding:0px 30px; width:auto;}

@media
only screen and (max-width : 786px){
	.program_box{margin-top: 10px}
	#program .program_com {
	padding:15px; 
	width:100%;
			}
#program .program_com .rogo,
#program .program_com .rogo2,
#program .program_com .rogo3{
position: static;
text-align: center;
margin: 10px auto 0 auto;;
	}
#program .program_com .innar {
    padding: 10px 0;
	}
#program .program_com .photo_box img,
#program .program_com00 .photo_box img{
    width: 70px;
    margin-left: 20px;}
}

#program_SP ul.dot li{
text-indent: -1em;
padding-left: 1em;
font-weight: bold;
line-height: 1.3em;
margin-bottom: 10px;
font-size: 0.9em;
}

#program_SP ul.dot li:before{
color: rgba(192,14,83,0.3)!important;
}

ol.list_no {
    counter-reset: my-counter;
    list-style: none;
    padding: 0;
    margin: 0;
}

ol.list_no li{
    line-height: 1.5;
    padding-left: 26px;
    position: relative;
    font-size: 0.8em;
    margin-bottom: 0.5em;
}

ol.list_no li:before {
    content: counter(my-counter);
    counter-increment: my-counter;
    background-color: #3C464C;
    border: 1px solid;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 20px;
    width: 20px;
    color: #ffffff;
    font-size: 80%;
    line-height: 1;
    position: absolute;
    top: 0;
    left:0;
	}
ol.list_no li ul{
margin: 0.5em 0 0 0 0;
}

ol.list_no li ul li{
list-style:  none;  /* デフォルトのアイコンを消す */
margin-left:-20px;
margin-bottom: 0.1em;
font-size: 1em;}

ol.list_no li ul li:before {
content:  "";     /* 空の要素作成 */
    width:  10px;               /* 幅指定 */
    height:  10px;              /* 高さ指定 */
    display:  inline-block;     /* インラインブロックにする */
    background-color: #999;  /* 背景色指定 */
    border-radius:  50%;        /* 要素を丸くする */
    position:  relative;        /* 位置調整 */
    top: -1px;                  /* 位置調整 */
    margin-right: 5px;          /* 余白指定 */
}

.program_box .icon_code{
	padding:15px;
	background-color:#EC7600;
	color:#fff;
	font-weight:bold;
	line-height:1.3em;
	display:block;
	text-align:center;
}

.program_box .icon_code span{ display:block; font-size:0.6em;}
.program_box .co_text01{ font-size:0.9em; font-weight:bold; line-height:1.4em;}
.program_box .co_text01 span{ font-weight:normal; font-size:0.8em;}
.program_box .co_text02{ font-size:1em; font-weight:bold; color: #1A1943; margin-bottom:20px;}


  /*リボン*/
.ribbon01 {
  display: inline-block;
  position: relative;
  height: 40px;/*高さ*/
  line-height: 40px;/*高さ*/
  text-align: center;
  padding: 0 30px 0 18px;/*文字の左右の余白*/
  font-size: 0.9em;/*文字サイズ*/
  background: rgba(176,3,6,1.00);/*背景色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
}

.ribbon01_w200{
width: 200px;
}

.ribbon01:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.ribbon01:after {
  top: 0;
  right: 0;
  border-width: 20px 15px 20px 0px;
  border-color: transparent #ffffff
  transparent transparent;
  border-style: solid;
}

  /*リボン*/
.ribbon02 {
  /*display: inline-block;*/
  position: relative;
  height: 24px;/*高さ*/
  line-height: 24px;/*高さ*/
  text-align: center;
  padding: 0 30px 0 15px;/*文字の左右の余白*/
  font-size: 0.75em;/*文字サイズ*/
  background:  #D90000;/*背景色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
  width: 180px;
}

.ribbon02:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.ribbon02:after {
  top: 0;
  right: 0;
  border-width: 12px 6px 12px 0px;
  border-color: transparent #ffffff
  transparent transparent;
  border-style: solid;
}

.ribbon03 {
  display: inline-block;
  position: relative;
  height: 40px;/*リボンの高さ*/
  line-height: 40px;/*リボンの高さ*/
  text-align: center;
  padding: 0 30px;/*横の大きさ*/
  font-size: 18px;/*文字の大きさ*/
  background: #f57a78;/*塗りつぶし色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
  margin-top:5px;
}

.ribbon03:before, .ribbon03:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.ribbon03:before {
  top: 0;
  left: 0;
  border-width: 20px 0px 20px 15px;
  border-color: transparent transparent transparent #fff;
  border-style: solid;
}

.ribbon03:after {
  top: 0;
  right: 0;
  border-width: 20px 15px 20px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
}
  /*吹き出し*/
.balloon2 {
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 5px 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 16px;
  background: #FFF;
  border: solid 3px #6BB82C;
  box-sizing: border-box;
}

.balloon2:before {
  content: "";
  position: absolute;
  bottom: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-top: 12px solid #FFF;
  z-index: 2;
}

.balloon2:after {
  content: "";
  position: absolute;
  bottom: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  border-top: 14px solid #6BB82C;
  z-index: 1;
}

.balloon2 p {
  margin: 0;
  padding: 0;
}

.balloon3 {
  position: relative;
  padding: 1.2rem 1.5rem;
  color: #fff;
  border-radius: 10px;
  background:  rgba(176,3,6,1.00);
  display: inline;
}

.balloon3:after {
  position: absolute;
  bottom: -9px;
  left: 40%;
  width: 0;
  height: 0;
  content: '';
  border-width: 10px 10px 0 10px;
  border-style: solid;
  border-color: rgba(176,3,6,1.00) transparent transparent transparent;
}

.balloon4 {
  position: relative;
  padding: 10px 20px 20px ;
  background: rgba(193,6,219,0.8);
  display: inline;
  margin-left: 1em;
}

.balloon4:before {
  position: absolute;
  top: -5px;
  left: -5px;
  width: 100%;
  height: 100%;
  content: '';
  border: 2px solid #000;
}
/*企画委員*/
.committee_box1,
.committee_box2{
padding-bottom: 15px;
margin-bottom: 20px;
border-bottom: 1px solid rgba(199,199,199,0.9);
width: 100%;
overflow: hidden;
box-sizing: border-box;
}

.committee_box1 p,
.committee_box2 p{
font-size: 0.9em;
line-height: 1.5em;
}

.committee_box1 figure{
float: left;
    /* width: 120px; */
    padding: 0px 15px 0px 0px;
}

.committee_box2 {
display: flex;
justify-content: space-between;
}

.committee_box2_inner{
width: calc(94% / 2);
}

@media
only screen and (max-width : 786px){
.committee_box2 {
display: block;
}
.committee_box2_inner{
overflow: hidden;
width: auto;
margin-bottom: 10px;
}
}

.committee_box2 figure{
float: left;
    /* width: 100px; */
    padding: 0px 15px 0px 0px;
}

table.TableCommittee {
	border: none;
    width: 100%
}

.TableCommittee td,
.TableCommittee th{ padding: 10px; background-color:#E4E4E4; font-size: 0.8em;line-height: 1.3em;}

.TableCommittee tr:nth-child(even) td {	background: #fff;}
.TableCommittee tr:nth-child(even) th {	background: #fff;}

.TableCommittee th {
	padding: 10px 25px 10px;
	font-weight: bold;
	white-space: nowrap;
	vertical-align: top;
     width: 80px;
}

@media
only screen and (max-width : 786px){
.TableCommittee td {
display: block;
}

.TableCommittee th {
	padding: 5px 10px;
    }
}

/*企画委員*/
ul.committee_list{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

ul.committee_list li{
width: 47%;
margin: 10px;
font-size: 0.9em;
font-weight: bold;
line-height: 1.4em;
}

ul.committee_list li span{
display: block;
font-size: 0.85em;
}

@media
only screen and (max-width : 786px){
ul.committee_list li{
width: 100%;
}
}


/*お問い合わせContact*/
#contact{
	width:100%;
	position:relative;
	overflow:hidden;
    background: #352b5e;
	/*background: linear-gradient(58deg, rgba(108,10,110,1) 0%, rgba(206,0,128,1) 29%, rgba(3,126,172,1) 100%);*/
	color:#fff;
}

#contact h2{
text-align: center;
}

/* #contact .head_text::before {
    color: rgba(232,236,243,0.77);
    left: 45%;
    right: 45%;
} */
.head_text::before,.sub-t {
    content: attr(data-en);
    position: absolute;
    top: -20px;
    left: 0;
    color: rgba(40, 0, 185, 0.3);
    font-size: 16px;
    font-weight: bold;
    font-style: italic;
    text-align: center;
    white-space: nowrap;
    
}

/* #contact .head_text::before {
    color: rgba(217, 159, 229, 0.77);
    left: 45%;
    right: 45%;
} */

#contact .innar{
	margin:0 auto;}
	
@media
only screen and (max-width : 786px){
	#contact .innar{ width:100%;}
}

#contact dl{
	width: 600px;
	margin:0 auto;
}
	
	
#contact dl dt{
	width:100%;
	font-weight:bold;
	text-align:center;
	background:#fff;
	border-radius: 4px;
	float:left;
	margin-bottom:20px;
	color:#666;
}

#contact dl dd{
	margin:0;
	padding:10px 15px 0 15px;
}

#contact dl dd p{ line-height:1.3em; font-size:0.9em;}
.btn_box2btn{
display: flex;
justify-content: space-around;
width: 800px;
margin: 0 auto ;
}
	
@media
only screen and (max-width : 786px){
	#contact .flex-container{ display:block;}
	#contact dl{
	width: 100%; margin-bottom:10px;}
#contact .cont_innar{
	width:100%;}
.btn_box2btn{
display: block;
width: auto;
}
}
.icon_map a {
    display: inline-block;
    position: relative;
    padding: 3px 3px 3px 3px;
    box-sizing: border-box;
    border: 1px solid #F8D344;
    background-color: #F8D344;
    font-weight: bold;
    font-size: 1em;
    line-height: 1em;
    letter-spacing: 0;
    text-align: center;
    text-decoration: none;
    color: #000;
}

.icon_map a:hover{
	border: 1px solid #F8D344;
	background-color:#FFF;
	
}

.icon_map a::after {
  content: url(../images/window01-07.png);
	font-size:1em;
	margin-left: 0.5em;
	font-weight: normal;
}

/*お問い合わせContact*/
#order{
	width:100%;
	position:relative;
	overflow:hidden;
	z-index:10;
}

#order h3{	font-size:1.3em;
	font-weight:bold;
	margin-bottom:1em;
	text-align:left;
	color: #cd398e;
	border-bottom: 2px solid #cd398e;}

#order p{ font-size: 0.9em; line-height: 1.5em;}


#order .innar{
	margin:0 auto;
	padding: 0 0 50px 0;}

#order ul.list li{
font-size: 0.9em;
text-indent: -1em;
padding-left: 1em;
}

#order ul.list li:before {
    content: "●";
    color: #C6C3C3;
}

	
#order table{
font-size: 0.9em;
    clear: both;
    border-collapse: collapse;
	margin: 0 auto 20px auto;
width:80%;
}

#order table td,
#order table th{
	border:1px solid #C6C3C3;
	text-align:center;
	vertical-align: middle;
	padding:0.5em;
	font-weight:bold;
}
#order table th { background-color:rgba(43,125,198,0.9); color:#fff; font-weight:bold;}

.tgreen { background-color:rgba(43,125,198,0.5) ;font-weight:bold;}

#order table.dgreen{ background-color:#359C36;color:#fff;  }
.lgreen{ background-color:#B5D300;color:#fff; }
#order .nsmal{ font-size:0.8em; font-weight:normal;}

#order .big{ font-size:1.5em !important; font-weight:bold;}

#order .btn_order{ text-align: center;}
#order .btn_order a{ margin: 0 auto;}




.scroll{
overflow: auto;　　　　/*tableをスクロールさせる*/
white-space: nowrap;　　/*tableのセル内にある文字の折り返しを禁止*/
}
.scroll::-webkit-scrollbar{　　/*tableにスクロールバーを追加*/
 height: 5px;
}
.scroll::-webkit-scrollbar-track{　　/*tableにスクロールバーを追加*/
 background: #F1F1F1;
}
.scroll::-webkit-scrollbar-thumb {　　/*tableにスクロールバーを追加*/
 background: #BCBCBC;
}
	


/* btn Style
-------------------------------------------------------- */
.btn_order{
	margin:0 auto 0 auto;	
}
.btn_order a{
	width:328px;
	    padding: 10px 0;
    margin: 0 auto;
    display: inline-block;
    /* background-color: #d81f64; */
    background: linear-gradient(0deg, #e5d308 0%, #ed6c00 100%);
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    text-align: center;
    color: #fff !important;
    font-weight: bold;
    font-size: 1em;
    transition: .2s;
	border:2px solid #fff;
}

.btn_order a:hover{
    background: rgba(192,14,83,1.00);
}

.btn_order_ss a{
    background: linear-gradient(0deg, #e5d308 0%, #ed6c00 100%);
}



.btn_style_m10{
margin: 10px;
}

.btn_order a.style_call{ background:none;}

@media
only screen and (max-width : 786px){
	.btn_order a{
	display: block;
    width: 90vw;
	}
}

.btn_detail a{
	padding: 5px 15px;
    display: inline-block;
    background-color: #d81f64;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    text-align: center;
    color: #fff !important;
    font-weight: bold;
    font-size: 1em;
    transition: .2s;
	border:2px solid #fff;
}

.btn_detail a:hover {
    background: #352b5e;
}
.btn_order a:hover,
.btn_order02 a:hover{
	/* background-color:#002C7D; 	 */
    /* background: #d81f64; */
    /* background: linear-gradient(0deg, #e5d308 0%,#d81f64 100%); */
    background: linear-gradient(0deg, #ed6c00 0%, #e5d308 100%);
    opacity: 0.7;
	text-decoration:none;
}

.btn_order_ss a:hover{
/* background-color: #002C7D; */
/* background: #d81f64 */
background: linear-gradient(0deg, #ed6c00 0%, #e5d308 100%);
opacity: 0.7;
}

.nolink a,
.nolink{
background: rgba(184,182,182,1.00) !important;
pointer-events: none!important;
	cursor: default;
	opacity: 0.8;
}





/* PageTop Style
-------------------------------------------------------- */



#page-top a {
 position: fixed;
    right: 10px;
    bottom: 10px;
    font-size: 1.3em;
    background: #352b5e;
    color: #ffffff;
    padding: 10px;
    border-radius: 50%;
	z-index:500;
    width: 30px;
    height: 30px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    
}
#page-top a:hover{
text-decoration: none;
background: #d81f64;
}

@media
only screen and (max-width : 786px){
#page-top a {
bottom: 30px;
}
}

/* Footer Area Style
-------------------------------------------------------- */

#footer{
	width:100%;
	background-color:#000;
}

#copyright{
	font-size: 12px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	clear: both;
	width: 700px;
	padding:10px 0;
	margin:0 auto;
}

@media
only screen and (max-width : 786px){
	#copyright{ width:100%;}
}


/* ヘッダーrogo */

.inner {
    width: 1050px;
    margin: 0 auto;
}
.inner:after {
    content: "";
    clear: both;
    display: block;
}
 
/* header */
#top-head {
    width: 100%;
    line-height: 1;
    z-index: 999;
}

#top-navi {
    width: 100%;
    line-height: 1;
    z-index: 999;
	background: rgba(255,255,255,.9);
}

#top-head a,
#top-head {
    color: #666;
    text-decoration: none;
}
 #top-head .inner {
    position: relative;
    width: 1000px;
}

@media
only screen and (max-width : 786px){
	#top-head .inner {
    position: relative;
    width: auto;
}
}

#top-head .logo {
   float: left;
    padding: 10px;
    height: 35px;
}

    #top-head h1 span {
    font-weight: bold;
    line-height: 55px;
    font-size: 0.8em;
}


@media all and (min-width: 768px){
#global-nav{
background: #352b5e;
padding: 5px 0;
}

#global-nav ul {
    list-style: none;
    font-size: 14px;
    margin: 10px 0;
    display: flex;
    justify-content: space-between;
}
#global-nav ul li {

padding: 0 !important;
background: none !important;
display: flex;
align-items: center;
}
#global-nav ul li a {
    padding: 0 10px 5px 10px;
    color: #ffffff;
    font-weight: bold;
}

#global-nav ul li a:hover{
color: #d81f64;
}

#global-nav ul.hover_ss li a:hover{
color:#d81f64;
}

#global-nav ul li a:after{
    content: '\f105';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-left: 0.3em;
}

/* Toggle Button */
#nav-toggle { display: none;}

}


@media all and (min-width: 768px){
	*::-ms-backdrop, #global-nav  {left:500px !important;}
	*::-ms-backdrop, #global-nav ul {
		width:700px !important;
		float:right !important;
	}
		*::-ms-backdrop, #global-nav ul li{
			max-width:8em!important;
			font-size:12px!important;}
		*::-ms-backdrop, #global-nav ul li:nth-child(3){ max-width:15em!important;}
}

 

 
/* Toggle Button */
#nav-toggle {
    position: absolute;
    right: 12px;
    top: 14px;
    width: 34px;
    height: 36px;
    cursor: pointer;
    z-index: 101;
}
#nav-toggle div {
    position: relative;
}
#nav-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #666;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
    top: 0;
}
#nav-toggle span:nth-child(2) {
    top: 11px;
}
#nav-toggle span:nth-child(3) {
    top: 22px;
}

#nav-toggle div br{ display:none;}


@media screen and (max-width: 789px) {
    #top-head,
    .inner {
        width: 100%;
        padding: 0;
    }
    #top-head {
        top: 0;
        position: fixed;
        margin-top: 0;
		background: rgba(255,255,255,.9);
    }
    /* Fixed reset */
    #top-head.fixed {
        padding-top: 0;
        background: transparent;
    }
    #mobile-head {
        background: rgba(255,255,255,.9);
        width: 100%;
        height: 56px;
        z-index: 999;
        position: relative;
    }
    #top-head.fixed .logo,
    #top-head .logo {
        position: absolute;
        left: 10px;
        top: 5px;
        color: #333;
        font-size: 26px;
		width:240px;
        display: none;
    }
    
     #top-head h1 { display: inline;}
    
    #top-head h1 span {
    float: none;
    font-weight: bold;
    line-height: 65px;
    text-align: left;
    margin-left: 10px;
}
    #global-nav {
        position: absolute;
        /* 開いてないときは画面外に配置 */
        top: -500px;
        background: #352b5e;
        width: 100%;
        text-align: center;
        padding: 0px 0;
        -webkit-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        transition: .5s ease-in-out;
    }
    #global-nav ul {
        list-style: none;
        position: static;
        right: 0;
        bottom: 0;
        font-size: 14px;
    }
    #global-nav ul li {
        float: none;
        position: static;
    }
    
    #global-nav ul li a:after{
    content: '\f105';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-left: 0.3em;
}
	@media all and (-ms-high-contrast:none){
	*::-ms-backdrop, #global-nav  {left:0px !important;}
	*::-ms-backdrop, #global-nav ul {
		width: auto !important;
		float: none !important;
	}
		*::-ms-backdrop, #global-nav ul li{
			max-width:auto!important;
			font-size:12px!important;}
		*::-ms-backdrop, #global-nav ul li:nth-child(2){ max-width:auto!important;}
}
 
    #global-nav ul li a,
    .fixed #global-nav ul li a {
        width: 100%;
        display: block;
        color: #fff;
        padding: 18px 0;
        border-bottom: 1px solid #ffffff;
    }
    
   #global-nav ul li br{
    display: none;
    }
    
     #global-nav ul li a:hover,
    .fixed #global-nav ul li a:hover {
    background: rgba(3,126,172,0.7);
    
    }
    #nav-toggle {
        display: block;
    }
    /* #nav-toggle 切り替えアニメーション */
    .open #nav-toggle span:nth-child(1) {
        top: 11px;
        -webkit-transform: rotate(315deg);
        -moz-transform: rotate(315deg);
        transform: rotate(315deg);
    }
    .open #nav-toggle span:nth-child(2) {
        width: 0;
        left: 50%;
    }
    .open #nav-toggle span:nth-child(3) {
        top: 11px;
        -webkit-transform: rotate(-315deg);
        -moz-transform: rotate(-315deg);
        transform: rotate(-315deg);
    }
    /* #global-nav スライドアニメーション */
    .open #global-nav {
        /* #global-nav top + #mobile-head height */
        -moz-transform: translateY(556px);
        -webkit-transform: translateY(556px);
        transform: translateY(556px);
    }
}


/* スマホ用メニュー */


/* 共通メニュー */

.fixed {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 10000;
}

#navi{
width: 100%;
background: rgba(255,255,255,1.00);
z-index: 100;
box-shadow: 0px 10px 10px -5px rgb(0 0 0 / 25%);

}

#navi .navi_innar{
 width: 1000px;
 margin: 0 auto;
 padding: 1px 0;
}

#navi .navi_innar ul{
display: flex;
align-content: center;
flex-wrap: wrap;
justify-content: space-between;
}

#navi .navi_innar ul li{
margin-right: 1em;
font-size: 0.9em;
}

#navi .navi_innar ul li a{
color: #352b5e;
text-align: center;
padding: 5px;
line-height: 2em;
display: block;
font-size: 0.9em;
}

#navi .navi_innar ul li a:after {
    content: '\f078';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-left: 0.3em;
    color: #352b5e;
}

#navi .navi_innar ul li a:hover{
	color: #d81f64;
	text-decoration: none;
	}
    
#navi .navi_innar_ss ul li a:hover{
	color: #4E3885;
	}

#navi .navi_innar_ss ul li a:after {
color: #4E3885;
}

#navi .navi_innar_ss ul li a.link_right:after {
content: '\f054';
width: 1em;
}


	
@media
only screen and (max-width : 786px){
#navi .navi_innar{
 width: auto;
}
#navi .navi_innar ul{
display: block;
}
#navi .navi_innar ul li {
    margin-right: 0;
    font-size: 0.8em;
    border-bottom: 1px solid rgba(151,149,149,1.00);
}
#navi .navi_innar ul li:last-child{ border-bottom: none;}
}

#info .info_box{
display: flex;
justify-content: space-between;
}

#info .info_box .info_box__left{
display: flex;
align-items: center;
text-align: center;
width: 200px;
color: #fff;
background: #676565;
justify-content: center;
}

#info .info_box .info_box__right{
background: #fff;
width: 700px;
}

#info .info_box .info_box__right dl{
margin: 20px;
width: auto;
display: block;
border-top: 1px solid rgba(173,171,172,1.00);
}

#info .info_box .info_box__right dl dt{ 
width: 7em;
font-size: 0.8em;
font-weight: bold;
float: left;
line-height: 1.5em;
padding: 0.3em 0;
}

#info .info_box .info_box__right dl dd{
font-size: 0.8em;
line-height: 1.5em;
border-bottom: 1px solid rgba(173,171,172,1.00);
padding: 0.3em 0 0.3em 7em;
}

@media
only screen and (max-width : 786px){
#info .info_box{
display: block;
}
#info .info_box .info_box__left{
display: block;
width: 100%;
text-align: center;
}
#info .info_box .info_box__right{
background: #fff;
width: 100%;
padding-top:10px;
padding-bottom: 10px;
}
}


/*——　文字の右にライン　——*/
.title-border-right {
display: flex;
align-items: center;
font-weight: bold;
margin-top: 0.5em;
}
.title-border-right:after {
border-top: 1px solid #CDC8C8;
content: "";
flex-grow: 1;
}
.title-border-right:after {
margin-left: 1rem;
}


/*協賛企業 バナー*/



ul.bnr_box {
    display: flex;
    text-align: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px 2%;
}

#bnr { text-align: center; position: relative;}

ul.bnr_box li {
    /* margin: 10px 15px; */
    vertical-align: middle;
 display: flex;
  justify-content: center;
  align-items: center;
    position: relative;
}

ul.bnr_box li figure{
padding-bottom: 30px;
}

ul.bnr_box li figcaption{
position: absolute;
bottom: 0;
font-size: 0.8em;
font-weight: bold;
vertical-align: baseline;
color: #333;
line-height: 1.3em;
white-space: nowrap;
}

@media
only screen and (max-width : 786px){
ul.bnr_box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

ul.bnr_box li.w300 { width:  43% ;}

ul.bnr_box li {
width: 43%;
flex-direction: column;
display: flex;
justify-content: center;
  align-items: center;
}

ul.bnr_box li figure{
padding-bottom: 10px;
}

ul.bnr_box li figcaption{
margin-top: auto;
position: static;
text-align: center;
white-space: pre-wrap;
}
}


#bnr .contents {
    width: 1100px;
    margin: 0 auto;
    padding: 50px 0;
}



.mov {
    text-align: center;
    margin: 0px auto 15px auto;
    position:relative;
    width:100%;
	text-align: center;
}

.mov iframe{
    width:100%!important;
    height:100%!important;
}

.btn_box{ 
display:flex;
justify-content:space-between;
width:719px;
margin:20px 10px 30px 10px;}

.btn-red a {
  display: block;
  text-decoration: none;
  border-radius: 4px;
  color: #ffffff;
  line-height:2.5em;
  text-align:center;
  /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#e51013+0,a80002+100 */
background: #e51013; /* Old browsers */
background: -moz-linear-gradient(top, #e51013 0%, #a80002 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, #e51013 0%,#a80002 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, #e51013 0%,#a80002 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e51013', endColorstr='#a80002',GradientType=0 ); /* IE6-9 */
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.2);
  border-bottom: solid 3px #680d14;
  width:300px;
  margin: 0 auto 5px auto;
  font-size:0.85em;
}



.btn-blue a {
  display: block;
  text-decoration: none;
  border-radius: 4px;
  color: #ffffff;
  line-height:3em;
  text-align:center;
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#0071bc+0,000d47+100 */
background: #0071bc; /* Old browsers */
background: -moz-linear-gradient(top, #0071bc 0%, #000d47 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, #0071bc 0%,#000d47 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, #0071bc 0%,#000d47 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0071bc', endColorstr='#000d47',GradientType=0 ); /* IE6-9 */
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.2);
  border-bottom: solid 3px #090E45;
  width:100%;
  float: none;
  margin-bottom:10px;
  font-size:0.85em;
}

.btn-green a {
  display: block;
  width:300px;
  text-decoration: none;
  border-radius: 4px;
  color: #ffffff;
  line-height:3em;
  text-align:center;
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#197f31+0,274943+100 */
background: #197f31; /* Old browsers */
background: -moz-linear-gradient(top, #197f31 0%, #274943 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, #197f31 0%,#274943 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, #197f31 0%,#274943 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#197f31', endColorstr='#274943',GradientType=0 ); /* IE6-9 */
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.2);
  border-bottom: solid 3px #090E45;
  margin:15px auto 0 auto;
  font-size:0.85em;
}

.btn-red a:hover,
.btn-blue a:hover,
.btn-green a:hover {
  box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.6);
  opacity:0.6;
}



dl.box_a dt{
width: 40px;
height: 40px;
background: rgba(108,10,110,1);
font-weight: bold;
color: #fff;
line-height: 40px;
border-radius: 5px;
float: left;
text-align: center;
}

dl.box_a dd{
text-align: left;
padding-left: 50px;
margin-bottom: 10px;
}

dl.box_a dd h5,
#sponsor .title{
color: rgba(108,10,110,1);
font-weight: bold;
}

dl.box_a dd p{
font-weight: 0.9em;
}

dl.box_a dd .flex-container{
justify-content: space-around;
}

dl.box_a dd .flex-container div:first-child{
width: 60%;
}

dl.box_a dd .img_box{
width: 300px;
margin-left: 20px;
}

dl.box_a dd figcaption{
font-size: 0.8em;text-align: center;
}

dl.box_a ul.dot li{
font-weight: bold;
color:#dd007f;
}

dl.box_a ul.dot li:before {
color: #dd007f;
}

dl.box_b{
width: 600px;
margin: 0 auto;
border: 1px solid #ce0080;
}

dl.box_b dt{
background: #ce0080;
font-weight: bold;
color: #fff;
float: left;
text-align: center;
font-size: 1.1em;
width: 300px;
height: 70px;
line-height: 70px;
}

dl.box_b dd{
background: #fff;
color: #666;
font-weight: bold;
text-align: center;
font-size: 1.1em;
height: 70px;
line-height: 70px;
}

@media
only screen and (max-width : 786px){
dl.box_a dd .flex-container{
display: block;
}

dl.box_a dd .flex-container div:first-child{
width:auto;
}

dl.box_a dd .img_box {
margin: 20px auto;
}
}



ul.list_check li{
text-indent: -1em;
padding-left: 1em;
text-align: left;
}

ul.list_check li:before {
    content: "check_box";
     font-family: 'Material Icons';
     font-size: 1.4em;
    margin-right: 0.2em;
    color: rgba(108,10,110,1);
      display: inline-flex;
  vertical-align: middle;
}

@media
only screen and (max-width : 786px){
#sponsor ul.list_check{
width: auto;
}
}

.material-icons {
  display: inline-flex;
  vertical-align: middle;
}

ul.dot li:before {
content: "●";
    margin-right: 0.3em;
    color: #CDF0C8;
    display: inline;
}

ul.list_down li{
text-indent: -1em;
padding-left: 1em;
}

ul.list_down li:before {
    content: '\f078';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-right: 0.3em;
    color: rgba(111,56,133,1)
}

.icon_check{
text-indent: -1em;
padding-left: 1em;
}

.icon_check:before {
    content: '\f560';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-right: 0.8em;
    color: #037EAC;
    font-size: 0.5em !important;
    vertical-align: 2px;
}

.porom_title {
  position: relative;
  padding: 20px 30px 20px 60px;
  text-align: center;
  font-size: 1.4em;
  font-weight: bold;
  background: rgba(255,255,255,0.80);
  margin-bottom: 25px;
  z-index: 1;
}

.porom_title span.code01 {
  position: absolute;
  top: 20px;
  left: 30px;
  padding: 10px 20px;
  color: #e3f5d8;
  background: #037EAC;
  font-size: 0.6em;
}

.porom_title span.code01:after {
  position: absolute;
  top: calc(50% - 7px);
  right: -11px;
  width: 0;
  height: 0;
  content: '';
  border-width: 7px 0 7px 12px;
  border-style: solid;
  border-color: transparent transparent transparent #037EAC;
}

@media
only screen and (max-width : 786px){
.porom_title {
    position: relative;
    padding: 10px 20px 20px 20px;
    }
.porom_title span.code01 {
  position: relative;
  top: auto;
  left: auto;
  margin: 0 auto 25px auto;
  padding: 0.3em 15px;
  display: block;
  width: 6em;
  }
.porom_title span.code01:after {
  position: absolute;
  top: 100%;
  bottom: 0;
  right: calc(45% - 7px);
  left: calc(45% - 7px);
  width: 0;
  height: 0;
  content: '';
   border: 15px solid transparent;
 border-top: 15px solid #037EAC;
}
}


@media
only screen and (max-width : 786px){
#sponsor_prom .flex-container{
display: block;
}
.btn_order a.w500{
width: 96% !important;
margin: 20px auto 0 auto;
}
}

.fig_box{
display: flex;
justify-content:space-between;
}

.box_2com{
width: calc(94% / 2);
background: #ffffff;
z-index: 1;
}

@media
only screen and (max-width : 786px){
.fig_box{ display: block;}

.box_2com{
width: 100%;

}
.box_2com figure{
	text-align: center;
	}
.box_2com figcaption {
	text-align: left;
	}
}


.box_2com h4{
background: #037EAC;
padding: 8px 0;
text-align: center;
font-weight: bold;
font-size: 1.1em;
color: #fff;
}

.box_2com .inner{
padding: 0px 20px 20px 20px;
width: auto;
}

.box_2com h5{
color: #037EAC;
font-weight: bold;
font-size: 1em;
margin-bottom: 8px;
line-height: 1.5em;
}

.box_2com .inner p{
font-size: 0.9em;
line-height: 1.4em;
}

.box_2com figcaption{
font-size: 0.9em;
line-height: 1.3;
margin-top: 10px;;
}

.code02{
    background: #B26700;
    color: #fff;
    display: block;
    border-radius: 4px;
    padding: 5px 7px;
    margin-bottom: 0.5em;
    line-height: 1.5;
    border: transparent 1px solid;
    font-size: 1em;
    text-align: center;
    font-weight: bold;
}

.code02_dot{
height:25px;
 width:25px;
 border-radius:50%;
 line-height:25px;
 text-align:center;
 color: #fff;
 font-weight: bold;
 background: #037EAC;
 display: inline-block;
 margin-right: 10px;
}

.balloon{
  position: relative;
  padding: 20px;
  width: 170px;
  height: 170px;
  border-radius: 50%;
  text-align: center;
  color: #ffffff;
  letter-spacing: 0.2em;
  background-color: #dd007f;
  line-height: 1.3em;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 30px auto 0 auto;
  z-index: 2;
}
.balloon::before{
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  right: 2px;
  top: 2px;
  border-left: 40px solid #dd007f;
  border-top: 15px solid transparent;
  border-bottom: 15px solid transparent;
  transform: rotate(-45deg);
}
.balloon p {
  font-display: 0.85em;
  font-weight: bold;
}

.icon_box{
position: absolute;
display: flex;
justify-content: center;
align-items: center;
flex-direction: column;
width: 100px;
background: #fff;
top:35%;
left: 45%;
right: 45%;
border-radius: 15px;
border: 1px solid rgba(167,198,246,1.00);
padding: 15px 0;
z-index: 2;
}

.icon_box p {
font-size: 0.6em;
}

.icon_box figure{
width: 60px;
margin: 10px;
padding: 0;
}

@media
only screen and (max-width : 786px){
.icon_box{
position: relative;
margin: 15px auto;
left: auto;
right: auto;
top: auto;
flex-direction: row;
width: auto;

}
.icon_box p {
font-size: 1em;
font-weight: bold;
margin-right: 20px;
margin-left: 1em;
}
}

ul.list_com li{
margin-right: 1em;
}

ul.list_com li:before {
    content: '\f111';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-right: 0.8em;
    color: rgba(243,137,220,0.5);
    font-size: 0.5em !important;
    vertical-align: 2px;
}

ul.list_com_b li{
margin-right: 1em;
font-weight: bold;
}

ul.list_com_b li:before {
    content: '\f111';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-right: 0.8em;
    color: rgba(3,126,172,0.5);
    font-size: 0.5em !important;
    vertical-align: 2px;
}

ul.list_right li{
text-indent: -0.5em;
padding-left: 0.8em;
}

ul.list_right li:before {
    content: '\f105';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-right: 0.3em;
    color: rgba(108,10,110,1);
    font-size: 0.8em !important;
    vertical-align: 2px;
}


#sponsor_achievements{
z-index: 1;
}

#sponsor_achievements .box_2com{
margin-bottom: 15px;
}


dl.box_color_2box dt{ 
width:160px; 
text-align:center; 
color:#fff; 
background: #ce0080;
padding:0.2em 0;
margin-bottom:0.5em;
font-weight: bold;
}

dl.box_color_2box dd{
	margin-left:0.5em;
font-weight:bold;
margin-bottom:0.5em;
background: #fff;
border-bottom: 1px solid rgba(199,199,199,0.9);
width: 660px;
padding: 0.2em 10px;
}

@media
only screen and (max-width : 786px){
dl.box_color_2box dt,
dl.box_color_2box dd
{ width: 100%; display: block; margin: 0 auto;}

}

/* -------------- 利用規約 -------------- */

.title-border-right {
display: flex;
align-items: center;
}
.title-border-right:after {
border-top: 1px solid;
content: "";
flex-grow: 1;
}
.title-border-right:after {
margin-left: 1rem;
}
/*参加規約*/

#participation_terms{ font-size: 0.9em;}
#participation_terms .terms-item dl {
    display: flex;
    flex-wrap: wrap;
}
@media screen and (max-width: 786px){
#participation_terms .m50-b{
margin-bottom: 30px!important;
}
}

#participation_terms .mdslevel-3{ font-size: 1.1em;}

#participation_terms .terms-item>p, #participation_terms .terms-item>ul, #participation_terms .terms-item>dl {
    margin-left: 20px;
    margin-right: 20px;
}

#participation_terms .terms-item dt {
    width: 25px;
}

#participation_terms .terms-item dd {
    width: calc(100% - 25px);
    margin-inline-start: 0;
    }

#privacy table[border="1"],
#participation_terms table[border="1"] {
	border-spacing: 0;
	margin: 35px auto;
	border: none;
}

#privacy table[border="1"] tr td,
#participation_terms table[border="1"] tr td {
	border: none;
	border-top: 1px solid #999;
	border-left: 1px solid #999;
	width: 50%;
	text-align: center;
	vertical-align: middle;
	padding: 5px 40px;
}

/* #privacy table[border="1"] td,
#participation_terms table[border="1"] td {
	width: 50%;
	text-align: center;
	vertical-align: middle;
	padding: 5px 40px;
} */

#privacy table[border="1"] td:last-child,
#participation_terms table[border="1"] td:last-child {
	border-right: 1px solid #999;
}

#privacy table[border="1"] tr:last-child td,
#participation_terms table[border="1"] tr:last-child td {
    border-bottom: 1px solid #999;
}

@media screen and (max-width: 786px){
	#privacy table[border="1"] tr td,
	#participation_terms table[border="1"] tr td {
		padding: 5px 8px;
	}
}

#outline .text{
font-size: 0.8em;
}

#outline .flex-2com-1com--1com{
margin-left: 40px;
text-align: right;
}

#outline .photo_box{
margin-left: 40px;
margin-bottom: 30px;
text-align: right;
float: right;
}
@media screen and (max-width: 450px){
    #outline .photo_box{
        /* float: none; */
        width: 40%;
        margin-left: 5px;
        margin-bottom: 5px;
    }
}


#outline .flex-2com-1com--1com figcaption,
#outline .photo_box figcaption{
font-size: 0.7em;
line-height: 1.5em;
margin-top: 10px;
}

@media screen and (max-width: 786px){
#outline .flex-2com-1com{ display: block;}
#outline .flex-2com-1com--2com,
#outline .flex-2com-1com--1com{ width: 100%;}
#outline .flex-2com-1com--1com {
    margin-left: 0;
    text-align: right;
}
}

/*-----------下層ページ---------*/

/*--タイトル--*/
#title{
    background: url("../img/bk_com_img.jpg") no-repeat center top;
    z-index: 1;
    background-size: cover;
}


#title .title_in {
    width: 980px;
    height: 210px;
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    text-align: left;
    flex-direction: column;
}

#title .title_in h1{
font-size: 2em;
font-weight: bold;
color: #352b5e;
line-height: 1.3em;
}

#title .title_in h1 span.small__2{
font-size: 0.5em!important;
font-weight: bold;
    padding: 5px 5px 5px 10px;
    background-color: #E7410B;
    line-height: 1em;
    display: inline;
    text-align: center;
    border-radius: 5px;
    color: #ffffff;
    margin-right: 0.5em;
}

#title .title_in h1 span.small{
font-size: 0.5em!important;
font-weight: bold;
}

#title .title_in .sab-title{
    display: inline;
    font-size: 1.4em;
    text-align: center;
    font-weight: bold;
    background: rgba(59,92,144,1.00);
    color: #ffffff;
    border-radius: 5px;
    padding: 0.3em 0.5em ;
    margin-bottom: 10px;
}

@media screen and (max-width: 786px){
#title{
    margin-top: 65px;
    height: auto;
}

#title .title_in {
    width: 65%;
padding: 15px;
    height: 150px;
}
#title .title_in h1{ line-height: 1.2em; font-size: 1.4em;}
#title .title_in h1 span.small{
font-size: 14px!important;
line-height: 14px!important;
}
}

/*--申込--*/
table.order_tb{
    border-collapse: separate;
    border-spacing: 0px 1px;
}

table.order_tb td,
table.order_tb th{
    padding: 10px;
    vertical-align: middle;
    background: #FFF;
    font-size: 0.9em;
}

table.order_tb td{ width: 40%; text-align: center;}

table.order_tb th{
background: #352b5e;
font-weight: bold;
    text-align: left;
    padding: 10px 15px;
    color: #ffffff;
}



/*--プログラム共通のボックス--*/
.icon_codeN1{
	padding:5px 10px;
	background-color:#352b5e;
	font-weight:bold;
	line-height:1em;
	display:block;
	text-align:center;
    border-radius: 10px;
    color: #ffffff;
    font-size: 0.9em;
}

#day1_program .icon_codeN1,
#day2_program .icon_codeN1{
	background-color:#ffffff;
    color: #666666;
    border-radius:5px;
    max-width: 30px;
}

#day2_program .icon_codeN1{
display: inline;
padding: 1px 8px;
font-size: 0.8em;
margin-left: 1em;
}

#day2_program .code03{
margin-top: 0;
margin-bottom: 5px;
padding: 2px 7px;
font-size: 0.8em;
line-height: 1em;
display: block;
}

.icon_codeN2{
	padding:5px 10px;
	background-color:rgba(244,159,1,1);
	font-weight:bold;
	line-height:1em;
	display:block;
	text-align:center;
    border-radius: 10px;
    color: #fff;
    font-size: 0.9em;
}

.icon_codeIR{
	padding:5px 10px;
	background-color:#F0C0E1;
	font-weight:bold;
	line-height:1em;
	display:inline;
	text-align:center;
    border-radius: 10px;
    color: #666;
    font-size: 0.9em;
}

.icon_codeN1_inline{
	padding:5px 10px;
	background-color:#F9F6EC;
	font-weight:bold;
	display:inline;
	text-align:center;
    border-radius: 5px;
    color: #666;
    font-size: 0.7em;
    margin-top: -5px;
}

.icon_codeN1_inline_sec{
	padding:1px 10px;
	background-color:#ffffff;
	font-weight:bold;
	display:inline;
	text-align:center;
    border-radius: 5px;
    color: #352b5e;
    font-size: 0.8em;
    line-height: 1em;
}

.icon_codeN3{
	padding:5px 10px;
	background-color:#F9F6EC;
	font-weight:bold;
	display: block;
	text-align:center;
    border-radius: 5px;
    color: #666;
    font-size: 0.7em;
    width: 3em;
    line-height: 1em;
    height: 1em;
}
.icon_codeSS_inlineW{
	padding:5px 10px;
	background-color:#ffffff;
	font-weight:bold;
	line-height:1.2em;
	display:inline;
	text-align:center;
    border-radius: 5px;
    color: #666;
    font-size: 0.7em;
}

.icon_codeU {
    background: rgb(246,108,2);
background: linear-gradient(58deg, rgba(246,108,2,1) 0%, rgba(243,159,3,1) 75%, rgba(240,205,4,1) 89%, rgba(240,221,60,1) 100%);
    width: 80px;
    padding: 6px;
    border-radius: 8px;
    color: #fff;
    font-size: 0.8em;
    text-align: center;
    white-space: nowrap;
    font-weight: bold;
    line-height: 1em;
}

.code_jirei {
  position: relative;
  padding: 0.3em 0.8em;
  text-align: center;
  display: inline;
  font-weight: bold;
  color: #076434;
}

/*.code_jirei:before,
.code_jirei:after {
  position: absolute;
  content: '';
}

.code_jirei:after {
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border-top: 2px solid #076434;
  border-left: 2px solid #076434;
}

.code_jirei:before {
  right: 0;
  bottom: 0;
  width: 15px;
  height: 15px;
  border-right: 2px solid #076434;
  border-bottom: 2px solid #076434;
}*/

.program_box{
display: flex;
justify-content: space-between;
    margin-top: 20px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
}

#day1_program .program_box{
    margin-top: 20px;
}

#day2_program .program_box{
    margin-top: 2px;
}

.program_box_ss .program_box{
display: block;
background: #ffffff;
position: relative;
}

.time_box{
    /* width: 135px; */
    width: 200px;
    text-align: center;
    font-weight: bold;
    background: #A3A3A8;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    font-size:1em;
}

#day1_program .time_box{
/* background: #009FB9; */
background: linear-gradient(180deg, #ed6c00 0%, #e5d308 100%);
}

#day2_program .time_box{
background: #352b5e;
width: 90px;
}

@media screen and (max-width: 786px){
#day2_program .time_box{
width: 100%;
}
}

#day2_program .theme_box{
width: 100%;
padding: 0;
font-size: 14px!important;
overflow: hidden;
display: flex;
justify-content: space-between;
}

#day2_program .theme_box .progAB_box{
width: calc( 100% / 2);
}

.bgc_ss_com_midashi{ background: rgba(129,73,18,1.00);}

.program_box_ss .time_box{
text-align: left;
padding: 8px 15px;
display: inline-block;
width: auto;
border-radius: 0 10px 10px 0;
margin-top:5px;
}

.program_box_ss .time_box .icon_codeN1,
.program_box_ss .time_box .icon_codeN2{ display: inline;}


@media screen and (max-width: 786px){
.program_box {
    display: block;
}
.time_box{
    width: 100%;
    display: block;
    padding: 5px 0;
    }
.icon_codeN1,
.icon_codeN2{ display: inline;}
}


.theme_box {
    background-color: #fff;
    overflow: hidden;
    /*box-shadow: 5px 5px 10px rgb(0 0 0 / 25%);*/
    display: block;
    padding: 20px;
    width: 100%;
    position: relative;
}



.program_box_ss .theme_box {
width: auto;
position: static;
}

.theme_box .rogo_img {
    float: right;
    margin: 0 0px 0 20px;
    max-width: 500px;
}


.theme_box .rogo_img_aabsolute {
position: absolute;
top:15px;
right: 15px;
}

.theme_box .rogo_flex_end{
display: flex;
flex-wrap: wrap;
justify-content: flex-end;
flex-direction: column;
}

.theme_box .rogo_img_aabsolute_m5 {
position: absolute;
top:5px;
right: 5px;
}

.theme_box .rogo_img_aabsolute_m25 {
position: absolute;
top:25px;
right: 25px;
}

.theme_box .img_bnr{
margin: 15px 20px 0 0;
}

.theme_box .img_bnr_2com{
display: flex;
align-items: center;
margin-top: 15px;
}

.theme_box .img_bnr_2com div{
height: 73px;
padding: 10px;
display: flex;
align-items: center;
}

.theme_box .img_bnr_2com div:first-child{
margin-right: 15px;
}

.theme_box .img_bnr_right{
margin: 15px 0 0 0;
float: right;
}

@media screen and (max-width: 786px){
.theme_box .img_bnr_right{
margin: 15px 0 0 0;
float: none;
}
}

.theme_box .line_left{
border-left: 1px solid #cccccc;
margin: 0 auto;
}

@media screen and (max-width: 786px){
.theme_box { width: auto;}
.theme_box .flex-2com{ display: block;}
.theme_box .w50per,
.theme_box .w47per{ width: 100%!important;}
.theme_box .w50per{ margin-bottom: 10px;}
.theme_box .rogo_img {
    float: none;
    margin: 0 0 10px 0;
    max-width: 300px;
}
.theme_box .img_bnr{
margin: 15px auto 0 auto;
}
.theme_box .rogo_img_aabsolute,
.theme_box .rogo_img_aabsolute_m25 {
position:static;
top:auto;
right: auto;
margin-bottom: 10px;
}

.program_box_ss .theme_box .flex-2com div{
width: 100%;
}
.program_box_ss .theme_box .flex-2com div:first-child{
margin-bottom: 10px;
}

.theme_box .line_left{
border-left: none;
border-bottom: 1px solid #cccccc;
margin: 10px 0;
width: 100%;
}

.theme_box .img_bnr_2com{
display: block;;
margin-top: 15px;
}

.theme_box .img_bnr_2com div{
height: auto;
margin-top: 10px;
}

.theme_box .img_bnr_2com div:first-child{
margin-right: 0px;
margin-top: 0;
}

}

.program_box_j{
position: relative;
box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
}

.program_box_j .time_box{
position: absolute;
top:0;
left: 0;
z-index: 999;
display: block;
padding: 5px 10px;
width: 200px;
}

.program_box_j .theme_box{
position: relative;
width: auto;
padding-top: 50px;
}

.clearfix{ width: 1px!important;}

@media screen and (max-width: 786px){
.clearfix{ width: 1px!important;}
.program_box_j .time_box{
width: 100%;
padding: 5px 0;
}
}

/* @media screen and (max-width: 786px){
.program_box_j .theme_box .flex-2com div{
width: auto;
overflow: hidden;
}
.program_box_j .theme_box .flex-2com div:first-child,
.program_box_j .theme_box .flex-2com div:last-child{
padding-bottom: 10px;
    margin-bottom: 10px;
    border-bottom: 1px solid rgba(175,173,173,1.00);
}
} */

.theme_box h2{
    font-size: 1.1em;
    font-weight: bold;
    margin-bottom: 10px;
    text-align: left;
    color: #E7410B;
    line-height: 1.5em;
}
#day2_program .theme_box h2{
color: #111111;
}

#day2_program .theme_box h5{
color: #352b5e;
font-weight: bold;
line-height: 1.3em;
margin-bottom: 20px;
}

@media screen and (max-width: 786px){
.theme_box h2 br{ display: none; overflow: hidden;}
}
.theme_box h2.kichou{
    /* font-size: 1.15em; */
    font-size: clamp(1.15em, 2vw, 1.3em);
    font-weight: bold;
    margin-bottom: 10px;
    text-align: left;
    color:#333333;
    line-height: 1.2em;
}

.theme_box h4.icon_award{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    color: #B60046
}

.program_box .theme_box h4.icon_award img{
width: 40px;
margin-right: 10px;
}

.program_box .program_box_3com{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

/* .program_box .program_box_3com blockquote{
width: calc(100% / 3);
} */
@media screen and (max-width: 786px){
/* .program_box .program_box_3com {
    display: block;
} */

.program_box .program_box_3com blockquote {
    width: 100%;
    font-size: 50%;
}
}

.program_box .program_box_3com .program_box_3com_inner{
padding: 15px;
overflow: hidden;
}

#day2_program .program_box .program_box_3com .program_box_3com_inner{
padding-bottom: 20px;
}

@media screen and (max-width: 450px){
    .program_box .program_box_3com .program_box_3com_inner{
        padding: 5px;
    }
}

.theme_box h5.kouhyou{
display: block;
background: rgba(11,158,231,0.50);
padding: 0 10px;
font-size: 0.8em;
}

.theme_box h5.midashi_ir{
display: block;
background: rgba(241,124,220,1.00);
font-weight: bold;
color: #ffffff;
padding: 0 10px;
margin-bottom: 15px;
}

.theme_box .com_name_l {
    font-size: 1.1em;
    font-weight: bold;
    line-height: 1.3em;
}

.theme_box .com_name {
    font-weight: bold;
    line-height: 1.3em;
    font-size: 0.95em;
}

.theme_box .com_name_s {
    font-weight: bold;
    line-height: 1.3em;
    font-size:0.8em;
}

.theme_box .copy{
font-size: 0.8em;
line-height: 1.4em;
overflow: hidden;
}

@media screen and (max-width: 786px){
.theme_box .copy{ overflow: visible;}
}

.theme_box .photo{
    float: right;
    width: 140px;
    box-sizing: border-box;
    margin-left: 15px;
}

/* .theme_box .photo img{
    border-radius: 15px;
} */

#day2_program .theme_box .photo{
 width: 90px;
}

.theme_box .photo__s{
    float: right;
    width: 80px;
    box-sizing: border-box;
    margin-left: 15px;
}

@media screen and (max-width: 786px){
.theme_box .photo,
.theme_box .photo__s{
width: 70px;}
}

.theme_box .btn_detail a{
font-size: 0.8em;
line-height: 1.3em;
}

.theme_box h4.title_ryo{
font-size: 1.1em;
font-weight: bold;
color: #B71253;
}

.theme_box h4.title_ryo span{
background: #B71253;
color: #ffffff;
font-weight: bold;
padding: 2px 10px;
font-size: 0.9em;
line-height: 1em;
}

.theme_box .jsho_box{
padding: 0px 0 10px 0;
margin-bottom: 10px;
/* border-bottom: 1px solid rgba(175,173,173,1.00); */
overflow: hidden;
}
@media screen and (max-width: 786px){
.theme_box .jsho_box{ border-bottom: none; margin-bottom: 0;}
}

.theme_box .jsho_box h5{ text-align: center; margin-bottom: 10px;}

.theme_box .jsho_box h5 .code03{
display: block;
width: auto;
}

.theme_box .jsho_box h5 .sub-title{
font-size: 1em;
    font-weight: bold;
    color: #B71253;
    margin-bottom: 10px;
    text-align: center;
}

#day1_program .contents{
z-index: 100;
position: relative;
}


/*--ss topプログラム--*/
.ss_top_program_box{
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
}

.ss_top_program_box::before{
  content:"";
  display: block;
  width:calc( 96% / 4);
  order:1;
}
.ss_top_program_box::after{
  content:"";
  display: block;
  width:calc( 96% / 4);
}

.ss_program_com{
position: relative;
width: calc( 96% / 4);
background: #ffffff;
margin: 5px 0;
padding-bottom: 15px;
display: flex;
flex-wrap: wrap;
flex-direction: column;
}

.ss_program_com figure{
margin: 10px 15px;
text-align: center;
}

@media screen and (max-width: 786px){
.ss_program_com{
width: 100%;
}
}

.ss_program_com__link::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  content: "";
  background-color: transparent;
}

.nolink::after {
  position: static;
}

.ss_program_com h5 {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px;
    font-weight: bold;
    line-height: 1.2em;
    text-align: center;
    font-size: 0.8em;
}

.ss_program_com .ss_program_com_in{
padding: 15px;
position: relative;

}

.ss_program_com p{
font-size: 0.9em;
line-height: 1.4em;
font-weight: bold;
padding: 15px 15px;

}

.ss_program_com .ribbon02{
margin: 10px 15px 0 15px;
}

.ss_program_com .btn_detail{
margin-top: auto;
}

.ss_program_com .btn_detail a{
line-height: 1.2em;
font-size: 0.7em;
text-align: center;
font-weight: normal;
}

.com__link:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  content: "";
  background-color: transparent;
}


#company .contents {
    width: 860px;
    z-index: 100;
    position: relative;
}

#company ul.dot{
margin: 0 auto;
width: 700px;
}

#company ul.dot li{
font-weight: bold;
font-size: 0.9em;
text-indent: -1em;
padding-left: 1em;
}

#company ul.dot li a{
color: rgba(111,56,133,0.7);
font-weight: bold;
white-space: nowrap;
}

#company ul.dot li a:after{
    content: '\f078';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-left: 0.3em;
}
#company ul.dot li span{
font-size: 0.9em;
font-weight: bold;
padding-left: 2em;
}

@media screen and (max-width: 786px){
#company ul.dot{width: auto;}
}

/*---------参加お申込みページ---------*/
#ppScroll {
    width: 90%;
    height: 200px;
    margin: 10px auto;
    overflow-y: scroll;
    border: 1px solid #aaa;
}

@media
only screen and (max-width : 786px){
#ppScroll { width: auto;}
}

#ppScroll p{
font-size: 0.85em;
line-height: 1.5em;
padding: 10px;
}

#ppScroll .privacyPolicy {

    padding: 0 20px;
    line-height: 1.5em;
}



#ppScroll .privacyPolicy p {

    font-size: 0.85rem;

    padding: 10px;

}



#ppScroll .privacyPolicy .ppContent {

    margin-bottom: 20px;

}



#ppScroll .privacyPolicy .ppContent .provItems {
    font-size: 0.85rem;
    padding-left: 1.5rem;
}
#ppScroll .privacyPolicy .ppContent ul.provItems li{
line-height: 1.5em;
}

#ppScroll .privacyPolicy .ppContent h4{
    font-size: 0.95em;
    margin-bottom: 0em;
    text-align: left;
    font-weight: normal;
}

#ppScroll .privacyPolicy .ppContent .provided {

    font-size: 0.85rem;

    padding-bottom: 20px;

}



#ppScroll .privacyPolicy .ppContent .purpose {
    padding-left: 2rem;
    list-style-type: disc;
}



#ppScroll .privacyPolicy .ppContent table {

    margin: 0 auto;

    border-collapse: collapse;

}



#ppScroll .privacyPolicy .ppContent table td {
    border: 1px solid;
    text-align: center;
    padding: 10px;
    font-size: 0.85em;
}

.agressBtnWrap{
    text-align: center;
    font-weight: bold;
    margin: 30px auto;
}

.agressBtnWrap .text{
    text-align: center;
    margin-bottom: 40px;
    font-weight: bold;
}

.btn_form {
    width: 328px;
    margin: 20px auto 0 auto;
    background-color:#B0ACAC;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    text-align: center;
    color: #fff !important;
    font-weight: bold;
    font-size: 1em;
    transition: .2s;
    border: 2px solid #fff;
    height: 60px;
    line-height: 60px;
}

.btn_form a{
background: #F42E02;
display: block;
    font-weight: bold;
    font-size: 1em;
    color: #fff;
    height: 60px;
    border-radius: 5px;
    text-decoration: none;
}

#plactnum_pro .contents{
z-index: 100;
position: relative;
}



#read_box h3.bottom-border::after{
width: 100%;
}

#read_box .flex-2com-1com p{
width: 70%;
}

#read_box .flex-2com-1com figure{
margin-left: 50px;
width: 200px;
}

#read_box .flex-2com-1com figure.w300{
width: 300px;
}

#read_box ul.list_down{
display: flex;
flex-wrap: wrap;
}

#read_box ul.list_down li{
font-size: 0.9em;
width: calc( 95% / 2);
}

#read_box ul.list_down li.w2nd{
width: 70%;
}

@media screen and (max-width: 786px){
#read_box .flex-2com-1com {
display: block;
}
#read_box ul.list_down li,
#read_box ul.list_down li.w2nd{
width: 100%;
}

#read_box .flex-2com-1com p{
width: 100%;
}

#read_box .flex-2com-1com figure{
margin: 15px auto 0 auto;
max-width: 200px;
}

}

/*ソリューションセッション　プログラム*/

#ss_program .contents {
    position: relative;
    z-index: 100;
}

.flex-4com {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.flex-4com .flex-4com_inner {
    background: #fff;
    box-shadow: 0 3px 6px 0 rgb(0 0 0 / 16%);
    position: relative;
    width: calc(95% / 4);
        margin-bottom: 20px;
}

@media screen and (max-width: 786px){
.flex-4com {
    display: block;
    }
.flex-4com .flex-4com_inner {
width: 100%;
}
}

#ss_program .flex-4com_inner h5 {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    padding: 10px;
    font-weight: bold;
    line-height: 1.2em;
    text-align: left;
    color: #FFFFFF;
    min-height: 3.5em;
}

@media screen and (max-width: 786px){
.flex-4com {
    display: block;
    }
.flex-4com .flex-4com_inner {
width: 100%;
}
#ss_program .flex-4com_inner h5 {
min-height: auto;
}
}

#ss_program h2{color: #ffffff;}
#ss_program .head_text:before{ color:rgba(255, 255, 255, 0.4) }


#ss_program .flex-4com_inner dl{
display: flex;
width: 90%;
margin: 15px auto 0 auto;
padding-bottom: 15px;
flex-wrap: wrap;
line-height: 1.2em;
}

#ss_program .flex-4com_inner dl dt{
width: 2.5em;
font-size: 0.8em;
}

#ss_program .flex-4com_inner dl dd{
width: calc( 100% - 3em);
line-height: 1.2em;
margin-bottom: 8px;
padding-top: 3px;
font-size: 0.85em;
}

.code_ss {
    background-color: rgba(192,14,83,1.00);
    color: #fff;
    display: inline-block;
    border-radius: 4px;
    padding: 3px 3px 2px 3px;
    line-height: 1.2;
    border: transparent 1px solid;
    font-size: 0.9em;
    font-weight: normal;
}

.bgd_C1{ background:#875A15 !important;}
.bgd_D1{ background:#007C6F !important;}
.bgd_E1{ background:#DC4F03 !important;}

.fnt_B1{ color:rgba(192,14,83,1.00);}
.fnt_C1{ color:#875A15 ;}
.fnt_D1{ color:#007C6F;}
.fnt_E1{ color:#DC4F03;}

.bgc_awards{
background: rgb(113,65,5);
background: -moz-linear-gradient(0deg, rgba(113,65,5,1) 0%, rgba(144,68,5,1) 28%, rgba(196,73,4,1) 100%);
background: -webkit-linear-gradient(0deg, rgba(113,65,5,1) 0%, rgba(144,68,5,1) 28%, rgba(196,73,4,1) 100%);
background: linear-gradient(0deg, rgba(113,65,5,1) 0%, rgba(144,68,5,1) 28%, rgba(196,73,4,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#714105",endColorstr="#c44904",GradientType=1);
}

#program_B1 .theme_box h2,
#program_C1 .theme_box h2,
#program_D1 .theme_box h2,
#program_D1 .theme_box h2,
#program_E1 .theme_box h2,
#SP .theme_box h2{
color: #000000;
}

/* 202311追加 */
.main_title {
    width: 75%;
    position: absolute;
    top: -25px;
    left: 0;
    z-index: 0;
}

@media
only screen and (max-width : 768px){
    .main_title {
        top: 20px;
    }
}

@media
only screen and (max-width : 450px){
    .main_title {
        width: 100%;
        position: static;
        top: -30px;
        left: 0;
        z-index: 0;
    }
    .itmc-logo {
        margin-top: -100px;
    }
}

.main_btn {
    position: absolute;
    bottom: 0;
    z-index: 3;
    left: 45px;
}

@media
only screen and (max-width : 786px){
    .main_btn {
        left: 0;
        bottom: -33px;
    } 
}

.summary_list {
    background: #fff;
    padding-top: 40px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    padding-bottom: 30px;
    justify-content: center;
    padding-left: 30px;
    padding-right: 30px;
}

@media
only screen and (max-width : 768px){
    .summary_list {
        padding-left: 5px;
        padding-right: 5px;
    }
}

.committee_in {
    background: #fff;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
padding: 20px;
}

#day1_program .theme_box .photo {
    width: 200px;
    margin-top: -30px;
}

#day1_program .program_box_j .theme_box .photo {
    width: 160px;
    margin-top: -30px;
}

#day1_program .theme_box .jsho_box .photo {
    margin-top: 0;
    float: none;
    margin: 0 auto;
    /* width: auto; */
}
@media
only screen and (max-width : 786px){
    #day1_program .theme_box .photo {
        width: 100px;
    }

    #day1_program .program_box_j .theme_box .photo {
        width: 100px;
    }
}

#day1_program .theme_box .jsho_box .photo img{
    border-radius: 15px;
}


#day1_program .com_name_l,
#day1_program .com_name_s,
#day1_program .com_name {
    text-align: right;
    line-height: 1.5;
}

#day1_program .jsho_box .com_name_l,
#day1_program .jsho_box .com_name_s,
#day1_program .jsho_box .com_name {
    text-align: center;
}

#day1_program .jsho_box.flex, .json_flex {
    display: flex;
    width: 100%;
    gap: 30px;
}

@media
only screen and (max-width : 786px){
	#day1_program .jsho_box.flex, .json_flex {
        flex-direction: column;
    }

    #day1_program .jsho_box .flex-2com {
        width: 100%;
        display: flex;
        justify-content: space-between;
    }

#day1_program .com_name_l,
#day1_program .com_name_s,
#day1_program .com_name {
    text-align: left;
    
}
}

#day1_program .jsho_box .flex-4 .code03 {
    width: 90%;
} 

#day1_program .theme_box {
padding: 10px 0 0 20px;
}

#day1_program .program_box_j .theme_box {
    padding: 10px;
    }

@media
only screen and (max-width : 786px){
    #day1_program .theme_box {
        padding: 10px;
        }
}


#day2_program blockquote {
    width: calc( 100% / 2);
    position: relative;
}

#day2_program .venue_box {
   /*display: flex;*/
    justify-content: center;
}

#day2_program .venue_box blockquote {
    width: calc( 100% / 2);
}



#day2_program .venue_box blockquote h2{
    text-align: center;
    font-size: 1.5em;
    margin-bottom: 0;
    color: #fff;
}

#day2_program .cate_box{
text-align: center;
font-weight: bold;
color: #ffffff;
padding: 3px 10px;
line-height: 1.3em;
font-size: 0.9em;
}

@media
only screen and (max-width : 786px){
#day2_program .cate_box{
font-size: 0.8em;
}
}
#day2_program .flex_catebox{
display: flex;
justify-content: space-between;
}

#day2_program .flex_catebox .cate_box{
width: calc(calc(100% - 10px) / 2);
}

.venue_topbk1 {
    background: #3880af;
}

.venue_topbk2 {
    background: #804c99;
}

.venue_bk1 {
    background: #c6dae7;
}

.venue_bk2 {
    background: #e9e2ed;
}


.head_text img {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.title-img {
    display: block;
}

.committee_inner {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
}

.committee_inner2 {
    display: flex;
    justify-content: flex-start;
    margin-bottom: 30px;
    gap: 5%;
}


.committee_inner p {
    line-height: 1.3;
}

.committee_inner img {
    border-radius: 15px;
    min-width: 150px;
}

.committee_inner-box {
    width: 48%;
}

@media
only screen and (max-width : 450px){
    .committee_inner {
        flex-direction: column;
        justify-content: left;
        align-items: flex-start;
        gap: 30px;
    }
    .committee_inner .flex-3 {
        width: 100%;
    } 
    .committee_inner-box {
        width: 90%;
        gap: 2%;
    }
}

#ss_program h5,
#program_B1 h3,
#program_C1 h3,
#program_D1 h3,
#program_E1 h3,
#program_F1 h3,
#program_SP h3
{
    /* background: #0c6451 !important; */
    background: linear-gradient(90deg, #412fa8 0%, #009e83 100%)!important;
}

#ss .flex-2com {
    width: 100% !important;
}

#ss figure.photo img {
    border-radius: 15px;
}

#OP4 .photo{
margin-top: -80px !important;
}

#OP5 .photo,#OP6 .photo {
    margin-top: -100px !important;
    }

    @media
    only screen and (max-width : 768px){
        #OP6 .photo,#OP5 .photo,#OP4 .photo {
            margin-top: 0!important;
            }
    }
    @media
    only screen and (max-width : 450px){
        .sp-flex {
            flex-direction: column;
            width: 50%;
            }
    }

.m-10t {
    margin-top: -10px !important;
}

.m-30t {
    margin-top: -30px !important;
}

.m-50t {
    margin-top: -50px !important;
}

@media
    only screen and (max-width : 768px){
        .m-10t {
            margin-top: 0 !important;
        }
        
        .m-30t {
            margin-top: 0 !important;
        }

        .m-50t {
            margin-top: 0 !important;
        }

    }