@charset "utf-8";
/* CSS Document  2026.第10回デジタルビジネス推進研究会*/

  /* サイトカラー */
:root {
    --primary-color: rgb(0, 86, 141);
    --sab-blule-color: rgb(8, 38, 56);
    --sab-yellow-color:#dbe000;
}

/*------------------------------------------------------------
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 ,picture{
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
}

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

html{
    overflow-y: scroll;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
    font-size: clamp(13px, 2vw, 18px);
  line-height:1.6em;
  font-family:  "Lato","YakuHanJP","Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
}

_::-webkit-full-page-media, :root, body {
-webkit-animation: safariFix 1s forwards infinite;
}
@-webkit-keyframes safariFix {
    100% {z-index: 1;}
}

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

.sup{
	font-size: 75.5%;
    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;}

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

.dnone{display: none;}

/*------------------------------------------------------------
個別パーツ 
------------------------------------------------------------*/
/*--- 画像 ---*/
img, canvas, iframe, video, svg, picture {
	max-width:100%;
	height: auto;
	vertical-align: middle;
	-ms-interpolation-mode: bicubic;
	border: 0;
    z-index: 2;
}

a img {border: none;}

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

/*--- 変化
.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);
}
変化 ---*/

/*--- box
.leftbox{float:left;}

.rightbox{float:right;}

.nojustify{ text-align:left !important;}
box ---*/
/*------------------------------------------------------------
幅
------------------------------------------------------------*/
.w125{width:145px;}
.w70{width:70px;}
.w300{width:270px;}
.w500{width:500px!important;}
.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・・・フォントサイズの設定
-------------------------------------------------------------*/
h2{
    font-size:1.8em ;
	font-weight:700;
	margin-bottom:30px ;
	text-align:left;
    color: #fff;
    @media only screen and (max-width : 768px){margin-bottom:20px!important;}
}

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

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

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

.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; }
/*------------------------------------------------------------
line-height・・・行間の設定
-------------------------------------------------------------*/
.lh12em{ line-height: 1.2em !important;}
.lh13em{ line-height: 1.3em !important;}
.lh14em{ line-height: 1.4em !important;}
.lh16em{ line-height: 1.6em !important;}
/*------------------------------------------------------------
色
-------------------------------------------------------------*/
.lgreen{ color:#18933b;}
.green{color:#006837;}
.blue{ color:#1c96d4;}
.dblue{ color:#032D6D;}
.ddblue{color: #162067;}
.pink{ color:#dd007f;}
.red{color:#d60a00 !important;}
.white{color:#fff;}
.black{ color:#000!important;}
.gray{ color:#999!important;}
.dgray{ color:#666!important;}
.brown{ color:#a36001!important;}

.fnt_lgreen{ 
    color:rgba(24,147,59,1.00); 
    font-weight:bold;
}
.fnt_blue{
    color:#1c96d4;
    font-weight:bold;
}
.fnt_pink{ 
    color:#dd007f;
    font-weight:bold;
}

/*--- 背景色 ---*/
/*background-color*/
.icon_code{
	padding:3px 8px;
	background-color:#C90306;
	color:#fff;
	font-weight:bold;
	line-height:1.3em;
	display: inline-block;
	text-align:center;
}
.bgc_white{ background-color: #fff;}
.bgc_red{ background-color: #B31114;}
.bgc_lred{ background-color: #dd007f;}
.bgc_pink{ background-color: #ea6099;}
.bgc_orenge{ background-color:#ED7B61;}
.bgc_lorenge{ background-color: rgba(244,159,1,1)!important;}
.bgc_lorenge_s{ background-color: rgba(244,159,1,0.5);}
.bgc_green{ background-color: rgba(146, 168, 36, 1)!important;}
.bgc_green_s{ background-color: rgba(146, 168, 36, 0.2);}
.bgc_llblue{ background-color: #00a9e4!important;}
.bgc_dlblue{ background-color: rgba(146,180,193,1.00);}
.bgc_dllblue{ background-color: rgba(146, 181, 223, 1);}
.bgc_dblue{ background-color: rgba(2,103,143,1.00);}
.bgc_lblue{ background-color: rgba(0,130,181,0.1);}
.bgc_blue{ background-color: #162067;}
.bgc_lgray{ background-color: #E6E6E6; z-index: 1;}
.bgc_blueg{ 
    background-color: #d3edfb;  /* fallback for old browsers */
/*background: -webkit-linear-gradient(to top, rgba(14,210,247,1.00), rgba(178,254,250,1.00));  /* Chrome 10-25, Safari 5.1-6 */
/*background: linear-gradient(rgba(211,237,251,1),rgba(211,237,251,1),rgba(211,237,251,1),rgba(1, 140, 216, 0.7)); /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
}
.bgc_blueg02{ 
    background-color: #d3edfb;  /* fallback for old browsers */
/*background: -webkit-linear-gradient(to top, rgba(14,210,247,1.00), rgba(178,254,250,1.00));  /* Chrome 10-25, Safari 5.1-6 */
background: linear-gradient(rgba(74,82,139,1),rgba(22, 32, 103, 0.1)); /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
}
.bgc_black{ background-color: linear-gradient(to right, rgba(0,0,0,1), rgba(0,0,0,0.8),rgba(0,0,0,0.6),rgba(0,0,0,0));}
.bgc_blue{
    background-color: var(--sab-blule-color);
    background-image: url(../img/bk_img_02.png); 
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
}
.bgc_gblue{
    background: rgba(22, 32, 103, 1)/*=#162067*/;
    background: linear-gradient(to bottom right,rgba(22, 32, 103, 1),rgba(15,57,133,1),);
}
/*background-color*/

/*background*/
.bg_white{ background: #ffffff;}
.bg_red{ background: #B31114;}
.bg_lred{ background: #dd007f;}
.bg_pink{ background: #ea6099;}
.bg_orenge{ background: #ED7B61;}
.bg_lorenge{background: rgba(244,159,1,1)!important;}
.bg_lorenge_s{background: rgba(244,159,1,0.5);}
.bg_green{ background: rgba(146, 168, 36, 1)!important;}
.bg_green_s{ background: rgba(146, 168, 36, 0.2);}
.bg_llblue{ background: #00a9e4!important;}
.bg_dlblue{ background: rgba(146,180,193,1.00);}
.bg_dllblue{ background: rgba(146, 181, 223, 1);}
.bg_dblue{ background: var(--sab-blule-color);}
.bg_lblue{ background: rgba(0,130,181,0.1);}
.bg_blue{ background: var(--primary-color);}
.bg_lgray{ background: #E6E6E6; z-index: 1;}
.bg_blueg{background: #d3edfb;  /* fallback for old browsers */
/*background: -webkit-linear-gradient(to top, rgba(14,210,247,1.00), rgba(178,254,250,1.00));  /* Chrome 10-25, Safari 5.1-6 */
/*background: linear-gradient(rgba(211,237,251,1),rgba(211,237,251,1),rgba(211,237,251,1),rgba(1, 140, 216, 0.7)); /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
}
.bg_blueg02{background: #d3edfb;  /* fallback for old browsers */
/*background: -webkit-linear-gradient(to top, rgba(14,210,247,1.00), rgba(178,254,250,1.00));  /* Chrome 10-25, Safari 5.1-6 */
background: linear-gradient(rgba(74,82,139,1),rgba(22, 32, 103, 0.1)); /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
}
.bg_black{ background: linear-gradient(to right, rgba(0,0,0,1), rgba(0,0,0,0.8),rgba(0,0,0,0.6),rgba(0,0,0,0));}
.pink_line{
background: linear-gradient(transparent 60%, rgba(255,255,102,0.6) 60%);
font-weight: bold;}
/*background*/
/*--- 背景色 ---*/



/*--- リンク色 ---*/
a:link {
    color: #b84a96;
    text-decoration: none;
}
.link02:link{
    color: #0071bc;
    text-decoration: none;

}
a:visited {
    color: #0041a5;
    text-decoration: none;
}
a:hover {
    color: #099694;
    text-decoration: underline;
}
.link02:hover {
    color: #099694;
    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;
}
.opacity1 {opacity:1;}
/*--- 点滅 ---*/

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

/*スマホのみ改行*/
.br-sp{
    display: none;
    @media only screen and (max-width : 768px){display: block;}
}

/*PCのみ改行*/
.br-pc{
    display: block;
    @media only screen and (max-width : 768px){display: none;}
}
/*--- 改行 ---*/

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

/* googleアイコン　位置のずれを調整. */
.material-icons {
    display: inline-flex;
    vertical-align: middle;
}

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

/*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により中央に配置する */
	margin-bottom:0 auto 30px auto;
}

.flex-st{
        align-items: flex-start!important;
}

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

/*--- アンカーリンクの調整 ---*/
.anchor{
  display: block;
   margin-top:-100px;
   padding-top:100px;
}
/*--- アンカーリンクの調整 ---*/

/*------------------------------------------------------------
コンテンツ幅
------------------------------------------------------------*/
.contents_s{
    width: 450px;
	margin:0 auto;
	padding:10px 0;
    z-index: 10;    
}
	
.contents{
	width: clamp(320px, 90%, 1024px);
	margin:0 auto;
	padding:75px 0;
    z-index: 10;}
    
.contents_800_s{
	width: 800px;
    margin: 0 auto;
}
.contents_800{
    width:800px;
    margin: 0 auto;
    padding: 30px 0;
}

.contents_1000{
	max-width:900px;
    margin: 0 auto;
    padding: 75px 0;
}
    
@media only screen and (max-width : 768px){
	.contents,
    .contents_800,
    .contents_1000{ 
        width:90%;
        padding:30px 0;
    }

}
/*------------------------------------------------------------
タイトル周りの装飾
------------------------------------------------------------*/
.bottom-border{
padding-bottom: 5px;
line-height: 1.6em;
max-width: 1200px;
}

/*.bottom-border::after {
	content: '';
	display: block;
	width: 60px;
	height: 3px;
    background: rgba(24,148,59,1);
}*/

.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-blborder{
    content: '';
	height: 36px !important;
    padding: 5px;
    background-image: url(../img/bk_parts05.svg);
    background-size: 85%;
    background-position: center;
    background-repeat: no-repeat;
    top:-3px;
    right: 60px;
    margin-left: 10px;
    z-index: 5;
}

.head-hexagon{
    display: flex;
    text-transform: uppercase;
    justify-content: center;
	position: relative;
    content: '';
    display: inline-block;
background-image: url(../img/bk_parts06.png);
background-repeat: no-repeat;
background-position: left;
background-size: 22%;
/*height: 40px;*/
margin: 2px;
}

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

  /*リボン*/
.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;
}

 /*テキスト前にdot*/
ul.dot li{
    padding-left: 1.3em;
    text-indent: -1.3em;
}

ul.dot li::before {
    content: "●";
    margin-right: 0.3em;
    color:rgba(0, 86, 141 ,0.3);
    display: inline;
}
/*------------------------------------------------------------
ヘッダー
------------------------------------------------------------*/
/*logo幅*/
.inner {
    width: clamp(320px, 90%, 1200px);
   margin: 0 auto;
}
.inner:after {
    content: "";
    clear: both;
    display: block;
}
/*logo幅*/

@media only screen and (max-width : 768px){
	#header .head_in{
	width:100%;
	padding:10px;
	height:auto;
	text-align:center;
	}
    #header .head_in .logobox{ 
    float:none; 
    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 : 768px){
	#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;
	display:block;
}

#top-head {
    width: 100%;
    line-height: 1;
    z-index: 10000;
	background: var(--sab-blule-color);
    @media only screen and (max-width : 786px){width: 90%;}
}
#top-head a,#top-head {
    color: #fff;
    text-decoration: none;
}
#top-head .inner {
    position: relative;
}
#top-head .logo {
   float: left;
    padding: 8px 0;
}

#top-head h1 span {
    float: right;
    font-weight: bold;
    line-height: 56px;
}
/*--- ヘッダー ---*/

/*------------------------------------------------------------
ナビ
------------------------------------------------------------*/
@media all and (min-width: 768px){
#global-nav {
display: none;
}
#global-nav ul {
display: none;
    list-style: none;
    position: absolute;
    right: 0;
    top: 18px;
    font-size: 14px;
}
#global-nav ul li {
    float: left;
	display: block !important;
width: auto !important;
height: auto !important;
padding: 0 !important;
background: none !important;
}
#global-nav ul li a {
    padding: 0 0 0 15px;
}

#global-nav ul li span:after{
    content: "keyboard_arrow_down";
    font-family: "Material Icons";
    margin-left: 0.3em;
    color: #999;
    display: inline;
}
}

@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 {
    display: none;
    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: #fff;
    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: 980px) {
    #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: var(--primary-color);
        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: var(--primary-color);
        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;
    }
	@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;}
}
 
#top-head #global-nav ul li a,
#top-head.fixed #global-nav ul li a {
        width: 100%;
        display: block;
        color: #fff;
        padding: 18px 0;
        border-bottom: 1px solid #ffffff;
    }
    
#top-head #global-nav ul li a:before,
#top-head.fixed #global-nav ul li a:before {
    content: '\f078';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    width: 0.8em;
    margin-right: 0.3em;
}

#top-head #global-nav ul li a:hover,
#top-head.fixed #global-nav ul li a:hover {
    background: rgba(45,121,143,0.95);
    
    }
    #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: 10002;
}

#navi{
width: 100%;
background: var(--primary-color);
z-index: 100;
}

#navi .navi_innar{
 min-width: 850px;
 max-width: 1024px;
 margin: 0 auto;
 padding: 0.5px 0;
}

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

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

#navi .navi_innar ul li a{
color: #fff;
text-align: center;
padding: 5px;
line-height: 2em;
display: block;
width: 100%;
}

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

#navi .navi_innar ul li a:hover{
background: rgba(2,105,143,0.9);
	text-align: center;
	padding: 5px;
	line-height: 2em;
	display: block;
	text-decoration: none;
	}
	
@media only screen and (max-width : 980px){
#navi{display: none;}
}

#navi .navi_innar ul li a.nolink,
#global-nav ul li a.nolink{
background: none!important;
color:#C0BCBC;
}

/*------------------------------------------------------------
メインビジュアル
------------------------------------------------------------*/



#top_main {

.bg-video-wrap {
  position: relative;
  overflow: hidden;
  background: var(--sab-blule-color);
  aspect-ratio: 16 / 7;
  @media only screen and (max-width : 1000px){
        aspect-ratio: 16 / 8;
  }

       @media only screen and (max-width : 768px){
        aspect-ratio: auto;
         min-height: 500px;
         background-image: url(../img/main_bk_sp.jpg) ;
         background-repeat: no-repeat;
         background-position: center center;
  }
}
.bg-video-wrap video{
  width: 101%;
  height: 101%;
  object-fit: cover;
    /* position: absolute; で固定するのも確実です */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); /* 中央に配置して1px分を外に逃がす */
  z-index: 1;
}

  @media only screen and (max-width : 768px){
.bg-video-wrap video,
.bg-video-wrap img{
    display: none;
    }
  }

  .video_w__mask {
  background-color: rgba(0, 0, 0, 0.1);
  position: absolute;
  left: 0;
  height: 100%;
  top: 0;
  width: 100%;
  z-index: 1;
}
.top_inner{
  position: absolute;
  width: 100%;
  margin: 0 auto;
  inset: 0;              /* ← 全面に広げる */
    img{
        display: block;
    }

  .main_contents{
    width: clamp(320px, 90%, 1024px);
    height: 100%;
    position: relative;
  display: flex;
  justify-content: center;
  /*align-items: center;*/
  z-index: 1;
  margin: 0 auto;
  flex-direction: column;
  padding: 1%; /* ← これ重要（はみ出し防止） */
    /* ボタンの分の高さ調整 */
  transform: translateY(-10px) translateX(0%);
     h1{
        display: block;
        z-index: 5;
     }

     h1 img{
            width: clamp( 600px, 78% , 800px);
     @media only screen and (max-width : 1440px){
           width: clamp( 400px, 60% , 700px)
     }
     @media only screen and (max-width : 1280px){
           width: clamp( 400px, 60% , 500px)

     }
       }
     h5{
        display: none;
    
     @media only screen and (max-width : 768px){
         display: block;
         color: #ffffff;
         font-weight: bold;
         margin-left: 1.5em;
         margin-bottom: 1em;
         }

     }


  .btn_order{
    z-index: 5;
  }
  .btn_order a{
    margin: 30px auto 0 auto;
      text-align: center;

      @media only screen and (max-width : 1280px){
        margin: 15px auto 0 auto;

      }

        }

  }

  .main_bk_top img{
    position: absolute;
    top: -30px;
    right: -20px;
    z-index: 2;
    text-align: right;
     img{
    object-fit: nene!important;
    height: auto;
    width: 70%;
    }
    @media only screen and (max-width : 1280px){
            img{
                width: 50%; 
            }
        }
        @media only screen and (max-width : 980px){
                top: -40px;
                right: -60px;
                width: 25%;
        }
    @media only screen and (max-width : 768px){
                top: -30px;
                right: -50px;
                width: 40%;
        }
  }

    .main_bk_bottom img{
    position: absolute;
    bottom: 40px;
    right: -50px;
    z-index: 2;
    text-align: right;
     img{
    object-fit: nene!important;
    height: auto;
    width: 70%;
    }
        @media only screen and (max-width : 1280px){
                bottom: 30px;
                right: 0px;
                width: 30%;
        }
                @media only screen and (max-width : 980px){
                bottom: 20px;
                right: 0px;
                width: 35%;
        }

        @media only screen and (max-width : 768px){
                bottom: 20px;
                right: -20px;
                width: 45%;
        }
  }



  }
  @media only screen and (max-width : 980px){
          margin-top: 55px!important;
  }
 }


/*--- bodyのトップ ---*/
#top{display:block !important;}
/*--- bodyのトップ ---*/

/*------------------------------------------------------------
開催にあたって
------------------------------------------------------------*/
#outline{
    .bg-img{
        background-color: var(--primary-color);
        background-image: url(../img/bk_parts02.png) ;
        background-repeat: no-repeat;
        background-position: left -30px bottom 20px ;
    }

    h2{
        margin-bottom: 0!important;
        padding: 0.5em;
        background: #082638;
        background: linear-gradient(90deg,rgba(8, 38, 56, 1) 0%, rgba(4, 43, 61, 0.74) 77%, rgba(8, 38, 56, 0) 99%);
    }

    .bg_white{
        padding: 1.5vw;
    }
}


/*------------------------------------------------------------
ポイント
------------------------------------------------------------*/
#point .contents{ 
z-index: 10;
position: relative;
padding: 75px 0 ;
@media only screen and (max-width : 768px){padding: 30px 0;}

h2{
    margin-bottom: 50px;
    @media only screen and (max-width : 768px){display: none;}
}
}

.point_img img{
margin: 0 auto;
padding: 0;
width: 100%;
@media only screen and (max-width : 786px){padding: 0px 0px;}
}

.point_box {
  padding: 30px 50px 30px 30px;
 background: rgba(255,255,255,0.8);
 margin-bottom: 15px;
 border-radius: 0 60px 60px 0;
 border: 1px solid rgba(255,255,255,1);
 box-sizing: inherit;
@media only screen and (max-width : 768px){padding: 15px 30px 15px 15px;}
}

.point_box dl{display: flex;}

.point_box dl dt{
 display: flex;
  justify-content: center;
  align-items: center;
  width: 2em;
  font-size: 2.5em;
  color: rgba(24,147,59,1.00);
  font-weight: bold;
}

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

/*--- ポイント ---*/

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


#gaiyou dl dd ul.dot li::before {
    content: "●";
    margin-right: 0.3em;
    color: rgba(27, 160, 243 ,0.8);
    display: inline;
}

#gaiyou dl{ 
    line-height: 1.5em;
    color: #ffffff;
 }
#gaiyou dl dt{ 
width:20%;; 
text-align:center; 
padding:0.5em 0;
border-bottom: 1px solid rgba(255,255,255,1.0);
}
#gaiyou dl dd{
	margin-left:0.5em;
    border-bottom: 1px solid rgba(255,255,255,1.0);
    width: 75%;
    padding: 0.5em 10px;
}
#gaiyou dl dt:first-child,
#gaiyou dl dd.top_lineg{border-top: 1px solid rgba(255,255,255,1.0);}

@media only screen and (max-width : 768px){
    #gaiyou dl dt{ 
        width: 100%;
        margin-bottom: 0;
        float:none;
    }
#gaiyou dl dd{
    margin-left:0;
    padding:10px 0;
    height:auto;
    font-weight: normal;
    width: 100%;
}           
#gaiyou  dl {margin-bottom: 0;}
#gaiyou dl dd ul.dot li{margin-left: 0px;}
}
/*------------------------------------------------------------
プログラム
------------------------------------------------------------*/
/*#program { height: 100vhw;}*/

.program_bk_img { 
      background: linear-gradient(rgba(8, 38, 56 ,0.5), rgba(8, 38, 56 ,0.8)),
              url('../img/bk_img_04.jpg');
    /* background-blend-mode: lighten;        ブレンドモードを指定 */
    background-attachment: fixed; /* 背景画像をスクロールに対して固定 */
    background-position: center; /* 背景画像を中央に配置 */
    background-repeat: no-repeat;
}

/*#program .flex-container{ justify-content:space-between;}
#program .flex-container blockquote{ width:calc(95%/2)}*/

#program .com_box {
    margin: 0 auto 50px auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: nowrap;
}
#program .pkouse{ width: 60%;}
#program .pkouse_inner{ 
    padding: 20px 20px 15px 20px;
    margin: 0 13px 13px;
    background: rgba(211, 237, 251, 0.8);}
    
@media only screen and (max-width : 768px){
    #program .com_box { display: block; margin-bottom: 30px;}
    #program .pkouse{ width:100%;}
    #program .pkouse_inner{ padding: 10px 10px 5px 10px;}
}

.box-border { border:2.5px solid #ffffff;}
.pkouse h3 {
    display: block;
    font-weight: bold;
	color:#fff;
	background: var(--sab-blule-color);
	margin:13px 13px 0;
	padding:15px 30px 15px 15px;
}

.pkouse h3 figure {
    display: inline;
    margin-right: 0.5em;
    vertical-align: top;
}

@media only screen and (max-width : 768px){
    .pkouse h3 figure{
        display: block;
        float: left;
    }
}

.pkouse dl {
margin: 0 auto 0.5em auto; 
padding: 0;
display: flex;
justify-content: space-between;
}

.pkouse dl dt{ 
width:8em;
color:rgba(22, 32, 103, 1);
text-align:center;
float:left;
font-weight:bold;
background-color:#fff;
padding:3px;
display: flex;
align-items: flex-start;
justify-content: center;
font-size: 0.95em;
}

.pkouse dl dd{
    width: calc( 100% - 8.5em);
    font-weight:bold;
    line-height: 1.5em;
    display: flex;
    align-items: center;
}

@media only screen and (max-width : 768px){
    .pkouse dl{ display: block;}
    .pkouse dl dt,
    .pkouse dl dd{ 
        width:auto;
        float: none;
        line-height: 1.5em;
        padding: 5px;
    }
}

#program .right_box {width: 35%;}
#program .right_box .code_box h4 {
    display: block;
    font-weight: bold;
	color:#fff;
	background: var(--sab-blule-color);
	margin:13px 13px 0;
	padding:13px 30px 13px 15px;
}

#program .right_box .code_box_play h4 {
    display: block;
    font-weight: bold;
	color:#fff;
	margin:13px 13px 0;
	padding:13px;
    background: var(--sab-blule-color);
}

#program .right_box .code_box_bottom {
padding: 15px;
margin: 0 13px 13px;
background: rgba(211, 237, 251, 0.8);
overflow: hidden;
}

#program .right_box .code_box_bottom_play {
padding: 15px;
margin: 0 13px 13px 13px;
background: rgba(211, 237, 251, 0.8);
overflow: hidden;
}

#program .right_box .code_box_bottom img{float: right;}

#program .bottomh3 {
    padding-left: 40px;
    margin:0 auto 30px auto;
}
@media only screen and (max-width : 768px){
#program .right_box{
    margin-top: 20px;
	width:100%;
}

#program .bottomh3 {
    padding-left: 40px;
    margin-bottom: 20px;
}

#program .right_box .m30-b{ margin-bottom: 20px!important;}
}

#program #right_box .zoom_box {
	display:block;
	overflow:hidden;
	text-align: center;
border-radius: 10px;
font-weight: bold;
background-color: rgba(30,115,121,1.00);
padding: 15px;
color: #fff;
}


#program #right_box .zoom_box h4{
	display:block;
    font-size:1.1em;
    margin-bottom:0.5em;
    text-align:center;
    font-weight:bold;
}

#program #right_box .zoom_box p{ 
    font-size:0.9em;
    text-align:center;
    font-weight:bold;
}

#program #right_box .zoom_box h4 img{ margin:10px;}

#program #right_box .photo{ 
    float:right; 
    width:80px; 
    margin-left:20px;
}
#program #TableArea .photo{ 
width: 230px;
padding: 1px;
border: 1px solid #ccc;
box-sizing: border-box;
text-align:center;
margin-bottom:10px;
}


#program .flex-container{justify-content: flex-end;}
/*#program .flex-container:first-child{margin-right: 30px ;}*/

 .program_box {
 display: flex;
 width: 97%;
 justify-content: space-between;
 background: rgba(255, 255, 255, 0.8);
 margin:0 auto 20px;
 flex-wrap: wrap;
 @media only screen and (max-width : 768px){margin: 0 7px 10px;}
 }

.program_midasi{
background: var(--sab-blule-color);
color: #fff;
font-weight: bold;
font-size: 1.1em;
display: flex;
margin: 10px 13px 0 0;
justify-content: flex-start;
position: relative;
@media only screen and (max-width : 768px){margin: 0;}
}



.program_midasi .nom{
/*border-right: 1px solid #00561f;*/
color:#ffffff;
font-size: 0.85em;
font-weight: bold;
background: var(--primary-color);
border: 1px solid #cecece;
border-radius: 5px;
display: flex;
align-items: center;
text-align: center;
justify-content: center;
position: absolute;
top: -20px;
left: -20px;
width: 50px;
height: 40px;
@media only screen and (max-width : 768px){
    top: 0;
    left: 0;
    width: 50px;
    height: 50px;
}
}

.program_midasi .time{
padding: 7px 10px 7px 35px;
color:rgba(22, 32, 103, 1);
font-size: 0.85em;
font-weight: bold;
background: rgba(211, 237, 251, 0.8);
display: flex;
align-items: center;
min-width: 80px;
}

.program_midasi .sub_icon{
padding: 5px 10px;
color: #162067;
font-size: 0.8em;
font-weight: bold;
background: var(--sab-yellow-color);
display: inline;
align-items: center;
margin-right: 0.5em;
/*border-radius: 5px;*/
}

.program_midasi h3{
font-weight: bold;
padding: 10px 30px 10px 10px;
line-height: 1.4em;
margin: 0 0 0 5px;
font-size: 1.1em;
text-align: left;
text-indent: -0.4em;
color: #ffffff;
}

.program_midasi .day{
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8em;
    color: #333;
    line-height: 1.4em;
    text-align: center;
    margin-left: 0.5em;
}

@media only screen and (max-width : 768px){
.program_midasi{display: block;}
.program_midasi .nom,
.program_midasi .time,
.program_midasi .sub_icon{
    display: inline;
    padding: 0.3em 1em;
}

.program_midasi .nom{
    position: static;
    border-radius:0;
    width: auto;
    height: auto;
}

.program_midasi .sub_icon{
    white-space: nowrap;
    margin: 5px;
}

.program_midasi h3{ padding: 10px;}
}

.program_com_2box{
display: flex;
justify-content: space-between;
padding: 15px;
width: calc(100% - 30px);
}

.program_com_1box{width: 100%;}

.program_com_1box_inner{
padding: 20px;
margin: 0 auto;
position: relative;
}

.program_com_2box_inner{width: calc(calc(100% - 40px) / 2);}

.program_com_2box_inner_line{
width: 40px;
background: url("../img/program_com_line.png") repeat-y center;
}

.program_com_2box_inner_line_yoko{
background: url("../img/program_com_line.png") repeat-x center;
height: 1px;
width: calc(100% - 40px);
margin: 0 20px;
}

@media only screen and (max-width : 768px){
    .program_box,
    .program_com_2box{
    display: block;
    width: auto;
    }
    .program_com_2box_inner{width: auto;}
    .program_com_2box_inner_line{
    width: auto;
    height: 30px;
    background: url("../img/program_com_line.png") repeat-x center;
    }
}

.program_com_2box_inner .inner_title{
display: flex;
align-items: center;
margin: 0 0 15px 0;
width: 100%;
padding: 0;
}

.program_com_2box_inner .inner_title_b{align-items: baseline;}

.program_com_2box_inner .inner_title h4{
margin-left: 10px;
font-weight: bold;
color: var(--primary-color);
font-size: 1em;
margin-bottom: 0;
line-height: 1.2em;
width: 100%;
}

.program_com_2box_inner .inner_title h4.styleS{
    width: calc(100% - 4em);
}

.program_com_2box_inner h6{
font-size: 1em;
margin-bottom: 0.5em;
line-height: 1.2em;
}

@media only screen and (max-width : 768px){
.program_com_2box_inner .inner_title h4{margin-left: 10px;}
}

.program_com_2box_inner .inner_title h4.m0-l{
margin-left: 0;
width: auto;
}


.program_com_1box_inner .inner_title h4{
font-weight: bold;
color: var(--primary-color);
font-size: 1.1em;
margin-bottom: 0;
}

.title_box{
    flex-basis: 100%;
    padding: 15px 15px 0 15px;
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    gap: 1%;

    @media only screen and (max-width : 768px){
        flex-direction: column;
        gap: 10px;
    }

    h4{
    font-weight: bold;
    color: var(--primary-color);
    font-size: 1em;
    margin-bottom: 0;
    line-height: 1.5em;

    }
}

.program_com_1box_inner .program_rogo{
position: absolute;
top:0px;
right: 0px;
background-color: #fff;
padding: 5px 15px;
}

.program_com_2box_inner .inner_title h4.w100per{
width: 100%;
margin-left: 0;
}

.program_com_2box_inner .inner_title h4 span{line-height: 1.2em;}

.program_com_2box_inner h5{
font-weight: bold;
text-align: right;
line-height: 1.2em;
}

.program_com_2box_inner .com_name{
font-weight: bold;
text-align: right;
line-height: 1.2em;
font-size: 0.9em;
}
.program_com_2box_inner .com_name span{font-size: 0.9em;}

.program_com_2box_inner .com_name span .small{
font-size: 0.9em;
font-weight: bold;
}

.program_com_2box_inner p.text{
font-size: 0.85em;
line-height: 1.6em;
}

.program_com_2box_inner ul.dot li{
font-size: 0.85em;
line-height: 1.6em;
}

@media only screen and (max-width : 768px){
	#program .program_com {
	padding:15px; 
	width:100%;
			}
    .program_com_1box_inner .program_rogo{
    position: static;
    right: auto;
    top:auto;
    text-align: center;
    }
}

.program_com_photo_box{
display: flex;
flex-wrap: nowrap;
align-items: flex-end;
justify-content: space-between;
}

.program_com_photo_box_2{
display: flex;
flex-wrap: nowrap;
margin-top: 60px;
justify-content: space-between;
gap: 15px 5%;
}

.program_com_photo_box .photo{margin-right: 20px;}

.program_com_photo_box_2 .photo2,
.program_com_photo_box_2 blockquote{width: calc(97% / 2);}

.program_com_photo_box_2 blockquote p.text {
    font-size: 0.8em;
    line-height: 1.5em;
}

@media only screen and (max-width : 768px){
    .program_com_photo_box{align-items: flex-start;}
    .program_com_photo_box .photo{width: 90px;}
    .program_com_photo_box_2{
    flex-direction: column;
    margin-top: 5px;
    }
    .program_com_photo_box_2 .photo2,
    .program_com_photo_box_2 blockquote{width: 100%;}
}

.program_com_2box_inner figcaption{
    font-size: 0.7em;
    text-align: right;
    margin-top: 0.2em;
}

.program_box .head-hexagon02 {
    color: var(--sab-yellow-color);
    padding: 8px;
    line-height: 1;
	text-align:center;
    font-size: 15px;
    width: 70px;
    margin: 5px 2px 5px 0 ;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    font-weight: bold;
    z-index: 5;
}

.program_box .head-hexagon02 span{
font-size: 1.8em;
display: block;
@media only screen and (max-width : 768px){font-size: 1.8em;}
}

.program_box .head-hexagon02 .wauto{ width:11em;}

.program_box .code01 {
    background-color:#09966F;
    display: inline-block;
    padding: 5px 7px;
    margin-bottom: 2px;
    line-height: 1;
    border: transparent 1px solid;
	text-align:center;
		border-radius:5px;
		font-size:0.9em;
        color: #fff;
}
.code02{
    background-color:rgba(22, 32, 103, 1);
    display: inline-block;
    padding: 5px 7px;
    margin-bottom: 10px;
    line-height: 1;
    border-radius:3px;
	text-align:center;
		font-size:0.8em;
		font-weight:bold;
		color:#ffffff; 
}
.code03 {
    background-color:rgba(1,140,216,1.00);
    /*display: inline-block;*/
    padding: 5px 7px;
    line-height: 1;
    /*border: transparent 1px solid;
	width:10em;*/
    border-radius:3px;
	text-align:center;
		font-size:0.8em;
		font-weight:bold;
		color:#ffffff;
}

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

.border_bttom{
    border-bottom: 1px solid rgba(22, 32, 103, 1);
    margin: 0 20px;
}

.prog_leftBox{
    display: flex;
    flex-direction: column;
    .mb_2line{
        margin-bottom:  1.3em !important;
        @media only screen and (max-width : 768px){margin-bottom:  0 !important;}
    }
    .img_bttom{margin-top: auto;}

}

/* モーダル　クリックで文章表示*/
/* 初期状態は非表示 */
#modal-toggle, .modal-overlay {
  display: none;
}

/* チェックが入ったらモーダルを表示 */
#modal-toggle:checked ~ .modal-overlay {
  display: flex;
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.5);
  justify-content: center;
  align-items: center;
    z-index: 99;
}

/* モーダルの中身のスタイル */
.modal-content {
  background: white;
  padding: 25px;
  position: relative;
    width: 60%;
  max-width: 900px;
  @media only screen and (max-width : 768px){
    width: 85%;
    padding: 15px;
  }

}
.modal-content p{
    margin-bottom: 45px;
}
.btn{
    padding: 5px 15px;
    font-size: 0.8em;
    font-weight: bold;
    color: var(--sab-blule-color);
    background: rgb(154, 207, 235);
    text-align: center;
    border-radius: 5px;

}

.btn:hover{
    color: #ffffff;
    background: var(--primary-color);
}
.open-btn{
    margin: 0 0 1em 0;
    font-size: 0.8em;
}

.modal-content .close-btn{
    position: absolute;
    bottom: 20px;
    right: 25px;
    line-height: 1.2em;
      @media only screen and (max-width : 768px){
        bottom: 10px;
    right: 15px;

      }
}

/*テキストの高さ調整*/
.line_35t{
    margin-top: 30px;
    @media only screen and (max-width : 768px){
        margin-top: 0;
    }
}



/*------------------------------------------------------------
企画委員
------------------------------------------------------------*/

#committee{
    color: #ffffff;
}
.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 img,
.committee_box2 img {
outline: 3px solid #ffffff;
  outline-offset: -3px; /* 線を内側へ */
}

.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;
flex-wrap: wrap;
}

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

.committee_box2_inner:first-child{margin-bottom: 15px;}

@media only screen and (max-width : 768px){
.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: 5px; 
    background-color:rgba(8, 38, 56,0.7); 
    font-size: 0.8em;
}

.TableCommittee tr:nth-child(even) td {	background: rgb(0, 86, 141);}
.TableCommittee tr:nth-child(even) th {	background: rgb(0, 86, 141);}

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

@media only screen and (max-width : 768px){
.TableCommittee td {
display: block;
line-height: 1.3em;
font-size: 0.9em;
}

.TableCommittee tr td:first-child {
    padding-bottom: 0;
}

.TableCommittee td .Name {padding: 5px 10px;}
}

/*------------------------------------------------------------
お問い合わせContact
------------------------------------------------------------*/
#contact{
	width:100%;
	position:relative;
	overflow:hidden;
    background: rgba(116, 161, 214, 1);
	color:#fff;
}


#contact h2 span {color: #D583EA;}

#contact h2 span::before {background-color: #D583EA;}

#contact .innar{
    margin:0 auto;
	@media only screen and (max-width : 768px){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;}
#contact .btn_box2btn,
#entry .btn_box2btn{
display: flex;
justify-content: space-around;
max-width: 800px;
margin: 0 auto 50px auto;
}
	
@media only screen and (max-width : 768px){
	#contact .flex-container{ display:block;}
	#contact dl{
        width: 100%; 
        margin-bottom:10px;}
#contact .cont_innar{width:100%;}
#contact .btn_box2btn,
#entry .btn_box2btn{
display: block;
width: auto;
margin: 0 auto 30px auto;
}
}




/* btn Style
-------------------------------------------------------- */
.btn_order{
	margin:0 auto;
    align-items: center;
}
.btn_order a{
	width:260px;
	padding: 7px 0;
    margin: 50px auto 0;
    display: inline-block;
    background-color: #96093d;
    border-radius: 10px;
    text-align: center;
    color: #fff !important;
    font-weight: bold;
    font-size: clamp(14.00px, calc(0.31vw + 12.84px), 16.00px);
    transition: .2s;
	border:2px solid #fff;
	font-family: body-apple-system,BlinkMacSystemFont,"Hiragino kaku Gothic ProN",MyYuGothicM,Meiryo,sans-serif;
    @media only screen and (max-width : 768px){
        margin: 30px auto 0;
        width:230px;
    }
}

.btn_style_m10{margin: 10px;}

.btn_order a.style_call{ background:none;}

@media only screen and (max-width : 768px){
	.btn_order a{
	display: block;
   /* width: auto;*/
	}
}

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

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

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

/* 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{
text-decoration: none;
background: var(--primary-color);
}

/*------------------------------------------------------------
申し込み
------------------------------------------------------------*/
#participation_terms{
        .bg-gradient{
        background: linear-gradient(180deg,rgba(0, 86, 141, 1) 0%, rgba(16, 108, 173, 1) 64%, rgba(8, 38, 56, 1) 100%);
    }
    
}
#entry {
    color: var(--sab-blule-color);


.inner{
    width: clamp(320px, 90%, 900px);
}
}
/* -------------- 利用規約 -------------- */

.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 h2 {
    margin-bottom: 0px;
}

#participation_terms .btn_order a {
margin: 10px auto 0;
justify-content: center;
}

#participation_terms .bg_blueg {
    padding: 60px 30px;
    @media screen and (max-width: 768px){
        padding: 30px 5px !important;
    }
}
#participation_terms .terms-item dl {
    display: flex;
    flex-wrap: wrap;
}

#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: 768px){
    #privacy table[border="1"],
    #participation_terms table[border="1"] {
	margin: 15px auto;
    width: 70%;
    }
	#privacy table[border="1"] tr td,
	#participation_terms table[border="1"] tr td {
		padding: 5px 8px;
	}
}


#gaiyou .mb55{
margin-bottom: 55px;
z-index: 1;
@media screen and (max-width: 768px){
    margin-bottom: 45px;
}

}

.program_com_2box_inner ul.list_com li{
font-size: 0.8em;
    line-height: 1.35em;
    margin-bottom: 5px;
    text-indent: -1em;
    padding-left: 1em;
}
.program_com_2box_inner ul.list_com li:before{
color: #000000;
}


/* 画像をクリックで拡大図
-------------------------------------------------------- */
.c {
    text-align: center;
}
.overlay { /* グレーの背景 */
  position: fixed;
  background: rgba(0, 0, 0, 0.2);
  transition: all 0.5s 0s ease;
  visibility: hidden;
  opacity: 0;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
#pop-up {
  display: none;
}
#pop-up:checked + .overlay {
  visibility: visible;
  opacity: 1;
  z-index: 100000;
  background-color: #000000D0;
  width: 100%;
}
.popWindow {
  border-radius: 5px;
  overflow: auto; /* スクロールバー用 */
  max-height: 95%; /* すき間 */
  min-width: fit-content; /* 横幅が広い時に白の部分が大きくならないため */
  width: 80%; /* すき間 */
  position: fixed;
  top: 50%; /* 中央に */
  left: 50%; /* 中央に */
  transform: translate(-50%, -50%); /* 中央に */
  z-index: 100010;
  font-size: 13px;
  line-height: 18px;
  margin: 10px auto;
  padding: 4px 10px;
  background: #ffffff; /* 枠の色 */
  text-align: center; /* 文字を中央寄せ */
  transition: all 500ms ease-in-out;
}
.popWindow .ptitle {
  font-size: 15px;
  margin: 8px;
  color: #333;
}

.popWindow .ptitle img{
    width: 70%;
}
.popWindow .close {
  position: absolute;
  top: 8px;
  right: 10px;
  transition: all 300ms;
  font-size: 24px;
  line-height: inherit;
  font-weight: bold;
  text-decoration: none;
  color: #000;
  padding: 2px;
}
.popWindow .close:hover {
  color: rgba(0,113,188,1);
}
.popWindow::-webkit-scrollbar-track {
  background: none;
}
.popWindow::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
.popWindow::-webkit-scrollbar-thumb {
  background: #999;
  border-radius: 5px;
}
.clickable:hover {
  cursor: pointer;
}
@media screen and (max-width: 700px){
  #pop-up:checked + .overlay {
    visibility: hidden;
    opacity: 0;
  }
}

/* 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 : 768px){ #copyright{ width:100%;}}