@charset "utf-8";

/* -------------------------------------------------------
	initialize
   ------------------------------------------------------- */

body,div,dl,dt,dd,ol,ul,li,p,h1,h2,h3,h4,h5,h6,img {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
body {
	color: #333;
	background-color: #fff;
	font-size: 1rem;
    line-height: 1.5;
	font-family: "メイリオ", Meiryo, Osaka, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", YuGothic, sans-serif;
}
h1,h2,h3,h4,h5,h6,address {
	font-size: 100%;
	font-weight: normal;
	font-style: normal;
	line-height: 100%;
}
dl,ol,ul { list-style: none;}
a {
	font-size: 100%;
	font-weight: normal;
	font-style: normal;
	line-height: 100%;
	text-decoration: none;
	outline:none;
}
a:focus { overflow: hidden;}
img {
	border: none;
	vertical-align: bottom;
}

/* -------------------------------------------------------
	common
   ------------------------------------------------------- */

a {
	color: #333;
	text-decoration: none;
}
a:hover {
	color: #333;
	text-decoration: none;
}
a:hover img {
	filter: alpha(opacity=75);
	-moz-opacity: 0.75;
	opacity: 0.75;
}

@media screen and (max-width: 480px) {
.pc-cont {
	display: none;
}
}

/* -------------------------------------------------------
	header
   ------------------------------------------------------- */

.drawer--navbarTopGutter {
	padding-top: 75px;
}
.drawer-navbar .drawer-navbar-header {
	border-bottom: solid 5px #01853a;
}
.drawer-navbar-header {
	height: 75px;
	text-align: left;
}

.drawer-navbar-header div {
	width: 100%;
	height: 70px;
}
.drawer-hamburger {
	top: 14px;
	width: 1.8rem;
	right: .75rem !important;
	padding-top: 8px;
	padding-right: .56rem;
	padding-bottom: 18px;
	padding-left: .56rem;
	border: solid 2px #01853a;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
	height: 3px;
	background-color: #01853a;
}
.drawer-navbar .drawer-nav {
	padding-top: 75px;
}
.drawer-navbar .drawer-nav li a {
	display: block;
	padding: 10px 15px;
	border-bottom: dotted 1px #01853a;
	color: #01853a;
}
.drawer-navbar .drawer-nav li a:first-child {
	padding-top: 15px;
}
.drawer-navbar .drawer-nav li a:hover {
	color: #fff;
	background-color: #5ba55a;
}
.drawer-navbar .drawer-nav li a span {
	font-size: 0.6rem;
	vertical-align: top;
}
.drawer-navbar-header div h1 {
	float: left;
}
.drawer-navbar-header div h2 {
	float: left;
	padding-left: 2%;
	font-size: 1.2rem;
    line-height: 70px;
	font-weight: bold;
}

@media screen and (max-width: 480px) {
.drawer-navbar-header div h2 {
	font-size: 4vw;
}
}

/* -------------------------------------------------------
	footer
   ------------------------------------------------------- */

footer {
	clear: both;
}
footer section {
	padding: 2rem 1.5rem 0;
	background-color: #f0f0f0;
	border-bottom: solid 1px #01853a;
	text-align: center;
}
footer section h3 {
	padding-bottom: 1rem;
	font-size: 1.1rem;
	font-weight: bold;
}
footer section ul {
	width: 640px;
	overflow: hidden;
	margin: 0 auto;
	padding: 1rem 0;
}
footer section li {
	float: left;
	margin: 10px 10px 0 0;
}
footer section li:last-child {
	margin: 0;
}

footer section .to-top {
	clear: both;
	margin-top: 1.5rem;
}
footer section .to-top a {
	display: block;
	width: 8rem;
	margin: 0 auto;
	color: #fff;
	line-height: 1.8;
	background-color: #01853a;
}
footer .copyright {
	padding: .7rem 1.5rem;
	font-size: 0.9rem;
	text-align: center;
}

@media screen and (max-width: 768px) {
footer section ul {
	width: 70%;
}
footer section li {
	margin: 0;
	width: 48%;
}
footer section li:first-child {
	margin-right: 4%;
}
footer section li:last-child {
	clear: both;
	float: none;
	width: 100%;
	padding-top: 4%;
}
footer section li img {
	width: 100%;
	height: auto;
}
}

@media screen and (max-width: 480px) {
footer section ul {
	width: 100%;
}
}

/* -------------------------------------------------------
	container
   ------------------------------------------------------- */

.name-area {
	padding: .75rem;
	border-bottom: solid 2px #01853a;
}
.name-area h2 {
	font-size: 1.1rem;
	line-height: 1.5;
	font-weight: bold;
}

.container {
	padding: 0 .75rem 2rem;
	max-width: 1000px;
	margin: 0 auto;
	overflow: hidden;
}

/* -------------------------------------------------------
	maincontent
   ------------------------------------------------------- */

.maincontent.cont-left {
	float: left;
	width: 68%;
}

@media screen and (max-width: 768px) {
.maincontent.cont-left {
	float: none;
	width: 100%;
}
}

/* -------------------------------------------------------
	login
   ------------------------------------------------------- */

.login {
	box-sizing: border-box;
	width: 100%;
	max-width: 768px;
	margin: 6% auto 0;
	padding: 3% 5%;
	border: double #b7d2aa;
}

.login input[type="text"],
.login input[type="password"]  {
	box-sizing: border-box;
	width: 100%;
	padding: .5rem;
	background-color: #fff;
	background-image: none;
	border: 1px solid #999;
	border-radius: 5px;
	box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}
#btnLogIn,
#btnClear,
#btnStartTraining,
#btnRegist,
#btnReturn,
.code-login input[type="submit"],
.search-btn-wrap input[type="submit"]  {
	/* width: 100%; */
	display: inline-block;
	margin: 0 .5rem;
	text-align: center;
	font-size: 1rem;
	text-shadow: 0px 0px 1px #000;
	padding: .75rem 1.25rem;
	color: #fff;
	background-color: #4ca052;
	border: none;
	border-radius: 5px;
	box-shadow: 1px 1px 4px -1px #000;
	cursor: pointer;
}
#btnClear,
#btnReturn  {
	background-color: #666;
}

.login .part-01 {
	width: 100%;
	overflow: hidden;
}
.login .part-01 h1 {
	float: left;
	width: 130px;
}
.login .part-01 h2 {
	width: 100%;
	font-size: 1.2rem;
	line-height: 70px;
	font-weight: bold;
}
.login .part-01 p {
	clear: both;
	padding: 2rem 0 1rem;
	text-align: center;
	border-top: solid 1px #b7d2aa;
}

.login .part-01 ul {
	list-style: inside circle;
	text-align: center;
	padding: 0 0 1rem;
}

.login .part-01 ul li a {
	color: #666;
    text-decoration: underline;
}

.login .part-01 ul li a:hover {
	color: #999;
    text-decoration: none;
}

.login .part-02 div {
	clear: both;
	width: 100%;
	overflow: hidden;
	margin-bottom: 1.5rem;
}
.login .part-02 h3 {
	float: left;
	width: 30%;
	padding: .5rem;
	text-align: center;
}
.login .part-02 p {
	float: left;
	width: 70%;
}
.login .part-02.alt-01 h3 {
	float: none;
	width: 100%;
	padding: 0 0 1rem;
}
.login .part-02.alt-01 p {
	float: none;
	width: 100%;
}

.login .part-03 {
	clear: both;
	text-align: center;
}

.login .part-04 {
	text-align: center;
	margin: 2rem 0;
}
.login .part-05 ul {
	list-style: inside circle;
}
.login .part-05 li {
	margin-bottom: .25rem;
}
.login .part-05 li a {
	font-size: .9rem;
	color: #666;
	text-decoration: underline;
}
.login .part-05 li a:hover {
	color: #999;
	text-decoration: none;
}

@media screen and (max-width: 480px) {
.login {
	margin-top: 0;
	padding: 0;
	border: none;
}

.login .part-01 p {
	text-align: left;
}
.login .part-02 h3 {
	float: none;
	width: 100%;
	padding: 0 0 .5rem;
	text-align: left;
}
.login .part-02 p {
	float: none;
	width: 100%;
}
}

/* -------------------------------------------------------
	sec
   ------------------------------------------------------- */

.sec .hl-wrap-01 {
	width: 100%;
	overflow: hidden;
	margin-top: 1.5rem;
	background: url(../../img/Training/hl_bg_01.gif) left bottom repeat-x;
}
.sec .hl-wrap-01.alt-01 {
	margin: 2.5rem 0 1.6rem;
}
.sec .hl-wrap-01 h2 {
	float: left;
	padding-right: 1rem;
	border-bottom: solid 5px #01853a;
	font-size: 1.04rem;
	line-height: 1.8;
	font-weight: bold;
}

.sec .hl-wrap-02 {
	width: 100%;
	overflow: hidden;
	margin-top: 1.5rem;
	border-bottom: solid 1px #333;
	border-left: solid 5px #333;
}
.sec .hl-wrap-02 h2 {
	font-size: 1rem;
	line-height: 1.8;
	font-weight: bold;
	padding-left: .4rem;
}

.sec .catch-01 {
	padding: .8rem .4rem .4rem;
}

.sec .ul-01 li {
	border-bottom: solid 1px #ccc;
}
.sec .ul-01 li a {
	display: block;
	padding: .8rem .4rem .4rem;
	line-height: 1.5;
}
.sec .ul-01 li a:hover {
	background-color: #e7fbe3;
}
.sec .ul-01 strong {
	font-weight: normal;
	color: #666;
	line-height: 2;
}
.sec .ul-01 .cat-tag-01 {
	display: inline-block;
	color: #fff;
	font-size: .9rem;
	padding: 0 .3rem;
	margin-left: .5rem;
}
.sec .ul-01 .color-01 { background-color: #cc3333;}
.sec .ul-01 .color-02 { background-color: #cc9933;}
.sec .ul-01 .color-03 { background-color: #009933;}
.sec .ul-01 .color-04 { background-color: #3333cc;}
.sec .ul-01 .color-05 { background-color: #cc33cc;}

.sec .ul-02 {
	list-style: circle outside;
	padding-left: 2rem;
	width: 98%;
	margin-top: 1.25rem;
	padding-bottom: .5rem;
}
.sec .ul-02 li {
	border-bottom: dotted 1px #333;
	font-size: .9rem;
	padding-bottom: .75rem;
	margin-bottom: 1rem;
}
.sec .ul-02 li a {
	color: #666;
	text-decoration: underline;
}
.sec .ul-02 li a:hover {
	color: #999;
	text-decoration: none;
}

.sec .tbl-01 {
	clear: both;
	width: 100%;
	border-collapse: collapse;
}
.sec .tbl-01 th,
.sec .tbl-01 td {
	text-align: left;
	vertical-align: top;
	font-weight: normal;
}
.sec .tbl-01 th {
	padding: .5rem;
	background-color: #6eb076;
	border-right: dotted 1px #fff;
	color: #fff;
	white-space: nowrap;
}
.sec .tbl-01 td {
	padding: 1rem .5rem;
	border-bottom: solid 1px #6eb076;
	border-right: dotted 1px #e0f1e2;
	font-size: 0.9rem;
}
.sec .tbl-01 th:last-child,
.sec .tbl-01 td:last-child {
	border-right: none;
}
.sec .tbl-01 th:nth-child(1) { width: 8%;}
.sec .tbl-01 th:nth-child(2) { width: 20%;}
.sec .tbl-01 th:nth-child(3) { width: 22%;}
.sec .tbl-01 th:nth-child(4) { width: 32%;}
.sec .tbl-01 th:nth-child(5) { width: 18%;}
.sec .tbl-01 a {
	color: #666;
	text-decoration: underline;
}
.sec .tbl-01 a:hover {
	color: #999;
	text-decoration: none;
}
.sec .tbl-01.alt-01 {
	margin: 1rem 0 1.6rem;
}
.sec .tbl-01.alt-01 th {
	width: auto !important;
	font-size: 0.9rem;
	white-space: normal;
}

.sec .tbl-02 {
	clear: both;
	width: 100%;
	border-collapse: collapse;
	margin-top: 1rem;
	border-top: solid 1px #6eb076;
}
.sec .tbl-02 th,
.sec .tbl-02 td {
	text-align: left;
	font-weight: normal;
	padding: 1rem 1.5rem;
	margin-bottom: 2rem;
}
.sec .tbl-02 th {
	vertical-align: middle;
	background-color: #fff;
	border-right: dotted 1px #999;
	border-bottom: solid 1px #6eb076;
	background-color: #f8f8f8;
	color: #027031;
	width: 6rem;
	white-space: nowrap;
}
.sec .tbl-02 td {
	vertical-align: top;
	border-bottom: solid 1px #6eb076;
}
.sec .tbl-02 th:last-child,
.sec .tbl-02 td:last-child {
	border-right: none;
}
.sec .tbl-02 a {
	color: #666;
	text-decoration: underline;
}
.sec .tbl-02 a:hover {
	color: #999;
	text-decoration: none;
}
.sec .tbl-02.alt-01 {
	margin-bottom: 1.6rem;
}

.sec .box-01 {
	padding: 1rem .75rem 0;
}
.sec .box-01 p {
	padding-bottom: 1rem;
}
.sec .box-01 img {
	display: inline-block;
	width: 60px;
	height: auto;
	padding: 4px;
	margin: 4px;
	border: solid 2px #999;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px; 
}

.sec .pagination-01 {
	clear: both;
	margin-top: 2rem;
	padding-bottom: 1rem;
	width: 100%;
	overflow: hidden;
	text-align: center;
}
.sec .pagination-01 li {
	display: inline-block;
	border: solid 1px #038338;
	margin: 0 .2rem 1rem;
}
.sec .pagination-01 li a {
	padding: 0 .5rem;
	color: #038338;
	line-height: 2rem;
	display: block;
}

.sec .pagination-01 li a.selected,
.sec .pagination-01 li a:hover {
	color: #fff;
	background-color: #038338;
}

.sec .btn-wrap-01 {
	clear: both;
	margin-top: 1.5rem;
}
.sec .btn-wrap-01 a {
	display: block;
	width: 300px;
	margin: 0 auto;
	color: #038338;
	text-align: center;
	font-size: 1.1rem;
	line-height: 3.4;
	font-weight: bold;
	border: solid 3px #038338;
	background: url(../../img/Training/arw_r_01.jpg) 280px center no-repeat;
}
.sec .btn-wrap-01 a:hover {
	color: #fff;
	background-color: #038338;
	background-image: none;
}

.sec .btn-wrap-02 {
	clear: both;
	margin-top: 1.5rem;
	width: 100%;
	overflow: hidden;
}
.sec .btn-wrap-02 p {
	float: left;
	width: 49%;
	margin-bottom: 2%;
}
.sec .btn-wrap-02 p:nth-child(odd) {
	margin-right: 2%;
}
.sec .btn-wrap-02 a {
	box-sizing: border-box;
	display: block;
	width: 100%;
	color: #038338;
	text-align: center;
	font-size: 1.1rem;
	line-height: 3.4;
	font-weight: bold;
	border: solid 3px #038338;
	background: url(../../img/Training/arw_r_01.jpg) 98% center no-repeat;
}
.sec .btn-wrap-02.alt-02 p:first-child a {
	background: url(../../img/Training/arw_l_01.jpg) 2% center no-repeat;
}
.sec .btn-wrap-02 p:first-child a:hover,
.sec .btn-wrap-02 a:hover {
	color: #fff;
	background-color: #038338;
	background-image: none;
}

.sec .btn-wrap-03 {
	clear: both;
	margin-top: .6rem;
}
.sec .btn-wrap-03 a {
	box-sizing: border-box;
	display: block;
	width: 100%;
	color: #038338;
	text-align: center;
	font-size: 1.1rem;
	line-height: 3.4;
	font-weight: bold;
	border: solid 3px #038338;
}
.sec .btn-wrap-03 a span {
	display: inline-block;
	padding-left: 30px;
	background: url(../../img/Training/ico_home_01.jpg) left 15px no-repeat;
}
.sec .btn-wrap-03 a:hover {
	color: #fff;
	background-color: #038338;
}
.sec .btn-wrap-03 a:hover span {
	background-image: url(../../img/Training/ico_home_01_on.jpg);
}

.sec .btn-wrap-03.alt-01 a {
	color: #242380;
	border: solid 3px #242380;
}
.sec .btn-wrap-03.alt-01 a:hover {
	color: #fff;
	background-color: #242380;
}

.sec .btn-wrap-04 {
	clear: both;
	margin-top: 2%;
	width: 100%;
	overflow: hidden;
}
.sec .btn-wrap-04 p {
	float: left;
	width: 32%;
	margin: 0 2% 2% 0;
}
.sec .btn-wrap-04 p:last-child {
	margin-right: 0;
}
.sec .btn-wrap-04 a {
	box-sizing: border-box;
	display: block;
	width: 100%;
	color: #038338;
	text-align: center;
	font-size: 1rem;
	line-height: 3;
	border: solid 1px #038338;
}
.sec .btn-wrap-04 a.selected,
.sec .btn-wrap-04 a:hover {
	color: #fff;
	background-color: #038338;
}

.sec .btn-wrap-05 {
	clear: both;
	margin-top: .6rem;
}
.sec .btn-wrap-05 a {
	box-sizing: border-box;
	display: block;
	width: 100%;
	color: #038338;
	text-align: center;
	font-size: 1.1rem;
	line-height: 1.3;
	padding: 1rem 0;
	font-weight: bold;
	border: solid 3px #038338;
}
.sec .btn-wrap-05 a:hover {
	color: #fff;
	background-color: #038338;
}

.form-wrap-01 .part-01 p {
	text-align: right;
	margin-top: 1rem;
}
.form-wrap-01 .part-01 select {
	display: inline-block;
	width: 30%;
	margin: 0 0 .5rem 1%;
	padding: .5rem;
	font-size: 1rem;
	line-height: 2;
	background-color: #fff;
    background-image: none;
	border: 1px solid #999;
	border-radius: 4px;
	box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}

.form-wrap-01 .part-02 {
	margin: 1.6rem 0;
}
.form-wrap-01 .part-02 p {
	margin-bottom: .6rem;
}
.form-wrap-01 .part-02 p:last-child {
	text-align: right;
}
.form-wrap-01 .part-02 textarea {
	box-sizing: border-box;
    width: 100%;
	padding: .5rem;
    background-color: #fff;
    background-image: none;
	border: 1px solid #999;
    border-radius: 5px;
    box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}

.form-wrap-02 {
	width: 100%;
	padding: 1.5rem;
	margin-top: 1rem;
	background-color: #e8f3e7;
    border-radius: 8px;
}
.form-wrap-02 select,
.form-wrap-02 input,
.form-wrap-02 textarea {
	box-sizing: border-box;
    width: 100%;
	padding: .5rem;
    background-color: #fff;
    background-image: none;
	border: 1px solid #999;
    border-radius: 5px;
    box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}
.form-wrap-02 div {
	clear: both;
	width: 100%;
	overflow: hidden;
}
.form-wrap-02 h4 {
	float: left;
	font-weight: bold;
	line-height: 2;
	width: 12%;
}
.form-wrap-02 p {
	float: left;
	width: 88%;
}
.form-wrap-02 .part-01,
.form-wrap-02 .part > div {
	margin-bottom: .75rem;
	padding-bottom: .75rem;
	border-bottom: solid 2px #ccc;
}
.form-wrap-02 .part-02 select,
.form-wrap-02 .part-02 input,
.form-wrap-02 .part-03 select {
	width: 40%;
}

@media screen and (max-width: 768px) {
.sec .btn-wrap-02.alt-01 a {
	font-size: 1rem;
}

.form-wrap-02 h4 {
	width: 20%;
}
.form-wrap-02 p {
	width: 80%;
}
.form-wrap-02 .part-02 select,
.form-wrap-02 .part-02 input,
.form-wrap-02 .part-03 select {
	width: 100%;
}
}

@media screen and (max-width: 480px) {
.sec .tbl-01 th {
	padding: .2rem;
	font-size: .9rem;
	white-space: normal;
}
.sec .tbl-01 td {
	padding: .2rem;
}

.sec .tbl-02,
.sec .tbl-02 tbody,
.sec .tbl-02 thead,
.sec .tbl-02 tfoot,
.sec .tbl-02 tr,
.sec .tbl-02 th,
.sec .tbl-02 td {
    display: block;
}
.sec .tbl-02 th,
.sec .tbl-02 td {
	padding: .75rem;
	margin-bottom: 0;
	width: 100%;
	box-sizing: border-box;
	font-size: .9rem;
}
.sec .tbl-02 th {
	padding: .3rem .75rem;
	text-align: center;
	border-right: none;
	white-space: normal;
	border-bottom: dotted 1px #ccc;
}

.sec .box-01 img {
	width: 50px;
}

.sec .btn-wrap-01 a {
	width: 100%;
	line-height: 3;
	box-sizing: border-box;
	background-position: 98% center;
}

.sec .btn-wrap-02 p {
	float: none;
	width: 90%;
	margin: 0 auto 2%;
}

.sec .btn-wrap-02 p:nth-child(odd) {
	margin: 0 auto 3%;
}

.sec .btn-wrap-03 a {
	line-height: 3;
}
.sec .btn-wrap-03 a span {
	background-position: left 12px;
}

.sec .btn-wrap-05 a {
	font-size: 1rem;
}

.form-wrap-02 h4,
.form-wrap-02 p {
	float: none;
	width: 100%;
}
.form-wrap-01 .part-01 select {
	display: block;
	width: 100%;
	margin-left: 0;
}
}

/* -------------------------------------------------------
	sidebar
   ------------------------------------------------------- */

.sidebar {
	float: right;
	width: 28%;
	margin-top: 1.5rem;
}

.sidebar ul {
	padding-bottom: 6px;
	border-bottom: dotted 1px #01853a;
}
.sidebar li {
	margin-bottom: 2px;
	background-color: #01853a;
	background-repeat: no-repeat;
	background-position: 20px center;
}
.sidebar li:hover {
	filter: alpha(opacity=75);
	-moz-opacity: 0.75;
	opacity: 0.75;
}
.sidebar li:nth-child(1) { background-image: url(../../img/Training/snav_ico_01.jpg);}
.sidebar li:nth-child(2) { background-image: url(../../img/Training/snav_ico_02.jpg);}
.sidebar li:nth-child(3) { background-image: url(../../img/Training/snav_ico_03.jpg);}
.sidebar li:nth-child(4) { background-image: url(../../img/Training/snav_ico_04.jpg);}
.sidebar li:nth-child(5) { background-image: url(../../img/Training/snav_ico_05.jpg);}
.sidebar li:nth-child(6) { background-image: url(../../img/Training/snav_ico_06.jpg);}
.sidebar li a {
	box-sizing: border-box;
	display: block;
	height: 80px;
	padding: 32px 0 0 60px;
	color: #fff;
	font-size: 1.06rem;
	line-height: 1.1;
}
.sidebar li:nth-child(2) a {
	padding-top: 24px;
}
.sidebar li:nth-child(2) a span {
	font-size: .8rem;
}

.sidebar h2 {
	padding-top: 8px;
}
.sidebar h2 img {
	width: 100%;
	height: auto;
}

@media screen and (max-width: 768px) {
.sidebar {
	float: none;
	width: 100%;
}


.sidebar ul {
	width: 100%;
	overflow: hidden;
	padding-bottom: 0;
	border-bottom: none;
}
.sidebar li {
	float: left;
	width: 50%;
	border-right: solid 2px #fff;
}

.sidebar h2 {
	padding: .75rem .75rem 0;
}


}

@media screen and (max-width: 480px) {
.sidebar li {
	float: none;
	width: 100%;
	border-right: none;
}
.sidebar li a {
	height: 60px;
	padding-top: 22px;
}
.sidebar li:nth-child(2) a {
	padding-top: 12px;
}
}


/* -------------------------------------------------------
	tooltip
   ------------------------------------------------------- */

#tooltip
{
    text-align: center;
    color: #fff;
    background: #111;
    position: absolute;
    z-index: 100;
    padding: 15px;
}
 
    #tooltip:after /* triangle decoration */
    {
        width: 0;
        height: 0;
        border-left: 10px solid transparent;
        border-right: 10px solid transparent;
        border-top: 10px solid #111;
        content: '';
        position: absolute;
        left: 50%;
        bottom: -10px;
        margin-left: -10px;
    }
 
        #tooltip.top:after
        {
            border-top-color: transparent;
            border-bottom: 10px solid #111;
            top: -20px;
            bottom: auto;
        }
 
        #tooltip.left:after
        {
            left: 10px;
            margin: 0;
        }
 
        #tooltip.right:after
        {
            right: 10px;
            left: auto;
            margin: 0;
        }

/* -------------------------------------------------------
	clearfix
   ------------------------------------------------------- */

.clearfix:after {
	content: ".";
	clear: both;
	height: 0;
	display: block;
	visibility: hidden;
}

.clearfix {
	display: inline-block;
}

.clearfix {
	display: block;
}

/* -------------------------------------------------------
	2019/09/24追加
   ------------------------------------------------------- */

.procedure-list {
	padding: .8rem .4rem .4rem;
}

.procedure-list li {
	margin-bottom: .2rem
}

.procedure-list .num {
	font-size: 1.04rem;
	font-weight: bold;
	color: #01853a;
	margin-right: .1rem;
}

.reception-time {
	border: solid 2px #ff0000;
	padding: .8rem;
	margin-bottom: 1rem;
}

.reception-time h3 {
	font-size: 1.4rem;
	font-weight: bold;
	color: #ff0000;
	margin-bottom: .4rem;
}

.reception-time a {
	color: #666;
    text-decoration: underline;
}

.reception-time a:hover {
	color: #999;
	text-decoration: none;
}

.code-login {
	margin-top: 1.5rem;	
}

.code-login .text {
	padding: 2rem 0 1rem;
}

.code-login .part-02 div {
	clear: both;
    width: 100%;
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.code-login .part-02 h3 {
    float: left;
    width: 30%;
    padding: .5rem;
    text-align: center;
}

.code-login .part-02 p {
    float: left;
    width: 70%;
}

.code-login input[type="text"],
.code-login input[type="password"] {
    box-sizing: border-box;
    width: 100%;
    padding: .5rem;
    background-color: #fff;
    background-image: none;
    border: 1px solid #999;
    border-radius: 5px;
    box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}


.code-login .part-04 {
    text-align: center;
    margin: 2rem 0;
}

input[type="checkbox"] {
    border: 1px #CCC solid;
    padding: 5px;
    border-radius: 10px;
    width: 2em;
    height: 2em;
    cursor: pointer;
    vertical-align: middle;
}

.announcement dl {
	padding-top: .8rem;
	overflow: hidden; 
}

.announcement dl dt {
	float: left;
	margin-bottom: .4rem;
	font-weight: bold
}

.announcement dl dd {
	padding-left: 180px;
	margin-bottom: .4rem;
}

.overview-list {
	margin-top: .8rem;
	background: #fbfbfb;
	padding: 1.4rem;
}

.overview-list li {
	position: relative;
	padding-left: 12px;
	margin-bottom: .4rem
}

.overview-list li:after {
	display: block;
    content: '';
    position: absolute;
    top: .6em;
    left: 0;
    width: 5px;
    height: 5px;
    background-color: #ff3c3c;
    border-radius: 100%;
}

.manual-link {
	text-align: center;
	margin-top: 30px;
	list-style: inside circle;
}

.manual-link a {
    color: #666;
    text-decoration: underline;
}

.manual-link a:hover {
	color: #999;
    text-decoration: none;
}

.movie-item,
.pdf-item,
.movie-item-isread,
.pdf-item-isread {
	margin-bottom: 15px;
}

.movie-item a,
.movie-item-isread a {
	box-sizing: border-box;
    display: block;
    width: 100%;
    font-size: 1.1rem;
    line-height: 3.4;
    font-weight: bold;
    padding-left: 60px;
    position: relative;
    background-color: #1d5eaf;
    border-radius: 8px;
    color: #fff;
    transition: .2s;
}

.movie-item a:hover {
	opacity: .8;
}



.movie-item a:before {
	content: "";
	display: block;
	width: 24px;
	height: 22px;
	background: url(../../img/Training/ico_video.png) no-repeat center center;
	background-size: 24px 22px;
	position: absolute;
	left: 15px;
	top: 17px;
}

.pdf-item a:before {
	content: "";
	display: block;
	width: 18px;
	height: 24px;
	background: url(../../img/Training/ico_pdf.png) no-repeat center center;
	background-size: 18px 24px;
	position: absolute;
	left: 15px;
	top: 16px;
}

.movie-item a span {
	position: absolute;
	right: 10px;
}

.pdf-list {
	margin-top: .8rem;
}

.pdf-item a,
.pdf-item-isread a {
	box-sizing: border-box;
    display: block;
    width: 100%;
    font-size: 1.1rem;
    line-height: 3.4;
    font-weight: bold;
    padding-left: 60px;
    position: relative;
    background: #af0b03;
    border-radius: 8px;
    color: #fff;
	transition: .2s;
}

.pdf-item a:hover {
	opacity: .8;
}

.movie-item-isread a,
.pdf-item-isread a {
    background-color: #ccc;
}

.keyword-wrap {
	margin-top: 2.5rem;
}

.keyword-wrap h2 {
	color: #ff0000;
	font-weight: bold;
	text-align: center;
	margin-bottom: 1.5rem;
}

.keyword-list {
	display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-pack: space-between;
}

.keyword-item {
	width: 17%;
}

.keyword-list input[type="text"] {
    box-sizing: border-box;
    width: 100%;
    padding: 1rem;
    background-color: #fff;
    background-image: none;
    border: 1px solid #999;
    border-radius: 5px;
    box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}

.question-text {
	padding-top: .8rem;
	margin-bottom: 2rem;
}

.question-item {
	width: 100%;
	/* padding: 10px; */
	margin-bottom: 1.5rem;
	border: solid 1px #ccc;
}

.question-item label {
	padding: 10px;
	display: block;
	/* width: 100%; */
	cursor: pointer;
	/* border: solid 1px #ccc; */
}

.question-item span {
	font-size: 1.5rem;
	font-weight: bold;
	color: #01853a;
	margin-right: .1rem;
	margin-right: 1rem;
}

.question-item input[type="checkbox"]:checked label {
	background: #31A9EE;/* マウス選択時の背景色を指定する */
	color: #ffffff; /* マウス選択時のフォント色を指定する */
}

.correct-answer-wrap {
	margin-top: .8rem;
}

.correct-answer-success {
	text-align: center;
}

.success-num {
	font-size: 1.5rem;
	font-weight: bold;
}

.success-num span {
	font-size: 2.5rem;
}

.correct-answer-success p {
	font-size: 1.2rem;
	font-weight: bold;
	color: #ff0000;
}

.correct-answer {
	margin-top: 30px;
	border: solid 1px #ccc;
	padding: 20px;
}

.correct-answer-item {
	display: flex;
	margin-bottom: 20px;
}

.correct-answer-item:last-child {
	margin-bottom: 0;
}

.correct-answer-item-left {
	width: 12%;
	display: flex;
}

.correct-answer-item-right {
	width: 88%;
}

.examination-sentence {
	margin-bottom: 10px;
	padding: 10px;
	background: #fbfbfb;
	border-radius: 6px;
}

.correct-answer-item-right .answer {
	padding: 10px;
	background: #eaf9ff;
	border-radius: 6px;
}

.correct-answer-item-title {
	font-size: 1.04rem;
	font-weight: bold;
	color: #01853a;
	margin-right: .1rem;
	margin-right: 1rem;
	padding-top: 5px;
}

.mark {
	font-size: 2.5rem;
	font-weight: bold;
	line-height: 1;
}

.search-box {
	margin-top: 1.5rem;
}

.search-box-title {
	font-size: 1.04rem;
	font-weight: bold;
	background: #01853a;
	padding: 1rem;
	color: #fff;
	position: relative;
	cursor: pointer;
}

.search-box-title span.close {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 13px 8px 0 8px;
	border-color: #ffffff transparent transparent transparent; 
	position: absolute;
	right: 20px;
	top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.search-box-title span.open {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 8px 13px 8px;
	border-color: transparent transparent #ffffff transparent;
	position: absolute;
	right: 20px;
	top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.search-box .search-box-inner {
	display: none;
}

.search-box-inner {
	background: #e8f3e7;
	padding: 1.5rem;
}

.search-box-inner dl dt {
	box-sizing: border-box;
	width: 20%;
	font-weight: bold;
	float: left;
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: solid 1px #ccc;
	line-height: 3;
}

.search-box-inner dl dd {
	box-sizing: border-box;
	margin-left: 20%;
	display: flex;
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: solid 1px #ccc;
	line-height: 3;
}

.search-box-inner dl dd:after {
  /* content: ''; */
  display: block;
  clear: both;
}

.search-box-inner input[type="text"],
.search-box-inner textarea {
	width: 100%;
	box-sizing: border-box;
	padding: .5rem;
	background-color: #fff;
	background-image: none;
	border: 1px solid #999;
	border-radius: 5px;
	box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}

.search-item {
	width: 48%;
}

.search-item:first-child {
	margin-right: 4%;
}

.search-item-s input[type="text"] {
	width: 65%;
	margin-left: 15px;
}

.search-item select {
	box-sizing: border-box;
    width: 70%;
    padding: .5rem;
    background-color: #fff;
    background-image: none;
    border: 1px solid #999;
    border-radius: 5px;
    box-shadow: inset 0 3px 3px rgba(0,0,0,.075);
}

.search-label {
	margin-right: 15px;
}

.search-item-text {
	margin-right: 15px;
}

.search-item-m {
	margin-right: 10px;
}

.search-item-m:last-child {
	margin-left: 10px;
	margin-right: 0;
}

.search-btn-wrap {
	text-align: center;
    margin: 2rem auto;
    width: 30%;
    display: flex;
}

.search-btn-wrap p {
	width: 48%;
}

.search-btn-wrap input[type="submit"] {
	/* display: inline; */
	background-color: #266fbd;
}

.search-btn-wrap .excel-btn input[type="submit"] {
	background-color: #01853a;
}

.sec .tbl-01.search-table th {
	width: 10%;
}

.sec .tbl-01.search-table th:first-child {
	width: 5%;
	text-align: center;
}

.sec .tbl-01.search-table th:first-child img {
	vertical-align: middle;
}

.sec .tbl-01.search-table th:nth-child(4)  {
	width: 8%;
}

.sec .tbl-01.search-table th:nth-child(5) {
	width: 8%;
}

.btn-list {
	display: flex;
	justify-content: space-between;
}

.btn-list li {
	width: 31%
}

.sec .part-04 {
    text-align: center;
    margin: 2rem 0;
}

.sec  input[type="submit"],
.sec  input[type="reset"]  {
	display: inline-block;
	margin: 0 .5rem;
	text-align: center;
	font-size: 1rem;
	text-shadow: 0px 0px 1px #000;
	padding: .75rem 1.25rem;
	color: #fff;
	background-color: #4ca052;
	border: none;
	border-radius: 5px;
	box-shadow: 1px 1px 4px -1px #000;
	cursor: pointer;
}
.sec input[type="reset"]  {
	background-color: #666;
}

.requred {
	color: #ff0000;
	margin-top: .8rem;
	margin-bottom: .8rem;
}

.question-select {
	background: #4ca052;

	color: #fff;
}

.question-select span {
	color: #fff;
}

.question-choice {
	display: none;
}

.form-block {
	display: flex;
	justify-content: space-between;
}

.form-block-item {
	width: 48%;
	display: flex;
	margin-bottom: 10px;
}

.form-block-item h4 {
	line-height: 1.5;
	font-weight: bold;
}

.form-block-item p {
	margin-left: 50px;
}

.search-box-inner .search-textarea-title {
	line-height: 5.2;
	vertical-align: top;
}

.planned {
	background: #fffdd8;
}

.movie-wrap {
	width: 100%;
	height: 80%;
	text-align: center;
	padding-top: 20px;
}

.movie-wrap video {
	width: 67%;
	cursor: pointer;
}

.close-btn-wrap {
	text-align: center;
}

.close-btn-wrap a {
	display: inline-block;
	width: 50%;
	background: #ccc;
	padding: 20px;
	margin-top: 10px;
	transition: .2s;
}

.close-btn-wrap a:hover {
	opacity: .8;
}

@media screen and (max-width: 992px) {
	.search-box-inner dl dt {
		width: 30%;
	}
	
	.movie-wrap video {
		width: 80%;
	}
}

@media screen and (max-width: 768px) {
	.reception-time h3 {
		font-size: 1rem;
	}

	.code-login .part-02 h3 {
		float: none;
		width: 100%;
		padding: 0 0 .5rem;
		text-align: left;
	}

	.code-login .part-02 p {
		float: none;
		width: 100%;
	}

	#btnLogIn, #btnClear, .code-login input[type="submit"] {
		width: 100%;
		margin: 10px 0;
	}
	.login input[type="text"],
	.login input[type="password"],
	.code-login input[type="text"] {
		padding: 1rem;
	}

	.announcement dl dt {
		float: none;
	}

	.announcement dl dd {
		padding-left: 0;
	}

	.overview-list {
		padding: 1rem;
	}

	.movie-item a,
	.pdf-item a,
.movie-item-isread a,
.pdf-item-isread a {
		font-size: .9rem;
	}

	.movie-item a {
		padding: 0 15px
	}

	.movie-title {
		padding-left: 30px;
	}

	.movie-item a:before {
		top: 12px;
	}

	.pdf-item a:before {
		top: 11px;
	}

	.correct-answer-success p {
		font-size: 1rem;
	}

	.correct-answer-item {
		display: block;
	}

	.correct-answer-item-left {
		width: 100%;
		margin-bottom: 10px;
	}

	.correct-answer-item-right {
		width: 100%;
	}

	.search-box-inner dl dt {
		width: 100%;
		float: none;
		line-height: 1.5;
	}

	.search-box-inner dl dd {
		margin-left: 0;
		display: block;
		line-height: 2.5;
	}

	.search-box-inner input {
		display: block;
	}

	.search-box-inner input[type="checkbox"] {
		display: inline-block;
	}

	.search-item {
		width: 100%;
	}

	.search-label {
		display: block;
		margin-right: 0;
	}

	.search-item-s input[type="text"] {
		width: 100%;
		margin-left: 0;
	}

	.search-item select {
		width: 100%;
	}

	.search-btn-wrap {
		width: 100%;
		display: block;
	}

	.search-btn-wrap p {
		width: 100%;
	}

	.search-btn-wrap input[type="submit"] {
		width: 100%;
		margin: 10px 0;
	}

	.form-block {
		display: block;
	}

	.form-block-item {
		display: block;
		width: 100%;
	}

	.form-block-item p {
		margin-left: 0;
	}

	.btn-list {
		display: block;
	}

	.btn-list li {
		width: 100%;
		margin-bottom: 10px;
	}

	.search-box-inner .search-textarea-title {
		line-height: 3;
	}

	div.outer{
		width: 100%;
		overflow-x: auto;
		margin-bottom: 2em;
	}

	div.outer::-webkit-scrollbar {
		height: 5px;
	}

	div.outer::-webkit-scrollbar-track {
		border-radius: 5px;
		background: #eee;
	}
	div.outer::-webkit-scrollbar-thumb {
		border-radius: 5px;
		background: #666;
	}

	.outer .search-table {
		width: 800px;
	}
	
	.movie-wrap video {
		width: 100%;
	}
	
}