/*-------------------------------------------------------------
|  一般用CSS
-------------------------------------------------------------*/
/* TOP */
#main-visual {
    width: 100%;
    background-color: #eee;
    text-align: center;
}
#main-visual p {
    width: 1100px;
    height: 350px;
    background-image: url(/img/top-main-visual-2.png);
    background-repeat: no-repeat;
    background-position: center top;
    margin: 0 auto;
    padding: 0;
    text-indent: -9999px;
}
@media screen and (max-width: 767px) {
  #main-visual {
  }
  #main-visual p {
    width: 100%;
    height: auto;
    background-size: 100% auto;
    padding-bottom: calc(84%*350/1100);
  }
}
#side-menu li a img {
  transition: all 0.5s ease;
}
#side-menu li a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
}
#side-menu {
  margin-top: 15px;
}
#side-menu li {
  margin: 10px 0;
}
@media screen and (max-width: 767px) {
  #side-menu {
    width: 100%;
  }
  #main-box {
    text-align: left;
    width: 100%;
  }
  #side-menu li {
    text-align: center;
    width: 100%;
  }
  #side-menu li a {
    text-align: center;
    width: 100%;
  }
  #side-menu li a img {
    width: 98%;
    height: 98%;
    max-width: 460px;
    max-height:100px;
  }
  #side-menu li a {
    width: 98%;
    height: 98%;
    max-width: 460px;
    max-height:100px;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px) {
  #side-menu {
    float: right;
    width: 480px;
  }
  #main-box {
    float: left;
/*    min-height: 600px;*/
    padding: 15px 0px 10px 20px;
    text-align: left;
    width: 580px;
  }
}


/* whats_new */
.top-whatnew {
}
.top-whatnew h2 {
  border-left-color: #006;
  border-left-width: 10px;
  background: #fff;
  color: #444;
}
.top-whatnew .g-web-box li::before {
  position: relative;
  top: -2px;
  left: -18px;
  display: inline-block;
  width: 6px;
  height: 6px;
  content: '';
  border-radius: 100%;
  background: #006;
}
.top-whatnew ul {
  margin: 15px 15px;
}
.top-whatnew ul li {
  border-bottom: 1px dotted #666;
}
.top-whatnew ul li:first-child {
  border-top: 1px dotted #666;
}
.top-whatnew ul li > div.whatnew-ttl-a,
.top-whatnew ul li > a {
  width: 100%;
  padding: 9px 0 8px;
  text-decoration: none;
  display: flex;
  flex-wrap: nowrap;
}
.top-whatnew ul .whatnew-ttl + * {
  margin-left: 20px;
}
.top-whatnew ul .whatnew-ttl {
  width: 14em;
}
.top-whatnew ul .whatnew-ttl {
  display: block;
}
.top-whatnew ul .whatnew-dtl {
  display: block;
}
.whatnew-date {
  font-weight: bold;
  color: #2e3136;
}
.whatnew-dtl {
  width: 100%;
  padding: 0 0 0 15px;
  position: relative;
}
.whatnew-ttl + * {
  margin: 0 0 0 30px;
}
a:link .whatnew-dtl > span,
a:visited .whatnew-dtl > span {
  text-decoration: underline;
}
a:hover .whatnew-dtl > span,
a:active .whatnew-dtl > span {
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .whatnew-ttl {
    width: auto;
    margin: 0 0 2px;
  }
  .whatnew-ttl + * {
    margin-left: 0;
  }
  .top-whatnew ul {
    margin: auto 20px;
  }
  .top-whatnew ul li > div.whatnew-ttl-a,
  .top-whatnew ul li > a {
    padding: 12px 0 11px;
    display: block;
  }
  .top-whatnew ul {
    height: auto !important;
  }
}
.whatnew-dtl::before {
  width: 15px;
  height: 11px;
  display: inline-block;
  margin-top: -.6em;
  position: absolute;
  top: 1em;
  background-image: url(/img/icn_arrow.png);
  background-size: 11px 11px;
  background-repeat: no-repeat; /* 繰り返し表示オフ */
  background-position: left center;
  content: '';
  left: 0;
}
