@charset "utf-8";

/* cmn */
a {
  font-size: inherit;
  color: inherit;
}

#block-headerblock { border-bottom: solid 1px #e6e6e6; }
.p-headerLogo.is-scroll { border-bottom: none; }
.p-headerIconMenu__mobileHamburger::before { display: none; }
.p-globalNav [class*="p-globalNav__unit"],
.p-globalNav [class*="p-globalNav__unit"] ul li:first-child { flex-wrap: wrap; padding: 0; }
.p-globalNav [class*="p-globalNav__unit"] ul { width: 100%; }
.p-globalNav__categoryName--mobile { padding: 14px 20px; align-items: center; }
.p-globalNav__categoryName--mobile.is-active { background-color: #f5f5f5;}
.p-globalNav [class*="p-globalNav__unit"] ul .p-globalNav__categoryName--mobile { padding: 14px 20px 14px 30px; }
.p-globalNav [class*="p-globalNav__unit"] [class*="p-globalNav__categoryName"] { white-space: inherit; }
.f-main {
  letter-spacing: 0;
  line-height: 1.5;
}
.f-main img { vertical-align: bottom; }
footer { margin-top: 0; }

p { padding-bottom: 0; }
@media only screen and (max-width:739px) {
  .pcDisp { display: none !important; }
}
@media only screen and (min-width:740px) {
  .spDisp { display: none !important; }
  .f-main { margin-top: 87px !important; }
  .l-header.is-scroll { justify-content: center; }
  .p-headerLogo.is-scroll { width: 1440px;  }
  .p-headerIconMenu.is-scroll,
  .l-header__navigationMenu { display: none !important; }
}

/*!  stracture
================================================ */
.layout {
  padding-right: 20px;
  padding-left: 20px;
}
@media only screen and (min-width:740px) {
  .layout {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: flex-start;
    width: 1040px;
    margin: 0 auto;
    padding-right: 0;
    padding-left: 0;
  }
  .page-top .layout { display: block; }
  .layout_content { width: 724px; }
  .layout_sidebar {
    width: 266px;
    position: -webkit-sticky; /* Safari */
    position: sticky;
    top: 120px;
  }
}


/*!  module
================================================ */
.mod-section01 { margin-top: 20px; }

.mod-h2 {
  margin-top: 0;
  margin-bottom: 1em;
  padding-bottom: 5px;
  font-size: 2.0rem;
  border-bottom: 1px solid #e1e1e1;
}
.mod-h3 {
  margin-top: 0;
  margin-bottom: .8em;
  font-size: 1.6rem;
  font-weight: 700;
}
.mod-h4 {
  margin-bottom: .5em;
  font-size: 1.4rem;
  font-weight: 700;
}
.mod-list01 {
  line-height: 1.6;
  font-size: 1.4rem;
}
.mod-list01 li {
  position: relative;
  padding-left: 1em;
}
.mod-list01 li + li { margin-top: .5em; }
.mod-list01 li:before {
  position: absolute;
  top: .5em;
  left: 0;
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 3px;
  background-color: #afafaf;
  content: '';
}
.mod-txt {
  line-height: 1.9;
  font-size: 1.4rem;
}
.mod-txt + .mod-txt,
.mod-txt + .mod-list01,
.mod-list01 + .mod-txt { margin-top: 1.5em; }
.mod-caption {
  margin-top: .8em;
  line-height: 1.6;
  font-size: 1.1rem;
  text-align: left;
}
.mod-box01 {
  padding: .8em;
  background-color: #f0f0f0;
}

.mod-table01 { 
  width: 100%;
  font-size: 1.4rem;
  margin-top: 1.5em;
}
.mod_scrollBox01 .mod-table01 { width: 709px; }
.mod-table01 th,
.mod-table01 td {
  box-sizing: border-box;
  line-height: 1.6;
  padding: 8px;
  border: 1px solid #e1e1e1;
  font-size: 1.4rem;
  vertical-align: middle;
  border-collapse: collapse;
}
.mod-table01.basic td { text-align: left; }
.mod-table01 > thead > tr>* { border-bottom: 1px solid #e1e1e1; }
.mod-table01 > thead > tr> th { background: #5a5a5a; color: #fff; text-align: center; font-weight:700; }
.mod-table01 > tbody:first-child th:first-child { border-right: none; }
.mod-table01 > tbody:first-child th:first-child + td { border-left: none; }
.mod-table01 > thead + tbody > tr:first-child>* { border-top: none; }
.mod-table01 > thead + tbody > tr > th { background: #f0f0f0; }
.mod-table01 .bt { border-top: 1px solid #e1e1e1; }
.mod-table01 .br { border-right: 1px solid #e1e1e1; }
.mod-table01 .bb { border-bottom: 1px solid #e1e1e1; }
.mod-table01 .bl { border-left: 1px solid #e1e1e1; }

.icon-open-new-win:before {
  display: inline-block;
  width: 1em;
  height: 1em;
  min-width: 13px;
  min-height: 13px;
  margin-left: .3em;
  vertical-align: middle;
  content: '';
  background: url(../img/open_in_new_black.svg) no-repeat 0 0;
  background-size: cover;
}
.icon-open-new-win.is-white:before {
  background-image: url(../img/open_in_new_white.svg);
}

@media only screen and (min-width:740px) {
  .mod-section01 { margin-top: 40px; }
  .mod-h2 {
    padding: 13px 0 11px;
    font-size: 2.6rem;
  }
  .mod-h3 { font-size: 1.8rem; }
  .mod-h4 { font-size: 1.6rem; }
  .mod-list01 { font-size: 1.6rem; }
  .mod-txt { font-size: 1.6rem; }
  .mod-caption { font-size: 1.3rem; }
  .mod-table01 {
    font-size: 1.6rem;
    margin-top: 1.5em;
  }
  .mod-table01 th,
  .mod-table01 td {
    padding: 10px;
    font-size: 1.5rem;
  }
}


/*!  .vi
================================================ */
.vi {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 20px;
  height: 200px;
  background: #343436 url(../img/vi_bg_sp.jpg) no-repeat right / cover;
}
.vi_title {
  max-width: 45%;
  text-align: center;
}
.vi_title_img {
  display: inline-block;
  width: 70%;
}
.vi_title h1 {
  display: inline-block;
  margin-top: 8px;
  padding: 6px 5px 7px;
  border: 1px solid #fff;
  font-size: 1.0rem;
  color: #fff;
}
@media only screen and (min-width:740px) {
  .vi {
    padding: 0;
    height: 247px;
    background: #343436 url(../img/vi_bg_pc.jpg) no-repeat right / auto;
  }
  .page-top .vi {
    height: 374px;
  }
  .vi_img {
    display: flex;
    align-items: flex-end;
    height: 100%;
  }
  .vi_title {
    max-width: 100%;
    padding: 0 80px;
    text-align: center;
  }
  .vi_title_img {
    display: inline-block;
    width: 167px;
  }
  .page-top .vi_title_img {
    width: 209px;
  }
  .vi_title h1 {
    display: block;
    width: 93%;
    margin: 10px auto 0;
    padding: 9px 0 8px;
    font-size: 1.1rem;
    letter-spacing: 0.2px;
  }
  .page-top .vi_title h1 {
    padding: 12px 0;
    font-size: 1.3rem;
  }
}

/*!  .paging
================================================ */
.paging {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
  border-top: 1px solid #e1e1e1;
  font-size: 1.1rem;
}
.paging_item {
  position: relative;
  min-width: 30%;
  margin-top: 15px;
}
.paging_item a { text-decoration: none; }
.paging_item.prev {
  padding-left: 12px;
  padding-right: 10px;
}
.paging_item.next {
  margin-left: auto;
  padding-left: 10px;
  padding-right: 12px;
  text-align: right;
}
.paging_item.prev:before,
.paging_item.next:after {
  position: absolute;
  top: 0.25em;
  display: inline-block;
  width: 9px;
  height: 9px;
  border-top: 3px solid #ff0000;
  border-left: 3px solid #ff0000;
  content: '';
}
.paging_item.prev:before {
  transform: rotate(315deg);
  left: 0;
}
.paging_item.next:after {
  transform: rotate(135deg);
  right: 0;
}
@media only screen and (min-width:740px) {
  .paging {
    margin-top: 30px;
    font-size: 1.4rem;
    letter-spacing: 0.8px;
  }
  .paging_item { margin-top: 20px; }
  .paging_item.prev { padding-left: 16px; }
  .paging_item.next { padding-right: 16px; }
  .paging_item.prev:before,
  .paging_item.next:after { top: 0.45em; }
}

/*!  .layout_sidebar
================================================ */
@media only screen and (min-width:740px) {
  .layout_sidebar { padding-top: 13px; }
  .sidebarBtn a {
    display: block;
    text-align: center;
    width: 100%;
    padding: 17px 10px;
    font-size: 1.3rem;
    line-height: 1;
    color: #fff;
    font-weight: 700;
    letter-spacing: 0.8px;
    text-decoration: none;
    border-radius: 30px;
    background-color: #333;
    transition: opacity 0.5s;
  }
  .sidebarBtn a:hover {
    opacity: 0.8;
  }
  .sidebarBtn a i {
    vertical-align: middle;
    margin-right: 8px;
    font-size: 2.0rem;
  }
  .sidebarBtn a i:before {
    vertical-align: top;
  }

  .sidebarNav { margin-top: 20px; }
  .sidebarNav > li + li { margin-top: -1px; }
  .sidebarNav > li > a {
    display: flex;
    align-items: center;
    height: 76px;
    padding: 0 80px 0 18px;
    cursor: pointer;
    border: 1px solid #ebebeb;
    border-left: 4px solid #ff0000;
    font-size: 14px;
    text-decoration: none;
    letter-spacing: 0.3px;
    transition: opacity 0.5s;
  }
  .sidebarNav > li > a:hover { opacity: 0.8; }
  .sidebarNav_item01 { background: url(../img/sidenav_what.png) no-repeat right top; }
  .sidebarNav_item02 { background: url(../img/sidenav_about.png) no-repeat right top; }
  .sidebarNav_item03 { background: url(../img/sidenav_history.png) no-repeat right top; }

  .sidebarNav > li > ul {
    display: none;
    font-size: 12px;
    letter-spacing: 1.2px;
    padding: 15px 0 17px 21px;
  }
  .sidebarNav > li.is-active > ul { display: block; }
  .sidebarNav > li > ul li { padding: 4px 0; }
  .sidebarNav > li > ul a {
    color: #464646;
    text-decoration: none;
  }
  .sidebarNav > li > ul a:hover {
    color: #6b6b6b;
  }
}


/*!  .footerBtn
================================================ */
.breadcrumb {
  margin: 15px 20px;
  font-size: 1.1rem;
}
.breadcrumb ol > li {
  display: inline-block;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.breadcrumb ol > li a {
  color: #464646;
  text-decoration: none;
}
.breadcrumb ol > li + li:before {
  display: inline-block;
  margin-left: 7px;
  margin-right: 7px;
  content: '>';
}
@media only screen and (min-width:740px) {
  .breadcrumb {
    width: 1040px;
    margin: 15px auto;
    font-size: 1.2rem;
  }
  .breadcrumb ol > li a:hover {
    text-decoration: underline;
  }
}

/*!  .footerBtn
================================================ */
.footerBtn {
  width: 100%;
  margin-top: 30px;
  padding: 20px;
  text-align: center;
  background-color: #f5f5f5;
}
.footerBtn a {
  display: inline-block;
  padding: 11px 25px;
  font-size: 1.3rem;
  line-height: 1;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-decoration: none;
  border-radius: 30px;
  background-color: #cc0000;
}
.footerBtn a i {
  margin-right: 8px;
  font-size: 2.0rem;
  vertical-align: middle;
}
.footerBtn a i:before {
  vertical-align: top;
}
@media only screen and (min-width:740px) {
  .footerBtn {
    margin-top: 60px;
    padding: 30px;
  }
  .footerBtn a {
    width: 330px;
    padding: 18px 10px;
    font-size: 1.5rem;
    border-radius: 30px;
    transition: opacity 0.5s;
  }
  .footerBtn a:hover {
    opacity: 0.8;
  }
  .footerBtn a i {
    font-size: 2.4rem;
  }
}

/*!  page-top
================================================ */
.sec_theme { margin-top: 20px; }
.sec_theme h2 {
  margin-top: 0;
  margin-bottom: .8em;
  font-size:2.3rem;
  text-align: center;
  line-height: 1.3;
}
.theme_list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -10px;
  margin-left: -10px;
}
.theme_list > li {
  width: calc(50% - 10px);
  margin-bottom: 10px;
  margin-left: 10px;
}
@media only screen and (min-width:740px) {
  .sec_theme { margin-top: 40px; }
  .sec_theme h2 {
    margin-bottom: .8em;
    font-size: 34px;
    letter-spacing: 1.6px;
  }
  .theme_list {
    margin-bottom: -4px;
    margin-left: -4px;
  }
  .theme_list > li {
    width: 344px;
    margin-bottom: 4px;
    margin-left: 4px;
  }
  .theme_list > li a { transition: opacity 0.5s; }
  .theme_list > li a:hover { opacity:.8; }
}


/*!  utility
================================================ */
.indent01 { text-indent: -1em; margin-left: 1em; }
.dB { display: block !important; }
.fwB { font-weight: 700 !important; }
.taC { text-align: center !important; }
.mt05 { margin-top: 5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt45 { margin-top: 45px !important; }
.mt50 { margin-top: 50px !important; }
.mt55 { margin-top: 55px !important; }
.mt60 { margin-top: 60px !important; }
.mt65 { margin-top: 65px !important; }
.mt70 { margin-top: 70px !important; }
.mt75 { margin-top: 75px !important; }
.mt80 { margin-top: 80px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb30 { margin-bottom: 30px !important; }
.fs13 { font-size: 1.3rem; }

@media only screen and (min-width:740px) {
  .alpha { transition: opacity .3s ease 0s; }
  .alpha:hover { opacity: .8; text-decoration: none; }
  .p_taC { text-align: center !important; }
  .p_mb30 { margin-bottom: 30px !important; }
  .p_fs14 { font-size: 1.4rem !important; }
}