@charset "UTF-8";

.forSp {
	display:none;
}
a:hover img {
	-ms-filter: "alpha( opacity=70 )";
	filter: alpha( opacity=70 );
	opacity: 0.7;
	transition-duration: .6s;
	-moz-transition-duration: .6s;
	-webkit-transition-duration: .6s;
}
img {
	max-width:100%;
	height:auto;
}
.tar {
	text-align:right;
}
.mb10 {
	margin-bottom:10px;
}
.spFoot {
	display:none;
}
.decimal {
	margin-left:25px;
	list-style:decimal;
}
#header {
	/zoom:1;
}
#header:after {
	content:'';
	display:block;
	clear:both;
}
#header_left {
	width:489px;
	float:left;
	text-align:left;
}
#spAddress {
	display:none;
}
#mainContents h3 + h3 {
	margin-top:10px;
}
#menu * {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
#menu_contents {
	display:block;
	background:url(../images/common/menu_bg.gif) repeat-x left bottom;
	/zoom:1;
}
#menu_contents:after {
	content:'';
	display:block;
	clear:both;
}
#menu_contents li {
	width:112px;
	height:30px;
	float:left;
	border-left:#ccc 1px solid;
}
#menu_contents .last {
	width:128px;
}
#menu_contents .first {
	border:0;
}
#menu_contents a {
	display:block;
	font-weight:bold;
	line-height:30px;
	text-align:center;
}
#mainbox_left {
	width:530px;
	float:left;
}
#mainbox_right {
	width:240px;
	float:right;
}
#mainbox {
	/zoom:1;
}
#mainbox:after {
	content:'';
	display:block;
	clear:both;
}
#footer {
	background-color: #0A50A0;
  padding: 5px 0;
}

#sidemenu_banner {
	padding:10px 10px 0px;
	border:1px solid #b3b3b3;
	border-radius:10px;
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
#sidemenu_banner li {
	margin-bottom:10px;
}
#sidemenu_text li {
	padding:0 5px;
}
#sidemenu_text a {
	height:40px;
	line-height:40px;
	padding-left:30px;
	display:block;
	font-weight:bold;
	text-align:left;
	background:url(../images/common/bg_sidemenu_li.png) no-repeat 10px center;
		border-bottom:1px dashed #b3b3b3;
}
#sidemenu_text  li:last-child a {
	border-bottom:0;
}
#sidemenu_text {
	border:1px solid #b3b3b3;
	border-radius:10px;
	background: #fff; /* Old browsers */
	background: -moz-linear-gradient(top,  #ececec 0%, #ffffff 6%, #ffffff 92%, #ececec 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ececec), color-stop(6%,#ffffff), color-stop(92%,#ffffff), color-stop(100%,#ececec)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #ececec 0%,#ffffff 6%,#ffffff 92%,#ececec 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #ececec 0%,#ffffff 6%,#ffffff 92%,#ececec 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #ececec 0%,#ffffff 6%,#ffffff 92%,#ececec 100%); /* IE10+ */
	background: linear-gradient(to bottom,  #ececec 0%,#ffffff 6%,#ffffff 92%,#ececec 100%); /* W3C */
}

h2.contents_head {
	height:auto;
	padding-top:4px;
	padding-bottom:12px;
	padding-left:24px;
	text-align:left;
	background-position:top center;
	background:url("../images/common/contents_head_bg_btm.png") no-repeat left bottom;
}
.contHead {
	padding-top:10px;
	background:url(../img/common/contents_head_bg_top.png) no-repeat left top;
}
.contentBody {
	margin-bottom:40px;
	text-align:left;
	padding:10px 10px 0 20px;
	line-height:1.8;
}
#mainContents h3 {
	margin-top:30px;
	margin-left:-10px;
	margin-bottom:15px;
}
#mainContents .contentBody > h3:first-child {
	margin-top:0;
}
#mainContents h4 {
	margin-bottom:5px;
}
#mainContents h5 {
	font-size:12px;
}
#mainContents p {
	margin-bottom:1.5em;
}
#mainContents ul {
	margin-bottom:15px;
	list-style:none;
	margin-left:20px;
}
#mainContents .indent2 {
	padding-left:2em;
}
#mainContents .indent4 {
	padding-left:4em;
}
#mainContents table {
	margin-bottom:15px;
}
.floatRight {
	float:right;
	padding:0 0 10px 10px;
}
.floatLeft {
	float:left;
	padding:0 10px 10px 0;
}
#mainimage {
	margin-top:10px;
}
#sidemenu_banner div {
	margin-bottom:10px;
}
#sidemenu_banner  .indexTopicsList {
	margin-bottom:20px;
	padding-top:10px;
	font-size:12px;
	text-align:left;
}
.indexTopicsList dl {
	margin-bottom:8px;
	  border-bottom: 1px solid #e1e1e1;
  padding-bottom: 5px;
}
.indexTopicsList dt {
	font-size:10px;
}
.indexCategoryHead {
	margin-bottom:10px;
	  color: #333;
  font-size: 120%;
  font-weight: bold;
  display: block;
  padding: 5px 0 5px 5px;
  border-left: 5px solid #333;
  text-align:left;
  background-color: #f0f0f0;
}
#mainContents ul.indexCourseList,
#mainContents ul.indexPickup {
	margin:0 0 20px;
	/zoom:1;
}
#mainContents ul.indexCourseList:after ,
#mainContents ul.indexPickup:after {
	content:'';
	display:block;
	clear:both;
}
.indexCourseList li,
.indexPickup li {
		list-style:none;
	margin:0 10px 10px 0;
	float:left;
}
.indexCourseList li.mr0 {
	margin-right:0;
}
.indexCourseList li.col2 {
	width:100%;
	float:none;
}
.indexCourseList li {
	width:260px;
}
.indexPickup .indexScene {
	width:220px;
	float:left;
}
.indexPickup .indexReason {
	width:300px;
	margin-right:0;
	float:left;
}
.toEntry {
	text-align:center;
	margin:30px auto;
}
.tal {
	text-align:left;
}
.greeting_body_left {
	width:170px;
	float:left;
}
.greeting_body_right {
	width:305px;
	float:right;
}
.flbox {
	/zoom:1;
}
.flbox:after {
	content:'';
	display:block;
	clear:both;
}
.formTable {
	width:98%;
	border-right:1px solid #e3e3e3;
	border-bottom:1px solid #e3e3e3;
}
.formTable th {
	width:30%;
  padding: 10px;
  border-top:1px solid #E3E3E3;
  border-left:1px solid #e3e3e3;
  background: #EAEDF6;
  font-weight: bold;
  line-height: 120%;
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
}
.formTable td {
	  border-top:1px solid #E3E3E3;
  border-left:1px solid #e3e3e3;
  padding:10px;
}
.inputM {
	width:240px;
	padding:4px;
	font-size:13px;
}
.inputS {
	width:80px;
	padding:4px;
	font-size:13px;
}
.formTable textarea {
	width:90%;
	height:200px;
}
.submitBtn {
	text-align:center;
}
#mainContents .instructor_detail p {
	margin-bottom: 0px;
}
#mainContents .instructor_preface p {
	margin-bottom:0;
}
#mainContents #environment {
	width:100%;
	margin:0;
}
#mainContents #environment table {
	margin-bottom:0;
}
#mainContents .environment_body table p {
	margin-bottom:0;
}	
.gMap {
	margin-bottom:20px;
}
.contentList dt {
	margin-bottom:5px;
	font-weight:bold;
}
.contentList dl {
	margin-bottom:15px;
}
#mainContents #reason {
	width:100%;
	margin: 0 0 20px 0;
}
#mainContents #reason table {
	margin-bottom:0;
}
.reason_body_left {
	width:200px;
}
.flow {
	width:160px;
}
.scene_body_right {
	width:200px;
}
#mainContents #scene {
	width:100%;
	margin:0;
}
#mainContents #scene table {
	margin-bottom:0;
}
.topics_list {
	margin:0;
}
.topics_list dl {
	margin-bottom:10px;
	/zoom:1;
}
.topics_list dl:after {
	content:'';
	display:block;
	clear:both;
}
.topics_list dt {
	font-weight:bold;
	width:100px;
	float:left;
}
.topics_list dd {
	padding-left:100px;
}
#mainContents table.topics_detail {
	width:100%;
	margin:0;
}

#passport table{
    width: 100%;
    text-align: center;
}



#passport table th, table td{
    border:1px solid #333;
    padding:5px;
    text-align: left;
}

#passport table th{
    background: #efefef;
}

#passport h4{
    border-left:10px solid #859CCC;
    padding-left: 7px;
}

#passport h5{
    border-bottom:2px dotted #859CCC;
    padding:0 5px;
    margin-bottom:7px;
    display: inline-block;
}

#passport dl{
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    margin-bottom:30px;
}

#passport dt{
    width: 45%;

}

#passport dd{
    width: 55%;

}


/*0914*/

h1{
    display: inline-block;
}

#head_links {
    float: right;
    margin-top: -12px;
    margin-right: -40px;
	text-align: center;
}

#head_links a{
    color: #fff;
    background: #224a92;
    display: block;
    padding: 5px 17px;
    margin-bottom:2px;
    border-radius: 5px;
}

body{
    padding-top: 90px;
}

#header_outer {
    background: #fff;
    width: 100%;
    position: fixed; /* ウィンドウを基準に画面に固定 */
    top: 0; /* 上下の固定位置を上から0pxにする */
    left: 0; /* 左右の固定位置を左から0pxにする */
}

#header{
    width: 800px;
    margin: 0 auto;
}

.top-news {
  max-width: 900px;
  margin: 40px auto;
  background: #fff;
  font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.news-list {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid #dcdcdc;
}

.news-list li {
  border-bottom: 1px solid #dcdcdc;
  
}

.news-list li a {
  display: flex;
  align-items: center;
  padding: 12px 10px;
  text-decoration: none;
  transition: background 0.2s ease;
  list-style: none;
}

/* ホバー時（ほんのりグレー） */
.news-list li a:hover {
  background: #f5f5f5;
}

/* 日付 */
.news-date {
  width: 110px;
  flex-shrink: 0;
  font-size: 13px;
  color: #333;
}

/* タイトル */
.news-title {
  font-size: 13px;
  color: #2a5db0; /* 画像っぽい青 */
  line-height: 1.6;
}

/* ホバー時に下線 */
.news-list li a:hover .news-title {
  text-decoration: underline;
}

/*TOPICS一覧*/

.topics-page {
  max-width: 900px;
  margin: 40px auto;
  padding: 0 15px;
}

.topics-page-title {
  margin-bottom: 30px;
  font-size: 28px;
  color: #333;
}

.topics-list-new {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid #dcdcdc;
}

.topics-list-new li {
  border-bottom: 1px solid #dcdcdc;
}

.topics-list-new li a {
  display: flex;
  align-items: center;
  padding: 14px 12px;
  text-decoration: none;
}

.topics-date-new {
  width: 110px;
  flex-shrink: 0;
  font-size: 13px;
  color: #333;
}

.topics-title-new {
  font-size: 13px;
  line-height: 1.6;
  color: #2a5db0;
}

.topics-list-new li a:hover .topics-title-new {
  text-decoration: underline;
}

.back-to-topics {
  margin-top: 50px;
  text-align: center;
}

.back-to-topics a {
  display: inline-block;
  padding: 12px 30px;
  background: #2a5db0;
  color: #fff;
  text-decoration: none;
  font-size: 13px;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.back-to-topics a:hover {
  background: #1f4e79;
}

.topics-pagination-new {
  margin: 50px 0;
  text-align: center;
}

.topics-pagination-new a,
.topics-pagination-new span {
  display: inline-block;
  margin: 0 4px;
  padding: 8px 14px;
  font-size: 13px;
  border-radius: 4px;
  border: 1px solid #dcdcdc;
  color: #333;
  text-decoration: none;
  transition: all 0.2s ease;
}

.topics-pagination-new a:hover {
  background: #2a5db0;
  color: #fff;
  border-color: #2a5db0;
}

@media screen and (max-width: 768px) {
  .topics-list li a {
    display: block;
  }

  .topics-date {
    display: block;
    width: auto;
    margin-bottom: 5px;
  }
}