@charset "utf-8";
/* ===================================================================
 style info : ヘッダーやフッターなどサイト内共通
=================================================================== */

/*----------------------------------------------------
	共通
----------------------------------------------------*/
html {
  background-color: #ffffff;
}

body {
  font-family: "Helvetica Neue", Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
  background-color: #ffffff;
  color: #000000;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.6;
  letter-spacing: 0.15em;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
}

/*----------------------------------------------------
    リンク
----------------------------------------------------*/
a:link,
a:visited,
a:hover,
a:active {
  color: #000000;
  text-decoration: none;
  transition: all .5s ease;
}

/*----------------------------------------------------
    .pe_element
----------------------------------------------------*/
.pe_element {
  pointer-events: none;
}

/*----------------------------------------------------
    .linknone
----------------------------------------------------*/
.linknone {
  pointer-events: none;
}

/* -----------------------------------------------------------
    .v_rl
----------------------------------------------------------- */
.v_rl {
  line-height: 0;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -webkit-font-feature-settings: "pkna";
  font-feature-settings: "pkna";
}

/* -----------------------------------------------------------
   .note
----------------------------------------------------------- */
.note {
  display: flex;
}

.note:before {
  content: "※";
  margin-right: 0.1em;
}

/*----------------------------------------------------
    hd
----------------------------------------------------*/
.hd_01 {
  font-size: 20px;
  font-size: 2.0rem;
  font-weight: 500;
  line-height: 0.8;
  transform: rotate(-180deg);
}

/* -----------------------------------------------------------
    header
----------------------------------------------------------- */
header {
  xbackground: linear-gradient(111.47727512558504deg, rgba(211, 211, 211,0) 13.229166666666666%,rgba(248, 248, 248,0) 45.67708333333332%,rgba(248, 248, 248,0) 71.56250000000001%,rgba(182, 170, 148,0) 100.72916666666666%);
  background-color: rgba(248,248,248,0);
  color: #ffffff;
  display: flex;
  align-items: center;
  height: 300px;
  padding: 0 5vw;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 2;
  transition: all .5s ease;
}

header .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

header.is-fixed {
  xbackground: linear-gradient(111.47727512558504deg, rgba(211, 211, 211,1) 13.229166666666666%,rgba(248, 248, 248,1) 45.67708333333332%,rgba(248, 248, 248,1) 71.56250000000001%,rgba(182, 170, 148,1) 100.72916666666666%);
  background-color: rgba(248,248,248,1);
  height: 100px;
}

header .site_id {
  line-height: 0;
  opacity: 0;
  width: 200px;
  transition: all .5s ease;
}

header.is-fixed .inner > .site_id {
  opacity: 1;
}

/* -----------------------------------------------------------
    #g_nav
----------------------------------------------------------- */
#g_nav {
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  xjustify-content: flex-end;
  xflex: 1 1;
}

#g_nav .main_nav ul {
  display: flex;
  align-items: center;
}

#g_nav .main_nav li:not(:first-of-type) {
  margin-left: 2vw;
}

#g_nav .main_nav li a.current,
#g_nav .main_nav li a:hover {
  color: #dda82c;
}

#g_nav .sub_nav {
  margin-top: 2vw;
  transition: all .5s ease;
}

header.is-fixed #g_nav .sub_nav {
  display: none;
}

#g_nav .sub_nav p a {
  background-image: url(../img/common/squad_bg.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5vw 1vw;
  width: 135px;
}

#g_nav .sub_nav p a:hover {
  opacity: 0.5;
}

/* -----------------------------------------------------------
    inner
----------------------------------------------------------- */
.inner {
  max-width: 1024px;
  min-width: 768px;
  width: 100%;
  margin: 0 auto;
}

/* -----------------------------------------------------------
    .main
----------------------------------------------------------- */
.main {
  padding-left: 5vw;
  padding-right: 5vw;
}

/* -----------------------------------------------------------
    footer
----------------------------------------------------------- */
footer {
  xbackground-image: url(../img/common/footer_bg.jpg);
  xbackground-position: center;
  xbackground-repeat: no-repeat;
  xbackground-size: cover;
  background: linear-gradient(111.47727512558504deg, rgba(211, 211, 211,1) 13.229166666666666%,rgba(248, 248, 248,1) 45.67708333333332%,rgba(248, 248, 248,1) 71.56250000000001%,rgba(182, 170, 148,1) 100.72916666666666%);
  padding: 5vw 5vw 3vw;
}

footer .inner {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}

footer .logo_box .tagline {
  margin-bottom: 0.5vw;
  line-height: 0;
  width: 165px;
}

footer .logo_box .logo {
  line-height: 0;
  width: 240px;
}

footer .copyright_box {
  line-height: 1;
}

footer .sitemap_box {
  flex: 0 1 400px;
  display: flex;
  align-items: flex-end;
  flex-direction: column;
}

footer .sitemap_box .nav_box ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  margin-top: -1vw;
}

footer .sitemap_box .nav_box ul li {
  margin-top: 1vw;
}

footer .sitemap_box .nav_box ul li:not(:first-of-type) {
  margin-left: 2vw;
}

footer .sitemap_box .nav_box ul li a:hover {
  color: #f39518;
}

footer .sitemap_box .sns_box {
  margin-top: 1vw;
}

footer .sitemap_box .sns_box ul {
  line-height: 1;
}

footer .sitemap_box .sns_box ul li a i {
  font-size: 30px;
  font-size: 3.0rem;
  letter-spacing: normal;
}

footer .sitemap_box .sns_box ul li a:hover {
  color: #4c64d3;
}

footer .sitemap_box .copyright {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  margin-top: 2vw;
}

/* -----------------------------------------------------------
    img:hover
----------------------------------------------------------- */
a img:hover {
  transition: all .5s ease;
}