@charset "UTF-8";
body,
h1, h2, h3, h4, h5, h6,
blockquote, dl, dd, figure, ol, ul, p, pre {
  margin: 0;
}

* {
  box-sizing: border-box;
}

html {
  overflow-y: scroll;
}

body {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-overflow-scrolling: touch;
}

html, body {
  height: 100%;
}

a {
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
}

a:active, a:focus,
button:focus, input[type="button"] {
  outline: none;
}

a.normalLink
{
	text-decoration: underline;
}
a.normalLink:hover
{
	text-decoration: none;
}
a.dotLink
{
	text-decoration: none;
	display: inline;
	transition: 0s;
}
a.dotLink:hover
{
	text-decoration: none;
	border-bottom: 1px dotted #000;
}
article, aside, details, figure, figcaption, footer, header, main, nav, section {
  display: block;
}

address, em, i {
  font-style: normal;
}

img {
  max-width: 100%;
  height: auto;
  border: 0;
  vertical-align: top;
}

ol, ul {
  list-style-type: none;
  padding: 0;
}

li {
  vertical-align: top;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

tr {
  vertical-align: top;
}

th, td {
  padding: 0;
}

.cf:after {
  content: "";
  display: block;
  clear: both;
}

body {
  color: #231815;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", "Osaka", sans-serif;
}

a {
  color: #231815;
  text-decoration: none;
  transition: 0.3s;
}
a:hover {
  text-decoration: underline;
}
#pagePath+a:hover
{
	text-decoration: none;
}




@media screen and (min-width: 1025px) {
  .pc {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .pc {
    display: none;
  }
}

@media screen and (max-width: 1024px) {
  .sp {
    display: block;
  }
}
@media screen and (min-width: 1025px) {
  .sp {
    display: none;
  }
}

.block {
  display: block;
}





/* ヘッダー
   ========================================================================== */
/*
 * PC
 */
#header, #header-pc {
  height: 80px;
  background: url(../images/common/bg_header.png);
}
@media screen and (max-width: 1024px) {
  #header, #header-pc {
    display: none;
  }
}
#header a, #header-pc a {
  color: white;
}
#header ul, #header-pc ul {
  width: 1100px;
  height: 100%;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0 auto;
}
#header li:first-child, #header-pc li:first-child {
  margin: 12px auto 0 0;
}
#header li:nth-child(2), #header-pc li:nth-child(2) {
  margin-right: 30px;
}
#header li:nth-child(2) a, #header-pc li:nth-child(2) a {
  position: relative;
}
#header li:nth-child(2) a:before, #header-pc li:nth-child(2) a:before {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 6px;
  height: 6px;
  left: -15px;
  top: 6px;
}
#header li:nth-child(3), #header-pc li:nth-child(3) {
  width: 260px;
  text-align: center;
}
#header li:nth-child(3) a, #header-pc li:nth-child(3) a {
  color: #0086d1;
  font-size: 0.75rem;
  display: block;
  padding: 6px 0;
  border-radius: 13px;
  background: white;
}
#header li:nth-child(3) a:hover, #header-pc li:nth-child(3) a:hover {
  text-decoration: none;
  background: #f9d904;
}

#header li:nth-child(4), #header-pc li:nth-child(4) {
  margin-left:15px;
  width: 320px;

}
#header li:nth-child(4) a, #header-pc li:nth-child(4) a {
}
#header li:nth-child(4) a:hover, #header-pc li:nth-child(4) a:hover {
}
#header li:nth-child(4) img { display: inline; }

#header-pc {
  min-width: 1100px;
  width: 100%;
}

#nav-global > ul > .current > a
{
    border-bottom: 5px solid #37A0DA;
}
@media screen and (max-width: 1024px) {
  #header-pc {
    display: block;
  }
}

/*
 * SP
 */
#header-sp {
  background: #2084bf;
}
#header-sp a {
  color: white;
}
#header-sp h1 img{
	width: 80px;
}
#header-sp > ul:not(#header-sp-nav-ul) {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  position: fixed;
  z-index: 100;
  width: 100%;
  height: 65px;
  background: #2084bf;
}
#header-sp .sd-trigger {
  width: 70px;
  height: 65px;
  color: white;
  text-align: center;
  line-height: 1;
  padding: 16px 0 0;
  background: #004c80;
}
#header-sp .sd-trigger span {
  font-size: 0.625rem;
  display: block;
  margin-top: 5px;
}
#header-sp ul:not(#header-sp-nav-ul *) li:nth-child(2) {
  width: 100px;
}
@media screen and (max-width: 1024px) {
  #header-sp ul:not(#header-sp-nav-ul) li:nth-child(2) {
    margin-top: 10px;
    margin-right: 60px;
  }
}
#header-sp ul:not(#header-sp-nav-ul) li:last-child {
  margin-right: 20px;
}
@media screen and (max-width: 640px) {
  #header-sp ul:not(#header-sp-nav-ul *) li:last-child {
    margin-right: 10px;
  }
}
#header-sp ul:not(#header-sp-nav-ul *) li:last-child a {
  position: relative;
}
#header-sp ul:not(#header-sp-nav-ul) li:last-child a:before {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 6px;
  height: 6px;
  left: -15px;
  top: 7px;
}
#header-sp div:not(#header-sp-nav) {
  text-align: center;
  padding: 15px 15%;
  background: #76caf6;
  padding-top: 80px;
}
#header-sp div:not(#header-sp-nav) a {
  color: #0086d1;
  display: block;
  padding: 10px 0;
  border-radius: 13px;
  background: white;
}
#header-sp div:not(#header-sp-nav) a.toRecruit{
	background:none;
	border-radius: 0;
	padding:0;
    display: inline;
}

@media screen and (min-width: 1025px) {
  #header-sp {
    display: none;
  }
}

/* グローバルメニュー
   ========================================================================== */
#nav-global {
  width: 1100px;
  font-size: 0.875rem;
  text-align: center;
  margin: 0 auto;
}
#nav-global > ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
#nav-global > ul > li {
  height: 65px;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  -webkit-align-self: center;
  -ms-flex-item-align: center;
  align-self: center;
}
#nav-global li ul {
	display: none;
}
#nav-global > ul > li:not(:last-child) {
  margin-right: 3px;
}
#nav-global ul li {
  position: relative;
}
#nav-global li li {
  margin-bottom: 1px;
}
#nav-global a {
  display: block;
}
#nav-global a:hover {
  text-decoration: none;
}
#nav-global > ul > li > a {
  padding: 19px 0 15px;
  border-bottom: 5px solid #dadada;
}
#nav-global > ul > li > a.active, #nav-global > ul > li > a.current {
  border-bottom-color: #37a0da;
}
#nav-global .level1, #nav-global .level2 {
  width: 100%;
  position: absolute;
  z-index: 9;
}
#nav-global .level1 a, #nav-global .level2 a {
  padding: 10px 0;
  background: rgba(255, 255, 255, 0.9);
}
#nav-global .level1 .active, #nav-global .level2 .active {
  color: white;
  background: #37a0da;
}
#nav-global .level1 {
  top: 100%;
  left: 0;
}
#nav-global .level2 {
  top: 0;
  left: 100.5%;
}
#nav-global .item-arrow:after {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 6px;
  height: 6px;
  top: 50%;
  right: 10px;
  margin-top: -3px;
  border-color: #37a0da;
}
#nav-global .item-nolink {
  pointer-events: none;
}

/* SP用 */
#header-sp li img {
    display: inline-block;
    vertical-align: baseline;
}
#header-sp-nav{
  display: none;
  background: white!important;
  position: fixed;
  top: 65px;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 10;
  box-shadow: 0 10px 15px rgba(125, 125, 125, 0.21);
}
#header-sp-nav-ul{
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 65px;
}
#header-sp-nav-ul li{
  border-bottom: 1px solid #eee;
  background: #fff;
  margin: 0!important;
  font-weight: bold;
}
#header-sp-nav-ul li>span{
  background: url(../images/common/arrow_close.png) no-repeat 98% 1.4em;
  -webkit-background-size: 9px 7px;
  background-size: 9px 7px;
  padding: 1em;
  display: block;
}
#header-sp-nav-ul li.open>span{
  background: url(../images/common/arrow_open.png) no-repeat 98% 1.4em;
  -webkit-background-size: 9px 7px;
  background-size: 9px 7px;
  color: #2084BF;
}
#header-sp-nav-ul li:last-child{
  margin: 0!important;
}
#header-sp-nav-ul>li>a{
  text-decoration: none;
  padding: 1em;
  display: block;
}
#header-sp-nav-ul li a{
  color: #333;
}
#header-sp-nav-ul li ul li a{
  display: block;
  padding: .5em 1.5em;
}
#header-sp-nav-ul ul{
  background: #eee;
  display: none;
  padding: .75em 0;
}
#header-sp-nav-ul ul li{
  background: #eee;
  /* display: none; */
}


/* パンくず
   ========================================================================== */
#breadcrumb {
  width: 1100px;
  color: #313131;
  font-size: 0.625rem;
  margin: 15px auto;
}
#breadcrumb ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
#breadcrumb li:not(:last-child):after {
  content: ">";
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=50);
  opacity: 0.5;
  margin: 0 10px;
}

/* ローカルナビ
   ========================================================================== */
#nav-local {
  margin-bottom: 25px;
}

/* キービジュアル
   ========================================================================== */
#block-keyvisual {
  min-width: 1100px;
  width: 100%;
  color: white;
  height: 260px;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 10px;
}
#block-keyvisual h2 {
  width: 1100px;
  font-size: 1.875rem;
  margin: 0 auto;
}

/* 下層ページ
   ========================================================================== */
/*
 * container
 */
#container {
  width: 1100px;
  color: #333;
  font-size: 0.9375rem;
  line-height: 1.7;
  margin: 0 auto 70px;
}
#container a {
  color: #0066cc;
  text-decoration: underline;
}
#container a:hover {
  text-decoration: none;
}
#container .item-btn {
  width: 200px;
  font-size: 0.875rem;
  text-align: center;
  margin: 0 auto;
}
#container .item-btn a {
  color: white;
  text-decoration: none;
  display: block;
  position: relative;
  padding: 10px 0;
  border-radius: 5px;
  background: #ea863c;
}
#container .item-btn a:hover {
  background: #efa36a;
}
#container .item-btn a:before {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 5px;
  height: 5px;
  left: 5px;
  top: 50%;
  margin-top: -3px;
}

/*
 * heading
 */
.heading-lead {
  color: #343434;
  font-size: 1.125rem;
  margin-bottom: 20px;
  padding: 8px 15px;
  border: 1px solid #b9b9b9;
  border-left: 3px solid #37a0da;
}

.heading {
  font-size: 1.125rem;
  margin-bottom: 18px;
  border-bottom: 2px solid #37a0da;
}

/* フッター
   ========================================================================== */
#footer, #footer-pc {
  color: white;
  font-size: 0.75rem;
  padding: 30px 0 20px;
  background: #37a0da;
}
@media screen and (max-width: 1024px) {
  #footer, #footer-pc {
    padding: 10px 0;
  }
}
#footer #inner-footer-top, #footer-pc #inner-footer-top {
  width: 1100px;
  margin: 0 auto 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #e6e6e6;
}
#footer #inner-footer-top ul, #footer-pc #inner-footer-top ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
#footer #inner-footer-top li:not(:last-child):after, #footer-pc #inner-footer-top li:not(:last-child):after {
  content: "|";
  margin: 0 20px;
}
@media screen and (max-width: 1024px) {
  #footer #inner-footer-top, #footer-pc #inner-footer-top {
    display: none;
  }
}
#footer #inner-footer-bottom, #footer-pc #inner-footer-bottom {
  width: 1100px;
  line-height: 2.2;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin: 0 auto 90px;
  padding-left: 13px;
}
@media screen and (max-width: 1024px) {
  #footer #inner-footer-bottom, #footer-pc #inner-footer-bottom {
    display: none;
  }
}
#footer a, #footer-pc a {
  color: white;
  font-size: 0.75rem;
}
#footer nav dt, #footer nav div, #footer-pc nav dt, #footer-pc nav div {
  position: relative;
}
#footer nav dt:before, #footer nav div:before, #footer-pc nav dt:before, #footer-pc nav div:before {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 6px;
  height: 6px;
  color: #f2f2f2;
  top: 50%;
  left: -15px;
  margin-top: -3px;
}
#footer nav div, #footer-pc nav div {
  font-weight: bolder;
}
#footer dt, #footer-pc dt {
  font-weight: bolder;
}
#footer .item-col2, #footer-pc .item-col2 {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
#footer .item-col2 > ul:first-child, #footer-pc .item-col2 > ul:first-child {
  margin-right: 30px;
}
#footer .box-list, #footer-pc .box-list {
  list-style-type: disc;
  padding-left: 40px;
  padding-left: 20px;
}
#footer .box-arrow li, #footer-pc .box-arrow li {
  position: relative;
}
#footer .box-arrow li:before, #footer-pc .box-arrow li:before {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 6px;
  height: 6px;
  color: #f2f2f2;
  top: 50%;
  left: -15px;
  margin-top: -3px;
}
#footer nav ul.box-arrow {
  margin-top: 20px;
}
#footer small, #footer-pc small {
  text-align: center;
  display: block;
}
#sp-footer-link{
  text-align: center;
  display: none;
  font-size: 0.85rem;
  line-height: 1.8;
  margin-bottom: 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #70B4DA;
}
@media screen and (max-width: 1024px) {
  #sp-footer-link{
    display: block;
  }
}
#footer-pc {
  min-width: 1100px;
  width: 100%;
  padding: 30px 0 20px;
}
@media screen and (max-width: 1024px) {
  #footer-pc #inner-footer-top {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  #footer-pc #inner-footer-bottom {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}

/* キービジュアル
   ========================================================================== */
#keyvisual {
  position: relative;
  margin-bottom: 40px;
}
#keyvisual h2 {
  color: #00acdf;
  font-size: 2.9375rem;
  position: absolute;
  top: 50px;
  left: 100px;
  z-index: 8;
}
@media screen and (max-width: 1024px) {
  #keyvisual h2 {
    font-weight: normal;
    top: 5%;
    left: 20px;
  }
}
#keyvisual h2 span {
  color: #3e9acf;
  font-size: 1.25rem;
  margin-top: 15px;
}
@media screen and (max-width: 1024px) {
  #keyvisual h2 span {
    margin-top: 5px;
  }
}
@media screen and (min-width: 640px) and (max-width: 1024px) {
  #keyvisual h2 span:first-of-type {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 480px) {
  #keyvisual h2 span:last-of-type {
    font-size: 1.125rem;
  }
}
@media screen and (min-width: 481px) {
  #keyvisual .item-sp {
    display: none;
  }
}
@media screen and (max-width: 480px) {
  #keyvisual h2 span.block {
    display: none;
  }
  #main .mainVisual {
  	background-position: center center !important;
  }
}/*
 * カルーセルスライダー
 */
.owl-dots {
  margin: -50px 0 0;
  position: relative;
  z-index: 9;
}
@media screen and (max-width: 1024px) {
  .owl-dots {
    margin-top: -40px;
  }
}

.owl-theme .owl-dots .owl-dot span {
  width: 18px;
  height: 18px;
  background: #c8c8c8;
}
@media screen and (max-width: 1024px) {
  .owl-theme .owl-dots .owl-dot span {
    width: 10px;
    height: 10px;
  }
}

.owl-theme .owl-dots .owl-dot.active span {
  background: #37a0da;
}

/* NEWS
   ========================================================================== */
#block-news {
  width: 1100px;
  font-size: 0.9375rem;
  margin: 0 auto 40px;
}
@media screen and (max-width: 1024px) {
  #block-news {
    width: 100%;
    font-size: 1rem;
    padding: 0 20px;
  }
}
#block-news h3 {
  width: 160px;
  color: white;
  font-size: 0.75rem;
  text-align: center;
  margin: 0 auto 40px;
  padding: 5px 0;
  border-radius: 10px;
  background: #37a0da;
}
@media screen and (max-width: 1024px) {
  #block-news h3 {
    width: 50%;
    font-size: 1rem;
    margin-bottom: 30px;
  }
}
#block-news dl {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px solid #b8b7b5;
}
@media screen and (max-width: 1024px) {
  #block-news dl {
    display: block;
  }
}
#block-news dt {
  width: 330px;
  font-size: 0.9375rem;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  float: left;
}
@media screen and (max-width: 1024px) {
  #block-news dt {
    width: 100%;
    float: none;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    -ms-grid-row-align: flex-start;
    align-items: flex-start;
  }
}
#block-news dt i {
  width: 130px;
  color: white;
  font-size: 0.6875rem;
  text-align: center;
  display: block;
  margin-left: 35px;
  padding-top: 3px;
  background: #a5a7a6;
}
@media screen and (max-width: 1024px) {
  #block-news dt i {
    margin: 0 0 10px 20px;
    padding: 2px 0;
  }
}
@media screen and (max-width: 480px) {
  #block-news dt i {
    width: 100px;
  }
}
#block-news dd {
  width: 760px;
  font-size: 0.9375rem;
  overflow: hidden;
}
#block-news dd a {
  position: relative;
}
#block-news dd a:hover {
  text-decoration: none;
}
#block-news dd a:hover:after {
  content: "";
  width: 100%;
  position: absolute;
  left: 0;
  top: 100%;
  border-bottom: 1px dotted #101010;
}
@media screen and (max-width: 1024px) {
  #block-news dd {
    width: 100%;
  }
}
#block-news div {
  width: 140px;
  font-size: 0.6875rem;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  #block-news div {
    width: 50%;
    padding-top: 10px;
    font-size: 1rem;
  }
}
#block-news div a {
  display: block;
  position: relative;
  padding: 5px 0;
  border: 1px solid #b8b7b5;
  border-radius: 10px;
}
@media screen and (max-width: 1024px) {
  #block-news div a {
    padding: 10px 0;
  }
}
#block-news div a:before {
  color: #63443b;
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 4px;
  height: 4px;
  left: 20px;
  top: 50%;
  margin-top: -4px;
  transition: 0.3s;
}
@media screen and (max-width: 1024px) {
  #block-news div a:before {
    width: 7px;
    height: 7px;
    left: 30%;
    margin-top: -4px;
  }
}
@media screen and (max-width: 640px) {
  #block-news div a:before {
    left: 10%;
  }
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, #block-news dd a:hover {
    text-decoration: underline;
  }
}
/* 3つのリンクバナー
   ========================================================================== */
#block-bnr {
  width: 1000px;
  margin: 0 auto 40px;
}
@media screen and (max-width: 1024px) {
  #block-bnr {
    width: 100%;
    padding: 0 20px;
  }
}
#block-bnr ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 40px;
}
@media screen and (max-width: 640px) {
  #block-bnr ul {
    display: block;
  }
}
#block-bnr li {
  font-size: 0.9375rem;
  text-align: center;
  transition: 0.3s;
  border: 1px solid #b8b7b5;
}
#block-bnr li:hover {
  background: #37a0da;
}
@media screen and (max-width: 1024px) {
  #block-bnr li {
    font-size: 1rem;
  }
}
@media screen and (min-width: 641px) and (max-width: 1024px) {
  #block-bnr li {
    width: 31%;
  }
}
@media screen and (max-width: 640px) {
  #block-bnr li {
    width: 100%;
    margin-bottom: 20px;
  }
}
#block-bnr dt {
  padding: 7px 0;
}
@media screen and (max-width: 1024px) {
  #block-bnr dt {
    padding: 15px 0;
  }
}
#block-bnr dd {
  font-size: 0rem;
}
#block-bnr a {
  color: #0086d1;
}
#block-bnr a:hover {
  color: white;
  text-decoration: none;
}
#block-bnr img {
  width: 100%;
}


#block-bnr .bnRec4sp { display: none; }

@media screen and (max-width: 1024px) {
  #block-bnr .bnRec4pc { display: none; }
  #block-bnr .bnRec4sp {
      display: block;
      overflow: hidden;
      background-color: #eae6de;
  }
  #block-bnr .bnRec4sp li {
      width: 32%;
      float: left;
      border: 0;
      padding: 15px 0;
  }
  #block-bnr .bnRec4sp li.bn1 { background-color: #5d5554; }
  #block-bnr .bnRec4sp li.bn2 { background-color: #eae6de; margin-left: 2%; }
  #block-bnr .bnRec4sp li.bn3 { background-color: #eae6de; margin-right: 2%; }
  #block-bnr .bnRec4sp img {
      width: 90%;
  }
}

@media screen and (max-width: 640px) {
  #block-bnr .bnRec4pc { display: none; }
  #block-bnr .bnRec4sp {
      display: block;
  }
  #block-bnr .bnRec4sp li {
      width: 100%;
      float: none;
      margin: 0;
  }
  #block-bnr .bnRec4sp li.bn2 { margin: 0; padding-bottom: 7px; }
  #block-bnr .bnRec4sp li.bn3 { margin: 0; padding-top: 7px; }
  #block-bnr .bnRec4sp img {
      width: 90%;
  }
}


 

/* 会場案内
   ========================================================================== */
#block-place {
  margin-bottom: 5px;
  padding: 30px 0;
  background: #92d4f6;
}

#block-place-lead {
  width: 1100px;
  margin: 0 auto 23px;
}
#block-place-lead h3 {
  font-size: 1.5rem;
  margin-bottom: 12px;
}
#block-place-lead p {
  font-size: 0.9375rem;
  line-height: 1.8;
}

#inner-place {
  width: 1100px;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 0 auto;
}

/*
 * 詳細情報
 */
#inner-place-detail {
  width: 560px;
  margin-right: 40px;
}

/* 各会場 */
.box-place-hall {
  height: 364px;
  margin-bottom: 30px;
  padding: 7px 30px 20px;
  border-radius: 5px;
  border: 4px solid #58bfc6;
  background: url(../images/top/ic_place.png) no-repeat #d1eaee;
}
.box-place-hall h4 {
  color: #187e85;
  margin-bottom: 10px;
  font-size: 1.125rem;
}
.box-place-hall h4 span {
  color: #9e9e9e;
  font-size: 0.8125rem;
  padding-left: 8px;
}
.box-place-hall ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.box-place-hall li:first-child {
  width: 250px;
}
.box-place-hall li:first-child div {
  width: 160px;
  text-align: center;
  margin-top: 15px;
}
.box-place-hall li:first-child a {
  color: white;
  font-size: 0.8125rem;
  display: block;
  padding: 5px 5px 5px 0;
  border-radius: 10px;
  background: url(../images/common/ic_blank.png) no-repeat top 7px right 20px #187e85;
}
.box-place-hall li:first-child a:hover {
  text-decoration: none;
  background: url(../images/common/ic_blank.png) no-repeat top 7px right 20px #20a7b0;
}
.box-place-hall li:last-child {
  width: 220px;
}
.box-place-hall dl {
  font-size: 0.8125rem;
}
.box-place-hall dl:not(:last-child) {
  margin-bottom: 6px;
  padding-bottom: 6px;
  border-bottom: 1px solid #58bfc6;
}
.box-place-hall dt {
  width: 100px;
  float: left;
}
.box-place-hall dd {
  overflow: hidden;
}
.box-place-hall#nagoya-ussr {
  border-color: #b7aa00;
  background: url(../images/top/ic_place_nagoya.png) no-repeat #f4f3e2;
}
.box-place-hall#nagoya-ussr h4 {
  color: #a3980c;
}
.box-place-hall#nagoya-ussr a {
  background: url(../images/common/ic_blank.png) no-repeat top 7px right 20px #b7aa00;
}
.box-place-hall#nagoya-ussr a:hover {
  background: url(../images/common/ic_blank.png) no-repeat top 7px right 20px #d1c200;
}
.box-place-hall#nagoya-ussr dl {
  border-bottom-color: #b7aa00;
}
.box-place-hall#kagoshima {
  border-color: #ec6941;
  background: url(../images/top/ic_place_kagoshima.png) no-repeat #fdf2ef;
}
.box-place-hall#kagoshima h4 {
  color: #e15d34;
}
.box-place-hall#kagoshima a {
  background: url(../images/common/ic_blank.png) no-repeat top 7px right 20px #ec6941;
}
.box-place-hall#kagoshima a:hover {
  background: url(../images/common/ic_blank.png) no-repeat top 7px right 20px #f18e6f;
}
.box-place-hall#kagoshima dl {
  border-bottom-color: #ec6941;
}

/* リンクバナー */
#box-place-bnr {
  font-size: 0.75rem;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#box-place-bnr li {
  width: 250px;
  border-radius: 5px;
  padding-bottom: 10px;
  background: white;
}
#box-place-bnr dl {
  margin-bottom: 12px;
  padding: 0 15px;
}
#box-place-bnr dt {
  color: #0086d1;
  font-size: 1rem;
  font-weight: bolder;
  text-align: center;
  line-height: 1;
  margin-bottom: 10px;
  padding: 6px 0 9px;
  border-bottom: 2px solid #37a0da;
}
#box-place-bnr img {
  transition: 0.3s;
}
#box-place-bnr img:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
}
#box-place-bnr div {
  width: 160px;
  text-align: center;
  margin: 0 auto;
}
#box-place-bnr div a {
  color: white;
  display: block;
  position: relative;
  padding: 5px 0;
  border-radius: 10px;
  background: #37a0da;
}
#box-place-bnr div a:hover {
  text-decoration: none;
  background: #62b4e2;
}
#box-place-bnr div a:before {
  color: #f2f2f2;
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 4px;
  height: 4px;
  left: 30px;
  top: 50%;
  margin-top: -3px;
}

/* 地図 */
#inner-place-map {
  width: 387px;
  height: 622px;
  position: relative;
  margin-top: 20px;
  background: url(../images/top/bg_place.png) no-repeat;
  background-size: cover;
}
#inner-place-map .ic-map {
  width: 19px;
  height: 19px;
  font-size: 0rem;
  position: absolute;
  transition: 0.3s;
  border: 2px solid #71bcc2;
  border-radius: 50%;
  background: white;
}
#inner-place-map .ic-map span {
  min-width: 200px;
  font-size: 0.8125rem;
  color: white;
  text-align: center;
  display: none;
  position: absolute;
  left: 150%;
  top: -3px;
  z-index: 9;
  padding: 1px 0;
  transition: 0.3s;
  border-radius: 3px;
  background: #187e85;
}
#inner-place-map .ic-map span.nagoya-ussr {
  width: 240px;
  display: none;
  background: #b7aa00;
}
#inner-place-map .ic-map span.kagoshima {
  width: 180px;
  display: none;
  background: #ec6941;
}
#inner-place-map .ic-map:hover, #inner-place-map .ic-map.active {
  cursor: pointer;
  background: #71bcc2;
}
#inner-place-map .ic-map:hover span, #inner-place-map .ic-map.active span {
  display: block;
}
#inner-place-map .ic-map#nagoya-ussr {
  border-color: #b7aa00;
}
#inner-place-map .ic-map#nagoya-ussr:hover, #inner-place-map .ic-map#nagoya-ussr.active {
  background: #b7aa00;
}
#inner-place-map .ic-map#kagoshima {
  border-color: #ec6941;
}
#inner-place-map .ic-map#kagoshima:hover, #inner-place-map .ic-map#kagoshima.active {
  background: #ec6941;
}
#inner-place-map #box-map-text {
  width: 200px;
  color: #545251;
  font-size: 0.8125rem;
  position: absolute;
  left: 0px;
  top: 100px;
  padding: 15px;
  border-radius: 5px;
  background: white;
}
#inner-place-map #box-map-text p:first-child {
  margin-bottom: 20px;
}

#sapporo {
  right: 100px;
  top: 80px;
}

#tokyo {
  right: 78px;
  bottom: 243px;
}

#saitama {
  right: 98px;
  bottom: 237px;
}

#tohoku {
  right: 75px;
  top: 270px;
}

#yokohama {
  right: 92px;
  bottom: 218px;
}

#shizuoka {
  right: 130px;
  bottom: 187px;
}

#nagoya {
  right: 153px;
  bottom: 178px;
}

#nagoya-ussr {
  right: 170px;
  bottom: 185px;
}

#shikoku {
  left: 90px;
  bottom: 110px;
}

#fukuoka {
  left: 35px;
  bottom: 75px;
}

#kyusyu {
  left: 13px;
  bottom: 70px;
}

#kagoshima {
  left: 32px;
  bottom: 22px;
}

#okayama {
  left: 110px;
  bottom: 151px;
}

#kobe {
  left: 140px;
  bottom: 163px;
}

#osaka {
  left: 168px;
  bottom: 155px;
}

#hokuriku {
  left: 170px;
  bottom: 240px;
}

#nigata {
  right: 135px;
  bottom: 285px;
}

#gunma {
  right: 115px;
  bottom: 255px;
}

#jaa {
  right: 76px;
  bottom: 225px;
}

#haaKobe {
  left: 157px;
  bottom: 168px;
}



/*
 * SP
 */
#block-place-sp {
  padding: 30px 20px;
  background: #92d4f5;
}
@media screen and (min-width: 1025px) {
  #block-place-sp {
    display: none;
  }
}
#block-place-sp h3 {
  font-size: 1.25rem;
  margin-bottom: 10px;
}
#block-place-sp p {
  margin-bottom: 20px;
}
@media screen and (max-width: 640px) {
  #block-place-sp p br {
    display: none;
  }
}

#accordion {
  margin-bottom: 30px;
}
#accordion > dl {
  padding: 0 20px;
  background: #f7f6f2;
}
#accordion > dl:not(:last-child) {
  margin-bottom: 5px;
}
#accordion > dl > dt {
  color: #545251;
  padding: 15px 0;
  position: relative;
}
#accordion > dl > dt:after {
  content: "";
  position: absolute;
  border-top: 1px solid;
  border-right: 1px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 10px;
  height: 10px;
  color: #37a0da;
  right: 0;
  top: 50%;
  margin-top: -10px;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  border-width: 2px;
}
#accordion > dl > dt.active:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  margin-top: -5px;
}
#accordion > dl > dd {
  padding-bottom: 20px;
}
#accordion > dl > dd dl {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #37a0da;
}
#accordion > dl > dd dt {
  width: 110px;
  float: left;
}
@media screen and (min-width: 480px) {
  #accordion > dl > dd dt {
    width: 130px;
  }
}
#accordion > dl > dd dd {
  overflow: hidden;
}
#accordion div {
  width: 80%;
  text-align: center;
  margin: 0 auto;
  padding-top: 10px;
}
@media screen and (min-width: 640px) {
  #accordion div {
    width: 50%;
  }
}
#accordion a {
  color: white;
  display: block;
  padding: 10px 0;
  border-radius: 10px;
  background: url(../images/common/ic_blank.png) no-repeat top 50% right 20px #187e85;
}
#accordion a.yokohama{
	background: none;
	color: #000;
	text-decoration: underline;
	padding: 0;
	margin-bottom: 10px;
}
#accordion img {
  margin-bottom: 10px;
}

.box-place-bnr-sp {
  padding-bottom: 20px;
  border-radius: 5px;
  background: white;
}
.box-place-bnr-sp:not(:last-of-type) {
  margin-bottom: 30px;
}
.box-place-bnr-sp img {
  width: 100%;
}
.box-place-bnr-sp dl {
  margin-bottom: 10px;
  padding: 0 10px;
}
@media screen and (min-width: 640px) and (max-width: 1024px) {
  .box-place-bnr-sp dl {
    padding: 0 30px;
  }
}
.box-place-bnr-sp dt {
  color: #0086d1;
  font-size: 1.125rem;
  font-weight: bolder;
  text-align: center;
  line-height: 1;
  margin-bottom: 10px;
  padding: 7px 0 10px;
  border-bottom: 2px solid #37a0da;
}
.box-place-bnr-sp div {
  width: 50%;
  text-align: center;
  margin: 0 auto;
}
.box-place-bnr-sp div a {
  color: white;
  display: block;
  position: relative;
  padding: 10px 0;
  border-radius: 10px;
  background: #37a0da;
}

/*------------------------------------------------------------
	微調整用クラス（※多用しないこと）
------------------------------------------------------------*/
.mt0 { margin-top: 0 !important; }
.mb0 { margin-bottom: 0 !important; }

/*------------------------------------------------------------
	パンクズリスト
------------------------------------------------------------*/
#pagePath {
	margin: 10px auto 11px;
	width: 1100px;
}

#pagePath li {
	margin-right: 2px;
	display: inline;
	font-size: 0.6rem;
	color: #313131;
	vertical-align: middle;
}

#pagePath li a {
	margin-right: 9px;
}

/*------------------------------------------------------------
	mainVisual
------------------------------------------------------------*/
#main .mainVisual {
	margin-bottom: 10px;
	height: 260px;
	background: url(../images/guidance/index/main_visual_bg.jpg) no-repeat;
	background-size: cover;
	filter:progid:DXImageTransform.Microsoft.AlphaImageLoader( src='../images/guide/main_img.jpg',sizingMethod='scale');
}

/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
#main .headLine01 {
	padding-top: 111px;
	margin: 0 auto;
	width: 1102px;
	color: #fff;
	font-size: 1.85rem;
	text-shadow: 5px 5px 5px #666;
	-moz-text-shadow: 5px 5px 5px #666;
	-webkit-text-shadow: 5px 5px 5px #666;
}

/*------------------------------------------------------------
	mainBox
------------------------------------------------------------*/
#main .mainBox {
	margin: 0 auto 74px;
	width: 1100px;
}

/*------------------------------------------------------------
	comLinkUl
------------------------------------------------------------*/
.comLinkUl {
	margin-bottom: 18px;
}

.comLinkUl li {
	padding-left: 2px;
	float: left;
	text-align: center;
}

.comLinkUl li:first-child {
	padding-left: 0;
}

.comLinkUl li a {
	padding: 21px 24px 22px;
	color: #000 !important;
	font-size: 0.9rem;
	display: block;
	background: #D6D6D6 url(../images/common/com_bg01.gif) repeat-x left top;
	text-decoration: none !important;
}

.comLinkUl .current a,
.comLinkUl li a:hover {
	text-decoration: none;
	color: #fff !important;
	background: #3299D6 url(../images/common/com_bg02.gif) repeat-x left top;
}
.comLinkUl .current a
{
	font-weight: bold !important;
}
.comLinkUl .liType01 {
	width: 232px;
}

.comLinkUl .liType02 {
	width: 162px;
}

/*------------------------------------------------------------
	comLinkUl01
------------------------------------------------------------*/
.comLinkUl01 {
	padding-bottom: 60px;
}

.comLinkUl01 li {
	position: relative;
	width: 150px;
}

.comLinkUl01 li .ulBox {
	position: absolute;
	padding: 11px 5px 12px 12px;
	left: -150px;
	top: 62px;
	width: 1100px;
	background: #3299D6 url(../images/common/com_bg04.gif) repeat left top;
}

.comLinkUl01 li .ulBox ul {
	text-align: left;
}

.comLinkUl01 li .ulBox ul li {
	width: auto;
	float: none;
	display: inline;
	color: #fff;
	text-align: left;
}

.comLinkUl01 li .ulBox ul li a {
	margin-bottom: 0;
	padding: 5px 24px 5px 18px;
	display: inline-block;
	border-right: 1px solid #fff;
	background: none;
}

.comLinkUl01 li .ulBox ul li a:hover {
	text-decoration: underline;
	background: none;
}

.comLinkUl01 li .ulBox ul .none a {
	border: none;
}

.comLinkUl01 .current a {
	padding: 21px 24px 28px;
	margin-bottom: -6px;
	color: #fff;
	background: #3299D6 url(../images/common/com_bg02.gif) repeat-x left top;
}

.comLinkUl01 .liTypeS {
	width: auto;
}
.comLinkUl01 .liTypeS a {
} 

.comLinkUl01 .liType01 {
	width: 152px;
} 

.comLinkUl01 .liType02 {
	width: 192px;
} 

.comLinkUl01 .liType02 a {
	padding: 21px 5px 22px;
}

.comLinkUl01 .liType03 {
	padding-left: 12px;
	width: 232px;
}

.comLinkUl01 .liType03 a {
	padding: 21px 5px 22px;
	color: #fff !important;
	background: #41AEBE url(../images/common/com_bg03.gif) repeat left top;
}
.comLinkUl01 .liType03 a:hover
{
	background: #41AEBE url(../images/common/com_bg03.gif) repeat left top !important;
	color: #fff !important;
	opacity: 0.7;
}
.comLinkUl01 .liType04 {
	width: 222px;
	padding-left: 2px;
}

/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
#main .headLine02 {
	margin-bottom: 30px;
	clear: both;
	color: #343434;
	font-size: 1.15rem;
	border-left: 3px solid #37A0DA;
}

#main .headLine02 span {
	padding: 13px 13px 13px;
	display: block;
	border: 1px solid #B9B9B9;
	border-left: none;
}

/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
#main .headLine03 {
	margin-bottom: 16px;
	padding-bottom: 1px;
	clear: both;
	color: #333;
	line-height: 1.4;
	font-size: 1.15rem;
	border-bottom: 2px solid #37A0DA;
}

/*------------------------------------------------------------
	headLine04
------------------------------------------------------------*/
#main .headLine04 {
	margin-bottom: 10px;
	padding-left: 10px;
	clear: both;
	color: #333;
	line-height: 1.4;
	font-size: 1rem;
	border-left: 3px solid #37A0DA;
}

/*------------------------------------------------------------
	imgBoxR
------------------------------------------------------------*/
#main .imgBoxR {
	margin-bottom: 54px;
	clear: both;
}

#main .imgBoxR .phoBox {
	margin-top: 8px;
	float: right;
}

#main .imgBoxR .phoBox span {
	margin-top: 7px;
	display: block;
	text-align: center;
	color: #000;
	font-size: 0.7rem;
}

#main .imgBoxR .txtBox {
	width: 755px;
	float: left;
}

#main .imgBoxR .txtBox p {
	margin-bottom: 30px;
	font-size: 0.94rem;
	line-height: 2;

}

/*------------------------------------------------------------
	comTable
------------------------------------------------------------*/
#main .comTable {
	width: 100%;
	border-collapse: collapse;
}

#main .comTable thead th {
	padding: 5px;
	color: #fff;
	font-size: 0.85rem;
	font-weight: normal;
	line-height: 1.2;
	text-align: center;
	vertical-align: middle;
	background-color: #37A0DA;
}

#main .comTable th,
#main .comTable td {
	padding: 17px 5px;
	color: #444;
	font-size: 0.8rem;
	text-align: left;
	vertical-align: middle;
	border: 2px solid #fff;
}

#main .comTable th {
	padding: 10px 5px 10px 18px;
	font-weight: normal;
	background-color: #CCE2F4;
}

#main .comTable td {
	text-align: center;
	background-color: #EDEDED;
}


@media screen and (max-width: 1024px) {	
	/*------------------------------------------------------------
		pagePath
	------------------------------------------------------------*/
	#pagePath {
		display: none;
	}
	
	/*------------------------------------------------------------
		mainVisual
	------------------------------------------------------------*/
	#main .mainVisual {
		height: 180px;
	}
	
	/*------------------------------------------------------------
		headLine01
	------------------------------------------------------------*/
	#main .headLine01 {
		padding: 80px 10px;
		width: auto;
		font-size: 1.3rem;
	}
	
	#main .headLine01 img {
		width: 280px;
	}
	
	/*------------------------------------------------------------
		mainBox
	------------------------------------------------------------*/
	#main .mainBox {
		margin-bottom: 30px;
		padding: 0 10px;
		width: auto;
	}

	/*------------------------------------------------------------
		comLinkUl
	------------------------------------------------------------*/
	#main .comLinkUl {
		display: none;
	}
	
	#page-submenu {
		display: none;
	}
	
}

/*access*/
.accessWindow
{
	width: 100%;
	height: 100%;
	z-index: 9999;
	left: 0;
	top: 0;
	position: fixed;
	display: none;
}
.accessWindow .bg
{
	left: 0;
	top: 0;
	position: absolute;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: 0.5;
}
.accessWindow .inner
{
	width: 100%;
	height: 100%;
	position: relative;
}
.accessWindow .access
{
	width: 900px;
	height: 530px;
	position: absolute;
	top: 50% !important;
	left: 50% !important;
	margin-left: -450px;
	margin-top: -265px;
	cursor: pointer;
	background: #fff;
	padding: 18px 25px;
	box-sizing: border-box;
}
.accessWindow .access .info
{
	width: 330px;
	font-size: 15px;
	float: left;
}
.accessWindow .access .info h3
{
	font-size: 24px;
	border-bottom: 1px solid #000;
	margin-bottom: 10px;
}
.accessWindow .access .info .address
{
	margin-bottom: 2em;
}
.accessWindow .access .accessTitle
{
	padding: 0.5em;
	font-size: 14px;
	border: 1px solid #000;
	display: inline-block;
	margin-bottom: 20px;
}
.accessWindow .access .accessMethod
{
	margin-bottom: 30px;
}
.accessWindow .access .accessMethod ul
{
	list-style: disc;
	paddine-left: 1.5em;
	margin-left: 1.5em;
}
.accessWindow .access .accessMethod div
{
	margin-bottom: 1em;;
}
.accessWindow .access .accessMethod ul
{
	margin-top: 1em;
}
.accessWindow .access .accessMethod ul li
{
	margin-bottom: 1em;
}
.accessWindow .access .map
{
	width: 500px;
	height: 480px;
	overflow: hidden;
	float: right;
}
.accessWindow .access .inner
{
	position: relative;
}
.accessWindow .access .inner:after
{
	content: url("../../images/top/access_close.png");
	right: -38px;
	top: -33px;
	position: absolute;
}

#keyvisual
{
	display: block;
	height: 0 !important;
	padding-bottom: 46% !important;
}

#topBannar
{
	text-align: center;
}
#topBannar a
{
	margin: 20px auto 30px;
	padding: 15px 50px;
	text-align: center;
	display: inline-block;
	background: #eeeeee;
	color: #0086d1;
	font-weight: bold;
	text-decoration: underline;
	font-size: 120%;
}
#topBannar a:hover
{
	text-decoration: none;
}
@media screen and (max-width: 1024px)
{
	#topBannar a
	{
		width: 100%;
		padding: 15px 0;
	}
}




/*--ページ上部へ戻る --*/
#pageTop {
	display: none;
    position: fixed;
    bottom: 0;
    right: 20px;
    width: 70px;
    height: 70px;
    font-size: 13px;
	background-color:#001142;
	color: #fff;
	text-decoration: none;
	text-align: center;
	font-weight: normal;
}

#pageTop:hover {
	background-color:#142e78;
}



/* 2018.05.10追加 --- トップページ 総会バナー */

/* バナー非表示 */
#block-news p.bnSokai {
    display: none;
}
/* バナー表示 */
/*
#block-news p.bnSokai {
    font-size: 0.85rem;
    text-align:right;
    width: 100%;
	margin-top:-70px;
    margin-bottom: 30px;
}
#block-news p.bnSokai a {
	display:inline-block;
	text-align:center;
	color:#1771b0;
	line-height:34px;
	height:40px;
	padding:0 20px;
	border:double 3px #b0cee3;
	background-color:#e1eef7;
}
#block-news p.bnSokai a:hover {
	text-decoration:none;
	background-color:#b0cee3;
}
@media screen and (max-width: 1024px)
{
    #block-news p.bnSokai {
        text-align:center;
	    margin-top:-10px;
        margin-bottom: 20px;
}
}
*/


