@charset 'utf-8';

@font-face {
	font-family: 'NotoSansJP';
	font-style: normal;
	font-weight: 400;
	src: url('../font/NotoSansJP-Regular.woff') format('woff'),
		url('../font/NotoSansJP-Regular.eot')  format('eot');
	font-display: swap;
}
@font-face {
	font-family: 'NotoSansJP';
	font-style: normal;
	font-weight: 700;
	src: url('../font/NotoSansJP-Bold.woff') format('woff'),
	url('../font/NotoSansJP-Bold.eot')  format('eot');
	font-display: swap;
}

html {
	font-size: 17px;
	line-height: 1.4;
	color: #000000;
  scroll-behavior: smooth;
}
body {
	font-family: 'NotoSansJP', "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	background-color: #e8f1f8;
	margin: 0px;
	padding: 0px;
	font-feature-settings: "palt" 1;
	word-wrap: break-word;
}
/* IEだけに適応 */
_:lang(x)::-ms-backdrop, .selector {
	font-family: "Segoe UI", Meiryo, sans-serif;
}
div,h1,h2,h3,h4,h5,p,img,ul,li {
	margin: 0px;
	padding: 0px;
	border: none;
}
#container {
	width: 900px;
	margin: 0px auto;
	background-color: #FFF;
	box-shadow: 0 0px 10px 0px rgba(0,0,0,0.5);
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	#container {
		width: 100%;
		margin: 0px;
		background-color: #FFF;
		box-shadow: 0 0px 0px 0px rgba(0,0,0,0);
	}
}

h2 {
	clear: both;
	font-size: 1.6rem;
	font-weight: 800;
	margin-bottom: 10px;
  background: #FFFFFF;
  padding: 20px 16px 20px 36px;
  position: relative;
}
h2::after {
  content:  "";     /* 空の要素作成 */
  width: 4px;                /* 幅指定 */
  height: 50px;               /* 高さ指定 */
  display: block;    /* インラインブロックにする */
  background-color: #fed958;  /* 背景色指定 */
  position: absolute;        /* 位置調整 */
  top: 14px;                   /* 位置指定 */
  left: 20px;
  margin-right: 20px;          /* 余白指定 */
}
.h2sub {
  font-size: 0.9rem;
}

h3 {
	clear: both;
	font-size: 1rem;
	margin-bottom: 10px;
  background: #F9F9F9;
  background-image: -webkit-linear-gradient(top, #F9F9F9, #E4E4E4);
  background-image: -moz-linear-gradient(top, #F9F9F9, #E4E4E4);
  background-image: -ms-linear-gradient(top, #F9F9F9, #E4E4E4);
  background-image: -o-linear-gradient(top, #F9F9F9, #E4E4E4);
  background-image: linear-gradient(to bottom, #F9F9F9, #E4E4E4);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  border: solid 1px #E4E4E4;
  padding: 10px 16px 10px 26px;
  position: relative;
}
h3::after {
  content:  "";     /* 空の要素作成 */
  width: 6px;                /* 幅指定 */
  height: 20px;               /* 高さ指定 */
  display: block;    /* インラインブロックにする */
  background-color: #fed958;  /* 背景色指定 */
  position: absolute;        /* 位置調整 */
  top: 10px;                   /* 位置指定 */
  left: 10px;
  border-radius:  25%;        /* 要素を丸くする */
  margin-right: 20px;          /* 余白指定 */
}
/*h4 {
  margin: 0px 20px 10px 20px;
}*/
h4 {
  margin: 0px 20px 6px 20px;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	h4 {
    margin: 0px 0px 6px 0px;
	}
}

h5 {
	display: flex;
	font-size: 1rem;
	color: #000000;
	background-color: #fed958;
	margin: 0px 0px 6px 0px;
	padding: 4px 10px;
}
.time {
	font-size: 0.8rem;
	font-weight: 500;
	margin-left: auto;
}
h6 {
	display: flex;
	font-size: 0.9rem;
	line-height: 1.2;
  border-left: 4px solid #fed958;
	background-color: #F0F0F0;
	margin: -6px 0px 6px 0px;
	padding: 4px 10px;
}
.bbstime {
	font-size: 0.8rem;
	font-weight: 500;
	margin-left: auto;
}
p {
	font-size: 0.9rem;
	margin: 0px 20px 10px 20px;
}
p.selftext {
	font-size: 1rem;
	font-weight: 600;
}
.shikai {
  text-align: right;
  margin-bottom: 4px;
}
.enjya {
  margin-left: 40px;
}
.alert {
	font-weight: 600;
	color: #cc0000;
}
.clear {
	font-weight: 600;
	color: #00cc00;
}
.qa_area {
	text-align: right;
	margin-bottom: -20px;
}
.noOndemand {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 500;
	color: #CC0000;
	border: #CC0000 solid 1px;
	padding: 2px;
	background-color: #FFF;
}
.waku {
	width: 90%;
	border: #999 solid 1px;
	margin: 30px auto 20px auto;
	padding: 20px;
}
.waku h6 {
  padding: 4px 16px 4px 10px;
  margin-bottom: 4px;
  font-size: 1rem;
}
.waku p {
	font-size: 0.9rem;
	margin: 0px 20px 10px 10px;
}
.halfOpacity {
	opacity: 0.5;
}
.fullOpacity {
	opacity: 1;
}
.currentSession {
	font-size: 0.9rem;
	line-height: 1.2;
  color: #CC0000;
  font-weight: bold;
}
.help {
	font-size: 0.9rem;
  margin: 20px 0px 20px 34px;
}
.help02 {
	font-size: 0.9rem;
  margin: 20px 0px 20px 64px;
}

/*
Link style -------------------------------------------------------------------------------------------- */
a {
  cursor: pointer;
}
a:link, a:visited {
	text-decoration:none;
	color: #0068b6;
}
a:hover, a:active {
	text-decoration:underline;
	color: #0068b6;
}

.btn {
  display: inline-block;
  border-radius: 3px;
  font-size: 1rem;
  text-align: center;
  padding: 10px;
  color: #ffffff;
	border: 1px solid #FFF;
  opacity: 1;
  transition: .2s;
  margin-bottom: 6px;
}
.btn:link, .btn:visited {
	text-decoration:none;
	color: #ffffff;
}
.btn:hover, .btn:active {
  opacity: 1;
	text-decoration:none;
}

.btn_gray {
	background-color: #444444;
}
.btn_gray:hover, .btn_gray:active {
	color: #444444;
	background-color: #FFF;
	border: 1px solid #444444;
}

.btn_blue {
	background-color: #1982c4;
}
.btn_blue:hover, .btn_blue:active {
	color: #1982c4;
	background-color: #FFF;
	border: 1px solid #1982c4;
}

.btn_green {
	background-color: #8ac926;
	color: #000000;
}
.btn_green:hover, .btn_green:active {
	color: #8ac926;
	background-color: #FFF;
	border: 1px solid #8ac926;
}

.btn_yellow {
	background-color: #ffca3a;
	color: #000000;
}
.btn_yellow:hover, .btn_yellow:active {
	color: #ffca3a;
	background-color: #FFF;
	border: 1px solid #ffca3a;
}

.btn_orange {
	background-color: #EF810F;
}
.btn_orange:hover, .btn_orange:active {
	color: #EF810F;
	background-color: #FFF;
	border: 1px solid #EF810F;
}

.btn_red {
	background-color: #ff595e;
}
.btn_red:hover, .btn_red:active {
	color: #ff595e;
	background-color: #FFF;
	border: 1px solid #ff595e;
}

.btn_purple {
	background-color: #6a4c93;
}
.btn_purple:hover, .btn_purple:active {
	color: #6a4c93;
	background-color: #FFF;
	border: 1px solid #6a4c93;
}


.downloadbtn {
  padding: 10px 26px 12px 20px;
  background-color: #0d2948;
  color: #ffffff;
	border: 1px solid #FFF;
}
.downloadbtn:hover, .downloadbtn:active {
	color: #0d2948;
	background-color: #FFF;
	border: 1px solid #0d2948;
}

.logoutbtn {
  display: inline-block;
  border-radius: 3px;
  font-size: 1rem;
  text-align: center;
  padding: 12px 26px 12px 20px;
  background-color: #cc0000;
  color: #ffffff;
	border: 1px solid #FFF;
  opacity: 0.8;
  transition: .2s;
  margin: 0px 10px 10px 10px;
}
.logoutbtn:link, .logoutbtn:visited {
	text-decoration:none;
	color: #ffffff;
}
.logoutbtn:hover, .logoutbtn:active {
  opacity: 1;
	text-decoration:none;
	color: #cc0000;
	background-color: #FFF;
	border: 1px solid #cc0000;
}

/*
page-top -------------------------------------------------------------------------------------------- */
.pagetop {
	text-align: right;
	margin: -6px 0px 20px 0px;
}
.pagetop img {
	border: none;
}

/*
header -------------------------------------------------------------------------------------------- */
#header {
	width: 100%;
	margin: 0px;
	line-height: 0em;
	background-color: #2272ba;
}
h1 {
	padding: 0px;
	background-color: #fed958;
	border-bottom: 4px solid #2272ba;
	display: flex;
	justify-content: space-between;
}
h1 img {
	width: auto;
  height: auto;
  object-fit: contain;
	margin: 0px;
}
@media screen and (max-width: 560px) {
	/* 560px以下に適用されるCSS（タブレット用） */
	h1 img {
		width: 100%;
 		height: 100%;
		object-fit: contain;
	}
}

/*
middle -------------------------------------------------------------------------------------------- */
#middle {
	display: flex;
	width: 100%;
  background-color: #F0F0F0;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	/*#middle {
		flex-direction: column;
	}*/
}

/*
rightbox -------------------------------------------------------------------------------------------- */
#rightbox {
	width: 700px;
  background-color: #FFF;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	#rightbox {
		width: 100%;
	}
}


/*
contents -------------------------------------------------------------------------------------------- */
#contents {
	margin: 0px 20px 0px 20px;
  background-color: #FFF;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	#contents {
		margin: 0px 10px;
	}
}
#indeximg {
	position: relative;
	height: auto;
	margin: 0px;
}
#indeximg img {
	width:100%;
	max-width: 100%;
	height: auto;
	margin: 0px;
}

ul.annai {
	margin:0px 20px 20px 20px;
}
ul.annai li {
	font-size: 0.9rem;
	margin: 0px 0px 10px 10px;
}
ol.annai {
	margin:0px 20px 20px 20px;
}
ol.annai li {
	font-size: 0.9rem;
	margin: 0px 0px 10px 10px;
}

.indexbox {
	margin-bottom: 10px;
}

.speakerArea {
	margin: 0px 10px 10px 10px;
}
.zachou {
  display: flex;
  justify-content: flex-end;
	margin: 0px 0px 4px 0px;
  font-size: 0.9rem;
}
.endai {
	display: flex;
	font-size: 0.9rem;
}
.endaiID {
	font-weight: 600;
	white-space: nowrap;
}
.titleText {
	font-weight: 600;
	margin: 0px;
}
.enjya {
	margin: 0px 0px 4px;
  font-size: 0.9rem;
}
.name {
}
.role {
  white-space: nowrap;
}
.doutu {
	background-color: #EF810F;
	color: #FFFFFF;
	text-align: center;
	font-size: 0.9rem;
	font-weight: 600;
}

.pbtn {
	font-size: 0.9rem;
  margin: 0px 0px 6px 10px;
  color: #e60012;
}
.pbtn i {
	vertical-align: middle;
}
.kyousai {
  text-align: right;
  margin-right: -10px;
}

.naiyou {
	border-spacing: 0px;
	border-collapse: collapse;
	font-size: 0.9rem;
  margin: -10px 0px 6px 0px;
}
.naiyou td {
	text-align: center;
	border: #999 solid 1px;
}

.video-container {
	
}

/*
navi -------------------------------------------------------------------------------------------- */
#navi {
	display: flex;
	flex-direction: column;
	width: 200px;
	background-color: #F0F0F0;
}
#member {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: 6px;
}
.nittei {
	margin: 0px auto 0px auto;
}
.nittei a {
	padding: 6px 22px 6px 16px;
}
.banner {
	margin: 10px auto 10px auto;
}
ul#menu, ul#menu * {
	font-size: 0.9rem;
	line-height: 1.2;
	font-weight: 800;
	margin:0; padding:0;
	list-style:none;
}
ul#menu li {
	margin: 0;
	padding: 0;
	text-align: left;
}
ul#menu li#select {
	background-color: #fed958;
}
ul#menu li#select a {
	color:#FFF;
	text-decoration:none;
}
ul#menu li#select a:hover {
	color:#000000;
	text-decoration:none;
}
ul#menu a:hover {
	color:#000000;
	background-color: #ccd9e7;
	text-decoration:none;
}
ul#menu a {
	display: block;
	padding: 8px 10px 8px 16px;
	margin: 0px 10px;
	color: #333333;
	text-decoration: none;
	border-bottom: #333333 dashed 1px;
	position: relative;
}
ul#menu a::after {
  content: ""; /* 空の要素作成 */
  width: 4px; /* 幅指定 */
  height: 18px; /* 高さ指定 */
  display: block; /* インラインブロックにする */
  background-color: #fed857; /* 背景色指定 */
  position: absolute; /* 位置調整 */
  top: 7px; /* 位置指定 */
  left: 6px;
  margin-right: 10px; /* 余白指定 */
}
ul#menu .subnavi {
	border-bottom: #333333 dashed 1px;
}
ul#menu .subnavi a {
	display: block;
	padding: 4px 10px 4px 26px;
	margin: 0px 10px;
	color: #333333;
	text-decoration: none;
	border: none;
	position: relative;
	text-indent: -1.2rem;
}
ul#menu .subnavi a::after {
  content: none;
}
ul#menu .subnavi a:hover {
	color:#bfe4ea;
	background-color: transparent;
}

ul#menu .subnavi p {
	display: block;
	padding: 4px 10px 4px 26px;
	margin: 0px 10px;
	color: #cc0000;
	text-decoration: none;
	border: none;
	position: relative;
	text-indent: -1.2rem;
}
.memu-arrow-right-r {
	box-sizing: border-box;
	position: relative;
	display: inline-block;
	transform: scale(var(--ggs,1));
	width: 14px;
	height: 14px;
	background: currentColor;
	border-radius: 2px;
 	top: 2px;
}

.memu-arrow-right-r::before {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 width: 0;
 height: 5px;
 border-top: 4px solid transparent;
 border-bottom: 4px solid transparent;
 border-left: 5px solid #F0F0F0;
 top: 3px;
 left: 5px
} 

@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	/*#navi {
		width: 100%;
	}
	#member {
		flex-direction: row;
	}*/
	.js-hiraku-offcanvas-body-right .js-hiraku-header-fixed {
			margin-left: -200px;
	}

	.js-hiraku-offcanvas-body-left .js-hiraku-header-fixed {
			margin-left: 200px;
	}

	.js-hiraku-offcanvas .js-hiraku-offcanvas-sidebar-left {
			margin-left: -200px;
	}

	.js-hiraku-offcanvas .js-hiraku-offcanvas-sidebar-right {
			margin-right: 200px;
	}

	.js-hiraku-offcanvas .js-hiraku-offcanvas-sidebar {
			width: 200px;
	}

	.js-hiraku-offcanvas-body-left {
			left: 200px;
	}

	.js-hiraku-offcanvas-body-right {
			right: 200px;
	}
}

.hiraku-open-btn {
	display: inline-block;
	margin: 6px 4px 6px 10px;
}
.hiraku-memu {
	color: #F0F0F0;
	font-size: 0.9rem;
}
@media screen and (min-width: 900px) {
	/* 900px以上に適用されるCSS */
	.hiraku-open-btn,
	.hiraku-memu {
		display: none;
	}
}

.child {
    display: none;
}

/*
footer -------------------------------------------------------------------------------------------- */
#footer {
	clear:both;
	background-color: #fed958;
	border-top: #2272ba solid 4px;
}
#footer p {
	line-height: 120%;
	text-align: center;
	margin: 0px;
	padding: 10px 0px 10px 0px;
	color: #000000;
}

/*
liveloginform -------------------------------------------------------------------------------------------- */
#liveloginform {
  text-align: center;
}


/*
loginform -------------------------------------------------------------------------------------------- */
#loginform {
	width: 80%;
	border: #999 solid 1px;
	margin: 30px auto 20px auto;
	padding: 20px;
}
#registerForm {
	width: 90%;
	margin: 0px auto;
	font-size: 0.9rem;
}
@media screen and (max-width: 959px) {
	/* 959px以下に適用されるCSS（タブレット用） */
	#loginform {
		width: 80%;
		height:80%;
		margin: 10px auto 40px auto;
	}
}
#loginform p {
	margin: 0px 0px 10px 0px;
}
#loginform label {
	margin-bottom: 4px;
	font-size: 0.9rem;
	font-weight: 600;
}

.inputform {
	margin-bottom: 10px;
}
.inputform input {
	box-sizing: border-box;
	width: 100%;
	padding: 0.6rem;
	letter-spacing: 1px;
	color: #333333;
	border: 1px solid #999999;
	border-radius: 5px;
}
.inputform input.name {
	width: 35%;
}

.inputform input:focus {
	border: 1px solid #da3c41;
	outline: none;
	box-shadow: 0 0 5px 1px rgba(218,60,65, .5);
}
	
.inputform input:invalid {
	/*background: #ffcdd2;*/
}
.inputform input:valid {
	background: transparent;
} 
.inputform label {
	display:block;
	margin-bottom: 4px;
	font-size: 0.9rem;
	font-weight: 600;
}

.inputform textarea {
	box-sizing: border-box;
	width: 90%;
	height: 150px;
	padding: 0.6rem;
	margin-left: 10px;
	margin-right: 10px;
	letter-spacing: 1px;
	color: #333333;
	border: 1px solid #999999;
	border-radius: 5px;
}

#loginform h6 {
  padding: 4px 16px 4px 10px;
  margin-bottom: 4px;
  font-size: 1rem;
}
#loginform .naiyou {
  font-weight: 600;
  font-size: 1rem;
  padding-left: 20px;
}
.r-label {
  display: inline-block;
  border-radius: 2px;
  font-size: 0.7rem;
  text-align: center;
  cursor: pointer;
  padding: 3px 6px;
  background: #D9534F;
  color: #ffffff;
  line-height: 1em;
}
.o-label {
  display: inline-block;
  border-radius : 2px;
  font-size: 0.7rem;
  text-align: center;
  cursor: pointer;
  padding: 3px 6px;
  background: #5CB85C;
  color: #ffffff;
  line-height: 1em;
}

input[type=checkbox] {
    display: none;
}
.checkbox {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
}
.checkbox::before {
    background: #fff;
    border: 1px solid #666666;
    content: '';
    display: block;
    height: 16px;
    left: 5px;
    margin-top: -8px;
    position: absolute;
    top: 50%;
    width: 16px;
}
.checkbox::after {
    border-right: 3px solid #ed7a9c;
    border-bottom: 3px solid #ed7a9c;
    content: '';
    display: block;
    height: 9px;
    left: 10px;
    margin-top: -7px;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: rotate(45deg);
    width: 5px;
}
input[type=checkbox]:checked + .checkbox::after {
    opacity: 1;
}
input[type=checkbox]:checked:disabled + .checkbox::before {
	opacity: 0.5;
}
input[type=checkbox]:disabled + .checkbox {
	color:#999;
	cursor: default;
}

.inputform label.radio-label {
	display: inline;
}
.radioBtn {
  display: flex;
	align-items: center;
}
.radioBtn02 {
	line-height: 3;
}
.radio-input {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
}

.radio-label {
	/*display: inline-block;*/
	padding: 0.5rem 1rem;
	margin: 0px 10px;
	border-radius: 3px;
	transition: all .1s;
	border: 1px solid #999999;
}

.radio-input:checked + .radio-label {
	background: #CC6666;
	color: #fff;
	text-shadow: 0 0 1px rgba(0,0,0,.7);
}

.radio-input:focus + .radio-label {
	outline-color: #da3c41;
	outline-style: auto;
	outline-width: 5px;
}

#quizForm {
	border: #999 solid 1px;
	border-radius: 5px;
	background-color: #FFF;
	width: 90%;
	margin: 20px auto;
	padding: 20px;
	
}

.quizArea {
  border-radius: 3px;
  border: #FFF solid 1px;
  margin: 10px;
  padding: 10px;
}
.quizArea p {
  margin: 0px;
}
.radioBtn {
  text-align: center;
  margin: 10px;
}

.quiz-radio {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
}

.quiz-label {
  display: inline-block;
  margin-right: 18px;
  border-radius: 3px;
  transition: all .2s;
  padding: 10px 40px;
  font-size: 1.2rem;
  font-weight: 600;
  border: #A0A0A0 solid 1px;
}

.quiz-radio:checked + .quiz-label {
  background: #B54A4A;
  color: #fff;
  text-shadow: 0 0 1px rgba(0,0,0,.7);
  border: none;
}

.quiz-radio:focus + .quiz-label {
  outline-offset: -2px;
  outline-style: auto;
  outline-width: 5px;
}

.quiz-radio:hover + .quiz-label {
  cursor: pointer;
}

.answer {
	margin: 6px 10px 0px 10px;
}
.answer p {
	text-indent: -2.9em;
	margin: 0px 10px 10px 50px;
}

.maru {
	background: #EFF;
}
.batu {
	background: #FEF;
}
.maruText {
  color: #00CC00;
  text-align: center;
  font-weight: 600;
  font-size: 1.2rem;
}
.batuText {
	color: #CC0000;
  text-align: center;
  font-weight: 600;
  font-size: 1.2rem;
}

#subBtn {
	text-align: center;
}
#submitBtn {
  display: inline-block;
  word-break: normal;
  padding: 1rem 1.4rem;
  font-size: 1rem;
	font-weight: 600;
  color: #fff;
  user-select: none;
  border: 0px #130CB7 solid;
	background:linear-gradient(135deg, #8395eb 0%,#2643d4 100%);
  border-radius: 3px;
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.14), 0 1px 2px 0 rgba(0, 0, 0, 0.12);
}
#submitBtn:hover {
  box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}

.closeBtn {
	text-align: center;
}
@media screen and (min-width: 790px) {
	/* 798px以上に適用されるCSS */
	.closeBtn {
		display: none;
	}
}

#qaform {
	background-color: #FFFFFF;
	padding: 20px;
	margin: 10px 10px;
	border-radius: 5px;
	box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}
.qaTextBox {
	background-color: #FFFFFF;
	padding: 20px;
	margin: 10px 10px;
	border-radius: 5px;
	box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}
.qaTextBox h6 {
	display: flex;
	font-size: 0.8rem;
	line-height: 1.2;
	color: #FFFFFF;
	background-color: #fed958;
	margin: 0px 0px 6px 0px;
	padding: 4px 10px;
}
.qaTextBox02 {
	background-color: #FFFFFF;
	padding: 20px;
	margin: 10px 10px;
	border-radius: 5px;
	box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}
.qaTextBox02 h6 {
	display: flex;
	font-size: 1rem;
	line-height: 1.2;
	color: #FFFFFF;
	background-color: #040d26;
	margin: 0px 0px 6px 0px;
	padding: 4px 10px;
}
.qaTextBox02 p {
	font-size: 1.2rem;
}
#listbox {
	overflow: hidden;
	width: 90%;
	margin: 0.4em auto;
	text-align: center;
	position: relative;
}
#listbox select {
	width: 100%;
	padding-right: 1em;
	cursor: pointer;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border-radius: 2px;
	border: 1px solid #666666;
  background-color: #333;
	-webkit-appearance: none;
	appearance: none;
	padding: 8px 38px 8px 8px;
	color: #F0F0F0;
  font-size: 14px;
}
#listbox select::-ms-expand {
    display: none;
}
#listbox::before {
	position: absolute;
	top: 0.8em;
	right: 0.8em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #F0F0F0;
	pointer-events: none;
}
#listbox option {
  background-color: #333;
  color: #F0F0F0;
}

#listbox02 {
	overflow: hidden;
	width: 90%;
	margin: 10px auto;
	/*text-align: center;*/
	position: relative;
}
#listbox02 select {
	width: 100%;
	padding-right: 1em;
	cursor: pointer;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border-radius: 2px;
	border: 1px solid #666666;
  background-color: #333;
	-webkit-appearance: none;
	appearance: none;
	padding: 10px 30px 10px 16px;
	color: #F0F0F0;
  font-size: 1.5rem;
	/*text-align: center;*/
}
#listbox02 select::-ms-expand {
  display: none;
}
#listbox02::before {
	position: absolute;
	top: 20px;
	right: 10px;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #F0F0F0;
	pointer-events: none;
}
#listbox02 option {
  background-color: #333;
  color: #F0F0F0;
}


/*
qrpublish -------------------------------------------------------------------------------------------- */
#qrContents {
	margin: 0px auto;
	width: 500px;
}
.qrTitle {
	font-size: 1.2rem;
	font-weight: 600;
	text-align: center;
	margin: 0px;
	padding: 6px;
	color: #2172BA;
	background-color: #FFD959;
	border-bottom: solid #2172BA 6px;
}
#qrinfo {
}
#qrcord {
	text-align: center;
	width: 140px;
	height: 140px;
	font-size: 0.9rem;
}
#img-qr {
	padding: 6px;
	border: solid #999 1px;
	width: 140px;
	height: 140px;
	margin: 0px auto 10px auto;
}
#memberinfo {
	margin: 10px;
}
@media screen and (min-width:501px) {
	/* 501px以下に適用されるCSS（タブレット用） */
	#qrinfo {
		display:flex;
		justify-content: center;
	}
}

@media screen and (max-width: 500px) {
	/* 500px以下に適用されるCSS（タブレット用） */
	#qrContents {
		margin: 0px 10px;
		width: 100%;
	}
	#qrinfo {
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
	#qrcord {
		margin: 0px auto 10px;
		width: 100%;
	}
	#memberinfo {
		margin: 10px auto;
	}
}

@media print{
  .print{display:none}
	#qrinfo {
		display:flex;
		justify-content: center;
	}
}


/*
qr reader -------------------------------------------------------------------------------------------- */

#qrform {
	width: 80%;
	border: #999 solid 1px;
	border-radius: 5px;
	margin: 30px auto 20px auto;
	padding: 20px;
}

.greenBox {
	background-color: #ddffdd;
	border: solid 2px #8ac926;
	border-radius: 5px;
	width: 60%;
	margin: 0px auto 20px auto;
	text-align: center;
	padding: 20px;
}
.redBox {
	background-color: #ffdddd;
	border: solid 2px #ff595e;
	border-radius: 5px;
	width: 60%;
	margin: 0px auto 20px auto;
	text-align: center;
	padding: 20px;
}

#results {
	
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	#qrform {
		width: 100%;
		padding: 0px;
	}
	#results {
		position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
	}
	.greenBox {
		width: 80%;
		padding: 10px;
	}
	.redBox {
		width: 80%;
		padding: 10px;
	}
}

#wrapper {
	margin: 0px auto 0px auto;
	width: 320px; height: auto;
}

#msg {
	margin: 0px; padding: 10px;
	background-color: lightgray;
	text-align: center;
}

#canvas {
	width: 100%; height: auto;
	background-color: silver;
}

.gg-arrow-up-r {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 width: 20px;
 height: 20px;
 border: 2px solid;
 transform: scale(var(--ggs,1));
 border-radius: 4px
}

.gg-arrow-up-r::after {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 top: 6px
}

.gg-arrow-up-r::after {
 width: 6px;
 height: 6px;
 border-top: 2px solid;
 border-left: 2px solid;
 transform: rotate(45deg);
 left: 5px
}


 .gg-arrow-right-r {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 width: 30px;
 height: 30px;
 border: 4px solid;
 transform: scale(var(--ggs,1));
 border-radius: 4px
}

.gg-arrow-right-r::after {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 right: 7px
}

.gg-arrow-right-r::after {
 width: 12px;
 height: 12px;
 border-top: 4px solid;
 border-right: 4px solid;
 transform: rotate(45deg);
 bottom: 5px
}

.gg-external {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 transform: scale(var(--ggs,1));
 width: 10px;
 height: 10px;
 box-shadow:
 -2px 2px 0 0,
 -4px -4px 0 -2px,
 4px 4px 0 -2px;
 margin-left: -2px;
 margin-top: 1px;
}

.gg-external::after,
.gg-external::before {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 right: -4px;
}

.gg-external::before {
 background: currentColor;
 transform: rotate(-45deg);
 width: 10px;
 height: 2px;
 top: 0px;
}

.gg-external::after {
 width: 6px;
 height: 6px;
 border-right: 2px solid;
 border-top: 2px solid;
 top: -4px;
}

.gg-chevron-down-r {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 transform: scale(var(--ggs,1));
 width: 20px;
 height: 20px;
 border: 2px solid;
 border-radius: 4px
}

.gg-chevron-down-r::after {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 width: 6px;
 height: 6px;
 border-bottom: 2px solid;
 border-right: 2px solid;
 transform: rotate(45deg);
 left: 5px;
 top: 4px
} 

.gg-log-out {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 width: 6px;
 height: 16px;
 border: 2px solid;
 transform: scale(var(--ggs,1));
 border-right: 0;
 border-top-left-radius: 2px;
 border-bottom-left-radius: 2px;
 margin-left: -10px;
 top: 3px;
}

.gg-log-out::after,
.gg-log-out::before {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
}

.gg-log-out::after {
 border-top: 2px solid;
 border-left: 2px solid;
 transform: rotate(-45deg);
 width: 8px;
 height: 8px;
 left: 4px;
 bottom: 2px;
}

.gg-log-out::before {
 border-radius: 3px;
 width: 10px;
 height: 2px;
 background: currentColor;
 left: 5px;
 bottom: 5px;
} 
