@charset "UTF-8";

/* ==============================================
header
============================================== */
.site-header { margin-bottom: 0; font-family: 'Noto Sans JP', sans-serif; border: none; }

.header-upside { padding-bottom: 10px; position: relative; }

.header-upside::after { content: ""; display: block; width: 100%; height: 35px; background: url(../images/common/bg_header.png) no-repeat center top/auto 100%; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }

.header-upside-inner { padding: 0 15px; max-width: 1010px; margin: 0 auto; }

.header-upside .header-logo { width: 222px; margin: 0; padding: 0; }

.header-upside .navbar-toggle { margin-top: 10px; margin-right: 0; padding: 10px 6px; border: none; box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.13); }

.header-upside .navbar-toggle .icon-bar { width: 36px; height: 4px; background-color: #3e4476; }

.header-upside .navbar-toggle .icon-bar + .icon-bar { margin-top: 8px; }

.header-nav-inner { width: 100%; max-width: 1030px; margin: 0 auto; padding: 18px 15px; }

.header-utilities-row01 { margin-bottom: 25px; }

.navbar-brand > a > img{ margin-top: 10px; }


/* ==============================================
fooder
============================================== */
.site-footer { margin-top: 100px; font-family: 'Noto Sans JP', sans-serif; background-color: transparent; }

.site-footer::before { content: ""; display: block; width: 100%; height: 35px; background: url(../images/common/bg_footer.png) no-repeat center top/auto 100%; }

.site-footer .footer-inner { width: 100%; max-width: 1030px; margin: 0 auto; padding: 0 15px; }

.site-footer .copyright { padding: 36px 0 1em; text-align: center; }

.site-footer .footer-nav { background: url(../images/common/bg_pattern_grn.jpg) repeat center center/1500px auto; }

.site-footer .footer-nav-title { font-size: 1.14286em; border-top: 1px solid #7fba00; }

.site-footer .footer-nav-list { padding: 0; display: flex; flex-wrap: wrap; list-style-type: none; }

.site-footer .footer-nav-list-item { line-height: 1; }

.site-footer .footer-nav-list-item > a { line-height: 1.5; }

.site-footer .footer-info { padding: 38px 0 24px; }

.site-footer .footer-info-logo { width: 238px; height: 70px; margin: 0 auto 22px; }

.site-footer .footer-info-logo > img { width: 100%; }

.site-footer .footer-info-txt { width: 78.26087%; margin: 0 auto; font-size: 1.14286em; line-height: 1.5; }

.site-footer .footer-btn-wrap { display: flex; justify-content: center; margin: 0 -15px; }

.site-footer .footer-btn-wrap .btn-footer { width: 50%; max-width: 212px; margin: 0 15px; padding: 12px 28px 12px 12px; background-color: #3e4476; border-radius: 6px; color: #fff; font-size: 1.14286em; letter-spacing: 2px; position: relative; transition: all .3s; }

.site-footer .footer-btn-wrap .btn-footer:hover { opacity: 0.8; }

.site-footer .footer-btn-wrap .btn-footer::after { content: ''; display: block; width: 10px; height: 16px; margin: auto; background: url(../images/common/icon_arrow_wht.svg) no-repeat center right/cover; position: absolute; top: 0; bottom: 0; right: 8px; }

#btn-page-top { display: block; width: 70px; height: 70px; background-color: #fff; border: 2px solid #3e4476; border-radius: 50%; cursor: pointer; position: fixed; bottom: 40px; right: 40px; z-index: 1000; transition: all .3s; }

#btn-page-top:hover { opacity: 0.8; }

#btn-page-top::before { content: ""; display: block; width: 0; height: 0; border-style: solid; border-width: 0 12px 20px 12px; border-color: transparent transparent #3e4476 transparent; position: absolute; bottom: 60%; left: 0; right: 0; margin: auto; }

#btn-page-top .btn-page-top-txt { display: inline-block; width: 100%; padding-top: 50%; color: #3e4476; font-family: 'Noto Sans JP', sans-serif; font-size: 12px; font-weight: bold; text-align: center; }

@media (min-width: 768px) { media query の順番制御のため記述 * { box-sizing: border-box; } .header-upside-inner { display: flex; justify-content: space-between; }
  .header-upside .navbar-header { float: none; margin: 0; padding-left: 24px; padding-top: 2px; }
  .header-upside .site-header-utilities { float: none; }
  .header-upside .header-logo { width: auto; } .header-nav.collapse { display: block; }
  .header-nav .nav { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; }
  .header-nav .nav-item { width: 16%; position: relative; font-size: 1.14286em; }
  .header-nav .nav-item:first-child::before, .header-nav .nav-item::after { content: ""; display: block; width: 1px; height: 100%; background-color: #bfbfbf; position: absolute; top: 0; bottom: 0; z-index: 1; margin: auto; }
  .header-nav .nav-item:first-child::before { left: 0; }
  .header-nav .nav-item::after { right: 0; }
  .header-nav .nav-item > a { padding: 12px 10px; text-align: center; position: relative; font-size: clamp(14px, 1.8vw, 16px); }
  .header-nav .nav-item > a::before { content: ""; display: block; width: 0; height: 2px; background-color: #3e4476; position: absolute; bottom: 0; right: 10%; transition: all .3s; }
  .header-nav .nav-item > a:hover { background: transparent; }
  .header-nav .nav-item > a:hover::before { width: 80%; left: 10%; right: auto; } .site-footer .footer-nav { padding: 30px 0 55px; }
  .site-footer .footer-nav-title { padding: 0.75em 0 4px; }
  .site-footer .footer-nav-title:first-child { border-top: none; }
  .site-footer .footer-nav-title .pull-right { display: none; }
  .site-footer .footer-nav-list { padding-bottom: 0.85714em; margin-bottom: 0; }
  .site-footer .footer-nav-list-wrapper:last-child { border-bottom: 1px solid #7fba00; }
  .site-footer .footer-nav-list-item { margin: 0.25em 0; }
  .site-footer .footer-nav-list-item::after { content: "／"; display: inline-block; margin: 2px; }
  .site-footer .footer-nav .collapse { display: block; } .site-footer .footer-info { padding: 35px 0 46px; display: flex; justify-content: center; }
  .site-footer .footer-info-logo { margin: 0 35px 0 0; }
  .site-footer .footer-info-txt { width: auto; margin: 0; } .site-footer .footer-btn-wrap { width: 100%; margin: 0; }
  .site-footer .footer-btn-wrap .btn-footer { padding: 14px 30px; }
  .site-footer .footer-btn-wrap .btn-footer::after { right: 20px; } #btn-page-top { width: 96px; height: 96px; }
  #btn-page-top .btn-page-top-txt { font-size: 14px; } }

@media (min-width: 992px) { * { box-sizing: border-box; } .header-upside { padding-bottom: 70px; }
  .header-upside::after { height: 72px; } .header-utilities-row02 { margin-top: -15px; margin-bottom: -15px; } .site-footer::before { height: 70px; }
  .site-footer .copyright { padding-top: 55px; font-size: 1.14286em; } }

@media screen and (max-width: 767px) { .header-nav { width: 100%; position: absolute; z-index: 1000; }
  .header-nav-inner { background-color: #ffffff; }
  .header-nav .nav-item { border-bottom: 1px solid #b3b3b3; } .site-footer .footer-nav { padding: 15px 0 18px; }
  .site-footer .footer-nav .footer-inner { position: relative; }
  .site-footer .footer-nav .footer-inner::after { content: ""; display: block; width: 100%; height: 1px; background-color: #7fba00; }
  .site-footer .footer-nav-title > a { display: inline-block; padding: 0.375em 5px; }
  .site-footer .footer-nav-title .pull-right { position: relative; }
  .site-footer .footer-nav-title .pull-right::after { content: ""; display: block; width: 100px; height: 100%; position: absolute; top: 0; right: 0; }
  .site-footer .footer-nav-title .pull-right .glyphicon { transition: all .3s; }
  .site-footer .footer-nav-title .pull-right:not(.collapsed) .glyphicon { transform: rotateX(-180deg); }
  .site-footer .footer-nav-list-item { width: 50%; padding: 0.5em 1em; border-top: 1px dotted #b3b3b3; }
  .site-footer .footer-nav-list-item:nth-child(odd) { border-right: 1px dotted #b3b3b3; }
  .site-footer .footer-nav-list-item:nth-child(-n+2) { border-top: none; } }
