@charset "utf-8";
@import"https://fonts.googleapis.com/css?family=Roboto:400,700";
@import"https://fonts.googleapis.com/earlyaccess/nanumgothic.css";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, hgroup, menu, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}
body {
  line-height: 1;
}
article, aside, details, figcaption, figure, hgroup, menu, section {
  display: block;
}
li {
  list-style: none;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
}
a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}
/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}
/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}
del {
  text-decoration: line-through;
}
abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}
input, select {
  vertical-align: middle;
}
sup {
  position: relative;
  top: -.5em;
  font-size: 75%;
}
button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  background: none;
  padding: 0;
  cursor: pointer;
}
/*common*/

* {
  box-sizing: border-box;
}
html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
}
body {
  position: relative;
  font-family: 'Noto Sans JP', Arial, Verdana, Lucida Grande, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "ヒラギノ角ゴ Pro W3", sans-serif;
  font-size: 18px;
  background-color: #F5F5F5;
  color: #000;
  line-height: 1.6;
  /* min-width: 1280px;*/
}
.wrap {
  overflow: hidden;
}
a {
  display: block;
  text-decoration: none;
  /*color: #00a1c9;*/
}
main {
  display: block;
  background-color: #fff;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
img[src$=".svg"] {
  width: 100%;
}
.bg01 {
  background-color: #F5F5F5;
}
.inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 50px 16px;
}
.inner2 {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 16px;
}
.sp {
  display: none;
}
#pagetop {
  cursor: pointer;
}
.main-wrap {
  padding: 143px 0 100px;
}
@media only screen and (max-width: 810px) and (min-width: 769px) {
  .main-wrap {
		padding: 185px 0 100px;
	}
}
.heading-level-2 {
  font-weight: bold;
  font-size: 27px;
  text-align: center;
  padding: 0 0 15px;
  border-bottom: 1px solid #D9D9D9;
  line-height: 1;
  margin: 0 0 32px;
}
.heading-level-2-lead {
  font-weight: normal;
  font-size: 13px;
  position: relative;
}
.heading-level-2-lead:before {
  position: absolute;
  content: "";
  display: block;
  background-color: #1A1A1A;
  height: 1px;
  width: 10px;
  top: 50%;
  left: -23px;
  margin-top: -1px;
}
.heading-level-2-lead:after {
  position: absolute;
  content: "";
  display: block;
  background-color: #1A1A1A;
  height: 1px;
  width: 10px;
  top: 50%;
  right: -23px;
  margin-top: -1px;
}
.btn-a {
  display: inline-block;
  font-size: 15px;
  background-color: #636464;
  color: #fff;
  padding: 5px 31px 5px 16px;
  text-align: center;
  border-radius: 5px;
}
.btn-arrow1 {
  position: relative;
}
.btn-arrow1::after {
  position: absolute;
  content: "";
  box-sizing: border-box;
  width: 4px;
  height: 4px;
  border: 7px solid transparent;
  border-left: 11px solid #fff;
  top: 50%;
  right: 5px;
  margin-top: -7px;
}
.btn-b {
  display: inline-block;
  font-size: 13px;
  background-color: #2878C8;
  color: #fff;
  padding: 6px 10px;
  text-align: center;
  border-radius: 3px;
}
.btn-c {
  display: inline-block;
  font-size: 18px;
  background-color: #E0E0E0;
  color: #1A1A1A;
  padding: 10px 55px 10px 35px;
  text-align: center;
  border-radius: 6px;
}
.btn-arrow2 {
  position: relative;
}
.btn-arrow2::after {
  position: absolute;
  content: "";
  box-sizing: border-box;
  width: 4px;
  height: 4px;
  border: 8px solid transparent;
  border-left: 12px solid #1A1A1A;
  top: 50%;
  right: 20px;
  margin-top: -8px;
}
.foot-notes {
  max-width: 1280px;
  margin: 0 auto;
  padding: 20px 0;
  font-size: 12px;
}
.foot-notes-number {
  padding-right: 1em;
}
#pagetop {
  position: fixed;
  bottom: 100px;
  right: 10px;
  cursor: pointer;
  z-index: 9999;
}
#pagetop img {
  position: relative;
  width: 40px;
}
#pagetop:hover {
  opacity: 0.7;
}
@media only screen and (max-width: 768px) {
  .wrap {
    min-width: inherit;
  }
  .inner {
    width: auto;
    margin: 0 auto;
    padding: 40px 20px;
  }
  .inner2 {
    width: auto;
    margin: 0 auto;
    padding: 0 20px;
  }
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
  .main-wrap {
    padding: 48px 0 100px;
  }
  .heading-level-2 {
    font-size: 32px;
  }
  .heading-level-2-lead {
    font-size: 13px;
  }	
  .foot-notes {
    padding: 0 20px 20px;
  }
  #pagetop {
    bottom: 30px;
    z-index: 1;
  }
}
@media only screen and (max-width: 480px) {
  .inner {
    padding: 30px 20px;
  }
  .main-wrap {
    padding: 44px 0 40px;
  }
  .heading-level-2 {
    font-size: 21px;
  }
  .heading-level-2-lead {
    font-size: 11px;
  }
}
@media only screen and (max-width: 320px) {
  .category-text-area {
    padding-top: 160px;
  }
  .heading-level-2 {
    font-size: 18px;
  }
}