@charset "UTF-8";
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video, *::before, *::after {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  word-break: break-word;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  vertical-align: baseline;
  background: transparent; }

html, body {
  overflow-x: hidden; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, main {
  display: block; }

li {
  list-style-type: none; }

blockquote, q {
  quotes: none; }
  blockquote::before, blockquote::after, q::before, q::after {
    content: '';
    content: none; }

a {
  text-decoration: none;
  color: inherit; }

img, picture {
  vertical-align: middle;
  max-width: 100%; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

input, select {
  vertical-align: middle; }

br {
  line-height: 0; }

/* safariでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  border: none;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }
  input[type="submit"]::-webkit-search-decoration,
  input[type="button"]::-webkit-search-decoration {
    display: none; }
  input[type="submit"]::focus,
  input[type="button"]::focus {
    outline-offset: -2px; }

h1, h2, h3, h4, h5, h6 {
  font-weight: normal; }

/* -----------------------------------------------------
	basic
----------------------------------------------------- */
html {
  font-size: 62.5%; }

body {
  font-family: mamelon, "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  -webkit-text-size-adjust: 100%;
  font-size: 1.8rem;
  line-height: 1.5;
  font-weight: 400;
  color: #fff;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt" 1;
  background: #FFF; }
  @media screen and (max-width: 768px) {
    body {
      font-size: 4vw; } }

main {
  width: 100%; }

.inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 40px; }
  @media screen and (max-width: 768px) {
    .inner {
      padding: 0 4vw; } }

a {
  opacity: 1;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
  text-decoration: none; }
  a:hover {
    opacity: .7; }

/* -----------------------------------------------------
	header
----------------------------------------------------- */
header {
  position: fixed;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.2)), color-stop(5%, rgba(0, 0, 0, 0.2)), color-stop(70%, rgba(0, 0, 0, 0.04)), color-stop(80%, rgba(0, 0, 0, 0.03)), to(rgba(0, 0, 0, 0))) !important;
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.2) 5%, rgba(0, 0, 0, 0.05) 70%, rgba(0, 0, 0, 0.04) 80%, rgba(0, 0, 0, 0) 100%) !important;
  background: -o-linear-gradient(top, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.2) 5%, rgba(0, 0, 0, 0.05) 70%, rgba(0, 0, 0, 0.04) 80%, rgba(0, 0, 0, 0) 100%) !important;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.2)), color-stop(5%, rgba(0, 0, 0, 0.2)), color-stop(70%, rgba(0, 0, 0, 0.05)), color-stop(80%, rgba(0, 0, 0, 0.04)), to(rgba(0, 0, 0, 0))) !important;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.2) 5%, rgba(0, 0, 0, 0.05) 70%, rgba(0, 0, 0, 0.04) 80%, rgba(0, 0, 0, 0) 100%) !important;
  z-index: 1;
  width: 100%; }
  @media screen and (max-width: 768px) {
    header {
      -webkit-overflow-scrolling: touch; } }
  header .inner {
    max-width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center; }
    @media screen and (max-width: 768px) {
      header .inner {
        height: 16vw; } }
    @media screen and (max-width: 768px) {
      header .inner {
        padding: 0 5.33333vw; } }
  header .menu {
    position: absolute;
    width: 100%;
    top: 30px;
    left: 30px;
    -webkit-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s; }
    @media screen and (max-width: 768px) {
      header .menu {
        top: 4vw;
        left: 5.33333vw; } }
    header .menu a:hover {
      opacity: 1;
      cursor: pointer; }
  header .gmenu {
    width: 28%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 2;
    position: fixed;
    top: 0;
    left: 0;
    opacity: 0;
    overflow: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
    -webkit-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
    visibility: hidden;
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%); }
    @media screen and (max-width: 768px) {
      header .gmenu {
        width: 100%; } }
    header .gmenu::-webkit-scrollbar {
      display: none; }
    header .gmenu ul {
      width: 80%;
      margin: 0 auto;
      padding: 48px 0 0 48px; }
      @media screen and (max-width: 768px) {
        header .gmenu ul {
          padding: 21.33333vw 0; } }
    header .gmenu ul li ul {
      width: 96%;
      margin: 0 0 0 auto;
      padding: 0; }
    header .gmenu li {
      font-size: 12px; }
      @media screen and (max-width: 768px) {
        header .gmenu li {
          font-size: 2.66667vw; } }
      header .gmenu li:not(:last-child) {
        border-bottom: solid 1px #a3a3a3; }
      header .gmenu li li {
        border-bottom: none !important;
        width: 90%;
        margin: 0 auto;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex; }
        header .gmenu li li::before {
          border-top: solid 1px #a3a3a3;
          content: "";
          width: 2em;
          margin: 1em 1em 0 0; }
        header .gmenu li li a {
          padding: 0 0 32px;
          line-height: 1; }
          @media screen and (max-width: 768px) {
            header .gmenu li li a {
              padding: 0 0 8.53333vw; } }
      @media screen and (max-width: 768px) {
        header .gmenu li {
          width: 100%; } }
      header .gmenu li em {
        font-size: 20px;
        line-height: 1.3;
        display: block;
        font-weight: bold;
        font-style: normal;
        font-family: mamelon, "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif; }
        @media screen and (max-width: 768px) {
          header .gmenu li em {
            font-size: 5.33333vw; } }
      header .gmenu li a {
        display: block;
        padding: 32px 0;
        font-family: roboto-condensed, sans-serif; }
        @media screen and (max-width: 768px) {
          header .gmenu li a {
            width: 64vw;
            margin: 0 auto;
            padding: 8.53333vw 0; } }
  header .open.gmenu {
    opacity: 1 !important;
    -webkit-transition: 0.7s;
    -o-transition: 0.7s;
    transition: 0.7s;
    visibility: visible;
    display: block;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0); }

/*==================================
menu
==================================*/
.menu-trigger, .menu-trigger span {
  display: inline-block;
  -webkit-transition: all .4s;
  -o-transition: all .4s;
  transition: all .4s;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.menu-trigger {
  position: relative;
  width: 22px;
  height: 18px;
  z-index: 3; }

.menu-trigger span {
  position: absolute;
  right: 0;
  width: 100%;
  height: 2px;
  background-color: #fff; }

.menu-trigger span:nth-of-type(1) {
  top: 0; }

.menu-trigger span:nth-of-type(2) {
  top: 8px; }

.menu-trigger span:nth-of-type(3) {
  bottom: 0; }

.menu-trigger span:nth-of-type(1) {
  -webkit-animation: menu-bar01 .75s forwards;
  animation: menu-bar01 .75s forwards; }

@-webkit-keyframes menu-bar01 {
  0% {
    -webkit-transform: translateY(8px) rotate(45deg); }
  50% {
    -webkit-transform: translateY(8px) rotate(0); }
  100% {
    -webkit-transform: translateY(0) rotate(0); } }

@keyframes menu-bar01 {
  0% {
    -webkit-transform: translateY(8px) rotate(45deg);
    transform: translateY(8px) rotate(45deg); }
  50% {
    -webkit-transform: translateY(8px) rotate(0);
    transform: translateY(8px) rotate(0); }
  100% {
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0); } }

.menu-trigger span:nth-of-type(2) {
  -webkit-transition: all .25s .25s;
  -o-transition: all .25s .25s;
  transition: all .25s .25s;
  opacity: 1; }

.menu-trigger span:nth-of-type(3) {
  -webkit-animation: menu-bar02 .75s forwards;
  animation: menu-bar02 .75s forwards; }

@-webkit-keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-8px) rotate(-45deg); }
  50% {
    -webkit-transform: translateY(-8px) rotate(0); }
  100% {
    -webkit-transform: translateY(0) rotate(0); } }

@keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-8px) rotate(-45deg);
    transform: translateY(-8px) rotate(-45deg); }
  50% {
    -webkit-transform: translateY(-8px) rotate(0);
    transform: translateY(-8px) rotate(0); }
  100% {
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0); } }

.active span:nth-of-type(1) {
  -webkit-animation: active-menu-bar01 .75s forwards;
  animation: active-menu-bar01 .75s forwards; }

@-webkit-keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0); }
  50% {
    -webkit-transform: translateY(8px) rotate(0); }
  100% {
    -webkit-transform: translateY(8px) rotate(45deg); } }

@keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0); }
  50% {
    -webkit-transform: translateY(8px) rotate(0);
    transform: translateY(8px) rotate(0); }
  100% {
    -webkit-transform: translateY(8px) rotate(45deg);
    transform: translateY(8px) rotate(45deg); } }

.active span:nth-of-type(2) {
  opacity: 0; }

.active span:nth-of-type(3) {
  -webkit-animation: active-menu-bar03 .75s forwards;
  animation: active-menu-bar03 .75s forwards; }

@-webkit-keyframes active-menu-bar03 {
  0% {
    -webkit-transform: translateY(0) rotate(0); }
  50% {
    -webkit-transform: translateY(-8px) rotate(0); }
  100% {
    -webkit-transform: translateY(-8px) rotate(-45deg); } }

@keyframes active-menu-bar03 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0); }
  50% {
    -webkit-transform: translateY(-8px) rotate(0);
    transform: translateY(-8px) rotate(0); }
  100% {
    -webkit-transform: translateY(-8px) rotate(-45deg);
    transform: translateY(-8px) rotate(-45deg); } }

/* -----------------------------------------------------
	footer
----------------------------------------------------- */
footer {
  background: #FFF;
  color: #29acd8; }
  footer .inner {
    padding: 32px 60px; }
    @media screen and (max-width: 768px) {
      footer .inner {
        padding: 11.73333vw 9.33333vw 10.66667vw; } }
  footer .copyright {
    font-size: 1.4rem;
    text-align: center;
    font-family: roboto-condensed, sans-serif; }
    @media screen and (max-width: 768px) {
      footer .copyright {
        font-size: 2.66667vw; } }

/* -----------------------------------------------------
	br
----------------------------------------------------- */
br.pc {
  display: block; }
  @media screen and (max-width: 768px) {
    br.pc {
      display: none; } }

br.sp {
  display: none; }
  @media screen and (max-width: 768px) {
    br.sp {
      display: block; } }

/* -----------------------------------------------------
	blank
----------------------------------------------------- */
.blank {
  position: relative; }
  .blank::after {
    content: '';
    display: inline-block;
    width: 14px;
    height: 14px;
    background-image: url(/common/images/icon_blank.png);
    background-size: contain;
    vertical-align: middle;
    margin-bottom: 5px;
    margin-left: 8px; }
    @media screen and (max-width: 768px) {
      .blank::after {
        width: 3.73333vw;
        height: 3.73333vw;
        margin-left: 2.13333vw; } }

/* -----------------------------------------------------
	言語切り替えガジェット
----------------------------------------------------- */
/*.selectWrap {
  display: none;
}*/
