@charset "utf-8";

/* -----------------------------------------------------------
　共通・可変画像（親要素幅まで）
----------------------------------------------------------- */

.fluid_image {
  max-width:100%;
  height: auto;
  width /***/:auto;
}

.fcRed {
  color:#ff0000;
}

.fcBlue{
  color:#187DE5;
}

.fcYellow {
  color:#ffff26;
}


.fwBold {
  font-weight:bold;
}

.fs120 {
  font-size:120%;
}

.fs140 {
  font-size:140%!important;
}

.fs150 {
  font-size:150%!important;
}

.fs70 {
  font-size:70%;
}

.left {
  float: left;
}

.right {
  float: right;
  text-align:right;
}

.center {
  text-align: center;
}

.clear {
  clear: both;
}

address {
  font-style: normal;
}

.hidden {
  font-size: 0;
  text-indent: -999999px;
  height: 0;
}

.marker {
    background:linear-gradient(transparent 60%, #ff6 60%);
}


.mb20{
	margin-bottom: 20px;
}
/* :::::::::: テキストリンク :::::::::: */

section a {
  text-decoration:underline;
  color:inherit;
}

section a:hover {
  text-decoration:underline;
  color:inherit;
}

@media screen and (min-width: 769px){
  
  /* :::::::::: 【PC】全体 :::::::::: */
  
  body {
    font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size:19px;
    color:#333333;
  }  
    
  .sp_cont {
    display:none;
  }
  
  figure {
    margin:0 auto 1.7em;
    text-align:center;
  }
  
  /* :::::::::: 【PC】画像・右寄せ回り込み :::::::::: */
  
  .pc_image_right {
    margin:0 0 1.7em 1.7em;
    float:right;
  }
  
  /* :::::::::: 【PC】画像・左寄せ回り込み :::::::::: */
  
  .pc_image_left {
    margin:0 1.7em 1.7em 0;
    padding:0;
    float:left;
  }
  
  /* ::::::::::【PC】 ホバー時opacity :::::::::: */        
  
  .hover_img {
    opacity:1;
    -webkit-transition: 0.5s;    
    -moz-transition: 0.5s;
    transition: 0.5s;
  }
  
  .hover_img:hover {
    opacity:0.6;
    -webkit-transition: 0.5s;    
    -moz-transition: 0.5s;
    transition: 0.5s;
  }
}

@media screen and (max-width: 768px){
  
  /* :::::::::: 【SP】全体・画像 :::::::::: */
  
  body {
       font-family:"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; 
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    font-size:4.375vw;
    color:#333333;
  }  

  .pc_cont {
    display:none;
  }
  
  figure {
    margin:0 auto 5%;
    text-align:center;
  }
  
  
  figure.pc_image_right {
    max-width:80%;
  }      
}


/* -----------------------------------------------------------
　ヘッダ
----------------------------------------------------------- */

@media screen and (min-width: 769px){
  
  /* :::::::::: 【PC】ヘッダー :::::::::: */
  
  header {
	position:relative;
    width:100%;
    min-width:1050px;
    height:470px;
    margin:0;
	background:url(../images/template/header_bg_pc.jpg) no-repeat top center;
  }
  
 #index header {
    height:390px;
    margin:0;
	background:url(../images/index/keyv_pc.jpg) no-repeat top center;
  }  
  
  header .header_box {
    width:1000px;
    height:100%;
    margin:0 auto;
  }
  
  header .header_box h1 {
    height: 20px;
	line-height:20px;
    font-size: 11px;
    text-align: left;
    padding:0;
    font-weight:normal;
    margin:0;
	color:#666;
  }
  
  header .header_box .h_logo {
    float:left;
    width:490px;
	height:auto;
	margin:15px 0 0;
  }
  
  header .header_box .h_tel {
    width:360px;
    float:right;
  }
  
  header .header_box .header_info p {
    font-size:17px;
    text-align:left;
  }
  
  header .header_box .h_info .h_tel {
    width:300px;
    height:50px;
  }
  
  header p.p_title { 
	position:absolute;
	width:1000px;  
	font-size:37px;
	color:#043587;
	line-height:1.2em;
	font-weight:bold;
	margin:auto;	 
	top:325px;
	left:0;
	right:0;	
  }
  
  header p.p_text { 
	position:absolute;
	width:1000px;   
	font-size:24px;
	color:#333;
	line-height:1.2em;
	font-weight:bold; 
	margin:auto;	
	top:375px;
	left:0;
	right:0;	
  }  
  
  #index header p.key_text { 
	position:absolute;
	width:705px;  
	height:99px; 
	margin:auto;	
	top:180px;
	left:0;
	right:0;
	background:url(../images/index/key_text_pc.png) no-repeat;	
  }   
  
  #index header p.key_text img {display:none;}
   
  /* :::::::::: 【PC】メインナビ :::::::::: */
  
  nav {
    width:100%;
    min-width:1050px;
    height:60px;
	background:url(../images/template/nav_bg.png) repeat-x;
	box-shadow:0 1px 3px #CCC;
	margin:0 0 75px;
  }
  
  nav p {
	display:none;  
  }
  
  nav ul {
    width:1000px;
    height: 60px;
    margin:0 auto;
  }
  
  nav ul li {
	height:60px;
	float:left;
	text-indent:-9999px;
  }

  nav ul li a {
	display:block;
	width:100%;
	height:100%;
	background:url(../images/template/mn.png) no-repeat;
  }

  nav ul li:nth-child(1) {width:167px;}
  nav ul li:nth-child(2) {width:167px;}
  nav ul li:nth-child(3) {width:166px;}
  nav ul li:nth-child(4) {width:168px;}
  nav ul li:nth-child(5) {width:167px;}
  nav ul li:nth-child(6) {width:165px;}

  nav ul li:nth-child(1) a {background-position:0 0;}
  nav ul li:nth-child(2) a {background-position:-167px 0;}
  nav ul li:nth-child(3) a {background-position:-334px 0;}
  nav ul li:nth-child(4) a {background-position:-500px 0;}
  nav ul li:nth-child(5) a {background-position:-668px 0;}
  nav ul li:nth-child(6) a {background-position:-835px 0;}
  nav ul li:nth-child(1) a:hover {background-position:0 -60px;}
  nav ul li:nth-child(2) a:hover {background-position:-167px -60px;}
  nav ul li:nth-child(3) a:hover {background-position:-334px -60px;}
  nav ul li:nth-child(4) a:hover {background-position:-500px -60px;}
  nav ul li:nth-child(5) a:hover {background-position:-668px -60px;}
  nav ul li:nth-child(6) a:hover {background-position:-835px -60px;}  
}

@media screen and (max-width: 768px){
  
  /* :::::::::: 【SP】ヘッダー :::::::::: */  
  
  header {
    width:100%;
    height:auto;
    margin:0 auto 10%;
	overfow:hidden;
	background:url(../images/template/header_bg_sp.jpg) no-repeat bottom center;
	background-size:100%;
	z-index:0;
  }
  
  #index header {
	background:url(../images/index/keyv_sp.png) no-repeat bottom center;
  }  
  
  header .header_box {
    width:96%;
    height:auto;
    margin:1% auto 10em;
  }  
  
  #index header .header_box {
    margin:1% auto 6em;
  }   
  
  header .header_box h1 {
    font-size: 0.6em;
	height:2em;
    text-align: left;
    padding:0;
    font-weight:normal;
    margin:0 0 3%;
    line-height:1.1em;
  }
  
  header .header_box .h_logo {
    width:100%;
    margin:0 0 3%;
  }
  
  header .header_box .h_tel {
	position:absolute;
	top:6.5em;
	left:2%;
    width:75%;
    margin:0 0 5%;
	z-index:1;
  }
  
  header p.p_title { 
	width:96%;  
	font-size:1.2em;
	color:#043587;
	line-height:1.2em;
	font-weight:bold;
	padding:0 0 1.4em;
	margin:0 auto 0.2em;
  }
  
  #seminar header p.p_title { 
	padding:0;
  }  
  
  header p.p_text { 
	width:96%;   
	font-size:1em;
	color:#333;
	line-height:1.2em;
	font-weight:bold; 
	margin:0 auto;
	padding:0 0 0.5em;
  }  
  
  #index header p.key_text { 
	width:70%;  
	height:auto; 
	margin:0 auto 5%;	
	padding:0 0 6em;
  }  
  
  /* :::::::::: 【SP】メインナビ :::::::::: */  
  
  nav {
	position:absolute;
    width:100%;
    height:auto;
	padding:6em 0 0;
	top:11em;
	right:0;
	z-index:1;
  }
  
  nav p {
	position:absolute;
	width:16.66%;  
	top:-4.5em;
	right:2%;
	z-index:11;
  }
  
  nav p span {
	position:absolute;
	display:none;
	z-index:12;
  }  
  
  nav ul {
    position:absolute;
	width:100%;
	top:-5em;
	z-index:10;
	background:rgba(76,152,229,0.8);
	padding:6em 0 0;
	display:none;
  }
  
  nav ul li {
    margin: 0;
    padding: 0;
    height: auto;
    text-align:center;
	border-top:solid 1px #FFF;
  }
  
  nav ul li a {
	box-sizing:border-box;
    display:block;
    width:100%;
    height:100%;
    font-size:1.2em;
    line-height:1.1em;
    color:#FFF;
    text-decoration:none;
    padding:0.5em 0;
  }
}

/* -----------------------------------------------------------
　メインコンテンツ
----------------------------------------------------------- */

@media screen and (min-width: 769px){
  
  /* :::::::::: 【PC】メインコンテンツ・共通要素 :::::::::: */  
  
  .contents_wrapper {
    width:1000px;
    height:auto;
    overflow:hidden;
    margin:0 auto 50px;
  }
  
  .contents_wrapper .main {
    display:block;
    width: 720px;
    height:auto;
    overflow:hidden;
    float:right;
	margin:0 auto;
  }
  
  .main section {
    height:auto;
    overflow:hidden;
    margin: 0 auto 60px;
    text-align:left;
    word-wrap: break-word;
  }
  
  .main section section.h3_box {
    margin: 0px auto 50px;
  }
  
  .main section section.h3_box section.h4_box {
    margin: 0px auto 40px;
  }  
  
  .main section section.h3_box section.h4_box section.h5_box {
    margin: 0px auto 30px;
  }
  
  .main section h2 {
	box-sizing:border-box;
	width:720px;
	height:50px;
	line-height:50px;
	color:#333;
	font-size:24px;
	font-weight:bold;
    margin:0 0 20px;
	padding:0 0.5em;
	background:url(../images/template/h2_bg.jpg) no-repeat;
  }  

  /* long */
  .main section h2.long {
	box-sizing:border-box;
	width:720px;
	height:auto;
	line-height:34px;
	color:#333;
	font-size:24px;
	font-weight:bold;
    margin:0 0 20px;
	padding:0.5em;
	background:url(../images/template/h2_bg_long.jpg) no-repeat bottom;
	border-top:solid 1px #CDCDCD;	  
  }  

  #index .main section h2 {
	height:auto;
	line-height:1.2em;
	color:#1985BE;
	padding:0;
	text-align:center;
	background:none;
	margin:0 0 15px;
  }
  
  .main section section.h3_box h3 {
	width:720px;
	height:auto;
	line-height:1.2em;
	color:#000066;
	font-size:20px;
	font-weight:bold;
    margin:0 0 10px;
	padding:0 0 0.8em;
	background:url(../images/template/h3_bg.gif) no-repeat bottom;
  }
  .main section section.h3_box h3.zabuton {
    width:100%;
	height:auto;
	line-height:1.3em;
	padding:0.3em 0;
	background:#DBF0FD;
	text-align:center;
	font-weight:bold;
	color:#333;
	font-size:22px;
	margin:0 0 20px;
  }

  
  .main section section.h3_box section.h4_box h4 {
	width:720px;
	height:auto;
	line-height:1.2em;
	color:#006CD8;
	font-size:19px;
	font-weight:bold;
    margin:0 0 10px;
	padding:0 0 0.2em;
	border-bottom:dotted 2px #006CD8;
  }    

  .main section section.h3_box section.h4_box section.h5_box h5 {
    
  }
    
  .main section:last-child ,
  .main section section.h3_box:last-child,
  .main section section.h3_box section.h4_box:last-child,
  .main section section.h3_box section.h4_box section.h5_box:last-child {  
    margin-bottom:0;
  }
    
  .main section p {
    margin:0 0 1.7em;
    font-size:1em;
    line-height:1.7em;
  }
  
  .main section ol {
    margin:0 0 1.7em 1.5em;
  }
  
  .main section ol li {
    list-style-type:decimal;
    font-size:1em;
    line-height:1.3em;
    margin:0 0 5px;
  }
  
  .main ul {
    margin:0 0 1.7em 1.5em;
  }
  
  .main ul li {
    list-style-type:disc;
    font-size:1em;
    line-height:1.5em;
    margin:0 0 5px;
  }
  
  .main ul.bullet {
    margin:0 0 1.7em;
  }
  
  .main ul.bullet li {
    list-style-type:none;
    font-size:1em;
    line-height:1.3em;
    margin:0 0 5px;
	padding:0 0 0 1.2em;
	background:url(../images/template/li_bg.jpg) no-repeat top 0.25em left 0.2em;
  } 
	
  .main ul.check {
    margin:0 0 1.7em;
  }
  
  .main ul.check li {
    list-style-type:none;
    font-size:1em;
    line-height:1.3em;
    margin:0 0 5px;
	padding:0 0 0 1.5em;
	background:url(../images/template/li_check.png) no-repeat top 0.25em left 0.2em;
  }  
  
  .main dl {
    overflow:hidden;
    margin:0 0 1.7em;
  }
  
  .main dl dt{
    font-size:1em;
    line-height:1.7em;
  }
  
  .main dl dd{
    font-size:1em;
    line-height:1.7em;
  }
  
  .main .section_head {
    margin-bottom:2em;
  }
  
  .main section p:last-child,  
  .main section ul:last-child,  
  .main section ol:last-child,  
  .main section dl:last-child{ 
    margin-bottom:0;
  }  
    
}

@media screen and (max-width: 768px){

  /* :::::::::: 【SP】メインコンテンツ・共通要素 :::::::::: */
    
  .contents_wrapper {
    width:96%;
    height:auto;
    overflow:hidden;
    margin:0 auto 10%;
  }
  
  #index .contents_wrapper {
    display: -webkit-flex;
    display:flex;
    -webkit-flex-direction: column;
    flex-direction:column;    
  }
  
  .main {
    display:block;
    width: 100%;
    height:auto;
	margin:0 auto 8%;
  }  
  
  #index .main {
    -webkit-order:1;
    order:1;   
  }

  .main section {
    margin: 0 0 10%;
    text-align:left;
    word-wrap: break-word;
    height:auto;
    overflow:hidden;
  }
  
  .main section section.h3_box {
    margin: 0 0 8%;
  }
  
  .main section section.h3_box section.h4_box {
    margin: 0 0 6%;
  }
  
  .main section section.h3_box section.h4_box section.h5_box {
    margin: 0 0 5%;
  }  
  
  .main section h2 {
	box-sizing:border-box;
	width:100%;
	height:auto;
	line-height:1.3em;
	font-size:1.2em;
	padding:0.4em 0.5em 0.3em;
	border:solid 1px #CDCDCD;
	border-bottom:solid 2px #006DD9;
    color:#333;
	margin:0 auto 5%;
  }
  
  #index .main section h2 {
	height:auto;
	line-height:1.2em;
	color:#1985BE;
	padding:0;
	text-align:center;
	border:none;
	margin:0 0 3%;
  }    
  
  .main section section.h3_box h3 {
    width:100%;
	height:auto;
	line-height:1.3em;
	padding:0.3em 0;
	background:#DBF0FD;
	text-align:center;
	font-weight:bold;
	color:#333;
	font-size:1.3em;
	margin:0 0 20px;
  }
	
  .main section section.h3_box h3.zabuton {
    width:100%;
	height:auto;
	line-height:1.3em;
	padding:0.3em 0;
	background:#DBF0FD;
	text-align:center;
	font-weight:bold;
	color:#333;
	font-size:1.3em;
	margin:0 0 20px;
  }
  
  .main section section.h3_box section.h4_box h4 {
	width:100%;
	height:auto;
	line-height:1.3em;
	color:#006CD8;
	font-size:1em;
	font-weight:bold;
    margin:0 0 3%;
	padding:0 0 0.2em;
	border-bottom:dotted 2px #006CD8;
  }  
  
  .main section section.h3_box section.h4_box  section.h5_box h5 {
    
  }
    
  .main section:last-child,
  .main section section.h3_box:last-child,
  .main section section.h3_box section.h4_box:last-child ,
  .main section section.h3_box section.h4_box section.h5_box:last-child {  
    margin-bottom:0;
  }
  
  .main section p {
    margin:0 0 3%;
    font-size:1em;
    line-height:1.7em;
  }
  
  .main section ol {
    margin:0 0 3% 1.7em;
  }
  
  .main section ol li {
    list-style-type:decimal;
    font-size:1em;
    line-height:1.3em;
	margin:0 0 3%;
  }
  
  .main ul {
    margin:0 0 3% 1.7em;
  }
  
  .main ul li {
    list-style-type:disc;
    font-size:1em;
    line-height:1.5em;
	margin:0 0 3%;
  }
  
  .main ul.bullet {
     margin:0 0 3%;
  }
  
  .main ul.bullet li {
	position:relative;
    list-style-type:none;
	padding:0 0 0 1.3em;
  } 
  
  .main ul.bullet li::before {  
    position:absolute;
	display:block;
	content:"";
	width:0.8em;
	height:0.8em;
	border-radius:50%;
	background:#8BBDEE;
	left:0.2em;
	top:0.2em;
  }
  
  .main ul.check {
    margin:0 0 1.7em;
  }
  
  .main ul.check li {
    list-style-type:none;
    font-size:1em;
    line-height:1.3em;
    margin:0 0 5px;
	padding:0 0 0 1.5em;
	background:url(../images/template/li_check.png) no-repeat top 0.25em left 0.2em;
  }  
	
  .main dl {
    overflow:hidden;
    margin:0 0 3%;
  }
  
  .main dl dt{
    font-size:1em;
    line-height:1.7em;
  }
  
  .main dl dd{
    font-size:1em;
    line-height:1.7em;
  }
  
  .main .section_head {
    margin-bottom:5%;
  }  
  
  .main section p:last-child,  
  .main section ul:last-child,  
  .main section ol:last-child,  
  .main section dl:last-child{ 
    margin-bottom:0;
  }    
}


/* -----------------------------------------------------------
　サブナビ
----------------------------------------------------------- */

@media screen and (min-width: 769px){
  
  /* :::::::::: 【PC】サブナビ :::::::::: */
  
  aside {
    width:250px;
    height:auto;
    overflow:hidden;
    float:left;
  }
  
  aside ul {
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;  
  }
  
  aside ul li {
	width:100%;
	height:250px;
	margin:0 0 20px; 
	font-weight:bold;
	font-size:16px;
	text-align:center; 
	transition:0.5s;
	opacity:1;
  } 
  
  aside ul li:hover {
	transition:0.5s;
	opacity:0.7;
  }
  
  aside ul li:nth-child(1) {background:url(../images/template/aside01.jpg) no-repeat;} 
  aside ul li:nth-child(2) {background:url(../images/template/aside02.jpg) no-repeat;}
  aside ul li:nth-child(3) {background:url(../images/template/aside03.jpg) no-repeat;}
  aside ul li:nth-child(4) {height:100px;text-align:right;background:url(../images/template/aside04.jpg) no-repeat;}
  aside ul li:nth-child(5) {background:url(../images/template/aside05.jpg) no-repeat;}
  
  aside ul li span {
	display:block;
    font-size:22px;
    color:#006CD8;
	margin:0 auto 8px;
	line-height:1.1em;
  }
  
  aside ul li a {
	box-sizing:border-box;
	display:block;
	width:100%;
	height:100%;
	color:inherit;
	text-decoration:none; 
	padding:150px 0 0; 
  }
  
  aside ul li:nth-child(3) a {padding:160px 0 0;}
  aside ul li:nth-child(4) a {padding:17px;}
  aside ul li:nth-child(5) a {padding:175px 0 0;}
}

@media screen and (max-width: 768px){
  
  /* :::::::::: 【SP】サブナビ :::::::::: */

  aside {
    width:100%;
    height:auto;
    overflow:hidden;
	margin:0 auto 8%;
  }
  
  aside ul {
	width:100%;
	height:auto;
	overflow:hidden;
	margin:0;  
  }
  
  aside ul li {
	box-sizing:border-box;  
	position:relative;
	width:100%;
	height:4em;
	margin:0 0 3%; 
	font-weight:bold;
	font-size:1em;
	text-align:center;
	border:solid 1px #CCC; 
  } 
  
  aside ul li::after {   
    position:absolute;
	display:block;
	content:"";
	width:0;
	height:0;
	bottom:0.1em;
	right:0.1em;
	border-bottom:1em solid #006CD8;
	border-left:1em solid transparent;
  }
  
  aside ul li span {
	display:block;
    font-size:1.1em;
    color:#006CD8;
	margin:0 auto 1%;
	line-height:1.1em;
  }
  
  aside ul li a {
	box-sizing:border-box;
	display:block;
	width:100%;
	height:100%;
	color:inherit;
	text-decoration:none; 
	padding:0.65em;
  } 
  
  aside ul li:nth-child(2) a {padding:0.3em;} 
  aside ul li:nth-child(5) a {padding:0.7em;} 
}

/* -----------------------------------------------------------
　フッタ
----------------------------------------------------------- */

@media screen and (min-width: 769px){
  
  /* :::::::::: 【PC】フッタ :::::::::: */  
  
  footer {
    width: 100%;
    min-width:1050px;
    clear: both;
    height: 220px;
	padding:30px 0 0;
    overflow:hidden;
    text-align:left;
    background:url(../images/template/footer_bg.png) repeat-x;
  }
  
  footer .footer_box {
    width:1000px;
    height:220px;
    overflow:hidden;
    margin:0 auto;
  }
  
  footer .footer_box .footer_left {
	width:400px;
	float:left;  
  }
  
  footer .footer_box .f_logo {
    width:360px;
	margin:0 0 30px;
  }
  
  footer .footer_box address {
	font-size:17px;
	line-height:1.5em;
  }  
  
  footer .footer_box .f_nav{
    width:500px;
    height: 195px;
	float:right;
    margin: 0;
    overflow:hidden;
  }
  
  footer .footer_box .f_nav ul li{
    font-size:14px;
    height:auto;
    line-height:1.6em;
    margin:0;
	text-align:right;
  }
  
  footer .footer_box .f_nav ul li a{
    text-decoration:none;
    color:#666;
  }
  
  footer .footer_box .f_nav ul li a:hover {
    text-decoration:underline;
  }
  
  footer .copyright{
    width:100%;
    min-width:1050px;
    height: 25px;
    text-align: center;
    font-size: 13px;
    line-height:25px;
    color:#333;
    margin:0;
	clear:both;
  }
  
  footer .copyright a {
    color:#333;
    text-decoration:none;
  }
  
  .Pagetop{
    width:50px;  
    height:50px;  
    position: fixed;
    bottom: 300px;
    right:10px;
  }
}
  
@media screen and (max-width: 768px){
  
  /* :::::::::: 【SP】フッタ :::::::::: */  
    
  footer {
	box-sizing:border-box;
    width: 100%;
    clear: both;
    height: auto;
	overflow:hidden;
	background:#F4F4F4;
	padding:1.5em 1em 0;
  }
  
  footer .footer_box .footer_left {
	margin:0 auto 10%;  
  }
  
  footer .footer_box .f_logo {
	margin:0 auto 3%;  
  }
  
  footer .footer_box .f_nav {
    display:none;
  }
  
  footer .copyright{
    width:100%;
    height: auto;
    text-align: center;
    font-size: 0.6em;
    line-height:1.1em;
    color:#333;
    margin:0;
    padding:0.5em 0;
    clear:both;
  }
  
  footer .copyright a {
    color:#333;
    text-decoration:none;
  }
  
  .Pagetop{
    position: fixed;
    width:10%;
    bottom: 2%;
    right:2%;
    z-index:999;
  }
}
