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

:root {
  --primary-color: #4DB675;
  --orenge-color: #FC5F00;
  --sab-color: #FFDC74;
}


/*------------------------------------------------------------
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;
}

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

html{
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
	font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-style: normal;
	color:#333;
	/*font-size:18px;*/
}

body{
    overflow-y: scroll;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
    font-size: clamp(12px, 2vw, 18px);
  line-height:1.8em;
}
 

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;}

/* 個別パーツ*/

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


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;}

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

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

.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: #0041a5;
    text-decoration: none;
}
a:visited {
    color: #0041a5;
    text-decoration: none;
}
a:hover {
    color: #0041a5;
    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;}
.w600{width:600px;}
.w650{width:650px;}
.w700{width:700px;}



/*------------------------------------------------------------
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; }
.f08em{ font-size: 0.8em; }
.f09em{ font-size: 0.9em; }
.f10em{ font-size: 1.0em; }
.f11em{ font-size: 1.1em; }
.f12em{ font-size: 1.2em; }
.f13em{ font-size: 1.3em; }
.f14em{ font-size: 1.4em; }
.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;}

.fnt_green{ color:#5e8e25;}
.fnt_blue{ color:#1c96d4;}
.fnt_dblue{ color:#032D6D;}
.fnt_pink{ color:#F762A3;}

.fnt_greenB{ color:#5e8e25; font-weight:bold;}
.fnt_blueB{ color:#1c96d4;font-weight:bold;}
.fnt_pinkB{ color:#F762A3;font-weight:bold;}

.red{color:#d60a00 !important;}
.orenge{color:var(--orenge-color);}
.white{color:#fff;}
.black{ color:#000!important;}
.gray{ color:#999;}
.brown{ color:#a36001!important;}

/*--背景色--*/
.bgc_red{ background: #C00205;}
.bgc_blue{ background: #005E92;}
.bgc_green{ background: #3C8A00;}
.bgc_pink{ background: #ea6099;}
.bgc_lgray{ background: #E6E6E6;}
.bgc_lgray2{ background: #E9E9E9;}
.bgc_orenge{ background: #DE9A00;}
.bgc_gray{ background: #616161;}

.bgc_lgreen{
background-color: rgba(208,244,218,1.00);
}

.bgc_lorenge{
background-color: rgba(249,245,223,1.00);
}
.lineh{line-height:1.3em;}

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

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

.al-c{ text-align: center; }/*中央寄せ*/
.al-r{ text-align: right; }/*右寄せ*/
.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;            /*横並び・左から右（デフォルト）*/
}

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

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

/*--注釈--*/
.note{ font-size:0.9em; padding-left:1em; text-indent:-1em;}

/* ------ アンカーリンクの調整------ */

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


/* --- wrapper --- */

.wrapper{
	width:100%;
	overflow:hidden;
	z-index:0;
	position:relative;
}

#top{display:block !important;}


.container{
	width: 100% !important;
	overflow:scroll;
	position:relative;
	padding:0!important;
	margin:0!important;
}


h2{
	font-size:1.8em !important;
	font-weight:bold;
	margin-bottom:30px !important;
	text-align:center;
}

h2 span{
font-family: 'Source Sans Pro', sans-serif;
    font-weight: 700;
    color: rgba(27, 28, 38, 0.3);
    font-size: 16px;
	display: block;
}
	
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:980px;
	margin:0 auto;
	padding:80px 0;}
	
@media
only screen and (max-width : 786px){
	.contents{ width:90% !important;padding:30px 0 !important;}
}
	
.contents01{
	width:1000px;
	margin:0 auto;
	padding:0;}
	
@media
only screen and (max-width : 786px){
	.contents01{ width:90%; padding:0px;}
}
	

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;}
}

@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: auto;
    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;}

	

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


#top_main .contents01{ text-align:center; position:relative;}
#top_main .contents01 h2{ text-align: center;margin-bottom: 0!important;}
#top_main .innar{ position:relative; padding:60px 0; overflow:hidden; margin: 0 50px;}

#top_main .contents01 .note_box{ width:332px; text-align:center; color:#fff;}

#top_main .innar .days_box{
display: flex;
justify-content: space-between;
margin: 20px 20px 25px 20px;
}

#top_main .innar .days_box figure:first-child{
margin-right: 50px;
}

#top_main .innar .btn_order a{ background-color:var(--orenge-color); }
#top_main .innar .btn_order a:hover{ background-color:var(--primary-color);}

@media
only screen and (max-width : 786px){
	#top_main .contents01{ text-align: center;}
	#top_main .innar{ padding: 10px 0 20px 0; margin: 0 auto;}
	#top_main .innar h2{ margin: 0 auto 0px auto !important;}
	#top_main .innar .arrow,#top_main .innar .main_img{ display: none;}
	#top_main .innar .days_box{
padding: 0;
max-width: 95%;
margin: 10px auto 0 auto;
}
}
#top_main .contents01 p{ margin-bottom:10px; text-align: center;margin-left: 10px;}

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

#top_main .read{ font-size:1em; text-align:left; line-height:1.8em;}


	
#top_main .contents01 p.note{
text-align: center;
font-weight: bold;
fonte-size:0.8em;
color: rgba(138,2,111,1.00);
text-shadow:0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff;
}
	
	

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

#top_main .contents01 .days{
	position: relative;
	top:auto;
	right:auto;
	width:140px;
	text-align:center;
	margin:10px auto;}
}



/*ナビゲーションまで*/
.section1{
	width:100%;
	padding: 0;
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#bfd500+0,53b332+100 */
background:url("../img/main_bk.jpg") no-repeat center top;
position:relative;
}

@media
only screen and (max-width : 786px){
	.section1{
	padding:25px 0 0 0;
    background:url("../img/main_bk_sp.jpg") no-repeat center top;}
	
}

@media
only screen and (min-width : 2000px){
	.section1{
    background:url("../img/main_bk.jpg") ;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;}
	
}

#profile{ background-color:#E6E6E6;}

#profile .prof_box{ display:flex; justify-content:flex-end; align-items:flex-end; width:580px; margin:0 auto 30px auto;}

#profile .prof_box p{ text-align:right; font-weight:bold;}

#profile .prof_box  .prof_box__imgbox{ width:160px; margin-left:30px;}

@media
only screen and (max-width : 786px){
	#profile .prof_box{ width:100%;margin-left:15px; align-items: flex-start;}
	#profile .prof_box  .prof_box__imgbox{ width:100px; margin-left:20px;}
}



.bk_bgimg {
    background: url("../img/main_bk.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(18,175,149,0.80);
}
#gaiyou .contents{ 
width:860px;
z-index: 100;
position: relative;
}

.section_gaiyou h2{
color: #ffffff;
}

.section_gaiyou h2 span{
color: rgba(133,133,133,1.00);
z-index: 88;
}

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

.section_gaiyou dl{ margin-bottom:20px; line-height: 1.5em;}

.section_gaiyou dl dt{ 
width:160px; 
text-align:center; 
color:#333333; 
background: var(--sab-color);
padding:0.2em 0;
margin-bottom:0.5em;
font-weight: bold;
}

.section_gaiyou dl dd{
	margin-left:0.5em;;
margin-bottom:0.5em;
background: #fff;
width: 660px;
padding: 0.2em 10px;
}
.icon_code{
	padding:3px 8px;
	background-color:#C90306;
	color:#fff;
	font-weight:bold;
	line-height:1.3em;
	display: inline-block;
	text-align:center;
}


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

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

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


#objectives .contents p{
font-size: 0.9em;
line-height: 1.8em;
text-align: justify;
}


/*プログラム--*/

#program {
position: relative;
z-index: 1;
}

.bk_bgimg_pro {
    background: url("../img/main_bk.jpg") no-repeat center center;
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
    position: relative;
    z-index: 1;
}

.bk_bgimg_pro:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: rgba(245,255,250,0.70);
}


#program .contents{ width:1100px;
    z-index: 100;
    position: relative;
}

#program .copy{ font-size: 0.9em; text-align: center;}

#program ul.sab-navi{
margin: 0 auto 20px auto;
width: 800px;
display: flex;
justify-content: space-between;
}

#program ul.sab-navi li{
width: calc(96%/2);
padding: 3px;
color: #fff;
font-weight: bold;
font-size: 0.8em;
text-align: center;
}

#program ul.sab-navi li a{ text-align: center;color: #fff;display: block;}
#program ul.sab-navi li:hover{ text-decoration: none; background: rgba(87,0,196,1.00);display: block;text-decoration: none;}

@media
only screen and (max-width : 786px){
#program ul.sab-navi{ width: 90%; display: block;}
#program ul.sab-navi li{width: 100%;}

}



#program .program_com00{
	     box-shadow: 0px 8px 8px -6px rgba(0, 0, 0, 0.25);
	    background-color: #fff;
		overflow: hidden;
		margin-top: 20px;
        position: relative;
}

#program .program_com00 .inner{
padding: 20px 30px 30px 30px;
}

@media
only screen and (max-width : 786px){
#program .program_com00 .inner{
    width:auto;
    padding: 10px 15px;
}
}

  #program .program_com00 .icon_se{
  display: inline-block;
  padding: 3px 0 3px 20px;
  font-size: 0.8em;
  color: #fff;
  border-radius: 0 5px 5px 0;
  width: 15em;
  font-weight: bold;
  margin-top: 15px;
  }

#program .program_com00 .title_ai{
	font-size: 1.6em;
	font-weight: bold;
	color: #03754C;
	margin-bottom: 0.5em;
}

#program .program_com00 h3{
	font-size: 1.4em;
	font-weight: bold;
	color: #A42F02;
}

#program .program_com00 .left-box01{
float: left;
width: 50%;
}

#program .program_com00 .content_box{
display: flex;
justify-content: space-between;
}

#program .program_com00 .content_box .content_box_inner{
width: 70%;
}

@media
only screen and (max-width : 786px){
#program .program_com00 .content_box{
display: block;
}
#program .program_com00 .content_box .content_box_inner{
width: 100%;
}
}

#program .program_com00 .left-box,
#program .program_com .left-box{
float: left;
width: 48%;
}

#program .program_com00 .right-box,
#program .program_com .right-box{
float: right;
width: 50%;
/* width: 48%; */
/* padding-left: 2%; */
border-left: 1px solid #c1c1c1;
}

.right-box h5{ color:#0A465C; padding-left:0.8em; text-indent:-0.8em; text-align:left; font-size:0.8em;}
.right-box p.text_link{ color:#0A465C; padding-left:2em; text-indent:-0.8em; text-align:left !important;}
.right-box p.text_fun{ text-align:center !important;float:none !important; font-size: 0.75em;}


#program .photo_box,
#kouyasai .photo_box{
    float: right;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    flex-wrap: wrap;
    margin-top: 10px;
}

#program .program_com00 .photo_box{
    float: right;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    margin-top: 10px;
    margin-left: 20px;
}



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

#program .program_com00 .photo_box img{
margin-bottom: 5px;
}

#kouyasai .photo_box img{
width: 90px;
margin-left: 10px;
}

@media
only screen and (max-width : 786px){
#kouyasai .photo_box img{
width: 60px;
}
#program .program_com00 .photo_box{
    float: none;
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: nowrap;
    margin-top: 10px;
    margin-left: 20px;
    width: 100%;
    margin-bottom: 15px;
}

#program .program_com00 .photo_box img{
width: 90px;
margin-left: 10px;
}

}

#program .program_com00 .photo_box .caption{
  line-height: 1.2em;
  font-size: 1em;
  text-align: right;
  font-weight: bold;
}

#kouyasai .photo_box .caption{
  line-height: 1.2em;
  text-align: right;
  font-size: 0.9em;
}

#program .photo_box .caption span{ font-weight: bold;}

@media
only screen and (max-width : 786px){
#program .program_com00 .left-box,
#program .program_com .left-box,
#program .program_com00 .right-box,
#program .program_com .right-box{
float: none;
width: auto;
overflow: hidden;
border-left: none;
}
#program .program_com00 .left-box,
#program .program_com .left-box{
margin-bottom: 20px;
}
}

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

 #program .program_com{
 background: #fff;
 padding: 15px 0 20px 0;
 width: calc(98%/2);
 margin-top:20px;
 position: relative;
  box-shadow: 0px 8px 8px -6px rgba(0, 0, 0, 0.25);
 }
 
  #program .program_com .innar{
  	padding: 10px 20px 0px 20px;
  }
 
  #program .program_com .icon_se,
 .prf_headbox .icon_se{
  display: inline-block;
  padding: 3px 0 3px 20px;
  font-size: 0.8em;
  color: #fff;
  border-radius: 0 5px 5px 0;
  width: 15em;
  font-weight: bold;
  }
  
#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 .categ{
   position: absolute;
   top: -5px;
   right: -5px;
   text-align: right;
   padding: 8px;
   color: #ffffff;
   background: rgba(129,70,0,1.00);
   font-size: 0.7em;
   display: inline;
   line-height: 1em;
   border-radius: 5px;
   font-weight: bold;
   }
  
   #program .program_com .rogo,
   #program .program_com00 .rogo{
   position: absolute;
   top: 40px;
   right: 20px;
   width: 240px;
   text-align: right;
   }
   
    #program .program_com .rogo2{
   position: absolute;
   top: 20px;
   right: 20px;
   width: 200px;
   text-align: right;
   }
   
 #program .program_com .rogo3{
   position: absolute;
   top: 30px;
   right: 20px;
   width: 240px;
   text-align: right;
   }
   
#program .program_com .rogo4{
   position: absolute;
   top: 70px;
   right: 5px;
   width: 200px;
   text-align: right;
   }
   
#program .program_com .rogo img,
#program .program_com .rogo2 img,
#program .program_com .rogo3 img,
#program .program_com .rogo4 img{
   vertical-align: top;
   }
  
  #program .program_com h3{
	font-size: 1em;
	font-weight: bold;
	color: #A42F02;
	margin-bottom: 10px;
    line-height: 1.4em;
	}

  #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 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 .com_name{
 font-weight: bold;
 color: #C85004;
 font-size: 1.1em;
 }
 #program .program_com .flex-container{
 justify-content: flex-end;
 }
 
  #program .program_com .flex-container .photo_box{
  float: none;
  }
 
 
.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,
#program .program_com .rogo4{
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 .program_com .m20-r{ margin-right: 0 !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: #0089d3;
    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.se_tb:before{
background-color: #DE9A00;
}
#program .program_com 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;          /* 余白指定 */
}
ul.list_dot li{
    text-indent: -1.3em;
    padding: 0 0 0 1.3em;
    vertical-align: baseline;
}

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

.program_box .theme h3 {
    font-size: 1.2em;
    font-weight: bold;
    color: #005bac;
	margin-bottom:0.8em;
}

.program_box .theme h4 {
    font-size: 1.1em;
    font-weight: bold;
}

.program_box .theme h3.styel_s{
	font-size:1.1em;}

.program_box .theme p.text {
    font-weight: bold;
	text-align: right;
	line-height:1.2em;
	font-size:0.8em;
}
.program_box .theme p.copy {
	line-height:1.5em;
	font-size:0.85em;
	margin-bottom:0.8em;
	text-align:justify;
}

.program_box .theme .img_box {
    float: right;
    width: 123px;
    margin-left: 20px;
	overflow:hidden;
}
.program_box .theme .img_box img{margin-bottom:0.5em;}


.program_box .theme .img_box p { 
font-size:0.75em; text-align:center;
display:block;
}

.program_box .theme .img_box p a{background-color:#6FA6E8; display:block;padding:0.2em 0.5em;}

.program_box .theme .img_box p a:hover{ background-color:#BED3E8;text-decoration: none !important;display:block;padding:0.2em 0.5em;}

.program_box .theme a{ color:#333 !important;background-color:#6FA6E8;}

@media
only screen and (max-width : 786px){
	.program_box .theme p.text{ font-size:0.9em;}
	.program_box .theme img_box { width:90px;}
}

.program_box .theme dl { margin-bottom:0.8em;}
.program_box .theme dl dt{
	float:left;
	border:1px solid #6BB82C;
	font-weight:bold;
	color:#6BB82C;
	text-align:center;
	width:6em;}
.program_box .theme dl dd {
	font-size:0.8em;
	padding-left:9em;
	margin:0;
	line-height:1.2em;}

.program_box .theme p.text span{ font-weight: normal; font-size:0.8em;}
.program_box .code {
    background-color:#6BB82C;
    color: #fff;
    display: inline-block;
    border-radius: 4px;
    padding: 0.2em 1em;
    margin-bottom: 2px;
    line-height: 1;
    border: transparent 1px solid;
}

@media
only screen and (max-width : 786px){
	.program_box .icon_code br{display:none;}
}

/*--詳しくはこちらwodal--*/

.modal{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
	z-index:100;
	overflow:scroll;
	font-size:0.7em;
}
.modal__bg{
    background: rgba(0,0,0,0.8);
    height: 100vh;
    position: absolute;
    width: 100%;
}
.modal__content{
    background: #fff;
    left: 50%;
    padding: 40px;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 60%;
	overflow:scroll;
	height:auto;
    max-height: 80%;
    }

@media
only screen and (max-width : 786px){
	.modal__content{
		padding: 20px;
		width: 80%;
	}
}

.modal__content .prf_headbox .icon_se{
font-size: 1.1em;
}

.modal__content h2{
  position: relative;
  padding: 5px 26px 5px 42px;
  background: #7ac943;
  font-size: 20px;
  margin-left: -15px;
  line-height: 1.3;
  z-index:-2;
  text-align:center;
  font-weight:bold;
  margin-bottom:30px;
}


.modal__content h4{
  font-size: 1.4em;
  color: #192172;
  line-height: 1.3;
  font-weight:bold;
  margin-bottom:15px;
}


.modal__content .prf_headbox{
	overflow:hidden;}
	
.modal__content .prf_headbox img{ float:right; width:120px; margin-left:15px; margin-bottom: 20px;}
@media
only screen and (max-width : 786px){
	.modal__content .prf_headbox img{ width:60px;}
}

.modal__content .prf_headbox h3{ font-size:1.5em; font-weight:bold; margin-top:15px;color: #A42F02;}
.modal__content .prf_headbox .com_name{ font-size:1.2em; font-weight: bold;line-height: 1.5em; margin-bottom: 20px;}

.modal__content .categ{
   position: static;
   top:auto;
   right: auto;
   text-align: center;
   padding: 8px;
   color: #ffffff;
   background: rgba(129,70,0,1.00);
   font-size: 1em;
   display: inline;
   line-height: 1em;
   margin-left: 10px;
   border-radius: 5px;
   font-weight: bold;
   }

.modal__content ul{ margin:0 auto 20px auto;}
.modal__content ul li { 
    padding-left: 1em; 
    text-indent: -1em;
	line-height:1.5em;
	margin-bottom:0.5em;
}
.modal__content ul li:before {
    content: "● ";
    color: grey;
}

.modal__content ol.list_no li{
font-size: 1em;
}

.modal__content dt{ width:4em; float:left; text-align:center; margin:0;}
.modal__content dd{ padding-left:4.5em; margin:0;}


.modal__content .imgbox { align-items:flex-end;
flex-wrap: wrap;
flex-direction: row;   }

.modal__content .imgbox div{ margin: 5px; width:calc(100% /4.3);}

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

.modal__content .photo_2com_innder{
width: 47%;
}

@media
only screen and (max-width : 786px){
.modal__content .photo_2com{
display: block;}
.modal__content .photo_2com_innder{
width: 100%;
overflow: hidden;
}
}

.js-modal-close{
display: flow-root;
}

.js-modal-close p { 
font-size:1em; text-align:center; margin-top:0.2em; vertical-align:bottom;
padding:0.2em 0.5em;
line-height:1.4em;
background-color:#6FA6E8;
margin-bottom:20px;
float:right;}

.js-modal-close p:hover{ background-color:#BED3E8;text-decoration: none !important;}

.btn_open{
float: right;
display: inline-block;
  text-decoration: none;
  border-radius: 4px;
  color: #ffffff;
  background:#4db2bc;
  line-height:2em;
  text-align:center;
  width:8em;
  margin: 10px auto 5px auto;
  font-size:0.7em;
}

.btn_open a,
.btn_open:hover{
color: #fff;
background-color:#d34b96;
text-decoration: none;
}

 a.prof_btn,
.js-modal-close a {
    background-color: var(--primary-color);
    padding: 0.5em 2em;
    color: #fff;
    font-size: 0.7em;
    margin-top:10px;
    border-radius: 5px;
    text-align:  center;
    line-height: 1.3em;
    display: inline-block;
}

 a.prof_btn span,
.js-modal-close a span{
vertical-align: middle;
font-size: 16px;
}
 a.prof_btn:hover,
.js-modal-close a:hover{
    background-color: var(--orenge-color);
    text-decoration: none;
}
.js-modal-close a {
line-height: 1.6em;
 padding: 0.5em 2em;
 font-size: 1em;
 float: right;
}

.modal_bnr{
 width: calc(500px - 20px);
background: #ffffff;
padding: 10px;
text-align: center;
}
@media
only screen and (max-width : 786px){
.modal_bnr{
 width: calc(100% - 20px);
}
}



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

.material-icons.small-size {
	font-size: 16px;
}



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

.material-icons.small-size {
	font-size: 16px;
}

.program_box .code01 {
    background-color:#E94D00;
    color: #fff;
    display: inline-block;
    padding: 5px 7px;
    margin-bottom: 2px;
    line-height: 1;
    border: transparent 1px solid;
	width:8em;
	text-align:center;
	border-radius:5px;
}

.program_box .code01.wauto{ width:11em;}

.program_box .code02 {
    background-color:#ffd800;
    display: inline-block;
    padding: 5px 7px;
    margin-bottom: 2px;
    line-height: 1;
    border: transparent 1px solid;
	width:8em;
	text-align:center;
		border-radius:5px;
		font-size:0.9em;
}

.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_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;}

/*プログラム　クリックで開閉*/

.program_box .detail_box {
    display: flex;
    justify-content: flex-start;
    /* width: 719px; */
    margin: 20px 10px 30px 10px;
}

.hidden_box {
    padding: 0;
}

/*ボタン装飾*/
.hidden_box label {
    cursor :pointer;
        padding: 5px 3em;
    background-color: #38b48b;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    text-align: center;
    color: #fff !important;
    font-weight: bold;
    font-size: 0.7em;
    transition: .2s;
    border: 2px solid #fff;
    line-height: 1.3em;
    display: inline-block;
}

/*アイコンを表示*/
.hidden_box label:before {
    display: inline-block;
    content: '\f078';
    font-family: 'FontAwesome';
    padding-right: 5px;
    transition: 0.2s;
}

/*ボタンホバー時*/
.hidden_box label:hover {
    background: rgba(0,47,123,1.00);
}

/*アイコンを切り替え*/
.hidden_box input:checked ~ label:before {
     content: '\f00d';
     -webkit-transform: rotate(360deg);
     transform: rotate(360deg);
     color: #ffffff;
}

/*チェックは見えなくする*/
.hidden_box input {
    display: none;
}

/*中身を非表示にしておく*/
.hidden_box .hidden_show {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show {
    padding: 10px 0;
    height: auto;
    opacity: 1;
}

.hidden_box .hidden_show P{
font-size: 0.75em;
text-align: left;
line-height: 1.3em;
padding: 0px 0 0px 10px;
}



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

.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 #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;
}



.section3{
	width:100%;
	padding:30px 0 30px 0;
position:relative;
z-index:10;
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#a3dcf7+0,009fe8+62,009844+100 */
background: #a3dcf7; /* Old browsers */
background: -moz-linear-gradient(top, #a3dcf7 0%, #009fe8 62%, #009844 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, #a3dcf7 0%,#009fe8 62%,#009844 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, #a3dcf7 0%,#009fe8 62%,#009844 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a3dcf7', endColorstr='#009844',GradientType=0 ); /* IE6-9 */
}

@media
only screen and (max-width : 786px){
	.section3{padding:30px 0 ;}
}

/*.section3::before{
  content: '';
  position: absolute;
  left:0;
  top: 0;
  /*四角形を傾けます*/
  /* transform: skewY(-3deg);
  transform-origin: bottom left;
  z-index: -1;
  width:100%;
  height:100%;
  background:#EDEDED;
}*/

	
/*お問い合わせContact*/
#contact{
background-image: linear-gradient( 135deg, #81FBB8 10%, #28C76F 100%);
}

#contact h2{
	margin-bottom:10px;
    color: #ffffff;
}

#contact h2 span{
color:rgba(133,133,133,1.00)
}

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

#contact dl{
	width: 600px;
	margin:0 auto;
    color: #333333;
}
	
	
#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;}

	
@media
only screen and (max-width : 786px){
	#contact .flex-container{ display:block;}
	#contact dl{
	width: 100%; margin-bottom:10px;}
#contact .cont_innar{
	width:100%;}
}

.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(../img/window01-07.png);
	font-size:1em;
	margin-left: 0.5em;
	font-weight: normal;
}

#com_bnr .bnr_box{
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;
width: 100%;
text-align:center;
  justify-content: center;
  align-items: center;
}

#com_bnr .bnr_box div{ width:400px;}

#bnr_box .contents{padding: 30px 0; text-align:center;}

/*お問い合わせ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;}

#order .entry_box{
width: 80%;
margin: 20px auto;
text-align: center;
padding: 20px 0;
border-radius: 15px;
}




	
@media
only screen and (max-width : 786px){
#order .entry_box{
width: auto;
padding: 20px;}
		#order table{ width:100%;}
	#order .innar{ width:100%;}
}

/* btn Style
-------------------------------------------------------- */
.btn_order{
	margin:0 auto 0 auto;	
}
.btn_order a{
	width:328px;
	    padding: 10px 0;
    margin: 20px auto 0 auto;
    display: inline-block;
    background-color: var(--orenge-color);
    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.style_call{ background:none;}
.btn_order a.style_call:hover{
background: var(--orenge-color);
}



.btn_order a:hover,
.btn_order02 a:hover{
	background-color:var(--primary-color); 	
	display: inline-block;
	text-decoration:none;
}

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



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



#page-top a {
    position: fixed;
    right: 10px;
    bottom: 10px;
    font-size: 2em;
    background: rgba(107,106,106,1.00);
    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{
    background: #F6AB00;
    text-decoration: none;
}



/* 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;
	background: #fff;
}
#top-head a,
#top-head {
    text-decoration: none;
	color:#333;
}

#top-head h1 span{
float: right;
font-weight: bold;
line-height: 65px;

}
#top-head .inner {
    position: relative;
}
#top-head .logo {
    float: left;
	padding:10px 0;
	height:45px;
}

/*#top-head .logo img{
    width:489px;
}*/

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

#top-head .logo {
height: 35px;
}

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

/* 共通メニュー */
.fixed {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000;
}

#navi{
width: 100%;
background:rgba(77,182,117,0.7);
      transition: all 0.3s ease 0s;
}

.nav {
      position: static;
      top: -30px;
      transition: all 0.3s ease 0s;
}

.is-fixed {
      position: fixed;
      top: 0;
      left: 0;
      z-index: 2;
      width: 100%;
}

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

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

#navi .navi_innar ul li{
 flex-grow:1;
}

#navi .navi_innar ul li a{
background-color: var(--primary-color);
color: #ffffff;
text-align: center;
padding: 5px;
line-height: 2em;
display: block;
font-size: 0.8em;
}

#navi .navi_innar ul li a.event{
background-color:  var(--sab-color);
color: #000;
}

#navi .navi_innar ul li a.event:hover{
color: #ffffff;
}

#navi .navi_innar ul li a:hover{
background: var(--orenge-color);
	text-align: center;
	padding: 5px;
	line-height: 2em;
	display: block;
	text-decoration: none;
	}

#navi .navi_innar ul li.nolink a{
background: none !important;
    pointer-events: none;
	opacity: 1;
    color:#666666;
}
@media
only screen and (max-width : 786px){
.inner {
    width: 95%;
	margin: 0 auto;
    padding: 0;
	}
#navi .navi_innar{
 width: 100%;
 }
#navi .navi_innar ul{
flex-wrap: wrap;
}
#navi .navi_innar ul li{
 width: calc(100%/2);
 border-bottom: 1px solid #ffffff;
 line-height: 1.2em;
 font-size: 0.9em;
 box-sizing: border-box;
}

#navi .navi_innar ul li a:nth-child(1){
border-left: 1px solid #ffffff;
}

#navi .navi_innar ul li a,
#navi .navi_innar ul li a:hover{
line-height: 1.2em;

}
/*奇数の場合
#navi .navi_innar ul li:last-child{
width: 100%;
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: block;
    text-align: center;
}

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

ul.bnr_box li {
    vertical-align: middle;
    display: inline-block;
    justify-content: center;
	margin:15px;
}

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

#bnr h2{
margin-bottom: 0!important;
}

#bnr h3 {
　　text-align: center;
    font-weight: bold;
	margin: 30px auto;
}

.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;
}

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

.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;
}

.bnr{
margin: 15px auto 0 auto;
text-align: center;
}

.btn_open{
float: right;
display: inline-block;
  text-decoration: none;
  border-radius: 4px;
  color: #ffffff;
  background:#4db2bc;
  line-height:2em;
  text-align:center;
  width:8em;
  margin: 10px auto 5px auto;
  font-size:0.7em;
}

#kouyasai h2{
margin-bottom: 10px!important;
color: var(--orenge-color);
}

#kouyasai h3{
margin-bottom: 15px!important;
color: var(--orenge-color);
font-size: 1.3em;
font-weight: bold;
}


#kouyasai .day{
text-align: center;
font-size: 1em;
font-weight: bold;
margin:0 auto 40px auto;
color: #035A00;
position: relative;
  padding:0.25em 1em;
  display: inline-block;
  top:0;
}

.day:before, .day:after {
  position: absolute;
  top: 0;
  content:'';
  width: 8px;
  height: 100%;
  display: inline-block;
  }
.day:before {
  border-left: solid 1px #035A00;
  border-top: solid 1px #035A00;
  border-bottom: solid 1px #035A00;
  left: 0;
}
.day:after {
  content: '';
  border-top: solid 1px #035A00;
  border-right: solid 1px #035A00;
  border-bottom: solid 1px #035A00;
  right: 0;
}

.toku_box{
display: flex;
    gap: 2%;
    margin-bottom: 20px;
    align-items: center;
}

.toku_box_l {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: var(--orenge-color);
    color: #fff;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    line-height: 1;
    min-width: 50px;
  padding: 0 5px;
  text-align: center;
  font-weight: bold;
  box-sizing: border-box;
    position: relative;
}

.toku_box_l span{
font-size: 0.6em;
}

.toku_box_l:before {
  content: "";
  position: absolute;
  top: 50%;
  right: -25px;
  margin-top: -15px;
  border: 15px solid transparent;
  border-left: 15px solid var(--orenge-color);
  z-index: 0;
}

.toku_box_r{
 width: calc(100% - 70px);
 font-size: 0.9em;
 line-height: 1.4em;
}

@media
only screen and (max-width : 786px){
.toku_box_l {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    min-width: 40px;
}
.toku_box_l:before {
  right: -15px;
  margin-top: -10px;
  border: 10px solid transparent;
  border-left: 10px solid var(--orenge-color);
  }
}

#kouyasai table{
  width: 100%;
  border-collapse: collapse;
  margin-top: 30px;
}

#kouyasai table tr{
  border-bottom: solid 2px white;
}

#kouyasai table tr:last-child{
  border-bottom: none;
}

#kouyasai table th{
 /* position: relative;*/
  text-align: left;
  width: 20%;
  background-color: var(--orenge-color);
  color: white;
  text-align: center;
  padding: 10px 0;
}

/*#kouyasai table th:after{
  display: block;
  content: "";
  width: 0px;
  height: 0px;
  position: absolute;
  top:calc(50% - 10px);
  right:-10px;
  border-left: 10px solid rgba(89,0,143,1.00);
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
}*/

#kouyasai table td{
  text-align: left;
  width: 80%;
  background-color: #eee;
  padding: 10px 15px;
  font-size: 0.9em;
}

@media
only screen and (max-width : 786px){
#kouyasai table td,
#kouyasai table th{
display: block;
width: 100%;
overflow: hidden;
}
#kouyasai table td{
  padding: 10px;
width:  calc(100% - 20px);
}
}



#kouyasai table td ol.list_no li{
    font-size: 0.9em;
}

#kouyasai table td ol.list_no li:before{
    background-color:rgba(153,38,185,1.00);
	}

#kouyasai table td p{
line-height: 1.4em;
}

.kouya_tb_midashi{
font-weight: bold;
color: var(--orenge-color);
margin-bottom: 5px;
}

.kouya_tb_title{
font-weight: bold;
font-size: 1em;
margin-bottom: 10px;
}

.kouya_tb_name{
font-size: 0.9em;
}

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

.kys_photo_2com_innder{
width: 50%;
}

.kys_photo_2com_innder:first-child{
width: 46%;
}

@media
only screen and (max-width : 786px){
.kys_photo_2com{display: block;
}
.kys_photo_2com_innder,
.kys_photo_2com_innder:first-child{
width: 100%;
}
#kouyasai .m30-t{
margin-top: 0!important;
}
}

#kouyasai .note{
line-height: 1.3em;
}

.mov_box-img img {
  border: 1px solid #c1c1c1;
  max-width: 300px;
}

.text_end{
font-size: 1.2em;
color: #666666;
font-weight: bold;
margin-bottom: 30px;
}

.mov_box{
margin: 0 auto;
display: flex;
justify-content: space-between;
}

.mov_box .img_box{
max-width: 60%;
text-align: center;
    figcaption{font-size: 0.7em;}
}

@media
only screen and (max-width : 786px){
.mov_box{
flex-direction: column;
gap: 10px 0;
}
.mov_box .img_box{
max-width: 100%;
}

}

#NV1_movie{
    .contents{ padding: 60px 0 50px 0;}
    h5{
        display: inline-block;
    padding: 3px 0 3px 20px;
    font-size: 0.8em;
    color: #fff;
    border-radius: 0 5px 5px 0;
    width: 15em;
    font-weight: bold;
    background: #616161;
    }
    .categ {
    text-align: center;
    padding: 8px;
    color: #ffffff;
    background: rgba(129, 70, 0, 1.00);
    font-size: 0.7em;
    display: inline;
    line-height: 1em;
    border-radius: 5px;
    font-weight: bold;
  }
  h3 {
    font-size: 1em;
    font-weight: bold;
    color: #A42F02;
    margin-bottom: 10px;
    line-height: 1.4em;
    margin-top: 10px;
    }
.copy{ font-size: 0.8em; line-height: 1.4em; margin-bottom: 10px;}
    .mov_box{
    gap:20px 5%;
        .inner{ width: 45%;}
        .mov_box-img img{ max-width: 100%!important; }
    }
    .name{ font-size: 0.8em;    line-height: 1.2em;}
    .photo_box {
    float: right;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    flex-wrap: wrap;
        img {
    width: 90px;
    margin-left: 20px;
        }
    }
}

@media
only screen and (max-width : 786px){
#NV1_movie{
  .mov_box .inner{ width: 100%;}

    .categ{ display: block; width: 18em; margin-top: 10px;}
    }
}

.pdf_box{
    margin: 50px auto;
    padding: 20px;
    border: 2px dashed rgba(145,144,144,1.00);
    width: 70%;
    background: rgba(255,220,116,0.2);
    }
@media
only screen and (max-width : 786px){
.pdf_box{
width: calc(100% - 40px);
}
}

.material-symbols-outlined{
display: inline-flex;
vertical-align: middle;

}

ul.list_pdf {
margin: 0 auto;
max-width: 80%;
}
ul.list_pdf li{
text-indent: -1em;
padding-left: 1em;
font-size: 0.9em;
}

ul.list_pdf li a:before{
content: "\f1c1";
font-weight: 900;
font-family: "Font Awesome 5 Free";
}

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