@charset "UTF-8";

/* ==== color ========================== */
:root {
  --en: "Montserrat", sans-serif;
  --ja: "BIZ UDPGothic", sans-serif;

  /* fs */
  /* e-ttl */
  --lv1-e-ttl: 7.2rem;
  --lv2-e-ttl: 6.4rem;
  --lv3-e-ttl: 5.6rem;
  --lv4-e-ttl: 4.8rem;
  --lv5-e-ttl: 4rem;
  --lv6-e-ttl: 3.2rem;

  /* j-ttl */
  --lv1-j-ttl: 5rem;
  --lv2-j-ttl: 4.4rem;
  --lv3-j-ttl: 3.6rem;
  --lv4-j-ttl: 2.8rem;
  --lv5-j-ttl: 2.4rem;
  --lv6-j-ttl: 2rem;

  /* lead */
  --lead-l: 2.6rem;
  --lead-m: 2.4rem;
  --lead-s: 2.2rem;

  /* p */
  --p-l: 1.8rem;
  --p-m: 1.6rem;
  --p-s: 1.4rem;
  --p-ss: 1.2rem;

  --t-black: #000000;
  --t-white: #ffffff;
  --t-blue: #10386B;
  --t-blue2: #2C7BBF;
  --t-green: #006E38;
  --t-green2: #3BAA6C;

  --t-gray1: #333333;
  --t-gray2: #727272;
  --t-gray3: #CFCFCF;
  --t-gray4: #EFEFEF;

  --a-1: #6D4C91;
  --a-2: #4A4A4A;
  --a-3: #FF7A59;
  --a-4: #F2C94C;

  --t-bg: #F9FAFB;
}


/*================================================
 *  一般・共通設定
 ================================================*/
html {
  /* font-size: 10px; */
  font-size: 62.5%;
  scroll-behavior: smooth;
  font-family: var(--ja);
  color: var(--t-black);
  font-weight: 400;
  background: var(--t-bg);
  line-height: 1.9;
}

* {
  letter-spacing: 0.08em;
}

body {
  font-size: var(--p-m);
}

body.hidden {
  overflow: hidden;
}


a {
  text-decoration: none;
  transition: all .4s;
}

a:hover {
  opacity: 1;
}

img {
  max-width: 100%;
  display: inline-block;
}

strong {
  font-weight: bold;
}

small {
  font-size: smaller;
}

ul,
ol,
dl {
  margin: 0;
}

ul li {
  list-style: none;
}

ol li {
  list-style: decimal;
}

li {
  margin-left: 0;
}


@media screen and (max-width:1023px) {}

/*================================================
 *  ttl
 ================================================*/
.--ja {
  font-family: var(--ja);
}

.--en {
  font-family: var(--en);
}

/* j-ttl */
.lv1-j-ttl {
  font-size: var(--lv1-j-ttl);
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.1em;
}

.lv2-j-ttl {
  font-size: var(--lv2-j-ttl);
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.1em;
}

.lv3-j-ttl {
  font-size: var(--lv3-j-ttl);
  font-weight: 700;
  line-height: 1.9;
  letter-spacing: 0.1em;
}

.lv4-j-ttl {
  font-size: var(--lv4-j-ttl);
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.1em;
}

.lv5-j-ttl {
  font-size: var(--lv5-j-ttl);
  font-weight: 700;
  line-height: 1.9;
  letter-spacing: 0.1em;
}

.lv6-j-ttl {
  font-size: var(--lv6-j-ttl);
  font-weight: 700;
  line-height: 1.9;
  letter-spacing: 0.1em;
}

/* e-ttl */
.lv1-e-ttl {
  font-size: var(--lv1-e-ttl);
  font-family: var(--en);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

.lv2-e-ttl {
  font-size: var(--lv2-e-ttl);
  font-family: var(--en);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

.lv3-e-ttl {
  font-size: var(--lv3-e-ttl);
  font-family: var(--en);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

.lv4-e-ttl {
  font-size: var(--lv4-e-ttl);
  font-family: var(--en);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

.lv5-e-ttl {
  font-size: var(--lv5-e-ttl);
  font-family: var(--en);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

.lv6-e-ttl {
  font-size: var(--lv6-e-ttl);
  font-family: var(--en);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
}


.t_blue {
  color: var(--t-blue);
}

.t_green {
  color: var(--t-green);
}

.en {
  font-family: var(--en);
  font-weight: 700;
}

.hd {
  font-weight: 700;
  margin-bottom: 4rem;
}

.hd.sp_l {
  margin-bottom: 6rem;
}

.hd.center {
  text-align: center;
}

.hd .en {
  font-family: var(--en);
  color: var(--t-green2);
  font-size: 2.4rem;
  letter-spacing: 0.02em;
  display: block;
  margin-bottom: 1rem;
}

.hd .ja {
  color: var(--t-blue);
  font-size: var(--lv3-j-ttl);
  display: block;
  letter-spacing: 0.1em;
}

@media screen and (max-width:1023px) {
  .hd {
    margin-bottom: 1.8rem;
  }

  .hd.sp_l {
    margin-bottom: 3rem;
  }

  .hd .en {
    margin-bottom: 2rem;
  }

  .hd .ja {
    font-size: var(--lv4-j-ttl);
    line-height: 1.7;
  }

  .hd.sp_l .ja {
    font-size: var(--lv3-j-ttl);
  }


  .lv2-j-ttl {
    font-size: var(--lv3-j-ttl);
  }
}

/*================================================
 *  section btn
 ================================================*/
section {
  position: relative;
  padding-bottom: 12.9rem;
}

.section {
  padding-top: 13.9rem;
}


.bg_wt {
  background: var(--t-white);
}

.bg_gy {
  background: var(--t-gray4);
}

.bg_wt-grad {
  background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}

.bg_radius {
  border-radius: 0 11.7rem 0 11.7rem;
}

.bg_all-radius {
  border-radius: 11.7rem 11.7rem;
}

.bg_top-radius {
  border-radius: 11.7rem 11.7rem 0 0;
}


.wrap--lg {
  /* width: 14.32rem; */
  width: 94.7%;
  margin-left: auto;
  margin-right: auto;
  min-width: 1000px;
}

.wrap--md {
  /* width: 1248px; */
  width: 82.67%;
  margin-left: auto;
  margin-right: auto;
  min-width: 1000px;
}

.wrap--sm {
  /* width: 1132px; */
  width: 74.8672%;
  margin-left: auto;
  margin-right: auto;
  min-width: 1000px;
}

.wrap--ss {
  /* width: 1068px; */
  width: 70.63%;
  margin-left: auto;
  margin-right: auto;
  min-width: 1000px;
}

.icon {
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: top;
  display: inline-block;
  width: 3rem;
  height: 3rem;
}

.icon_dl {
  background-image: url(../images/icon_dl.png);
}

.icon_mail {
  background-image: url(../images/icon_mail.png);
}

.icon_blank {
  background-image: url(../images/icon_blank.png);
}

.icon_blank.blue {
  background-image: url(../images/icon_blank_b.png);
}

.icon_insta {
  background-image: url(../images/icon_insta.png);
}

.icon_tel {
  background-image: url(../images/icon_tel.png);
}


.c_btn {
  display: flex;
  align-items: anchor-center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: var(--p-m);
  color: var(--t-white);
  font-weight: 400;
  background: var(--t-blue);
  border-radius: 1000px;
  padding: 1.6rem 2rem 1.6rem 3.2rem;
  line-height: 1.7;
  transition: .4s;
  gap: 0 1rem;
}

.center .c_btn {
  margin-left: auto;
  margin-right: auto;
}

.right .c_btn {
  margin-left: auto;
  margin-right: 0;
}

.c_btn.wt {
  background: var(--t-white);
  color: var(--t-blue);
}


.c_btn:hover {
  background: var(--t-white);
  color: var(--t-blue);
}

.c_btn.wt:hover {
  color: var(--t-white);
  background: var(--t-blue);
}


.c_btn-l {
  width: 32.4rem;
  justify-content: space-between;
}


/* grad_btn */

.grad_btn {
  line-height: 1;
  display: flex;
  align-items: center;
  color: var(--t-white);
  font-weight: 700;
  border-radius: 2.4rem;
  position: relative;
  border: 1px solid var(--t-white);
  padding-right: 1.6rem;
  padding-left: 2.4rem;
  z-index: 1;

  height: 7.2rem;
  width: 30rem;
  background: linear-gradient(180deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
  box-shadow: 0 0 0.8rem 0 rgb(16 56 107 / 30%);
}


.grad_btn::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 2.4rem;
  opacity: 0;
  transition: .4s;
  top: 0;
  left: 0;
  z-index: -1;
  background: linear-gradient(0deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
}

.grad_btn:hover::before {
  opacity: 1;
}

.grad_btn span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}


.center .grad_btn {
  margin: 0 auto;
}

/* c_nml-link */

.c_nml-link {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 2.4rem;
  color: var(--t-blue);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: 700;
}




.c_nml-link.lg {
  font-size: var(--lv4-j-ttl);
}


.c_nml-link i {
  min-width: 3rem;
}















.c_btn-arrow {
  transition: .4s;
}

.c_btn .c_btn-arrow {
  margin-left: 1.5rem;
}

.c_btn-arrow {
  background-image: url(../images/c_btn-arrow.png);
}

.c_btn-arrow.blue {
  background-image: url(../images/c_btn-arrow_b.png);
}



a:hover .c_btn-arrow {
  background-image: url(../images/c_btn-arrow_b.png);
}

a:hover .c_btn-arrow.blue {
  background-image: url(../images/c_btn-arrow.png);
}

a:hover .c_btn-arrow.h-not {
  background-image: url(../images/c_btn-arrow.png);
}

a:hover .c_btn-.wrap--sm.blue.h-not {
  background-image: url(../images/c_btn-arrow_b.png);
}



/* blank */
.c_btn-arrow.blank {
  background-image: url(../images/icon_blank.png) !important;
}


a:hover .c_btn-arrow.blank {
  background-image: url(../images/icon_blank_b.png);
}


.c_btn-arrow.blank.gr {
  background-image: url(../images/icon_blank_gr.png);
}

a:hover .c_btn-arrow.blank {
  background-image: url(../images/icon_blank_b.png);
}



/* pdf */
.c_btn-arrow.pdf,
a[href$=".pdf"] .c_btn-arrow {
  background-image: url(../images/icon_pdf_b.png);
}

a:hover .c_btn-arrow.pdf,
a[href$=".pdf"]:hover .c_btn-arrow {
  background-image: url(../images/icon_pdf_w.png);
}

.c_btn-arrow.pdf.wt,
a[href$=".pdf"] .c_btn-arrow.wt {
  background-image: url(../images/icon_pdf_w.png);
}

a:hover .c_btn-arrow.pdf.wt,
a[href$=".pdf"]:hover .c_btn-arrow.wt {
  background-image: url(../images/icon_pdf_b.png);
}


/* .bkParts a[target="_blank"] .c_btn-arrow.dl, */
.c_btn-arrow.dl {
  background-image: url(../images/icon_dl_b.png) !important;
}

a:hover .c_btn-arrow.dl {
  background-image: url(../images/icon_dl_b.png) !important;
}



/* pin */
.c_btn-arrow.pin {
  background-image: url(../images/icon_pin_b.png);
}

a:hover .c_btn-arrow.pin {
  background-image: url(../images/icon_pin_w.png);
}




.c_btn-arrow.list {
  background-image: url(../images/icon_list_w.png);
}

a:hover .c_btn-arrow.list {
  background-image: url(../images/icon_list_b.png);
}

.c_btn-arrow.list.blue {
  background-image: url(../images/icon_list_b.png);
}

a:hover .c_btn-arrow.list.blue {
  background-image: url(../images/icon_list_w.png);
}


.icon_farrow {
  background-image: url(../images/icon_farrow.png);
}


.right:not(:has(.c_btn)) .icon {
  margin-left: auto;
  display: block;
}





@media screen and (max-width:1023px) {
  .bg_radius {
    border-radius: 0 6.4rem 0 6.4rem;
  }

  .bg_all-radius {
    border-radius: 6.4rem;
  }

  .bg_top-radius {
    border-radius: 6.4rem 6.4rem 0 0;
  }

  .wrap--sm {
    width: 86%;
    max-width: unset;
    min-width: unset;
  }

  .wrap--md {
    width: 88.84%;
    min-width: unset;
    max-width: unset;
  }

  .wrap--lg {
    width: 86%;
    min-width: unset;
    max-width: unset;
  }

  .wrap--ss {
    width: 88.84%;
    max-width: unset;
    min-width: unset;
  }

  .c_btn.sp_s {
    font-size: var(--p-s);
  }

  .sp_center .c_btn {
    margin-left: auto;
    margin-right: auto;
  }

  .c_btn-l {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }

  .c_nml-link.lg {
    font-size: var(--lv6-j-ttl);
  }
}

/*================================================
 *  header
 ================================================*/
header {
  position: fixed;
  top: 4rem;
  left: 0;
  width: 100%;
  z-index: 100;
  transition: all .6s;
}


header.hidden {
  transform: translateY(calc(-100% - 6rem));
}

.nav_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 94.7%;
  /* max-width: 1432px; */
  margin: 0 auto;
  padding-left: 2.7%;
  padding-bottom: 1.4rem;
  border-radius: 3.2rem;
  position: relative;
}

.nav_inner::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border-radius: 3.2rem;
  border-bottom: 1px solid rgb(255 255 255 / 70%);
  backdrop-filter: blur(18px);
  background: rgb(255 255 255 / 50%);
  z-index: -1;
}

/* nav_left */
header .nav_left {
  width: 17.2%;
  max-width: 240px;
}

header .nav_left h1 {
  margin-top: 1rem;
}

/* nav_right */
/* nav_top */
nav.gnav .nav_top {
  display: flex;
  align-items: end;
  justify-content: end;
  margin-bottom: 1.8rem;
}

nav.gnav .nav_search {
  margin-right: 1.6rem;
  width: 20rem;
}

nav.gnav .nav_search form {
  position: relative;
}

/* .gsc-control-cse {
  padding: 0 !important;
  background-color: transparent !important;
  border: none !important;
}

.gsc-input-box {
  border-radius: 10000px !important;
  padding: 0 !important;
  background: transparent !important;
}

nav.gnav .nav_search input {
  display: block;
  width: 20rem !important;
  padding: 1.1rem 4.8rem 0.9rem 1.6rem !important;
  background: var(--t-white);
  border-radius: 10000px;
  font-size: var(--p-s);
  font-weight: 400;
  height: auto !important;
}

.gsc-search-button-v2 {
  padding: 0 !important;
  background-color: transparent !important;
  border: none !important;
}

.gsc-input-box {
  border: none !important;
}

.gsc-search-button-v2 svg {
  display: none !important;
}

table.gsc-search-box td#gs_tti50 {
  padding: 0 !important;
}

table.gsc-search-box td.gsc-input {
  padding: 0 !important;
}

table.gsc-search-box .gsib_b {
  display: none !important;
}

input.gsc-input::placeholder,
nav.gnav .nav_search input::placeholder {
  color: var(--t-gray3) !important;
}

nav.gnav .nav_search button {
  position: absolute;
  content: "";
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  display: inline-block;
  background-image: url(../images/icon_search.png);
  width: 3rem;
  height: 3rem;
  top: 50%;
  right: 2rem;
  transform: translateY(-50%);
  border-radius: 10000px;
} */


nav.gnav .nav_search {
  margin-right: 1.6rem;
}

nav.gnav .nav_search form {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
}

nav.gnav .nav_search input {
  display: block;
  max-width: 20rem;
  width: 100%;
  padding: 1.1rem 4.8rem 0.9rem 1.6rem;
  background: var(--t-white);
  border-radius: 10000px;
  font-size: var(--p-s);
  font-weight: 400;
}

nav.gnav .nav_search input::placeholder {
  color: var(--t-gray3);
}

nav.gnav .nav_search .button {
  position: absolute;
  content: "";
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  display: inline-block;
  background-image: url(../images/icon_search.png);
  width: 3rem;
  height: 3rem;
  top: 50%;
  right: 0.8rem;
  transform: translateY(-50%);
  border-radius: 10000px;
  padding: 0;
}

nav.gnav .nav_top a {
  padding: 1.6rem 1.6rem;
  color: var(--t-white);
  display: block;
  position: relative;
  overflow: hidden;
}

nav.gnav .nav_top a::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0;
  transition: .4s;
}

nav.gnav .nav_top a:hover::before {
  opacity: 1;
}

nav.gnav .nav_top .dl a {
  background: linear-gradient(180deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
  padding-left: 2.4rem;
  border-radius: 0 0 0 3.2rem;
}

nav.gnav .nav_top .dl a::before {
  background: linear-gradient(0deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
}


nav.gnav .nav_top .ct a {
  background: linear-gradient(180deg, rgba(59, 170, 108, 1) 0%, rgba(0, 110, 56, 1) 100%);
  border-radius: 0 3.2rem 0 0;
}

nav.gnav .nav_top .ct a::before {
  background: linear-gradient(0deg, rgba(59, 170, 108, 1) 0%, rgba(0, 110, 56, 1) 100%);
}

nav.gnav .nav_top li.dl a span,
nav.gnav .nav_top li.ct a span {
  position: relative;
  z-index: 1;
  font-size: var(--p-ss);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 0.8rem;
}


nav.gnav .nav_menu {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 3.2rem;
  font-size: var(--p-m);
  font-weight: 700;
  padding-right: 5.2rem;

  gap: clamp(1rem, 2.11vw, 3.2rem);
}

nav.gnav .nav_menu a:hover {
  color: var(--t-blue);
}

.nav_top .nav_left,
nav.gnav .nav_menu li ul,
nav.gnav .nav_menu .label,
nav.gnav .copy {
  display: none;
}




@media screen and (max-width:1200px) {
  nav.gnav .nav_menu {
    padding-right: 2rem;
    font-size: 1.4rem;
  }
}

@media screen and (max-width:1023px) {
  header {
    top: 3rem;
  }

  .nav_inner {
    width: 85.58%;
    padding: 3rem 3rem 3.8rem;
    border-radius: 2.4rem;
  }



  /* nav_left */
  header .nav_left {
    width: 17rem;
    transition: .4s;
  }

  header .nav_left h1 {
    margin-top: 0;
    transition: .2s;
  }

  .open_nav .nav_left h1 {
    opacity: 0;
  }

  nav.global__nav {
    position: fixed;
    left: 0;
    top: 0;
    min-height: 100svh;
    z-index: 200;
    overflow-y: scroll;
    padding: 3rem 7% 10rem;
    inset: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .1s ease;
  }

  .gnav_inner {
    padding: 3rem 3rem 3.6rem;
    border-radius: 2.4rem;
    backdrop-filter: blur(18px);
    background: rgb(255 255 255 / 50%);
    border: 1px solid rgb(255 255 255 / 70%);
  }


  .open_nav .global__nav {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  /* hamburger */
  .hamburger {
    position: absolute;
    right: 3rem;
    top: 3.7rem;
    width: 2.2rem;
    height: 2rem;
    cursor: pointer;
    z-index: 300;
  }

  /* line open */
  .hamburger__line {
    position: absolute;
    left: 0px;
    width: 100%;
    height: 0.26rem;
    background-color: var(--t-blue);
    transition: all .2s ease-out;
    transform: translateY(-50%);
  }

  .hamburger__line--1 {
    top: 0;
  }

  .hamburger__line--2 {
    top: 50%;
  }

  .hamburger__line--3 {
    top: 100%;
  }

  /* line close */
  .open_nav .hamburger__line--1 {
    transform: rotate(45deg);
    top: 50%;
    width: 2.8rem;
  }

  .open_nav .hamburger__line--2 {
    width: 0;
    left: 50%;
  }

  .open_nav .hamburger__line--3 {
    transform: rotate(-45deg);
    top: 50%;
    width: 2.8rem;
  }



  .nav_top .nav_left,
  nav.gnav .nav_menu li ul,
  nav.gnav .nav_menu .label,
  nav.gnav .copy {
    display: block;
  }

  nav.gnav .nav_top {
    flex-wrap: wrap;
    justify-content: start;
  }

  nav.gnav .nav_search {
    margin: 4.8rem 0 0.8rem 0;
    width: 100%;
  }

  nav.gnav .nav_search form {
    width: 100%;
  }

  nav.gnav .nav_search input {
    max-width: unset;
    width: 100%;
    border-radius: 2.4rem;
  }

  nav.gnav .nav_search .button {
    width: 4rem;
    height: 4rem;
  }

  nav.gnav .nav_top .dl,
  nav.gnav .nav_top .ct {
    width: 50%;
  }

  nav.gnav .nav_top .dl a,
  nav.gnav .nav_top .ct a {
    padding: 0.8rem 0 1rem;
  }

  nav.gnav .nav_top .dl a {
    border-radius: 2.4rem 0 0 2.4rem;
  }

  nav.gnav .nav_top .ct a {
    border-radius: 0 2.4rem 2.4rem 0;
  }

  nav.gnav .nav_top a span {
    flex-wrap: wrap;
    flex-direction: column-reverse;
    gap: 0;
  }

  nav.gnav .nav_top a span i {
    margin-bottom: -0.3rem;
  }

  nav.gnav .nav_menu {
    display: block;
    font-size: var(--p-l);
    padding: 0;
  }

  nav.gnav .nav_menu>li {
    margin-top: 4.8rem;
  }

  nav.gnav .nav_menu>li a:not(.pc) {
    color: var(--t-blue);
    display: block;
    width: 100%;
    position: relative;
  }

  nav.gnav .nav_menu>li a::before {
    position: absolute;
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    display: inline-block;
    background-image: url(../images/nav_arrow_sp.png);
    width: 2rem;
    height: 2rem;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
  }

  nav.gnav .nav_menu li .label {
    color: var(--t-blue);
    display: block;
    position: relative;
  }

  nav.gnav .nav_menu li .label::before,
  nav.gnav .nav_menu li .label::after {
    position: absolute;
    content: "";
    width: 2rem;
    height: 0.15rem;
    background: var(--t-blue);
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    transition: .2s;
  }

  nav.gnav .nav_menu li .label::after {
    transform: translateY(-50%) rotate(90deg);
  }

  nav.gnav .nav_menu li .open.label::after {
    opacity: 0;
  }

  nav.gnav .nav_menu li#acc div {
    display: none;
  }

  nav.gnav .nav_menu li ul {
    display: block;
  }

  nav.gnav .nav_menu li#acc div a {
    border-top: 1px solid var(--t-white);
    margin-top: 1.6rem;
    padding-top: 1.6rem;
    font-weight: 400;
    display: block;
    color: var(--t-black);
  }

  nav.gnav .nav_menu li#acc div a::before {
    content: none;
  }

  nav.gnav .copy {
    text-align: center;
    color: var(--t-gray2);
    font-size: var(--p-ss);
    font-weight: 700;
    margin-top: 4.8rem;
  }

}


/*================================================
* 
================================================*/


@media screen and (max-width:1023px) {}


/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}


/*================================================
* 
================================================*/

.c_case-list {
  display: grid;
  gap: 4rem 3.2rem;
  grid-template-columns: repeat(3, 1fr);
}


.case_list .case_card a {
  height: 100%;
  display: block;
  background: var(--t-white);
  box-shadow: 0 0 2rem 0 rgb(0 0 0 / 10%);
  border-radius: 1.6rem;
  overflow: hidden;
}

.case_list .case_card a:hover {
  background: var(--t-blue);
}


.case_list .case_card .thumbnail {
  aspect-ratio: 334 / 238;
  overflow: hidden;
}

.case_list .case_card .thumbnail img {
  overflow: hidden;
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  transition: .4s;
}

.case_list .case_card a:hover .thumbnail img {
  transform: scale(1.15);
}

.case_list .case_card .meta {
  padding: 0 2.4rem 3.5rem;
  background: var(--t-white);
  transition: .4s;
}

.case_list .case_card a:hover .meta {
  background: var(--t-blue);
  color: var(--t-white);
}

.case_list .case_card .cat {
  background: var(--t-gray3);
  /* font-size: var(--p-ss); */
  font-size: 10px;
  color: var(--t-black);
  font-weight: 700;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 1rem 2rem 1rem 2.4rem;
  border-radius: 0 0 1.6rem 1.6rem;
  transition: .4s;
  display: flex;
  align-items: stretch;
}

.case_list .case_card a:hover .cat {
  background: var(--t-white);
}

.case_list .case_card .cat span:first-of-type {
  padding-right: 1.6rem;
  margin-right: 1.6rem;
  border-right: 1px solid var(--t-gray2);
  white-space: nowrap;
}

.case_list .case_card .ttl {
  font-size: 2.4rem;
  color: var(--t-blue);
  line-height: 1.7;
  font-weight: 700;
  margin: 2rem 0 1rem;
  transition: .4s;
  letter-spacing: 0.1em;
}

.case_list .case_card a:hover .ttl {
  color: var(--t-white);
}

.case_list .case_card .txt {
  min-height: 5.7em;
  line-height: 2.1;
}

.case_list .case_card .tag {
  display: flex;
  align-items: center;
  justify-content: start;
  flex-wrap: wrap;
  gap: 1rem 1.2rem;
  padding-top: 1.8rem;
  margin-top: 1.6rem;
  border-top: 1px solid var(--t-gray3);
}

.case_list .case_card .tag span {
  position: relative;
  display: inline-block;
  padding-left: 1.6rem;
  font-size: var(--p-ss);
  font-weight: 700;
}

.case_list .case_card .tag span::before {
  position: absolute;
  content: "";
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  display: inline-block;
  background-image: url(../images/icon_tag.png);
  width: 1rem;
  height: 1rem;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.case_card .c_btn .c_btn-arrow.dl {
  background-image: url(../images/icon_dl_b.png);
}

@media screen and (max-width:1023px) {

  .c_case-list {
    grid-template-columns: repeat(1, 1fr);
  }

  .case_list .case_card .txt {
    min-height: unset;
    height: 6em;
    overflow: hidden;
    position: relative;
  }

  .case_list .case_card .meta {
    padding: 0 2.6rem 3rem;
  }

  .case_list .case_card .thumbnail {
    aspect-ratio: 382 / 272;
  }
}


/*================================================
 *  footer
 ================================================*/
footer {
  overflow: hidden;
  border-radius: 5.6rem 5.6rem 0 0;
  position: relative;
}

footer::before,
footer::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
}

footer::before {
  background: radial-gradient(circle at 100% 100%, #3BAA6C 0%, #2C7BBF 39%, #FFFFFF 100%);
  opacity: .6;
}

footer::after {
  background: linear-gradient(180deg, rgba(207, 207, 207, 1) 0%, rgba(255, 255, 255, 0) 100%);
  mix-blend-mode: screen;
}

footer .outer {
  position: relative;
  width: auto;
  height: auto;
}

footer .outer::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1rem;
  bottom: 0;
  left: 0;
  background: linear-gradient(90deg, rgba(59, 170, 108, 1) 0%, rgba(44, 123, 191, 1) 100%);
}

footer .inner {
  position: relative;
  padding: 5.6rem 0;
  width: 90.47%;
  margin: 0 auto;
}



.ft_breadcrumbs {
  padding-bottom: 3rem;
  position: relative;
  display: flex;
  align-items: end;
  justify-content: space-between;
}

.ft_breadcrumbs::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  bottom: 0;
  left: 0;
  background: linear-gradient(90deg, rgba(59, 170, 108, 1) 0%, rgba(44, 123, 191, 1) 100%);
  opacity: .2;
}

.ft_breadcrumbs .pageTop {
  width: 4rem;
  height: 4rem;
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
  background-image: url(../images/icon_page.png);
  transition: .4s;
}

.ft_breadcrumbs .pageTop:hover {
  background-image: url(../images/icon_page_lb.png);
  transition: .4s;
}

.ft_breadcrumbs-list {
  display: flex;
  align-items: center;
  justify-content: start;
  flex-wrap: wrap;
  gap: 0.8rem 2.4rem;
  width: calc(100% - 6rem);
}

.ft_breadcrumbs-list span {
  font-size: var(--p-ss);
  color: var(--t-blue);
  font-weight: 700;
  position: relative;
}

.ft_breadcrumbs-list span:not(:first-child) {
  padding-left: 2.4rem;
}

.ft_breadcrumbs-list span:not(:first-child)::before {
  position: absolute;
  content: "/";
  top: 0;
  left: 0;
}

.ft_under {
  display: flex;
  align-items: start;
  justify-content: space-between;
  margin-top: 5.6rem;
}

.ft_logo {
  width: 32rem;
  margin-top: 2.7rem;
  margin-right: 3rem;
  min-width: 20rem;
}

.ft_menu-btn {
  display: flex;
  justify-content: end;
  align-items: center;
  gap: 1.4rem;
  margin-bottom: 5.6rem;
}

.ft_menu-btn li {
  width: 18.5rem;
}

.ft_menu-btn li.mag {
  width: 20rem;
}

.ft_menu-btn li a {
  line-height: 1;
  display: flex;
  align-items: center;
  height: 7.2rem;
  width: 100%;
  color: var(--t-white);
  font-weight: 700;
  border-radius: 2.4rem;
  position: relative;
  border: 1px solid var(--t-white);
  /* padding-right: 1.6rem;
  padding-left: 2.4rem; */
  padding-right: 0.6rem;
  padding-left: 1.4rem;
  z-index: 1;
  font-size: var(--p-s);
}

.ft_menu-btn li a span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.ft_menu-btn li.mag a {
  padding-right: 1rem;
}

.ft_menu-btn li a i {
  width: 4rem;
  height: 4rem;
}

.ft_menu-btn li.mg a i {
  background-image: url(../images/icon_blank_w_clear.png);
}

.ft_menu-btn li.mag a {
  color: var(--t-blue);
  font-family: var(--en);
  background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(207, 207, 207, 1) 100%);
}

.ft_menu-btn li.mag a:hover {
  color: var(--t-blue2);
}

.ft_menu-btn li.mag a span {
  justify-content: end;
}

.ft_menu-btn li.mag img {
  width: 11rem;
  position: absolute;
  left: -0.8rem;
  top: -2.4rem;
}

.ft_menu-btn li.mg a {
  background: linear-gradient(180deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
  box-shadow: 0 0 0.8rem 0 rgb(16 56 107 / 30%);
}

.ft_menu-btn li.dl a {
  background: linear-gradient(180deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
  box-shadow: 0 0 0.8rem 0 rgb(16 56 107 / 30%);
}

.ft_menu-btn li.ct a {
  background: linear-gradient(180deg, rgba(59, 170, 108, 1) 0%, rgba(0, 110, 56, 1) 100%);
  box-shadow: 0 0 0.8rem 0 rgb(0 110 56 / 45%);
}

.ft_menu-btn li.mg a::before,
.ft_menu-btn li.dl a::before,
.ft_menu-btn li.ct a::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 2.4rem;
  opacity: 0;
  transition: .4s;
  top: 0;
  left: 0;
  z-index: -1;
}

.ft_menu-btn li.mg a::before,
.ft_menu-btn li.dl a::before {
  background: linear-gradient(0deg, rgba(44, 123, 191, 1) 0%, rgba(16, 56, 107, 1) 100%);
}

.ft_menu-btn li.ct a::before {
  background: linear-gradient(0deg, rgba(59, 170, 108, 1) 0%, rgba(0, 110, 56, 1) 100%);
}

.ft_menu-btn li.mg a:hover::before,
.ft_menu-btn li.dl a:hover::before,
.ft_menu-btn li.ct a:hover::before {
  opacity: 1;
}


.ft_menu-link {
  display: flex;
  align-items: center;
  justify-content: end;
  flex-wrap: wrap;
  gap: 2.4rem;
  margin-top: 2rem;
}

.ft_menu-link a {
  font-size: var(--p-ss);
  font-weight: 700;
  display: flex;
  align-items: center;
}

.ft_menu-link a i {
  width: 2rem;
  height: 2rem;
  margin-left: 0.8rem;
}

.ft_menu-link a:hover {
  color: var(--t-white);
}


.ft_social i {
  width: 2.5rem;
  height: 2.5rem;
  position: relative;
  top: -1px;
}


.ft_copy {
  font-size: var(--p-ss);
  font-weight: 700;
  color: var(--t-gray2);
  margin-top: -2.6rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}


@media screen and (max-width:1100px) {
  .ft_logo {
    margin: 0 auto 3rem;
  }

  .ft_under {
    flex-wrap: wrap;
  }
}

@media screen and (max-width:1023px) {
  footer .inner {
    padding: 4.8rem 0;
    width: 85.1%;
  }

  .ft_breadcrumbs {
    align-items: center;
  }

  .ft_under {
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }

  .ft_menu-btn {
    flex-wrap: wrap;
    flex-direction: column;
    justify-content: center;
    margin-bottom: 4.8rem;
  }

  .ft_menu-btn li {
    width: 23.5rem;
  }

  .ft_menu-btn li.mag {
    width: 23.5rem;
  }

  .ft_menu-link {
    justify-content: start;
  }

  .ft_social {
    margin-top: 4.8rem;
    justify-content: center;
  }

  .ft_copy {
    margin-top: 4.8rem;
    text-align: center;
    width: 100%;
  }

  .ft_logo {
    width: 26rem;
    margin: 4rem auto 0;
  }

  .ft_logo a {
    display: block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

/*================================================
* 
================================================*/


@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* 
================================================*/

@media screen and (max-width:1023px) {}

/*================================================
* privacyPage
================================================*/
#privacyPage a {
  text-decoration: underline;
}

@media screen and (max-width:1023px) {}

/*================================================
* ani
================================================*/

.fadeIn {
  opacity: 0;
  transition: all 2.4s ease;
}

.fadeIn.on {
  opacity: 1;
}

.fadeUp {
  opacity: 0;
  transform: translateY(2rem);
  transition: all .8s ease;
  position: relative;
}

.fadeUp.on {
  opacity: 1;
  transform: translateY(0);
}

.delay02 {
  transition-delay: 0.2s;
}

.delay03 {
  transition-delay: 0.3s;
}

.delay04 {
  transition-delay: 0.4s;
}

.delay05 {
  transition-delay: 0.5s;
}

.delay06 {
  transition-delay: 0.6s;
}

.delay08 {
  transition-delay: 0.8s;
}

.delay10 {
  transition-delay: 1s;
}

@media screen and (max-width:1023px) {}