html {
  font-size: 49.6%;
}

body {
  background-color: #fff;
}

#container {
  background-color: #fff;
  overflow: hidden;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: 500;
}

.pc-only {
  display: none !important;
}

/* common-header */
#common-header {
  padding-left: 15px;
  margin-top: 20px;
}

#common-header .left {
  display: block;
}

#common-header .logo {
  width: 52%;
  min-width: 150px;
}

#common-header .logo picture {
  width: 100%;
}

#common-header .left .nav {
  display: none;
}

#common-header .right {
  display: none;
}

/* common footer */
#common-footer {
  width: 100%;
  margin: auto;
  padding-left: 20px;
  padding-right: 20px; 
  margin-top: 80px;
}

#common-footer .external-link {
  height: 50px;
/*  border-top: 3px solid #a5a5a6; */
  border-bottom: 3px solid #a5a5a6;
}

#common-footer .content {
  display: flex;
  margin-top: 40px;
  justify-content: space-between;
}

#common-footer .list ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  margin-bottom: 30px;
  gap: 15px 20px;
}

#common-footer .list ul li {
  font-size: 1.7rem;
  font-weight: 600;
  letter-spacing: 0.2rem;
  color: #A5A5A6;
}

#common-footer .list ul li.sub {
  font-size: 1.4rem;
  font-weight: 600;
}

#common-footer .list ul li a {
  color: #A5A5A6;
}

#common-footer .icon {
  margin-top: 15px;
}

#common-footer .icon ul {
  list-style: none;
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 0px 30px;
}

/* Twitter */
#common-footer .icon ul li:nth-of-type(1) {
  width: calc(29px * 0.9);
}

/* Instagram */
#common-footer .icon ul li:nth-of-type(2) {
  width: calc(25.6px * 0.9);
}

/* Contest */
#common-footer .icon ul li:nth-of-type(3) {
  width: calc(168px * 0.7);
  margin-left: 20px;
}

#common-footer .logo {
  width: 70px;
  margin: auto;
  margin-top: 60px;
}

#common-footer .logo img {
  width: 100%;
}

#common-footer .copyright {
  font-size: 1.5rem;
  font-weight: 500;
  color: #A5A5A6;
  text-align: center;
  margin-top: 25px;
  padding-bottom: 15px;
}

/* common section */
.common-section .inner {
  position: relative;
  width: 100%;
  margin: auto;
  padding-left: 20px;
  padding-right: 20px; 
}

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

.common-section .inner .heading .text {
  position: relative;
  width: 55%;
}

.common-section .inner .heading .text .arch {
  position: absolute;
  top: -8vw;
  left: 50%;
  transform: translate(-50%, 0);
  width: 90%;
}

.common-section .inner .heading h2 {
  font-size: 2.4rem;
  font-weight: 600;
  letter-spacing: 1rem;
  color: #687A87;
  text-align: center;
  padding-left: 12px;
}

.common-section .inner .heading .h-line {
  width: 25%;
  display: block;
  height: 2px;
  background-color: #A5A5A6;
}

/* sp menu */
.global-menu-wrap * {
  margin: 0;
  padding: 0;
}

.global-menu-trigger-wrap {
  position: fixed;
  z-index: 999;
  top: 5vw;
  right: 5vw;
  padding: 15px 15px 15px 15px;
  margin: -15px -15px -15px -15px;
}

.global-menu-trigger, .global-menu-trigger span {
  display: inline-block;
  box-sizing: border-box;
  transition: all .3s;
}

.global-menu-trigger {
  position: relative;
  width: 7.7vw;
}

.global-menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1vw;
  background-color: #A5A5A6;
  border-radius: 4px;
}

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

.global-menu-trigger span:nth-of-type(2) {
  bottom: 1.3vw;
}

.global-menu-trigger.active span:nth-of-type(1) {
  transform: translateY(-1.8vw) rotate(-45deg); 
}

.global-menu-trigger.active span:nth-of-type(2) {
  transform: translateY(1.8vw) rotate(45deg); 
}

.global-menu {
  width: 100%;
  height: 100%;
  z-index: 90;
  position: fixed;
  top: 0;
  left: 0;
  background-color: #fff;
  overflow: scroll;
}

.global-menu-footer .logo {
  width: 70px;
  margin: auto;
  margin-top: 60px;
  margin-bottom: 15px;
}

.global-menu-footer .logo img {
  width: 100%;
}

.global-menu .global-menu-header {
  display: block;
  margin-top: 20px;
  padding-left: 15px;
  padding-right: 15px;
}

.global-menu .global-menu-header .inner {
  border-bottom: 2px solid #A5A5A6;
  padding-bottom: 2vw;
}

.global-menu .global-menu-header .logo {
  width: 52%;
  min-width: 150px;
}

.global-menu .global-menu-content {
  position: relative;
  width: 100%;
  background-color: #fff;
  padding-left: 15px;
  padding-right: 15px
}

#sp-nav-menu ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#sp-nav-menu li {
  width: 100%;
  border-bottom: 1px solid #A5A5A6;
  padding-left: 15px;
}

#sp-nav-menu li.sub {
  display: none;
}

#sp-nav-menu li.sub.open {
  display: block;
}

#sp-nav-menu li.sub a {
  font-size: 1.7rem;
  padding-left: 15px;
}

#sp-nav-menu li a {
  height: 50px;
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: flex-start;
  font-family: 'Kosugi Maru', sans-serif;
  font-size: 1.9rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
  background-color: #fff;
  color: #A5A5A6;
  padding-top: 10px;
  padding-bottom: 10px;
}

#sp-nav-menu li p {
  height: 50px;
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: flex-start;
  font-family: 'Kosugi Maru', sans-serif;
  font-size: 1.9rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
  background-color: #fff;
  color: #A5A5A6;
  padding-top: 10px;
  padding-bottom: 10px;
}

#sp-nav-menu li.sub-parent a img.open {
  transform: rotate(180deg);
}

#sp-nav-menu li.sub-parent p img.open {
  transform: rotate(180deg);
}

#sp-nav-menu li.sub-parent a {
  justify-content: space-between;
}

#sp-nav-menu li.sub-parent p {
  justify-content: space-between;
}

#sp-nav-menu li.sub-parent a img {
  width: 25px;
  margin-right: 10px;
}

#sp-nav-menu li.sub-parent p img {
  width: 25px;
  margin-right: 10px;
}

#sp-nav-menu li img.email-icon {
  width: 25px;
  margin-right: 10px;
}

#sp-nav-menu li.selected {
  border-top: 0px;
}

#sp-nav-menu li.selected>a {
  background-color: #fff;
  color: #A5A5A6;
}

#sp-nav-menu li .font-small {
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
  margin-left: 10px;
}

.global-menu-content .icon {
  margin-top: 20px;
}

.global-menu-content .icon ul {
  list-style: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0px 20px;
}

/* Twitter */
.global-menu-content .icon ul li:nth-of-type(1) {
  width: calc(29px * 0.9);
}

/* Instagram */
.global-menu-content .icon ul li:nth-of-type(2) {
  width: calc(25.6px * 0.9);
}

.global-menu-footer {
  margin-top: 5vh;
}

.global-menu-footer .logo02 {
  width: 32.3%;
  max-width: 20vh;
  margin: auto;
  margin-top: 2vh;
}

.global-menu-footer .sns {
  display: flex;
  justify-content: center;
  margin-top: 2vh;
}

.global-menu-footer .sns div {
  width: 9.3%;
  max-width: 6vh;
}

.global-menu-footer .sns .twitter {
  margin-right: 3.2%;
}

.global-menu-footer .sns .instagram {
  margin-left: 3.2%;
}

.global-menu-footer .sns img {
  width: 100%;
}

@media screen and (min-width: 530px) and (max-width: 960px) {
  #sp-nav-menu li a {
    height: 13vw;
    max-height: 8vh;
    font-size: 2.5vw;
    line-height: 3vw;
    letter-spacing: 0.6vw;
  }

  #sp-nav-menu li:nth-of-type(5)>a {
    height: 16vw;
  }
}