@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');

@font-face {
  font-family: "TTCommons-DemiBold";
  src: url("./webfonts/TT-Commons-DemiBold.eot");
  src: url("./webfonts/TT-Commons-DemiBold.eot?#iefix") format("embedded-opentype"), url("./webfonts/f51y7-1zjlk.woff2") format("woff2"), url("./webfonts/TT-Commons-DemiBold.woff") format("woff"), url("./webfonts/TT-Commons-DemiBold.ttf") format("truetype");
}

@font-face {
  font-family: "TTCommons-Bold";
  src: url("./webfonts/TT-Commons-Bold.eot");
  src: url("./webfonts/TT-Commons-Bold.eot?#iefix") format("embedded-opentype"), url("./webfonts/tbyje-cssgz.woff2") format("woff2"), url("./webfonts/TT-Commons-Bold.woff") format("woff"), url("./webfonts/TT-Commons-Bold.ttf") format("truetype");
}

@font-face {
  font-family: "TTCommons-Medium";
  src: url("./webfonts/TT-Commons-Medium.eot");
  src: url("./webfonts/TT-Commons-Medium.eot?#iefix") format("embedded-opentype"), url("./webfonts/172q6-egza8.woff2") format("woff2"), url("./webfonts/TT-Commons-Medium.woff") format("woff"), url("./webfonts/TT-Commons-Medium.ttf") format("truetype");
}

@font-face {
  font-family: "TTCommons-Regular";
  src: url("webfonts/37BD21_0_0.eot");
  src: url("webfonts/37BD21_0_0.eot?#iefix") format("embedded-opentype"), url("webfonts/37BD21_0_0.woff2") format("woff2"), url("webfonts/37BD21_0_0.woff") format("woff"), url("webfonts/37BD21_0_0.ttf") format("truetype");
}

@font-face {
  font-family: "TTCommons-Light";
  src: url("webfonts/3A0AD4_0_0.eot");
  src: url("webfonts/3A0AD4_0_0.eot?#iefix") format("embedded-opentype"), url("webfonts/3A0AD4_0_0.woff2") format("woff2"), url("webfonts/3A0AD4_0_0.woff") format("woff"), url("webfonts/3A0AD4_0_0.ttf") format("truetype");
}

/* ================================================
Reset CSS
================================================ */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
main, menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
  max-width: 100%;
}

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

ol, ul {
  list-style: none;
}

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

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

*, *::before, *::after {
  box-sizing: inherit;
}

button {
  background: none;
  border: none;
  cursor: pointer;
}

input, textarea, select, button {
  font: inherit;
  color: inherit;
  background-color: transparent;
  border: none;
  outline: none;
}

html {
  font-size: 62.5%;
  box-sizing: border-box;
  scroll-behavior: smooth;
}

body {
  color: #393c41;
  letter-spacing: 0.1em;
  font-size: 1.6rem;
  line-height: 1.75;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", "YuGothic", "Meiryo", "メイリオ", "ＭＳ Ｐゴシック", "MS PGothic", Verdana, Roboto, "Droid Sans", sans-serif;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

@media (max-width: 768px) {
  body {
    font-size: 1.2rem;
  }
}

#main {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.l-wrapper {
  flex: 1;
}

a {
  color: inherit;
  text-decoration: none;
  transition: 0.3s;
  cursor: pointer;
}

a:hover {text-decoration: none;}

p {
  line-height: 2;
}

img {
  width: 100%;
  height: auto;
  display: block;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

.spOnly {
  display: none;
}

@media (max-width: 768px) {
  .spOnly {
    display: block;
  }
}

.pcOnly {
  display: block;
}

@media (max-width: 768px) {
  .pcOnly {
    display: none;
  }
}

/* ================================================
utility
================================================ */
.u-en {
  font-family: "TTCommons-Regular", sans-serif;
  font-size: 120%;
  line-height: 1;
}

.u-en.--lh-wide {
  line-height: 1.5;
}

.u-tt-regular {
  font-family: "TTCommons-Regular", sans-serif;
}

.u-mt0 {
  margin-top: 0!important;
}
.u-mt10 {
  margin-top: 1rem!important;
}
.u-mt16 {
  margin-top: 1.6rem!important;
}
.u-mt24 {
  margin-top: 2.4rem!important;
}
.u-mt32 {
  margin-top: 3.2rem!important;
}
.u-mt40 {
  margin-top: 4rem!important;
}
.u-mt50 {
  margin-top: 5rem!important;
}
.u-mt80 {
  margin-top: 8rem!important;
}
.u-mb0 {
  margin-bottom: 0!important;
}

.u-talign-c {
  text-align: center;
}
.u-talign-l {
  text-align: left;
}
.u-talign-r {
  text-align: right;
}
@media (max-width: 768px) {
  .u-talign-c-sp {
    text-align: center;
  }
  .u-talign-l-sp {
    text-align: left;
  }
  .u-talign-r-sp {
    text-align: right;
  }
}

.u-text-uline {
  text-decoration: underline;
  display: inline-block;
}

.u-text-large {
  font-size: 125%;
}

/* フェードインアニメーション */
.js-up {
  opacity: 0;
  transform: translateY(60px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.is-visible-up {
  opacity: 1;
  transform: translateY(0);
}

.js-blur {
  opacity: 0;
  transform: translateY(60px);
  filter: blur(4px);
  transition:
    opacity 1.4s ease,
    transform 1.4s ease,
    filter 1s ease;
  will-change: opacity, transform, filter;
}

.is-visible-blur {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

/* header */
.header {
  background: #fff;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 100;
  margin: 0 auto;
  width: 100%;
  border-bottom: 1px solid #D9D9D9;
}

.header__inner {
  position: relative;
  padding: 2.4rem;
}

.header__content {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header__logo img {
  width: 25rem;
}

.header__nav {
  margin: 0 auto;
}

.main-menu__list {
  display: flex;
  align-items: center;
  column-gap: 5.6rem;
}

.main-menu__link {
  display: inline-block;
  position: relative;
  font-weight: 600;
}

.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

@media screen and (min-width: 960px) {
  .main-menu__link:hover {
    text-decoration: underline;
  }
}

@media screen and (max-width: 959px) {
  .header__inner {
    padding: 2rem;
  }

  .header__logo img {
    width: 18.5rem;
  }

  .menu-toggle {
    display: block;
    cursor: pointer;
  }

  .main-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: calc(100svh - 60px);
    overflow-y: scroll;
    background: #fff;
    padding: 2.4rem;
  }

  .main-menu.is-active {
    display: block;
  }

  .main-menu__list {
    flex-direction: column;
  }

  .main-menu__item {
    border-bottom: 1px solid #ccc;
    width: 100%;
  }

  .main-menu__item + .main-menu__item {
    margin-top: 2.4rem;
  }

  .main-menu__link {
    display: block;
    font-size: 1.4rem;
    padding: 1.6rem 1rem;
  }
}

.menu-toggle-bar {
  display: block;
  width: 30px;
  height: 2px;
  transition: transform 0.3s ease;
  background-color: #949494;
}
.menu-toggle-bar:not(:last-child) {
  margin-bottom: 8px;
}

.menu-toggle.is-active .menu-toggle-bar:first-child {
  transform: translateY(10px) rotate(45deg);
}

.menu-toggle.is-active .menu-toggle-bar:last-child {
  transform: translateY(-10px) rotate(-45deg);
}

.menu-toggle.is-active .menu-toggle-bar:nth-child(2) {
  opacity: 0;
}

/* footer */
.footer {
  background-color: #fff;
  border-top: 1px solid #D9D9D9;
  width: 100%;
}

.footer__logo {
  margin-right: 8rem;
}

.footer__logo img {
  width: 6.4rem;
}

.footer__inner {
  position: relative;
  padding: 2.4rem;
}

.footer__content {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.footer-menu__list {
  display: flex;
  align-items: center;
  column-gap: 3.2rem;
  row-gap: 3.2rem;
  flex-wrap: wrap;
}

.footer-menu__link {
  display: inline-block;
  position: relative;
  font-size: 1.2rem;
  font-weight: 600;
}

@media screen and (min-width: 960px) {
  .footer-menu__link:hover {
    text-decoration: underline;
  }
}

.text-copy {
  font-family: "TTCommons-Regular", sans-serif;
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: 0.04em;
  margin-left: auto;
}

@media screen and (max-width: 959px){
  .footer-nav {
    width: 100%;
    margin-bottom: 2.4rem;
  }

  .text-copy {
    margin-left: 0;
  }
}

/* パンくず */
.breadcrumb {
  font-size: 1.2rem;
  padding: 2.4rem;
}

.breadcrumb__list {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  column-gap: 0.8rem;
}

.breadcrumb__item {
  display: flex;
  align-items: center;
}

.breadcrumb__item:not(:last-child)::after {
  content: "/";
  margin-left: 8px;
  color: #949494;
}

@media screen and (min-width: 960px) {
  .breadcrumb__item a:hover {
    text-decoration: underline;
  }
}

@media screen and (max-width: 959px) {
  .breadcrumb {
    padding: 2.4rem 1.5rem;
  }
}

/* button*/
.c-button {
  display: inline-block;
  padding: 1.4rem 2.4rem;
  border: 1px solid transparent;
  color: #000030;
  background-color: #fff;
  text-align: center;
  text-decoration: none;
  transition: 0.3s;
  line-height: 1.5;
  cursor: pointer;
}

.c-button.--primary {
  background-color: #000030;
  color: #fff;
}

.c-button.--secondary {
  border: 1px solid #000030;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .c-button.--primary:hover {
    background-color: #fff;
    border: 1px solid #000030;
    color: #000030;
  }

  .c-button.--secondary:hover {
    background-color: #000030;
    color: #fff;
  }
}

.c-button.--extra {
  width: 32rem;
  padding: 4rem 2.4rem;
  font-size: 2.4rem;
}

.c-button.--regular {
  width: 26rem;
}

.c-button.--small {
  width: 20rem;
  padding: 1rem 1.6rem;
}

.button-wrapper {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  column-gap: 8rem;
  row-gap: 4rem;
}

.button-wrapper.--center {
  justify-content: center;
}

@media (max-width: 768px) {
  .button-wrapper {
    column-gap: 2.4rem;
  }

  .c-button.--extra {
    max-width: 16rem;
    padding: 2rem 0.8rem;
    font-size: 1.4rem;
  }

  .c-button.--small {
    font-size: 1.2rem;
  }
}

.page-header {
  background-color: #eee;
  padding: 0 2.4rem;
}

.page-header__inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 4.8rem 0;
}

.section-header {
  background-color: #000030;
  padding: 0 2.4rem;
}

.section-header__inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 2.4rem 0;
}

*[class*="c-heading"] {
  color: #000030;
  letter-spacing: 0.1em;
  margin-bottom: 2.4rem;
}

*[class*="c-heading"].--white {
  color: #fff;
}

.c-heading-primary {
  font-size: 3.8rem;
    letter-spacing: 0.18em;
}

.c-heading-secondary {
  font-size: 3.2rem;
  letter-spacing: 0.25em;
}

.c-heading-tertiary {
  font-size: 2rem;
}

@media (max-width: 768px) {
  .page-header {
    padding: 0 1.5rem;
  }

  .page-header__inner {
    padding: 4rem 0;
  }

  .section-header__inner {
    padding: 1.8rem 0;
  }

  *[class*="c-heading"] {
    margin-bottom: 1.8rem;
  }

  .c-heading-primary {
    font-size: 2.4rem;
  }

  .c-heading-secondary {
    font-size: 2rem;
  }

  .c-heading-tertiary {
    font-size: 1.6rem;
  }
}

.l-section {
  padding: 0 2.4rem 8rem;
  margin-bottom: auto;
}

.l-section__inner {
  max-width: 1140px;
  margin: 0 auto;
}

.lead-text {
  padding: 5rem 0;
}

.flow > * + * {
  margin-top: var(--flow-space, 4rem);
}

.c-content {
  padding: 6.4rem 0 5.6rem;
}

.l-section__inner > .c-content:last-child {
  padding-bottom: 0;
}

*[class*="c-content"].--border-top {
  border-top: 1px solid #ccc;
}

.c-content-button {
  padding: 10rem 0 0;
}

.c-box {
  padding: 4.8rem 6.4rem;
}

.c-box.--border {
  border: 1px solid #000030;
}

.c-box-attention {
  padding: 3.2rem 4rem;
  border: 1px solid #ccc;
}

@media (max-width: 768px) {
  .l-section {
    padding: 0 1.5rem 6.4rem;
  }

  .lead-text {
    padding: 4rem 0;
  }

  .flow > * + * {
    margin-top: var(--flow-space, 2.4rem);
  }

  .flow * + .c-box {
    --flow-space: 4rem;
  }

  .c-content {
    padding: 4rem 0;
  }

  .c-box, .c-box-attention  {
    padding: 2.4rem 1.6rem;
  }

  .c-content-button {
    padding: 4rem 0 0;
  }
}

.c-grid-half {
  display: flex;
  column-gap: 4rem;
  row-gap: 4rem;
}

.c-grid-half__item {
  width: calc((100% - 4rem) / 2);
}

@media (max-width: 768px) {
  .c-grid-half {
    flex-direction: column;
  }

  .c-grid-half__item {
    width: 100%;
  }
}

.transfer-list__row {
  display: flex;
}

.transfer-list__term {
  min-width: 5.8em;
}

.transfer-list__desc::before {
  content: "：";
  padding-right: 0.5em;
}

.qa-list__row + .qa-list__row {
  margin-top: 4rem;
}

.qa-list__term {
  font-weight: 600;
}

.qa-list__desc {
  margin-top: 1.4rem;
}

.director-list {
  line-height: 2;
}

.director-list__row {
  display: flex;
}

.director-list__row + .director-list__row {
  margin-top: 1rem;
}

.director-list__term {
  width: 4em;
  margin-right: 1em;
}

@media (max-width: 768px) {
  .qa-list__row + .qa-list__row {
    margin-top: 3.2rem;
  }
}


/* list */
.c-list-disc__item {
  position: relative;
  padding-left: 1em;
}

.c-list-disc__item::before {
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}

.c-list-arrow__item {
  position: relative;
  padding-left: 1em;
}

.c-list-arrow__item::before {
  content: "〉";
  position: absolute;
  left: 0;
  top: 0;
}

*[class*="c-list"].--emphasis > *[class*="c-list"] + *[class*="c-list"] {
  margin-top: 0.8rem;
}

/* チャート図 */
.info-step__item {
  position: relative;
}

.info-step__item:not(:last-child) {
  padding-bottom: 2.8rem;
}

/* ▼ */
.info-step__item:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  transform: translateY( -50% );
  width: 16px;
  height: 12px;
  background: #000030;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.info-form__text {
  margin-top: 2.4rem;
}

/* TOP */
.l-mv {
  padding: 9% 20%;
}

.l-mv__img {
  width: 65rem;
  margin: 0 auto;
}

.top-message {
  padding-bottom: 10rem;
}

.top-message__title {
  font-size: 4.5rem;
  margin-bottom: 4rem;
  text-align: center;
  letter-spacing: 0.2em;
}

.top-message__desc {
  text-align: center;
}

.top-message__desc > * + * {
  margin-top: 4rem;
}

.top-message .button-wrapper {
  margin-top: 6.4rem;
}

@media (max-width: 1000px) {
  .top-message__title {
    font-size: 3.2142vw;
  }
}

@media (max-width: 768px) {
  .l-mv {
    padding: 16% 10%;
  }

  .l-mv__img {
    width: 65.4%;
    min-width: 24.5rem;
  }

  .top-message {
    padding-bottom: 4rem;
  }

  .top-message__title {
    font-size: 2rem;
    margin-bottom: 2rem;
  }

  .top-message__desc > * + * {
    margin-top: 2.4rem;
  }

  .top-message .button-wrapper {
    margin-top: 4.8rem;
  }
}

/* about */
.page-hero {
  position: relative;
}
.page-hero__img img {
  width: 100%;
  height: auto;
  display: block;
}

.page-hero__content {
  position: absolute;
  inset: 0;
  max-width: 1188px;
  margin: 0 auto;
  padding: 0 2.4rem;
  display: flex;
  flex-direction: column;
}

.page-hero__title {
  font-size: 4.5rem;
  line-height: 1.4;
  letter-spacing: 0.24em;
  margin-bottom: 3.2rem;
}

.page-hero__title::after {
  content: attr(data-en);
  display: block;
  font-family: "TTCommons-regular", sans-serif;
  font-size: 120%;
  line-height: 1;
  margin-top: 1rem;
}

.page-hero__text {
  margin-top: auto;
  color: #000030;
  font-size: 1.6rem;
  padding: 4% 0 5%;
}

.page-hero__text p + p {
  margin-top: 2.4rem;
}

@media screen and (max-width: 1100px) {
  .page-hero__title {
    font-size: 4.687vw;
  }

  .page-hero__text {
    font-size: 1.666vw;
  }

  .page-hero__text p + p {
    margin-top: 0;
  }
}

@media screen and (max-width: 768px) {
  .page-hero__title {
    font-size: 6.4vw;
    margin-bottom: 1.8rem;
  }

  .page-hero__text {
    font-size: 3.2vw;
    padding-bottom: 2.4rem;
  }
}

@media screen and (max-width: 480px) {
  .page-hero__content {
    padding: 0 1.8rem;
  }

  .page-hero__title {
    font-size: 2.4rem;
    margin-bottom: 1.6rem;
  }

  .page-hero__text {
    font-size: 1.2rem;
  }
}


/* table */
.c-table {
  width: 100%;
  border-collapse: collapse;
}

.c-table th,
.c-table td {
  border: 1px solid #000030;
  vertical-align: top;
}

.c-table th {
  width: 30%;
  padding: 2.4rem;
  text-align: center;
  font-weight: 600;
}

.c-table td {
  padding: 2.4rem 4rem;
}

.c-table td > p + p {
  margin-top: 1rem;
}

@media (max-width: 768px) {
  .c-table th, .c-table td {
    padding: 1.4rem 1rem;
  }
}



/* mailadd */
.c-content.mail-add input[type="email"] {
    border: solid 1px #aaa;
    padding: 8px;
    margin: 8px 0 0;
}
@media (max-width: 768px) {
  .c-content.mail-add input[type="email"] {
    width: 100%;
  }
}

.c-content.mail-add input.button {
    border: 1px solid #000030;
    border-radius: 3px;
    background-color: #000030;
    color: #fff;
    cursor: pointer;
    padding: 8px 24px;
    transition: 0.3s;
}

.c-content.mail-add button[type="submit"] {
    background-color: #fff;
    border: solid 1px #000030;
    color: #000030;
    padding: 8px 24px;
    border-radius: 3px;
    transition: 0.3s;
}

@media screen and (min-width: 768px) {
  .c-content.mail-add input.button:hover {
    background-color: #fff;
    border: 1px solid #000030;
    color: #000030;
  }

  .c-content.mail-add button[type="submit"]:hover {
    background-color: #000030;
    color: #fff;
  }
}
