/* Wrapper */
.l-wrapper {
  position: relative; }

/* Header */
.l-header {
  padding-top: calc(100*50vw/375); }

@media print, screen and (min-width: 768px) {
  .l-header {
    padding-top: calc(768*50px/375); } }
@media print, screen and (min-width: 1320px) {
  .l-header {
    display: grid;
    grid-template-columns: 1fr auto 240px 280px;
    gap: 10px 20px;
    padding: 0 20px 10px;
    position: relative;
    width: auto;
    height: auto; } }
.l-header-in {
  padding: calc(100*10vw/375);
  height: calc(100*50vw/375);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%; }

@media print, screen and (min-width: 768px) {
  .l-header-in {
    padding: calc(768*10px/375);
    height: calc(768*50px/375); } }
@media print, screen and (min-width: 1320px) {
  .l-header-in {
    display: contents; } }
/* Header Logo */
.l-header__logo {
  position: relative;
  z-index: 100; }

.l-header__logo-img {
  width: auto;
  height: calc(100*30vw/375); }

@media print, screen and (min-width: 768px) {
  .l-header__logo-img {
    height: calc(768*30px/375); } }
@media print, screen and (min-width: 1320px) {
  .l-header__logo {
    margin-top: 15px;
    grid-row: 1;
    grid-column: 1; }

  .l-header__logo-img {
    height: 46px; } }
/* Gnavi Btn */
.l-gnavi-btn {
  background: url("../images/common/cmn-ico16.svg") no-repeat center/contain;
  margin-left: auto;
  position: fixed;
  top: calc(100*10vw/375);
  right: calc(100*10vw/375);
  width: calc(100*37vw/375);
  height: calc(100*31vw/375);
  z-index: 100;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden; }

.l-member-gnavi-btn {
  background-image: url("../images/member/common/cmn-ico16.svg"); }

@media print, screen and (min-width: 768px) {
  .l-gnavi-btn {
    top: calc(768*10px/375);
    right: calc(768*10px/375);
    width: calc(768*37px/375);
    height: calc(768*31px/375); } }
@media print, screen and (min-width: 1320px) {
  .l-gnavi-btn {
    display: none; } }
/* Gnavi */
.l-gnavi__link,
.l-gnavi__child-link {
  text-decoration: none; }

.l-gnavi__link {
  font-weight: 500; }

@keyframes gnavi-open {
  0% {
    opacity: 0;
    visibility: visible; }
  100% {
    opacity: 1;
    visibility: visible; } }
@keyframes gnavi-close {
  0% {
    opacity: 1;
    visibility: visible; }
  100% {
    opacity: 0;
    visibility: hidden; } }
@media screen and (max-width: 1319px) {
  .l-gnavi {
    background: #e8f2f1;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: 100vh;
    height: 100dvh;
    font-size: calc(768*1.4rem/375);
    padding-top: calc(768*50px/375);
    z-index: 99;
    opacity: 0;
    visibility: hidden; }

  .l-member-gnavi {
    background: #f2f5fb; }

  .is-gnavi-open {
    overflow: hidden; }
    .is-gnavi-open .l-header-in {
      box-sizing: border-box;
      position: fixed;
      width: 100%;
      z-index: 100; }
    .is-gnavi-open .l-gnavi {
      opacity: 1;
      visibility: visible;
      animation: gnavi-open .2s ease forwards; }

  .is-gnavi-close .l-gnavi {
    opacity: 0;
    visibility: hidden;
    animation: gnavi-close .2s ease forwards; }

  .l-gnavi__scroll {
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    padding: calc(768*30px/375) calc(768*10px/375) calc(768*40px/375); }

  .l-gnavi__list {
    border-bottom: calc(768*1px/375) solid #1d8073; }

  .l-gnavi__item {
    border-top: calc(768*1px/375) solid #1d8073;
    position: relative; }

  .l-member-gnavi__list {
    border-bottom-color: #385aa7; }

  .l-member-gnavi__item {
    border-top-color: #385aa7; }

  .l-gnavi__link {
    padding: calc(768*12px/375) calc(768*32px/375) calc(768*12px/375) calc(768*8px/375);
    display: flex; }
    .l-gnavi__link::before {
      background: url(../images/common/cmn-ico08.svg) no-repeat center/42.85%;
      content: "";
      display: block;
      margin-right: calc(768*4px/375);
      width: 1em;
      height: 1.6em; }

  .l-gnavi__link-home::before {
    background-image: url(../images/common/cmn-ico01-m.svg); }

  .l-member-gnavi__link::before {
    background-image: url(../images/member/common/cmn-ico08.svg); }

  .l-gnavi__child-btn {
    display: block;
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
    width: calc(768*32px/375);
    height: 3.3142em;
    z-index: 1;
    text-indent: 200%;
    white-space: nowrap;
    overflow: hidden; }
    .l-gnavi__child-btn::before, .l-gnavi__child-btn::after {
      background: #1d8073;
      content: '';
      position: absolute;
      top: 50%;
      right: calc(768*10px/375);
      width: calc(768*12px/375);
      height: calc(768*1px/375);
      transition: rotate .3s ease; }
    .l-gnavi__child-btn::before {
      transform: rotate(90deg); }
    .l-gnavi__child-btn.is-open::before {
      transform: rotate(180deg); }

  .l-member-gnavi__child-btn::before, .l-member-gnavi__child-btn::after {
    background: #385aa7; }

  .l-gnavi__child-list {
    display: none;
    margin-left: calc(768*24px/375); }

  .l-gnavi__child-item {
    border-top: calc(768*1px/375) dashed #1d8073; }
    .l-gnavi__child-item ul {
      margin: 0 !important; }
      .l-gnavi__child-item ul li::marker {
        content: none !important; }

  .l-member-gnavi__child-item {
    border-top-color: #385aa7; }

  .l-gnavi__child-link {
    display: block;
    padding: calc(768*9px/375) calc(768*32px/375) calc(768*9px/375) calc(768*8px/375); } }
@media screen and (max-width: 767px) {
  .l-gnavi {
    font-size: calc(100*14vw/375);
    padding-top: calc(100*50vw/375); }

  .l-gnavi__scroll {
    padding: calc(100*30vw/375) calc(100*10vw/375) calc(100*40vw/375); }

  .l-gnavi__list {
    border-bottom-width: calc(100*1vw/375); }

  .l-gnavi__item {
    border-top-width: calc(100*1vw/375); }

  .l-gnavi__link {
    padding: calc(100*12vw/375) calc(100*32vw/375) calc(100*12vw/375) calc(100*8vw/375); }
    .l-gnavi__link::before {
      margin-right: calc(100*4vw/375); }

  .l-gnavi__child-btn {
    width: calc(100*32vw/375); }
    .l-gnavi__child-btn::before, .l-gnavi__child-btn::after {
      right: calc(100*10vw/375);
      width: calc(100*12vw/375);
      height: calc(100*1vw/375); }

  .l-gnavi__child-list {
    margin-left: calc(100*24vw/375); }

  .l-gnavi__child-item {
    border-top-width: calc(100*1vw/375); }
    .l-gnavi__child-item ul {
      margin: 0 !important; }
      .l-gnavi__child-item ul li::marker {
        content: none !important; }

  .l-gnavi__child-link {
    padding: calc(100*9vw/375) calc(100*32vw/375) calc(100*9vw/375) calc(100*8vw/375); } }
@media print, screen and (min-width: 1320px) {
  .l-gnavi,
  .l-gnavi__scroll {
    display: contents; }

  .l-gnavi__list {
    background: #1d8073;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 110px;
    height: 70px;
    grid-row: 3;
    grid-column: 1/5; }

  .l-member-gnavi__list {
    background: #385aa7;
    gap: 0 72px; }

  .l-gnavi__item {
    display: flex;
    justify-content: center;
    height: 100%; }

  .l-gnavi__link {
    color: #fff;
    font-size: 1.6rem;
    line-height: 1.5;
    text-align: center;
    display: flex;
    align-items: center; }

  .l-gnavi__link-home {
    border: 1px solid #fff;
    border-radius: 100px;
    padding: 6px 12px;
    transition: background .3s ease; }
    .l-gnavi__link-home::before {
      background-image: url(../images/common/cmn-ico01-w.svg); }

  .l-gnavi__child-btn {
    display: none; }

  .l-gnavi__item {
    position: relative; }
    .l-gnavi__item:hover > .l-gnavi__child-list {
      visibility: visible;
      opacity: 1;
      transform: translateY(6px);
      transition: .3s; }
    .l-gnavi__item:hover > .l-gnavi__link:after {
      opacity: 1; }

  .l-gnavi__item-home:hover > .l-gnavi__link:after {
    opacity: 0; }
  .l-gnavi__item-home:hover .l-gnavi__link-home {
    background: rgba(113, 156, 255, 0.5); }

  .l-gnavi__link {
    position: relative; }
    .l-gnavi__link:after {
      background: #32d2bc;
      border-radius: 3px;
      content: "";
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 4px;
      opacity: 0;
      pointer-events: none;
      transition: opacity .3s ease; }

  .l-member-gnavi__link:after {
    background: #719cff; }

  .l-gnavi__child-list {
    background: #e8f2f1;
    border-radius: 10px;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: max-content;
    transition: 0s;
    z-index: 9999;
    padding: 8px 16px;
    visibility: hidden;
    opacity: 0;
    transform: translateY(0); }
    .l-gnavi__child-list:after {
      content: "";
      position: absolute;
      top: -6px;
      left: 0;
      width: 100%;
      height: 6px; }

  .l-member-gnavi__child-list {
    background: #f2f5fb; }

  .l-gnavi__child-item {
    padding: 7px 0; }
    .l-gnavi__child-item ul {
      margin: 7px 0 0 !important; }
      .l-gnavi__child-item ul li::marker {
        content: none !important; }

  .l-gnavi__child-link {
    font-size: 1.4rem;
    line-height: 1.4;
    font-weight: 500;
    display: flex; }
    .l-gnavi__child-link::before {
      background: url(../images/common/cmn-ico08.svg) no-repeat center;
      content: "";
      display: block;
      margin-right: 4px;
      width: 1em;
      height: 1.6em; }
    .l-gnavi__child-link:hover {
      text-decoration: underline; }

  .l-member-gnavi__child-link::before {
    background: url(../images/member/common/cmn-ico08.svg) no-repeat center; } }
/* Gnavi Search */
.l-gnavi__search {
  margin: calc(100*20vw/375) calc(100*18vw/375) 0; }

.l-gnavi__search-form {
  position: relative;
  line-height: 0; }

.l-gnavi__search-input {
  background: #fff;
  border: calc(100*1vw/375) solid #1d8073;
  border-radius: calc(100*100vw/375);
  font-size: calc(100*16vw/375);
  font-weight: 500;
  padding: 0 calc(100*32vw/375) 0 calc(100*20vw/375);
  width: 100%;
  height: calc(100*32vw/375);
  line-height: calc(100*32vw/375); }

.l-gnavi__search-button {
  background: url(../images/common/cmn-ico04.svg) no-repeat left center/56.25%;
  display: grid;
  place-items: center;
  position: absolute;
  top: 0;
  right: 0;
  width: calc(100*32vw/375);
  height: calc(100*32vw/375);
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden; }

@media print, screen and (min-width: 768px) {
  .l-gnavi__search {
    margin: calc(768*20px/375) calc(768*18px/375) 0; }

  .l-gnavi__search-input {
    border: calc(768*1px/375) solid #1d8073;
    border-radius: calc(768*100px/375);
    font-size: calc(768*1.6rem/375);
    padding: 0 calc(768*32px/375) 0 calc(768*20px/375);
    height: calc(768*32px/375);
    line-height: calc(768*32px/375); }

  .l-gnavi__search-button {
    width: calc(768*32px/375);
    height: calc(768*32px/375); } }
@media print, screen and (min-width: 1320px) {
  .l-gnavi__search {
    margin: 20px 0 0;
    grid-row: 1;
    grid-column: 3; }

  .l-gnavi__search-input {
    border: 1px solid #1d8073;
    border-radius: 100px;
    font-size: 1.4rem;
    padding: 0 30px 0 20px;
    height: 30px;
    line-height: 30px; }

  .l-gnavi__search-button {
    width: 30px;
    height: 30px; } }
/* Gnavi Sub */
.l-gnavi-sub {
  display: flex;
  flex-wrap: wrap;
  gap: calc(100*12vw/375) 0;
  margin-top: calc(100*14vw/375);
  padding: 0 calc(100*10vw/375); }

.l-gnavi-sub__item {
  width: 50%; }

.l-gnavi-sub__link {
  font-weight: 500;
  text-decoration: none; }

@media print, screen and (min-width: 768px) {
  .l-gnavi-sub {
    gap: calc(768*12px/375) 0;
    margin-top: calc(768*14px/375);
    padding: 0 calc(768*10px/375); } }
@media print, screen and (min-width: 1320px) {
  .l-gnavi-sub {
    gap: 0 24px;
    justify-content: end;
    margin-top: 25px;
    padding: 0;
    grid-row: 1;
    grid-column: 2; }

  .l-gnavi-sub__item {
    width: auto; }

  .l-gnavi-sub__link {
    font-size: 1.4rem; }
    .l-gnavi-sub__link:hover {
      text-decoration: underline; } }
/* Gnavi Info */
.l-gnavi-info {
  columns: 2;
  gap: 0;
  column-rule: calc(100*1vw/375) solid #1d8073;
  border-top: calc(100*1vw/375) solid #1d8073;
  border-bottom: calc(100*1vw/375) solid #1d8073;
  margin-top: calc(100*20vw/375);
  padding: calc(100*4vw/375) 0; }

.l-gnavi-info__item {
  text-align: center;
  padding: calc(100*5vw/375) 0; }

.l-gnavi-info__link {
  font-weight: 500;
  text-decoration: none; }

@media print, screen and (min-width: 768px) {
  .l-gnavi-info {
    column-rule: calc(768*1px/375) solid #1d8073;
    border-top: calc(768*1px/375) solid #1d8073;
    border-bottom: calc(768*1px/375) solid #1d8073;
    margin-top: calc(768*20px/375);
    padding: calc(768*4px/375) 0; }

  .l-gnavi-info__item {
    padding: calc(768*5px/375) 0; } }
@media print, screen and (min-width: 1320px) {
  .l-gnavi-info {
    background: #e8f2f1;
    border: none;
    border-radius: 0 0 10px 10px;
    display: flex;
    height: 50px;
    margin: 0;
    padding: 0;
    overflow: hidden;
    grid-row: 1;
    grid-column: 4; }

  .l-gnavi-info__item {
    padding: 0;
    width: 50%; }
    .l-gnavi-info__item:nth-child(2) {
      position: relative; }
      .l-gnavi-info__item:nth-child(2)::before {
        content: "";
        position: absolute;
        top: 15px;
        bottom: 15px;
        left: 0;
        border-left: 1px dashed #1d8073; }

  .l-gnavi-info__link {
    font-size: 1.4rem;
    padding: 15px 0;
    transition: background .2s ease; }
    .l-gnavi-info__link:hover {
      background: #1d8073;
      color: #fff; }

  .l-gnavi-info__link.c-icon__english:hover::before {
    background-image: url(../images/common/cmn-ico05-on.svg); }

  .l-gnavi-info__link.c-icon__members:hover::before {
    background-image: url(../images/common/cmn-ico06-on.svg); } }
/* Main */
.l-main {
  padding-top: calc(100*8vw/375);
  margin-bottom: calc(100*40vw/375); }

@media print, screen and (min-width: 768px) {
  .l-main {
    padding-top: 10px;
    margin-bottom: 100px; } }
/* Footer */
.l-footer {
  background: #f5f5f5; }

.l-footer-in {
  padding-top: calc(100*30vw/375);
  padding-bottom: calc(100*30vw/375); }

.l-footer__btn {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: calc(100*220vw/375);
  height: calc(100*34vw/375);
  padding-left: calc(100*14vw/375);
  margin-bottom: calc(100*20vw/375);
  border-radius: calc(100*5vw/375);
  border: calc(100*1vw/375) solid #1d8073;
  color: #1d8073;
  font-size: calc(100*14vw/375);
  font-weight: 700;
  position: relative;
  cursor: pointer; }
  .l-footer__btn::before, .l-footer__btn::after {
    content: "";
    width: calc(100*12vw/375);
    height: calc(100*1vw/375);
    background: #1d8073;
    transition: transform .4s ease;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: calc(100*12vw/375); }
  .l-footer__btn::after {
    transform: translateY(-50%) rotate(90deg); }
  .l-footer__btn.is-open::after {
    transform: translateY(-50%) rotate(-180deg); }

@media print, screen and (min-width: 768px) {
  .l-footer-in {
    padding-top: 60px;
    padding-bottom: 20px; }

  .l-footer__btn {
    width: 220px;
    height: 34px;
    padding-left: 14px;
    margin-bottom: 30px;
    border-radius: 5px;
    font-size: 14px;
    border-width: 1px; }
    .l-footer__btn::before, .l-footer__btn::after {
      width: 12px;
      height: 1px;
      right: 12px; } }
/* Footer Bnrs */
.l-footer-bnrs {
  display: flex;
  flex-wrap: wrap;
  gap: calc(100*13vw/375) calc(100*15vw/375);
  height: 0;
  overflow: hidden;
  transition: height .4s ease-in-out; }

.l-footer-bnrs__item {
  width: calc((100% - (100*15vw/375))/2); }

.l-footer-bnrs__img {
  border: calc(100*1vw/375) solid #e5e5e5;
  border-radius: calc(100*4vw/375);
  overflow: hidden;
  width: 100%; }

@media print, screen and (min-width: 768px) {
  .l-footer-bnrs {
    display: flex;
    justify-content: center;
    gap: 10px; }

  .l-footer-bnrs__item {
    width: 248px; }

  .l-footer-bnrs__img {
    border: 1px solid #e5e5e5;
    border-radius: 4px;
    transition: opacity .3s ease; }
    .l-footer-bnrs__img:hover {
      opacity: .7; } }
/* Footer Nav */
.l-footer-nav-group {
  display: none; }

@media print, screen and (min-width: 768px) {
  .l-footer-nav-group {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    margin: 60px 0 40px; }

  .l-footer-nav {
    border-left: 1px solid #e8e8e8;
    padding: 0 20px;
    width: calc(50% - 24px); }

  .l-footer-nav__item {
    line-height: 1; }
    .l-footer-nav__item:not(:last-child) {
      margin-bottom: 18px; }

  .l-footer-nav__child {
    margin-top: 1em; }

  .l-footer-nav__child-item {
    padding: 4px 0; }

  .l-footer-nav__link,
  .l-footer-nav__child-link {
    font-size: 1.4rem;
    line-height: 1.4;
    text-decoration: none; }
    .l-footer-nav__link:hover,
    .l-footer-nav__child-link:hover {
      text-decoration: underline; }

  .l-footer-nav__link {
    color: #1d8073;
    font-weight: 700; }

  .l-member-footer-nav__link {
    color: #385aa7; } }
@media print, screen and (min-width: 1000px) {
  .l-footer-nav-group {
    border-right: 1px solid #e8e8e8;
    display: grid;
    grid-template-columns: min(38vw,430px) repeat(3, minmax(min-content,280px));
    gap: 24px 0; }

  .l-footer-nav {
    width: auto; } }
/* Footer Subnav */
.l-footer-subnav {
  display: none; }

@media print, screen and (min-width: 768px) {
  .l-footer-subnav {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px 40px;
    margin-bottom: 40px; }

  .l-footer-subnav__link {
    font-size: 1.4rem;
    font-weight: 500;
    text-decoration: none; }
    .l-footer-subnav__link:hover {
      text-decoration: underline; } }
@media print, screen and (min-width: 1000px) {
  .l-footer-subnav {
    justify-content: flex-end; } }
/* Footer Info */
.l-footer-info {
  margin-top: calc(100*20vw/375); }

.l-footer-info__logo {
  margin-bottom: calc(100*10vw/375); }

.l-footer-info__logo-img {
  width: auto;
  height: calc(100*46vw/375); }

.l-footer-info__address {
  font-size: calc(100*10vw/375); }

.l-footer-info__address-tit {
  font-weight: inherit; }

.l-footer-info__address-postal {
  margin-right: 1em; }

.l-footer-info__address-tel {
  margin-right: 2em; }

@media print, screen and (min-width: 768px) {
  .l-footer-info {
    margin-top: 0; }

  .l-footer-info__logo {
    margin-bottom: 10px; }

  .l-footer-info__logo-img {
    height: 46px; }

  .l-footer-info {
    border-top: 1px solid #e8e8e8;
    display: flex;
    gap: 0 min(2.60416vw,40px);
    padding-top: 20px; }

  .l-footer-info__address {
    font-size: 1.4rem;
    line-height: 1.4; } }
/* Footer Copy */
.l-footer-copy {
  background: #1d8073;
  color: #fff;
  display: block;
  font-size: calc(100*13vw/375);
  font-weight: 500;
  height: calc(100*40vw/375);
  line-height: calc(100*40vw/375);
  text-align: center; }

.l-member-footer-copy {
  background: #385aa7; }

@media print, screen and (min-width: 768px) {
  .l-footer-copy {
    font-size: 1.3rem;
    height: 40px;
    line-height: 40px; } }
