@charset "utf-8";
/* ==========================================================================
Layout [ header / main / side / footer... ]
========================================================================== */

body#toppage {
  background: url(./assets/images/top/kv_bg.jpg) no-repeat left top / 1800px auto,
              url(./assets/images/top/bg.png) center top 1052px / 1800px auto;
}
body.active ,
body.header-fixed {
  padding-top: 50px;
}
body#subpage {
  background: url(./assets/images/common/head.png) no-repeat center top / 100% 140px,
              url(./assets/images/common/lv01.png) no-repeat right top 10px / 250px auto,
              url(./assets/images/common/head_white.png) no-repeat center top / 100% 140px,
              url(./assets/images/common/bg.png) center top 300px / 1920px auto;
}
body#subpage.sub2 {
  background: url(./assets/images/common/head.png) no-repeat center top / 100% 140px,
              url(./assets/images/common/lv02.png) no-repeat right top 10px / 250px auto,
              url(./assets/images/common/head_white.png) no-repeat center top / 100% 140px,
              url(./assets/images/common/bg.png) center top 300px / 1920px auto;
}

/* Header
---------------------------------------------------------------*/

#header {
  top: 0;
  left: 0;
  width: 100%;
  position: relative;
  z-index: 99999;
  top: -60px;
}
#header.active,
#header.is-fixed {
  top: 0;
  left: 0;
  z-index: 99999;
  position: fixed;
  background-color: #646464;
  box-shadow: 0 0 10px rgba(0,0,0,.16);
  height: 60px;
  transition: top .4s;
}
.header__inner {
  display: flex;
  position: relative;
  z-index: 1;
  top: 60px;
}
#header.active .header__inner,
#header.is-fixed .header__inner {
  top: 0;
}
.logo__wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px;
}
.logo__tokyo {
  width: 72px;
}
body.en .logo__tokyo {
  width: 96px;
}
.logo {
  width: 201px;
}
body.en .logo {
  width: 190px;
}
.menu {
  position: absolute;
  top: 0;
  right: 0;
  width: 64px;
  height: 60px;
  z-index: 99999;
}
.menu span{
  display: inline-block;
  transition: all .3s;
  position: absolute;
  left: 17px;
  height: 3px;
  background: #fff;
  width: 45%;
}
.menu span:nth-of-type(1) {
  top:21px;
}
.menu span:nth-of-type(2) {
  top:28px;
}
.menu span:nth-of-type(3) {
  top:35px;
}
.menu.active span:nth-of-type(1) {
  top: 23px;
  left: 21px;
  transform: translateY(6px) rotate(-45deg);
  width: 30%;
}
.menu.active span:nth-of-type(2) {
  opacity: 0;
}
.menu.active span:nth-of-type(3){
  top: 35px;
  left: 21px;
  transform: translateY(-6px) rotate(45deg);
  width: 30%;
}
.nav__wrap {
  position: fixed;
  top: 0;
  right: -360px;
  transition: .4s;
  height: 100vh;
  width: 330px;
  box-sizing: border-box;
  padding: 62px 30px 100px;
  background: #1A405F;
  background: linear-gradient(216deg, rgba(26, 64, 95, 1) 59%, rgba(3, 128, 151, 1) 100%);
  z-index: 999;
  overflow: auto;
}
.nav__wrap.active {
  right: 0;
}
.nav__wrap__layer.active {
  background-color: rgba(0,0,0,.4);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.nav__head__list {
  display: none;
}
.nav__lang {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border-radius: 50px;
  gap: 16px;
  margin-bottom: 10px;
  padding: 4px 0;
  color: #1A405F;
  font-size: var(--fz-18);
}
.nav__lang__ttl {
  color: #1A405F;
  font-size: var(--fz-18);
  font-weight: 500;
}
.nav__lang__item {
  color: #1A405F;
  font-size: var(--fz-18);
  font-weight: 500;
}
.nav__lang__item.selected {
  text-decoration: underline;
}
.nav {
  display: flex;
  flex-direction: column;
  margin-bottom: 32px;
}
.nav__item a {
  border-bottom: 1px solid #fff;
  padding: 16px 0;
  color: #fff;
  font-size: var(--fz-16);
  display: block;
}
.nav__sub {
  display: flex;
  margin-bottom: 32px;
  gap: 20px;
  flex-wrap: wrap;
}
.nav__sub__item a {
  color: #fff;
  font-size: var(--fz-13);
}
.nav__btn {
  display: none;
}

/* Main
---------------------------------------------------------------*/
#main {
  overflow-x: hidden;
}
#subpage #main {
  margin-top: 20px;
}

/* footer
---------------------------------------------------------------*/
#footer {
  background-color: #fff;
  padding: 40px 0 0;
}
.footer__wrap {
}
.footer__head {
  flex-shrink: 0;
  margin-bottom: 24px;
}
.footer__logo {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-bottom: 24px;
}
body.en .footer__logo {
  gap: 24px;
}
.footer__logo__tokyo {
  width: 100px;
}
body.en .footer__logo__tokyo {
  width: 116px;
}
.footer__logo__link {
  width: 170px;
  height: 26px;
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  border: 1px solid #707070;
  border-radius: 40px;
  color: #222;
  font-size: var(--fz-13);
}
body.en .footer__logo__link {
  width: 186px;
  height: 46px;
  padding: 0 10px;
  line-height: 1.3;
}
.footer__logo__link:after {
  content: "";
  content: "";
  width: 9px;
  height: 6px;
  border-top: solid 2px #222;
  border-right: solid 2px #222;
  transform: rotate(45deg);
}
.footer__logo__tgc {
  width: 300px;
}
.footer__contact {
  color: #1A405F;
  border-left: 1px solid #1A405F;
  padding-left: 10px;
}
.footer__contact__txt {
  font-size: var(--fz-14);
  font-weight: bold;
  margin-bottom: 16px;
}
.footer__contact__txt2 {
  font-size: var(--fz-14);
  font-weight: bold;
  margin-bottom: 8px;
}
.footer__contact__access {
  font-size: var(--fz-14);
  margin-bottom: 16px;
}
.footer__contact__wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
}
.footer__contact__mail {
  display: flex;
  gap: 4px;
  color: #1A405F;
  font-size: var(--fz-15);
  font-weight: 500;
  align-items: center;
}
.footer__contact__mail:before {
  content: "";
  display: block;
  background-image: url(./assets/images/common/icon_mail.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 20px;
  height: 15px;
}
.footer__contact__tel {
  display: flex;
  gap: 4px;
  color: #1A405F;
  font-size: var(--fz-12);
  font-weight: 500;
}
.footer__contact__tel:before {
  content: "";
  display: block;
  background-image: url(./assets/images/common/icon_tel.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 18px;
  height: 18px;
}
.footer__contact__tel span {
  display: block;
  font-size: var(--fz-19);
  font-weight: 500;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  line-height: 1.2;
}
.footer__contact__tel__time {
  margin-top: 0;
  font-size: var(--fz-12);
  font-weight: 500;
}
.footer__bottom {
  margin-left: auto;
}
.footer__nav {
  border-bottom: 1px dashed #1A405F;
  padding-bottom: 24px;
  margin-bottom: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 24px;
  font-size: var(--fz-13);
}
.footer__nav__item a {
  color: #1A405F;
  font-weight: 500;
}
.footer__subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 24px;
  font-size: var(--fz-13);
}
.footer__subnav__item a {
  color: #1A405F;
  font-weight: 500;
}
.copyright {
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 38%, rgba(0, 150, 177, 1) 100%);
  color: #fff;
  font-size: var(--fz-12);
  padding: 20px 0;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  text-align: center;
}
.copyright .container {
  margin-bottom: 0;
}
.floating__btn__pc {
  display: none;
}
.floating__btns {
  display: flex;
  padding: 4px;
  gap: 4px;
  background-color: rgba(255,255,255,.8);
  position: fixed;
  bottom: -80px;
  left: 0;
  width: 100%;
  transition: .4s;
  z-index: 999999;
}
.floating__btns.show {
  bottom: 0;
}
.floating__btn__sp1,
.floating__btn__sp2 {
  width: 100%;
  display: block;
  height: 52px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  font-size: var(--fz-13);
  text-align: center;
  background: #245882;
  background: linear-gradient(244deg, rgba(36, 88, 130, 1) 0%, rgba(17, 120, 154, 1) 84%, rgba(0, 150, 177, 1) 100%);
  position: relative;
}
.floating__btn__sp2 {
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 60%, rgba(0, 150, 177, 1) 100%);
}
.floating__btn__sp1:before ,
.floating__btn__sp2:before {
  content: "";
  background-image: url(./assets/images/common/icon_arrow_white.svg);
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 100% auto;
  width: 8px;
  height: 8px;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
}
.floating__btn__sp2:before {
  background-image: url(./assets/images/common/icon_external_white.svg);
  width: 14px;
  height: 14px;
}
.floating__btn__sp2 span {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
}

/* ==========================================================================
Project [ articles / ranking / promo... ]
========================================================================== */
.kv {
}
.kv__inner.container {
  position: relative;
  margin-bottom: 0;
  overflow: hidden;
  margin-top: -50px;
}
.kv__event {
  background-color: #fff;
  width: 100%;
  padding: 0 0 20px;
  position: relative;
  z-index: 1;
  margin-bottom: 32px;
}
.kv__event__ttl {
  width: 100%;
  padding: 8px 16px;
  box-sizing: border-box;
  color: #fff;
  letter-spacing: 0.05em;
  font-size: var(--fz-13);
  font-weight: 500;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 60%, rgba(0, 150, 177, 1) 100%);
  text-shadow: 0 0 6px rgba(0,0,0,.3);
  margin-bottom: 20px;
}
.kv__event__ttl span {
  font-size: var(--fz-16);
}
.kv__event__date {
  margin: 0 16px;
  border-bottom: 1px solid #1A466A;
  line-height: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  color: #1A466A;
  padding-bottom: 6px;
  font-weight: bold;
}
.kv__event__date__num {
  width: 100%;
  font-size: var(--fz-16);
  margin-bottom: -10px;
}
body.en .kv__event__date__num {
  font-size: var(--fz-13);
  margin-bottom: 0;
}
.kv__event__date__num span {
  font-size: var(--fz-20);
  font-family: "din-2014", sans-serif;
  padding: 0 2px;
}
.kv__event__date__day {
  font-size: var(--fz-23);
  font-family: "din-2014", sans-serif;
  font-weight: 800;
  line-height: 1;
}
.kv__event__date__day span {
  font-size: var(--fz-36);
  font-weight: 400;
}
.kv__event__date__dow {
  font-size: var(--fz-18);
  font-family: "din-2014", sans-serif;
  font-weight: 800;
  width: 60px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #1A466A;
  border-radius: 30px;
  box-sizing: border-box;
  position: relative;
  top: -2px;
  margin: 0 6px 0 4px;
}
.kv__event__date__time {
  font-family: "din-2014", sans-serif;
  font-size: var(--fz-18);
  position: relative;
  top: -4px;
}
.kv__event__date__note {
  font-size: var(--fz-13);
  padding: 4px 0;
  padding-left: 1em;
  text-indent: -1em;
}
.kv__event__date__note span {
  font-size: var(--fz-14);
  font-family: "din-2014", sans-serif;
}
.kv__event__dl {
  margin: 0 16px;
  padding: 10px 0;
  display: flex;
  border-bottom: 1px dashed #1A466A;
}
.kv__event__dl dt {
  width: 5.5em;
  flex-shrink: 0;
  font-size: var(--fz-14);
  font-weight: bold;
  color: #1A466A;
  letter-spacing: 0.05em;
}
body.en .kv__event__dl dt {
  width: 7.5em;
}
.kv__event__dl dd {
  font-size: var(--fz-14);
  letter-spacing: 0.05em;
}
.kv__event__place {
  display: flex;
  gap: 6px;
}
.kv__event__place__left {
  font-size: var(--fz-13);
  line-height: 1.3;
}
.kv__event__place__right {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.kv__event__place__img {
  width: 52px;
}
.kv__event__place__map {
  font-size: var(--fz-11);
  color: #fff;
  font-weight: bold;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 60%, rgba(0, 150, 177, 1) 100%);
  width: 90px;
  height: 23px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 40px;
}
.kv__event .btn01 {
  margin: 16px auto 0;
  width: calc(100% - 32px);
}
.kv__img {
}
.kv__img img {
  max-width: unset;
  width: 460px;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.kv__logo {
  width: 90%;
  max-width: 370px;
  margin: 0 auto;
  position: absolute;
  top: 140px;
  left: 50%;
  transform: translateX(-50%);
}
.news {
  overflow: hidden;
}
.news__list {
  /*display: flex;*/
  width: calc(100% + 20px);
  opacity: 0;
  margin-bottom: 20px!important;
}
.news__item {
  margin-right: 20px;
  background-color: #fff;
  border: 1px solid #E4E4E4;
  box-shadow: 0 3px 6px rgba(0,0,0,.1);
  padding: 8px 30px 10px 10px;
  box-sizing: border-box;
  position: relative;
  height: auto;
}
a.news__item {
  background-image: url(./assets/images/common/icon_arrow.svg);
  background-position: right 10px bottom 10px;
  background-size: 8px auto;
  background-repeat: no-repeat;
}
.news__item__head {
  display: flex;
  gap: 10px;
  margin-bottom: 8px;
  align-items: baseline;
}
.news__item__time {
  font-size: var(--fz-13);
  color: #1A405F;
  font-weight: 700;
  font-family: "din-2014", sans-serif;
  letter-spacing: 0.05em;
}
.news__item__new {
  font-size: var(--fz-13);
  color: #C20000;
  font-weight: 400;
  font-family: "din-2014", sans-serif;
  letter-spacing: 0.05em;
}
.news__item__inner {
  display: flex;
  gap: 10px;
}
.news__item__img {
  width: 100px;
  flex-shrink: 0;
  overflow: hidden;
}
.news__item img {
  transition-duration: .3s;
}
a.news__item:hover img {
  transform: scale(1.05);
}
.news__item__ttl {
  font-size: var(--fz-14);
  color: #1A466A;
  font-weight: bold;
  margin-bottom: 6px;
}
.news__item__txt {
  font-size: var(--fz-13);
}
.news__list .slick-list {
  overflow: visible;
}
.news__list .slick-track {
  display: flex;
}
.news__list .slick-slide {
  /*opacity: 0;*/
}
.news__list .slick-active {
  /*opacity: 1;*/
}
.news__list__nav__wrap .slick-dots {
  bottom: 0;
  position: relative;
  width: auto;
  font-size: 0;
}
.news__list__nav__wrap .slick-dots li {
  width: 10px;
  height: 10px;
  margin: 0 6px;
}
.news__list__nav__wrap .slick-dots li button:before {
  display: none;
}
.news__list__nav__wrap .slick-dots li button {
  background: #1A466A;
  opacity: .2;
  width: 100%;
  height: 100%;
}
.news__list__nav__wrap .slick-dots li.slick-active button {
  opacity: 1;
}
.news__list__nav__wrap {
  display: flex;
  flex-direction: row-reverse;
  gap: 20px;
  align-items: center;
  justify-content: center;
}
.news__list__nav__switch:hover {
  opacity: .7;
  transform: .3s;
  cursor: pointer;
}
.news__list__nav__switch img {
  display: none;
  width: 30px;
}
.news__list__nav__switch img.active {
  display: block;
}
.overview__logo {
  width: 80%;
  max-width: 400px;
  margin: 0 auto 20px;
}
.overview__lead {
  text-align: center;
  color: #1A466A;
  font-size: var(--fz-20);
  font-weight: bold;
  margin-bottom: 24px;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
body.en .overview__lead {
  font-size: var(--fz-18);
  line-height: 1.6;
}
.overview__txt {
  font-size: var(--fz-14);
  margin-bottom: 24px;
}
.overview__wrap {
}
.overview__img {
  width: 100%;
  max-width: 500px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  margin: 0 auto 16px;
}
.overview__img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.overview__event {
  width: 100%;
  flex-shrink: 0;
}
.overview__event__date {
  border-bottom: 1px solid #1A466A;
  line-height: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  color: #1A466A;
  padding-bottom: 14px;
  font-weight: bold;
}
.overview__event__date__num {
  font-size: var(--fz-12);
  width: 54px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #1A466A;
  color: #fff;
  box-sizing: border-box;
  margin-right: 6px;
}
body.en .overview__event__date__num {
  width: unset;
  height: 24px;
  padding: 0 6px;
}
.overview__event__date__num span {
  font-size: var(--fz-14);
  font-family: "din-2014", sans-serif;
  padding: 0 2px;
  position: relative;
  top: 1px;
}
.overview__event__date__day {
  font-size: var(--fz-16);
  font-family: "din-2014", sans-serif;
  font-weight: 800;
  line-height: 1;
}
.overview__event__date__day span {
  font-size: var(--fz-23);
  font-weight: 400;
}
.overview__event__date__dow {
  font-size: var(--fz-14);
  font-family: "din-2014", sans-serif;
  font-weight: 800;
  width: 42px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #1A466A;
  border-radius: 30px;
  box-sizing: border-box;
  position: relative;
  top: -2px;
  margin: 0 3px 0;
}
.overview__event__date__time {
  font-size: var(--fz-14);
  font-family: "din-2014", sans-serif;
  position: relative;
  top: -4px;
}
.overview__event__date__note {
  padding: 4px 0;
  font-size: var(--fz-13);
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.4;
  margin-left: 60px;
}
body.en .overview__event__date__note {
  margin-left: 92px;
}
.overview__event__date__note span {
  font-size: var(--fz-14);
  font-family: "din-2014", sans-serif;
}
.overview__event__dl {
  padding: 10px 0;
  display: flex;
  border-bottom: 1px dashed #1A466A;
}
.overview__event__dl dt {
  width: 5em;
  flex-shrink: 0;
  font-size: var(--fz-14);
  font-weight: bold;
  color: #1A466A;
  letter-spacing: 0.05em;
}
body.en .overview__event__dl dt {
  width: 7.5em;
}
.overview__event__dl dd {
  font-size: var(--fz-14);
  letter-spacing: 0.05em;
}
.overview__event__place {
  display: flex;
  gap: 6px;
}
.overview__event__place__left {
  font-size: var(--fz-13);
  line-height: 1.3;
}
.overview__event__place__right {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.overview__event__place__img {
  width: 52px;
}
.overview__event__place__map {
  font-size: var(--fz-11);
  color: #fff;
  font-weight: bold;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 60%, rgba(0, 150, 177, 1) 100%);
  width: 90px;
  height: 23px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 40px;
}
.overview__event__access {
  border-bottom: 1px dashed #1A466A;
  padding-bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.overview__event__access li {
  font-size: var(--fz-13);
  padding-left: 22px;
  position: relative;
}
.overview__event__access li:before {
  content: "";
  background-image: url(./assets/images/common/icon_pin.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 16px;
  height: 22px;
  position: absolute;
  left: 0;
  top: 0;
}
#timetable {
  margin-top: 48px;
}
.timetable__ttl {
  color: #fff;
  font-size: var(--fz-18);
  font-weight: 500;
  letter-spacing: 0.05em;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 58%, rgba(0, 150, 177, 0.43) 90%, rgba(0, 150, 177, 0) 100%);
  padding: 10px 14px;
  margin-bottom: 14px;
}
.timetable__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 920px;
  margin: 0 auto;
}
.timetable__item {
  background-color: #F5F5F5;
  padding: 0 10px;
  display: flex;
  gap: 16px;
}
.timetable__item__notice {
  background-color: #F6EEEE;
}
.timetable__item__notice2 {
  background-color: #EAF4FC;
}
.timetable__item__time {
  width: 90px;
  color: #1A466A;
  font-weight: bold;
  font-size: var(--fz-13);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 10px 0;
  flex-shrink: 0;
}
.timetable__item__time span {
  z-index: 3;
  position: relative;
}
.timetable__item__time:before {
  content: "";
  display: block;
  width: 50px;
  height: 50px;
  border-radius: 30px;
  background-color: #E3E7EB;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
.timetable__item__time:after {
  content: "";
  display: block;
  width: 10px;
  height: 100%;
  background-color: #1A466A;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
}
.timetable__last {
  position: relative;
}
.timetable__last .timetable__item__time:after {
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 4px solid #1A466A;
  background: unset;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.timetable__item__notice .timetable__item__time {
  color: #C20000;
}
.timetable__item__notice .timetable__item__time:before {
  background-color: #EEE2E2;
}
.timetable__item__notice2 .timetable__item__time {
  color: #1A466A;
}
.timetable__item__notice2 .timetable__item__time:before {
  background-color: #D1E5F6;
}
.timetable__item__body {
  padding: 18px 0;
}
.timetable__item__txt {
  font-size: var(--fz-14);
  font-weight: bold;
}
.timetable__item__notice2 .timetable__item__txt {
  color: #1A466A;
}
.timetable__item__note {
  font-size: var(--fz-13);
  font-weight: 500;
  margin-top: 4px;
}
#venue_guidemap {
  margin-top: 48px;
}
.flow__list {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
}
.flow__item {
  width: 100%;
  background-color: #F5F5F5;
  border-radius: 10px;
  position: relative;
}
.flow__item__num {
  position: absolute;
  width: 50px;
  height: 46px;
  background-image: url(./assets/images/common/step_bg1_sp.svg);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100% auto;
  top: -8px;
  left: 10px;
  text-align: center;
  font-size: var(--fz-12);
  font-weight: bold;
  color: #1A466A;
  box-sizing: border-box;
  padding-top: 12px;
  padding-right: 4px;
  line-height: 1.1;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  letter-spacing: 0.02em;
}
.flow__item__last .flow__item__num {
  background-image: url(./assets/images/common/step_bg2_sp.svg);
  color: #C20000;
}
.flow__item__num span {
  display: block;
  text-align: center;
  font-size: var(--fz-14);
}
.flow__item__ttl {
  background-color: #1A466A;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: 500;
  padding: 6px 6px 6px 70px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
.flow__item__last .flow__item__ttl {
  background-color: #C20000;
}
.flow__item__txt {
  text-align: center;
  padding: 10px;
  color: #1A466A;
  font-size: var(--fz-14);
  font-weight: 500;
}
.top__bg {
  background-image: url(./assets/images/top/img01.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 200px;
  margin-bottom: -60px;
}
.search__wrap {
  background-color: #F5F5F5;
  padding: 20px 16px;
  margin-bottom: 32px;
}
.search__inner {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 24px;
}
.search__dl {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.search__dl dt {
  color: #1A466A;
  font-size: var(--fz-14);
  font-weight: bold;
  flex-shrink: 0;
}
.search__dl dd {
  width: 100%;
}
.input {
  -webkit-appearance: none;
  border: 1px solid #0054A7;
  border-radius: 5px;
  background-color: #fff;
  padding: 10px;
  font-size: var(--fz-14);
  font-weight: 500;
  color: #1A466A;
  width: 100%;
  box-sizing: border-box;
}
.input::placeholder {
  color: #5B7B95;
}
select.input {
  background-image: url(./assets/images/common/icon_chevron_down.svg);
  background-repeat: no-repeat;
  background-position: center right 10px;
  padding-right: 30px;
  cursor: pointer;
  color: #1a466a;
}
.search__btns {
  display: flex;
  justify-content: center;
  gap: 16px;
}
.search__clear {
  -webkit-appearance: none;
  border: unset;
  background: #707070;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: bold;
  border-radius: 50px;
  width: 160px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
}
.search__submit {
  -webkit-appearance: none;
  border: unset;
  background: #1A466A;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: bold;
  border-radius: 50px;
  width: 260px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
  gap: 10px;
}
.search__submit:before {
  content: "";
  display: block;
  background-image: url(./assets/images/common/icon_search.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;
  width: 14px;
  height: 14px;
}
.search__clear:hover,
.search__submit:hover {
  opacity: .7;
  transition: .3s;
  cursor: pointer;
}
.startups__list {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.startups__item {
  background-color: #fff;
  box-shadow: 0 3px 10px rgba(0,0,0,.05);
  display: block;
  width: 100%;
  border: 1px solid #E4E4E4;
  box-sizing: border-box;
  position: relative;
  padding: 37px 10px 20px;
}
.startups__item.hidden {
  opacity: 0;
  max-height: 0;
  padding: 0;
  overflow: hidden;
  display: none;
}
.startups__item.hidden.show {
  max-height: 2000px;
  overflow: unset;
  padding: 37px 10px 20px;
  opacity: 1;
  transition: opacity .4s;
  display: block;
}
.startups__item__status {
  background-color: #7B7B7B;
  color: #fff;
  font-size: var(--fz-13);
  font-weight: 500;
  padding: 2px 10px;
  position: absolute;
  top: 0;
  right: 0;
}
.startups__item__status.participation {
  background-color: #C20000;
}
.startups__item__head {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}
.startups__item__cat {
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 74%, rgba(0, 150, 177, 1) 100%);
  color: #fff;
  padding: 2px 10px;
  border-radius: 30px;
  color: #fff;
  font-size: var(--fz-13);
  flex-shrink: 0;
  height: fit-content;
}
.startups__item__area {
  color: #1A466A;
  font-size: var(--fz-14);
  font-weight: bold;
}
.startups__item__name {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
  color: #1A466A;
  font-size: var(--fz-14);
  font-weight: bold;
}
.startups__item__name dt {
  flex-shrink: 0;
}
.startups__item__business {
  margin-bottom: 20px;
  font-size: var(--fz-14);
}
.startups__item__business dt {
  color: #1A466A;
  font-weight: bold;
}
.startups__item__business dd {
  font-size: var(--fz-13);
}
.startups__item__bottom {
  display: flex;
  align-items: flex-end;
  gap: 10px;
}
.startups__item__img {
  border: 1px solid #E4E4E4;
  max-width: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.startups__item__btns {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  width: 100%;
}
.startups__item__btn {
  width: 100%;
  border-radius: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: bold;
  border: 1px solid #1A466A;
  background-color: #1A466A;
  padding: 6px 24px 6px 8px;
  box-sizing: border-box;
  background-image: url(./assets/images/common/icon_arrow_white.svg);
  background-size: 8px auto;
  background-repeat: no-repeat;
  background-position: center right 12px;
  text-align: center;
}
.startups__item__btn__interview {
  background-color: #fff;
  color: #1A466A;
  background-image: url(./assets/images/common/icon_arrow.svg);
  text-align: center;
}
#interview {
  background-color: rgba(26,7,106,.1);
  padding-bottom: 40px;
}
.top__interview__wrap {
  padding: 0 20px;
}
.interview__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  padding: 0;
  margin: 0 auto 20px;
}
.interview__item {
  width: 100%;
}
.interview__item.hidden {
  opacity: 0;
  max-height: 0;
  padding: 0;
  overflow: hidden;
  display: none;
}
.interview__item.hidden.show {
  max-height: 2000px;
  overflow: unset;
  opacity: 1;
  transition: opacity .4s;
  display: block;
}
.top__interview__wrap .slick-list {
  overflow: visible;
  width: calc(100% + 20px);
}
.top__interview__wrap .slick-track {
  display: flex;
}
.top__interview__wrap .slick-slide {
  opacity: 0;
}
.top__interview__wrap .slick-active {
  opacity: 1;
}
.top__interview__nav__wrap .slick-dots {
  bottom: 0;
  position: relative;
  width: auto;
  font-size: 0;
}
.top__interview__nav__wrap .slick-dots li {
  width: 10px;
  height: 10px;
  margin: 0 6px;
}
.top__interview__nav__wrap .slick-dots li button:before {
  display: none;
}
.top__interview__nav__wrap .slick-dots li button {
  background: #1A466A;
  opacity: .2;
  width: 100%;
  height: 100%;
}
.top__interview__nav__wrap .slick-dots li.slick-active button {
  opacity: 1;
}
.top__interview__nav__wrap {
  display: flex;
  flex-direction: row-reverse;
  gap: 20px;
  align-items: center;
  justify-content: center;
}
.top__interview__nav__switch:hover {
  opacity: .7;
  transform: .3s;
  cursor: pointer;
}
.top__interview__nav__switch img {
  display: none;
  width: 30px;
}
.top__interview__nav__switch img.active {
  display: block;
}
@media screen and (max-width: 1520px) {
  .interview__list {
    max-width: 1020px;
  }
}
#case {
  background-color: #fafafa;
  padding-bottom: 40px;
  overflow: hidden;
}
.top__case__wrap {
  padding: 0 10px;
}
.top__case__slider {
  /*display: flex;*/
  max-width: 1480px;
  opacity: 0;
  justify-content: center;
  margin: 0 auto;
  margin-bottom: 20px!important;
}
.top__case__item {
  margin-right: 20px;
  background-color: #fff;
  border: 1px solid #E4E4E4;
  box-shadow: 0 0 20px rgba(24,64,95,.2);
  padding: 16px 10px 24px;
  box-sizing: border-box;
  position: relative;
  height: auto;
}
a.top__case__item:before {
  content: "";
  background: #1A405F;
  background: linear-gradient(153deg, rgba(26, 64, 95, 1) 53%, rgba(0, 150, 177, 1) 100%);
  width: 24px;
  height: 24px;
  position: absolute;
  bottom: 0;
  right: 0;
}
a.top__case__item:after {
  content: "";
  background-image: url(./assets/images/common/icon_arrow_white.svg);
  background-position: center;
  background-size: 8px auto;
  background-repeat: no-repeat;
  width: 24px;
  height: 24px;
  position: absolute;
  bottom: 0;
  right: 0;
}
.top__case__slider img {
  transition-duration: .3s;
}
a.top__case__slider:hover .top__case__item__img img {
  transform: scale(1.05);
}
.top__case__slider .slick-list {
  overflow: visible;
  width: calc(100% + 20px);
}
.top__case__slider .slick-track {
  display: flex;
}
.top__case__slider .slick-slide {
  opacity: 0;
}
.top__case__slider .slick-active {
  opacity: 1;
}
.top__case__nav__wrap .slick-dots {
  bottom: 0;
  position: relative;
  width: auto;
  font-size: 0;
}
.top__case__nav__wrap .slick-dots li {
  width: 10px;
  height: 10px;
  margin: 0 6px;
}
.top__case__nav__wrap .slick-dots li button:before {
  display: none;
}
.top__case__nav__wrap .slick-dots li button {
  background: #1A466A;
  opacity: .2;
  width: 100%;
  height: 100%;
}
.top__case__nav__wrap .slick-dots li.slick-active button {
  opacity: 1;
}
.top__case__nav__wrap {
  display: flex;
  flex-direction: row-reverse;
  gap: 20px;
  align-items: center;
  justify-content: center;
}
.top__case__nav__switch:hover {
  opacity: .7;
  transform: .3s;
  cursor: pointer;
}
.top__case__nav__switch img {
  display: none;
  width: 30px;
}
.top__case__nav__switch img.active {
  display: block;
}
.top__case__ttl {
  font-size: var(--fz-14);
  font-weight: bold;
  color: #1A466A;
  padding-bottom: 6px;
  margin-bottom: 8px;
  position: relative;
}
.top__case__ttl:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 2px;
  background: #0096B1;
  background: linear-gradient(90deg, rgba(0, 150, 177, 0) 0%, rgba(13, 108, 137, 0.8) 13%, rgba(26, 64, 95, 1) 25%, rgba(26, 64, 95, 1) 75%, rgba(13, 108, 137, 0.8) 87%, rgba(0, 150, 177, 0) 100%);
}
.top__case__name {
  font-size: var(--fz-14);
  font-weight: bold;
  color: #1A466A;
  margin-bottom: 10px;
}
.top__case__item__inner {
  display: flex;
  gap: 10px;
}
.top__case__item__img {
  max-width: 100px;
  overflow: hidden;
  flex-shrink: 0;
}
.top__case__item img {
  transition-duration: .3s;
}
a.top__case__item:hover img {
  transform: scale(1.05);
}
.top__case__item__toc {
  display: flex;
  flex-direction: column;
}
.top__case__item__toc li {
  font-size: var(--fz-13);
  font-weight: bold;
  border-bottom: 1px dotted #ABABAB;
  padding-bottom: 5px;
  margin-bottom: 5px;
}
.top__case__item__toc li span {
  font-weight: normal;
  display: block;
}
#attraction {
  background-image: url(./assets/images/top/img03.jpg);
  background-size: auto 200px;
  background-repeat: no-repeat;
  background-position: left top;
  padding-top: 150px;
}
.attraction__inner {
  width: 100%;
  margin-left: auto;
  background-color: #fff;
  box-shadow: 0 3px 20px rgba(0,0,0,.05);
}
.attraction__head {
  font-size: var(--fz-18);
  color: #fff;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 38%, rgba(0, 150, 177, 1) 100%);
  padding: 16px 20px 20px;
  width: calc(100% + 20px);
  margin-left: -10px;
  text-shadow: 0 0 6px rgba(0,0,0,.3);
  letter-spacing: 0.05em;
  position: relative;
}
.attraction__head:after{
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  border-style: solid;
  border-color: #09253B transparent transparent transparent;
  border-width: 16px 0 0 10px;
  z-index: 10;
}
.attraction__ttl {
  position: relative;
  padding-bottom: 10px;
}
.attraction__ttl:after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 2px;
  bottom: 0;
  left: 0;
  background: #fff;
  background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}
.attraction__body {
  padding: 20px 16px 24px;
}
.attraction__body p {
  margin-bottom: 16px;
  font-size: var(--fz-14);
}
.check__list {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 24px;
}
.check__item {
  padding-left: 24px;
  position: relative;
  font-size: var(--fz-13);
  font-weight: bold;
}
.check__item:before {
  content: "";
  display: block;
  position: absolute;
  top: 1px;
  left: 0;
  background-image: url(./assets/images/common/icon_check.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;
  width: 20px;
  height: 17px;
}
.attraction__img {
  background-color: #F5F5F5;
  padding: 20px;
  text-align: center;
}
.attraction__img img {
  width: 713px;
}
.startups__single__head {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}
.startups__single__cat {
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 74%, rgba(0, 150, 177, 1) 100%);
  color: #fff;
  padding: 2px 10px;
  border-radius: 30px;
  color: #fff;
  font-size: var(--fz-13);
  font-weight: 500;
  flex-shrink: 0;
  height: fit-content;
}
.startups__single__status {
  background-color: #7B7B7B;
  color: #fff;
  font-size: var(--fz-13);
  font-weight: 500;
  padding: 2px 10px;
}
.startups__single__status.participation {
  background-color: #C20000;
}

.case__wrap {
  padding: 0 10px;
}
.case__list {
  max-width: 1480px;
  justify-content: center;
  margin: 0 auto;
  margin-bottom: 20px!important;
  gap: 20px;
  display: flex;
  flex-direction: column;
}
.case__item {
  background-color: #fff;
  border: 1px solid #E4E4E4;
  box-shadow: 0 0 20px rgba(24,64,95,.2);
  padding: 16px 10px 24px;
  box-sizing: border-box;
  position: relative;
  height: auto;
  display: block;
}
.case__item.hidden {
  opacity: 0;
  max-height: 0;
  padding: 0;
  overflow: hidden;
  display: none;
}
.case__item.hidden.show {
  max-height: 2000px;
  overflow: unset;
  padding: 16px 10px 24px;
  opacity: 1;
  transition: opacity .4s;
  display: block;
}
a.case__item:before {
  content: "";
  background: #1A405F;
  background: linear-gradient(153deg, rgba(26, 64, 95, 1) 53%, rgba(0, 150, 177, 1) 100%);
  width: 24px;
  height: 24px;
  position: absolute;
  bottom: 0;
  right: 0;
}
a.case__item:after {
  content: "";
  background-image: url(./assets/images/common/icon_arrow_white.svg);
  background-position: center;
  background-size: 8px auto;
  background-repeat: no-repeat;
  width: 24px;
  height: 24px;
  position: absolute;
  bottom: 0;
  right: 0;
}
.case__ttl {
  font-size: var(--fz-14);
  font-weight: bold;
  color: #1A466A;
  padding-bottom: 6px;
  margin-bottom: 8px;
  position: relative;
}
.case__ttl:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 2px;
  background: #0096B1;
  background: linear-gradient(90deg, rgba(0, 150, 177, 0) 0%, rgba(13, 108, 137, 0.8) 13%, rgba(26, 64, 95, 1) 25%, rgba(26, 64, 95, 1) 75%, rgba(13, 108, 137, 0.8) 87%, rgba(0, 150, 177, 0) 100%);
}
.case__name {
  font-size: var(--fz-14);
  font-weight: bold;
  color: #1A466A;
  margin-bottom: 10px;
}
.case__item__inner {
  display: flex;
  gap: 10px;
}
.case__item__img {
  max-width: 100px;
  overflow: hidden;
  flex-shrink: 0;
}
.case__item img {
  transition-duration: .3s;
}
a.case__item:hover .case__item__img img {
  transform: scale(1.05);
}
.case__item__img__wrap {
  max-width: fit-content;
  overflow: hidden;
  flex-shrink: 0;
}
.case__item__img__wrap .case__item__img {
  width: 100%;
}
.case__item__tag {
  font-size: var(--fz-13);
  font-weight: bold;
  color: #fff;
  background: #1A466A;
  padding: 2px 10px;
  margin-bottom: 8px;
  width: fit-content;
}
.case__item__toc {
  display: flex;
  flex-direction: column;
}
.case__item__toc li {
  font-size: var(--fz-13);
  font-weight: bold;
  border-bottom: 1px dotted #ABABAB;
  padding-bottom: 5px;
  margin-bottom: 5px;
}
.case__item__toc li span {
  font-weight: normal;
  display: block;
}
.interview__head {
  background: #1A405F;
  background: linear-gradient(70deg, rgba(26, 64, 95, 1) 50%, rgba(0, 150, 177, 1) 100%);
  padding: 10px 10px 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 32px;
}
.interview__head__body {
  color: #fff;
}
.interview__head__ttl {
  font-size: var(--fz-20);
  font-weight: 500;
  padding-bottom: 12px;
  margin-bottom: 16px;
  position: relative;
}
.interview__head__ttl:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #fff;
  background: linear-gradient(70deg, rgba(255, 255, 255, 1) 64%, rgba(255, 255, 255, 0) 100%);
}
.interview__head__name {
  font-size: var(--fz-14);
  font-weight: 500;
  margin-bottom: 10px;
}
.interview__head__txt {
  font-size: var(--fz-13);
}
.faq {
  margin-bottom: 24px;
}
.faq__que {
  background: #EFF4F9;
  color: #1A466A;
  font-size: var(--fz-16);
  font-weight: 500;
  padding: 10px 10px;
  position: relative;
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}
.faq__que .que {
  font-size: var(--fz-30);
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  line-height: 1;
  position: relative;
  top: -2px;
}
.faq__ans {
  position: relative;
}
.faq__ans:after {
  content: "";
  display: block;
  clear: both;
}
.case__head {
  margin-bottom: 40px;
}
.case__head__body {
  width: 100%;
  margin-bottom: 24px;
}
.case__head__info {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
}
.case__head__cat {
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 74%, rgba(0, 150, 177, 1) 100%);
  color: #fff;
  padding: 2px 16px;
  border-radius: 30px;
  color: #fff;
  font-size: var(--fz-13);
  flex-shrink: 0;
  height: fit-content;
}
.case__head__area {
  color: #1A466A;
  font-size: var(--fz-14);
  font-weight: bold;
}
.case__head__ttl {
  font-size: var(--fz-20);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #1A466A;
  position: relative;
  padding-bottom: 10px;
}
.case__head__ttl:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #1A405F;
  background: linear-gradient(70deg, rgba(26, 64, 95, 1) 64%, rgba(0, 150, 177, 0) 100%);
}
.case__head__img {
  width: 240px;
  flex-shrink: 0;
  border: 1px solid #E4E4E4;
}
.check__list2 {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 40px;
}
.check__item2 {
  padding-left: 24px;
  position: relative;
}
.check__item2:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(./assets/images/common/icon_check2.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;
  width: 20px;
  height: 17px;
}
.check__item2__lead {
  font-size: var(--fz-14);
  font-weight: bold;
  margin-bottom: 8px;
}

.case__single__item {
  margin-bottom: 32px;
  padding-bottom: 32px;
  border-bottom: 1px dashed #1A466A;
}
.case__single__item__num {
  background-color: #1A466A;
  color: #fff;
  font-size: var(--fz-14);
  padding: 8px 40px;
  width: fit-content;
  text-align: center;
}
.case__single__item__ttl {
  background: #F7F7F7;
  padding: 18px 20px;
  color: #1A466A;
  font-weight: bold;
  font-size: var(--fz-16);
  margin-bottom: 16px;
}
.case__single__item__ul {
  margin-bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.case__single__item__li h4 {
  margin-bottom: 16px;
  font-weight: bold;
}
.case__single__item__li {
  font-size: var(--fz-14);
  font-weight: 500;
  position: relative;
}
.case__single__item__li > p {
  position: relative;
  padding-left: 18px;
}
.case__single__item__li > p:before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  background-color: #CBD7E3;
  border-radius: 20px;
  position: absolute;
  top: 6px;
  left: 3px;
}
.case__single__item__free a {
  position: relative;
}
.case__single__item__free a[target="_blank"]:after {
  content: "";
  display: inline-block;
  background-image: url(./assets/images/common/icon_external2.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 14px;
  height: 12px;
  margin: 0 4px;
}
.case__single__item__img {
  max-width: unset;
  display: flex;
  gap: 20px;
  overflow: auto;
  padding-bottom: 16px;
}
.case__single__item__img img {
  max-width: 260px;
  max-height: 260px;
  height: fit-content;
}
.case__single__item__img__caption {
  font-size: var(--fz-13);
  margin-top: 16px;
}
.case__single__item__link {
  display: flex;
  width: 100%;
  margin-top: 24px;
}
.case__single__item__link__ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fz-14);
  font-weight: 500;
  color: #fff;
  background-color: #1A466A;
  padding: 10px;
  flex-shrink: 0;
}
.case__single__item__link__url {
  font-size: var(--fz-13);
  background: #F5F5F5;
  padding: 10px;
  width: 100%;
  position: relative;
}
.case__single__item__link__url a[target="_blank"]:after {
  content: "";
  display: inline-block;
  background-image: url(./assets/images/common/icon_external2.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 14px;
  height: 12px;
  margin: 0 4px;
}

/* accessibility */
.accessibility-table {
  width: 100%;
  overflow-y: scroll;
}
.accessibility-table table {
  table-layout: fixed;
  width: 410px;
  border-collapse: collapse;
  border-spacing: 0;
  background: #fff;
}
.accessibility-table table th {
  background-color: #F7F7F7;
  padding: 5px;
  border: 1px solid #C5C5C5;
  border-bottom: none;
  text-align: center;
  vertical-align: middle;
  font-size: .8125rem;
}
.accessibility-table table td {
  border: 1px solid #C5C5C5;
  padding: 5px;
  text-align: center;
  vertical-align: middle;
  font-size: .8125rem;
}
.accessibility-table table .wd30 {
  width: 40%;
  text-align: left;
}
.accessibility-table table .wd20 {
  text-align: left;
}
.accessibility-table table th.wd30 ,
.accessibility-table table th.wd20 {
  text-align: center;
}

.sitemap__lang {
  display: flex;
  background-color: #1A466A;
  padding: 4px 20px;
  border-radius: 50px;
  justify-content: center;
  font-size: var(--fz-14);
  font-weight: 500;
  color: #fff;
  max-width: 180px;
  margin-left: auto;
}
.sitemap__lang a {
  color: #fff;
}
.sitemap__lang__ttl {
  font-size: var(--fz-14);
  font-weight: 500;
  margin-right: 10px;
}
.sitemap__lang__item.selected {
  text-decoration: underline;
}
.sitemap__lang__seperator {
  margin: 0 2px;
}
.sitemap__home {
  font-size: var(--fz-14);
  font-weight: 500;
  color: #1A466A;
  border-bottom: 1px solid #E4E4E4;
  padding-bottom: 8px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.sitemap__home:before {
  content: "";
  background-image: url(./assets/images/common/icon_home.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 17px;
  height: 16px;
  display: block;
}
.sitemap__nav {
  display: flex;
  padding-left: 24px;
  margin: 0 auto 40px;
  flex-wrap: wrap;
  gap: 12px 16px;
}
.sitemap__nav__item {
  width: 100%;
}
.sitemap__nav__item a {
  font-size: var(--fz-14);
  font-weight: 500;
  color: #1A466A;
  border-bottom: 1px solid #E4E4E4;
  padding-bottom: 8px;
  display: block;
  width: 100%;
}
.sitemap__wrap .btn__wrap {
  margin-bottom: 40px;
}
.sitemap__subnav {
  display: flex;
  justify-content: flex-end;
  margin: 0 auto;
  flex-wrap: wrap;
  gap: 8px 24px;
  padding-top: 16px;
  border-top: 1px dotted #1A466A;
}
.sitemap__subnav__item a {
  font-size: var(--fz-14);
  font-weight: 500;
  color: #1A466A;
  display: block;
  width: 100%;
}

.startups__logo{
  max-width: 320px;
  border: 1px solid #E4E4E4;
}

/* ==========================================================================
Component [ grid / button / form / media... ]
========================================================================== */
.container {
  max-width: 100%;
  margin: 0 auto 40px;
  padding: 0 10px;
}
.inner {
  background-color: #fff;
  box-shadow: 0 3px 20px rgba(0,0,0,.05);
  padding-bottom: 64px;
  padding: 0 10px 32px;
}
.cont {
  max-width: 960px;
  margin: 0 auto;
}
a.link {
  color: #1A466A;
  text-decoration: underline;
}
.txt {
  font-size: var(--fz-14);
}
.section {
  margin-bottom: 32px;
}
.externalLink:after {
  content: "";
  display: inline-block;
  background-image: url(./assets/images/common/icon_external.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 12px;
  height: 12px;
  margin: 0 4px;
}
.more__btn {
  background-color: #1A466A;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: 500;
  letter-spacing: 0.05em;
  gap: 16px;
  width: 100%;
  padding: 14px;
}
.more__btn:hover {
  cursor: pointer;
  opacity: .7;
  transition: .4s;
}
.more__btn:before {
  content: "";
  width: 8px;
  height: 8px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(135deg);
  position: relative;
  top: -2px;
}
.more__btn.close:before {
  transform: rotate(-45deg);
  top: 2px;
}
.more__btn.close {
  display: none;
}
.hidden__area {
  opacity: 0;
  transition: .4s;
}
.hidden__area.show {
  opacity: 1;
}

/* single */
.singlepage {
  margin-bottom: 64px;
  overflow-wrap: anywhere;
}
.singlepage strong {
  font-weight: bold;
}
.singlepage table {
  table-layout: fixed;
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 40px;
}
.singlepage table th {
  background-color: #1A466A;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: bold;
  text-align: left;
  width: 80px;
  padding: 16px 10px;
  box-sizing: border-box;
  border-top: 1px solid #E4E4E4;
  border-bottom: 1px solid #E4E4E4;
  vertical-align: middle;
}
.singlepage table td {
  border-top: 1px solid #E4E4E4;
  border-bottom: 1px solid #E4E4E4;
  border-right: 1px solid #E4E4E4;
  padding: 16px 10px;
  font-size: var(--fz-14);
  vertical-align: middle;
}
.singlepage table td a[target="_blank"]:after {
  content: "";
  display: inline-block;
  background-image: url(./assets/images/common/icon_external2.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 14px;
  height: 12px;
  margin: 0 4px;
}
.singlepage .table2 th {
  background-color: #EFF4F9;
  color: #1A466A;
  font-size: var(--fz-14);
  font-weight: bold;
  text-align: left;
  width: 80px;
  padding: 16px 10px;
  box-sizing: border-box;
  border: 1px solid #1A466A;
  vertical-align: middle;
}
.singlepage .table2 td {
  border-top: 1px solid #1A466A;
  border-bottom: 1px solid #1A466A;
  border-right: 1px solid #1A466A;
  padding: 16px 10px;
  font-size: var(--fz-14);
  vertical-align: middle;
}

.singlepage .large {
  font-size: var(--fz-16);
}
.singlepage p {
  font-size: var(--fz-14);
}
.singlepage p + p {
  margin-top: 1em;
}
.singlepage a {
  text-decoration: underline;
  color: #1A466A;
}
.singlepage .aligncenter {
  display: block;
  margin-right: auto;
  margin-left: auto;
}
.singlepage .alignright {
  float: right;
  margin-bottom: 20px;
  margin-left: 20px;
}
.singlepage .alignleft {
  float: left;
  margin-right: 20px;
  margin-bottom: 20px;
}
.singlepage .wp-caption {
  display: block;
  max-width: 100% !important;
  margin-top: 1.5em;
  text-align: center;
}
.singlepage [class*='wp-image'] {
  display: block;
  max-width: 100% !important;
  text-align: center;
}
.singlepage .wp-caption-text {
  margin-top: 0;
}

/* cta */
.cta {
  background-color: #F5F5F5;
  padding: 24px 10px;
  margin-top: 40px;
}
.cta__logo {
  width: 80%;
  max-width: 400px;
  margin: 0 auto 14px;
}
.cta__lead {
  text-align: center;
  color: #1A466A;
  font-size: var(--fz-20);
  font-weight: bold;
  margin-bottom: 20px;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.cta__info {
  margin: 0 auto;
}
.cta__date {
  display: flex;
  gap: 6px;
  margin-bottom: 16px;
}
.cta__date__ttl {
  background: #1A405F;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--fz-12);
  font-weight: bold;
  width: 84px;
  height: 28px;
  flex-shrink: 0;
}
.cta__date__ttl span {
  font-size: var(--fz-16);
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
}
.cta__date__body {
  color: #1A405F;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
}
.cta__date__day {
  font-size: var(--fz-16);
  font-family: "din-2014", sans-serif;
  font-weight: 800;
  line-height: 1;
}
.cta__date__day span {
  font-size: var(--fz-22);
  font-weight: 400;
}
.cta__date__dow {
  font-size: var(--fz-16);
  font-family: "din-2014", sans-serif;
  font-weight: 800;
  width: 44px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #1A466A;
  border-radius: 30px;
  box-sizing: border-box;
  position: relative;
  top: -1px;
  margin: 0 4px 0 4px;
}
.cta__date__time {
  font-family: "din-2014", sans-serif;
  font-size: var(--fz-14);
  position: relative;
  top: -2px;
  line-height: 1;
  font-weight: bold;
}
.cta__date__note {
  font-size: var(--fz-12);
  padding: 4px 0;
  font-weight: bold;
  padding-left: 1em;
  text-indent: -1em;
}
.cta__date__note span {
  font-size: var(--fz-14);
  font-family: "din-2014", sans-serif;
}
.cta__place {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}
.cta__place__ttl {
  background: #1A405F;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--fz-14);
  font-weight: bold;
  width: 84px;
  height: 28px;
  flex-shrink: 0;
}
.cta__place__body {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.cta__place__left {
  font-size: var(--fz-13);
  font-weight: 500;
  color: #1A466A;
}
.cta__place__right {
  display: flex;
  gap: 10px;
}
.cta__place__img {
  width: 50px;
}
.cta__place__map {
  font-size: var(--fz-12);
  color: #fff;
  font-weight: 500;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 60%, rgba(0, 150, 177, 1) 100%);
  width: 90px;
  height: 23px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 40px;
}
.cta .btn__wrap {
  margin-top: 24px;
}

/* list */
.list {
  padding-left: 20px;
  position: relative;
  font-size: var(--fz-14);
  overflow-wrap: anywhere;
}
.list:before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  background: #1A466A;
  position: absolute;
  top: 9px;
  left: 6px;
  border-radius: 8px;
}
.list a {
  color: #1A466A;
  text-decoration: underline;
}
.list a[target="_blank"]:after {
  content: "";
  display: inline-block;
  background-image: url(./assets/images/common/icon_external2.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 14px;
  height: 12px;
  margin: 0 4px;
}

/* lv */
.lv__wrap {
  background: #1A405F;
  background: linear-gradient(70deg, rgba(26, 64, 95, 1) 64%, rgba(0, 150, 177, 0) 100%);
}
.lv {
  margin: 0 auto;
  padding: 20px 16px;
  color: #fff;
  font-size: var(--fz-20);
  letter-spacing: 0.05em;
  text-shadow: 0 3px 6px rgba(0,0,0,.16);
}

/* wrap */
.wrap {
  background-color: #EFF4F9;
  padding: 12px;
}
.wrap2 {
  padding: 0;
}

/* btn */
.btn__wrap {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 24px;
}
.btn01 {
  width: 100%;
  height: 60px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0;
  font-size: var(--fz-16);
  font-weight: 500;
  color: #fff;
  background: #1A405F;
  background: linear-gradient(90deg, rgba(26, 64, 95, 1) 60%, rgba(0, 150, 177, 1) 100%);
  max-width: calc(100vw - 40px);
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
}
.btn01:after {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background-image: url(./assets/images/common/icon_external_white.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 20px;
}
.btn02 {
  width: 100%;
  max-width: calc(100vw - 40px);
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 1px solid #1A405F;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
  color: #1A405F;
  font-size: var(--fz-14);
  font-weight: bold;
  text-align: center;
  background-image: url(./assets/images/common/icon_file.svg);
  background-repeat: no-repeat;
  background-position: center right 16px;
  background-size: 14px auto;
}
.btn03 {
  width: 100%;
  max-width: calc(100vw - 40px);
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #1A405F;
  border: 1px solid #1A405F;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
  color: #fff!important;
  text-decoration: unset!important;
  font-size: var(--fz-14);
  font-weight: bold;
  text-align: center;
  background-image: url(./assets/images/common/icon_arrow_white.svg);
  background-repeat: no-repeat;
  background-position: center right 16px;
  background-size: 12px auto;
}
.btn04 {
  width: 100%;
  max-width: 460px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 1px solid #1A405F;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
  color: #1A405F;
  font-size: var(--fz-16);
  font-weight: bold;
  text-align: center;
  background-image: url(./assets/images/common/icon_arrow.svg);
  background-repeat: no-repeat;
  background-position: center right 16px;
  background-size: 12px auto;
}
.btn05 {
  width: 100%;
  max-width: calc(100vw - 40px);
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background-color: #fff;
  border: 1px solid #1A405F;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
  color: #1A405F;
  font-size: var(--fz-14);
  font-weight: bold;
  text-align: center;
}
.btn05:before {
  content: "";
  width: 20px;
  height: 15px;
  display: block;
  background-image: url(./assets/images/common/icon_mail.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
}
.btn06 {
  width: 100%;
  max-width: calc(100vw - 40px);
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 1px solid #1A405F;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0,0,0,.16);
  color: #1A405F;
  font-size: var(--fz-14);
  font-weight: bold;
  text-align: center;
  background-image: url(./assets/images/common/icon_external2.svg);
  background-repeat: no-repeat;
  background-position: center right 16px;
  background-size: 16px auto;
}
body.en .btn06 {
  font-size: var(--fz-13);
}

/* heading */
.heading01 {
  text-align: center;
  color: #1A466A;
  font-size: var(--fz-24);
  font-weight: 500;
  padding-top: 40px;
  padding-bottom: 16px;
  margin-bottom: 24px;
  letter-spacing: 0.05em;
  position: relative;
}
.heading01:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 4px;
  background: #0096B1;
  background: linear-gradient(90deg, rgba(0, 150, 177, 0) 0%, rgba(13, 108, 137, 0.8) 13%, rgba(26, 64, 95, 1) 25%, rgba(26, 64, 95, 1) 75%, rgba(13, 108, 137, 0.8) 87%, rgba(0, 150, 177, 0) 100%);
}
.heading02 {
  color: #1A466A;
  font-size: var(--fz-18);
  font-weight: 500;
  margin-bottom: 12px;
  letter-spacing: 0.05em;
}
.heading02 span {
  font-size: var(--fz-14);
  margin-left: 0.7em;
}
.heading03 {
  background: #0096B1;
  background: linear-gradient(90deg, rgba(0, 150, 177, 0) 0%, rgba(13, 108, 137, 0.8) 5%, rgba(26, 64, 95, 1) 10%, rgba(26, 64, 95, 1) 90%, rgba(13, 108, 137, 0.8) 95%, rgba(0, 150, 177, 0) 100%);
  color: #fff;
  text-align: center;
  font-size: var(--fz-20);
  font-weight: 500;
  padding: 18px;
  max-width: 1280px;
  margin: 0 auto 24px;
  text-shadow: 0 0 6px rgba(0,0,0,.3);
}
.heading04 {
  font-size: var(--fz-18);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #1A466A;
  position: relative;
  padding-bottom: 10px;
  margin-bottom: 20px;
  line-height: 1.4;
}
.heading04 span {
  font-size: var(--fz-14);
}
.heading04:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #1A405F;
  background: linear-gradient(70deg, rgba(26, 64, 95, 1) 64%, rgba(0, 150, 177, 0) 100%);
}
.heading05 {
  text-align: center;
  color: #1A466A;
  font-size: var(--fz-18);
  font-weight: 500;
  padding-bottom: 16px;
  margin-bottom: 24px;
  letter-spacing: 0.05em;
  position: relative;
}
.heading05:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 2px;
  background: #0096B1;
  background: linear-gradient(90deg, rgba(0, 150, 177, 0) 0%, rgba(13, 108, 137, 0.8) 13%, rgba(26, 64, 95, 1) 25%, rgba(26, 64, 95, 1) 75%, rgba(13, 108, 137, 0.8) 87%, rgba(0, 150, 177, 0) 100%);
}
.heading06 {
  color: #1A466A;
  font-size: var(--fz-18);
  font-weight: 500;
  margin-bottom: 12px;
  letter-spacing: 0.05em;
}
.heading07 {
  background: #EFF4F9;
  color: #1A466A;
  font-size: var(--fz-16);
  font-weight: 500;
  padding: 10px;
  position: relative;
  margin-bottom: 16px;
}
.heading07 div {
  width: auto;
  display: inline-block;
}
.heading07 div > img {
  width: auto;
  height: 28px;
  display: inline-block;
}
.heading08 {
  background: #EFF4F9;
  font-size: var(--fz-16);
  font-weight: 500;
  padding: 10px;
  position: relative;
  margin-bottom: 16px;
}
.heading09 {
  color: #1A466A;
  border-bottom: 2px solid #1A466A;
  font-size: var(--fz-16);
  letter-spacing: 0.05em;
  font-weight: bold;
  padding-bottom: 8px;
  margin-bottom: 16px;
  position: relative;
}

/* skip */
.skip {
  width: 1px;
  color: #000000;
  font-size: 0.1%;
  line-height: 0.1;
  background-color: #FFFFFF;
  position: absolute;
  left: -3000px;
  z-index: 30000;
}
a.skip {
  background-color: #FFFFFF;
  /* 変更しない */
  text-align: center;
  /* 変更しない */
  padding: 2px 0;
  /* 変更しない */
  top: auto;
  /* 変更しない */
}
a.skip:active {
  display: block;
  width: 99.99%;
  /* 変更しない */
  font-size: 100%;
  /* 変更しない */
  line-height: 1.6;
  /* 変更しない */
  top: 0;
  /* 変更しない */
  left: 0;
  /* 変更しない */
}
a.skip:focus {
  display: block;
  width: 99.99%;
  /* 変更しない */
  font-size: 100%;
  /* 変更しない */
  line-height: 1.6;
  /* 変更しない */
  top: 0;
  /* 変更しない */
  left: 0;
  /* 変更しない */
}

/* breadcrumbs */
.breadcrumbs_wrap {
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  text-align: right;
  font-size: var(--fz-10);
  letter-spacing: 0.05em;
  padding: 10px 10px 10px;
}
.breadcrumbs_list {
  box-sizing: border-box;
  display: inline-block;
}
.breadcrumbs_list span {
  display: inline-flex;
  position: relative;
  vertical-align: top;
}
.breadcrumbs_list span:first-of-type a {
  color: #1A466A;
  padding-left: 20px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 4px;
}
.breadcrumbs_list span:first-of-type a span {
  text-transform: uppercase;
}
body.en .breadcrumbs_list span:first-of-type a span {
  text-transform: capitalize;
}
.breadcrumbs_list span:first-of-type a:before {
  content: "";
  background-image: url(./assets/images/common/icon_home.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 10px;
  height: 10px;
  display: block;
  position: relative;
  top: 1px;
}
.breadcrumbs_list a {
  color: #1A466A;
}
.breadcrumbs_list span:last-of-type {
  padding-right: 0;
}
.breadcrumbs_list span:last-of-type:after {
  display: none;
}
.breadcrumbs_list span img {
  position: relative;
  top: -2px;
}