/*! minireset.css v0.0.6 | MIT License | github.com/jgthms/minireset.css */
html,
body,
p,
ol,
ul,
li,
dl,
dt,
dd,
blockquote,
figure,
fieldset,
legend,
textarea,
pre,
iframe,
hr,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%
}

ul {
  list-style: none
}

button,
input,
select {
  margin: 0
}

html {
  box-sizing: border-box
}

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

img,
video {
  height: auto;
  max-width: 100%
}

iframe {
  border: 0
}

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

td,
th {
  padding: 0
}

*,
*::before,
*::after {
  box-sizing: border-box
}

html {
  width: 100%;
  min-height: 100vh;
  font-size: 62.5%
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  position: relative;
  width: 100%;
  min-height: 100%;
  overflow-x: hidden;
  color: #000;
  word-wrap: break-word;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: unset;
  -webkit-text-size-adjust: 100%
}

a {
  color: currentColor;
  text-decoration: none
}

input,
button,
select,
textarea {
  outline: none;
  background: rgba(0, 0, 0, 0);
  padding: 0;
  border: none;
  border-radius: 0;
  font: inherit;
  color: currentColor;
  text-align: left;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

textarea {
  resize: vertical
}

input[type=checkbox],
input[type=radio] {
  display: none
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer
}

select::-ms-expand {
  display: none
}

img,
video,
picture,
svg {
  display: block;
  width: 100%
}

svg {
  overflow: visible
}

.mask {
  position: relative;
  overflow: hidden
}

.mask::before {
  content: "";
  background-color: #00338e;
  position: absolute;
  top: -50%;
  left: 0;
  width: 100%;
  height: 150%;
  z-index: 2;
  -webkit-clip-path: polygon(0 0, 100% 25%, 100% 100%, 0 100%);
  clip-path: polygon(0 0, 100% 25%, 100% 100%, 0 100%)
}

.box-link {
  position: relative;
  overflow: hidden;
  border: 1px solid #00338e
}

.box-link p,
.box-link span {
  position: relative;
  transition: color .3s;
  z-index: 2
}

.box-link--blue {
  border-color: #fff
}

.box-link--blue .box-link__bg::after {
  background-color: #00338e
}

.box-link--green {
  border-color: #fff
}

.box-link--green .box-link__bg::after {
  background-color: #008086
}

.box-link__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 120%;
  height: 100%
}

.box-link__bg::before,
.box-link__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateX(100%) skewX(30deg)
}

.box-link__bg::before {
  background-color: #edf5fa;
  transition: transform .5s ease
}

.box-link__bg::after {
  background-color: #fff;
  transition: transform .8s ease
}

.js-scroll-locked {
  position: fixed;
  left: 0;
  overflow-y: scroll
}

.br::before {
  content: "\a";
  white-space: pre
}

.br--md::before {
  content: "";
  white-space: normal
}

.inline-block {
  display: inline-block
}

.none-sp {
  display: none
}

.header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999
}

.header__inner {
  position: relative;
  width: 100%
}

.header__contents {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 20 / 768 * 100, 15px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 20 / 768 * 100, 15px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 20 / 768 * 100, 15px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px)
}

.header__contents--fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 50%;
  transform: translateX(100%);
  transition: transform .5s, -webkit-clip-path .5s;
  transition: transform .5s, clip-path .5s;
  transition: transform .5s, clip-path .5s, -webkit-clip-path .5s;
  -webkit-clip-path: polygon(0 0, 0 0, 0 0);
  clip-path: polygon(0 0, 0 0, 0 0)
}

.header__contents--fixed.is-active {
  -webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
  clip-path: polygon(0 0, 200% 0, 0 200%)
}

.header__logo {
  display: block;
  position: absolute;
  top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px);
  left: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px);
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 170 / 768 * 100, 127.5px);
  max-width: 120px
}

.header__box {
  display: none
}

.header__drawer {
  background: #000;
  position: relative;
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 120 / 768 * 100, 90px);
  height: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 120 / 768 * 100, 90px)
}

.header__drawer .header__drawer-menu {
  display: block;
  color: #fff;
  text-align: center;
  text-transform: uppercase
}

.header__drawer[aria-expanded=true] {
  background: #fff
}

.header__drawer[aria-expanded=true] .header__drawer-menu {
  display: none
}

.header__drawer[aria-expanded=true] .header__drawer-close {
  display: block
}

.header__drawer[aria-expanded=true] .header__border span {
  background: #000
}

.header__drawer[aria-expanded=true] .header__border span:nth-of-type(1),
.header__drawer[aria-expanded=true] .header__border span:nth-of-type(3) {
  top: 50%;
  transition: top .3s .05s ease, transform .3s .35s ease
}

.header__drawer[aria-expanded=true] .header__border span:nth-of-type(1) {
  transform: translate(-50%, -50%) rotate(45deg)
}

.header__drawer[aria-expanded=true] .header__border span:nth-of-type(2) {
  opacity: 0
}

.header__drawer[aria-expanded=true] .header__border span:nth-of-type(3) {
  transform: translate(-50%, -50%) rotate(-45deg)
}

.header__drawer-close {
  display: none;
  color: #000;
  text-align: center;
  text-transform: uppercase
}

.header__border {
  position: relative;
  left: 50%;
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px);
  height: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 24 / 768 * 100, 18px);
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 12 / 768 * 100, 9px);
  transform: translateX(-50%)
}

.header__border span {
  content: "";
  background: #fff;
  position: absolute;
  left: 50%;
  width: 100%;
  height: 2px;
  transform: translate(-50%, -50%);
  transition: top .3s .35s ease, transform .3s .05s ease
}

.header__border span:nth-of-type(1) {
  top: 0
}

.header__border span:nth-of-type(2) {
  top: 50%;
  transition: opacity .5s
}

.header__border span:nth-of-type(3) {
  top: 100%
}

.header__contents--fixed .header__logo {
  position: relative
}

.header__contents--fixed .header__drawer {
  border-radius: 0
}

.header__contents--fixed .header__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #00338e;
  color: #fff
}

.header-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  visibility: hidden;
  pointer-events: none;
  z-index: -1
}

.header-drawer[aria-expanded=true] {
  visibility: visible;
  pointer-events: auto
}

.header-drawer[aria-expanded=true] .header-drawer__inner {
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%)
}

.header-drawer .box-link {
  border: none
}

.header-drawer .box-link__bg {
  top: -5%;
  height: 110%
}

.header-drawer .header__logo {
  position: absolute;
  top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px);
  left: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px);
  z-index: 1
}

.header-drawer .txt {
  font-size: clamp(1.5rem,
      calc(1.8rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.046875),
      2.7rem)
}

.header-drawer .txt-small-1 {
  font-size: clamp(1.1666666667rem,
      calc(1.4rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0364583333),
      2.1rem)
}

.header-drawer__inner {
  background: #333;
  position: relative;
  right: 0;
  width: 100%;
  height: 100%;
  margin: 0 0 0 auto;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 180 / 768 * 100, 135px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px);
  transition: .5s cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-clip-path: polygon(30% 70%, 50% 50%, 70% 30%, 50% 50%);
  clip-path: polygon(30% 70%, 50% 50%, 70% 30%, 50% 50%)
}

.header-drawer__deco {
  position: absolute;
  z-index: -1
}

.header-drawer__deco--1 {
  top: 0;
  right: 0
}

.header-drawer__deco--2 {
  display: none
}

.header-drawer__scroll {
  height: 100%;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 30 / 768 * 100, 22.5px) 0;
  overflow-y: scroll
}

.header-drawer__scroll::-webkit-scrollbar {
  display: none
}

.header-drawer__scroll::-webkit-scrollbar-thumb {
  display: none
}

.header-drawer__nav {
  display: grid;
  width: 100%;
  margin: 0 auto;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px) 0
}

.header-drawer__nav--left {
  display: grid;
  row-gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px)
}

.header-drawer__nav--right {
  display: grid;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px)
}

.header-drawer__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  width: 100%;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 30 / 768 * 100, 22.5px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 24 / 768 * 100, 18px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 30 / 768 * 100, 22.5px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 57 / 768 * 100, 42.75px)
}

.header-drawer__link--nolink {
  pointer-events: none
}

.header-drawer__link--nolink .circle-arrow {
  opacity: 0
}

.header-drawer__children {
  display: grid;
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 24 / 768 * 100, 18px);
  padding: 0 min(min(var(--vw, 1vw), var(--svh, 1vh)) * 44 / 768 * 100, 33px);
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px)
}

.header-drawer__bottom {
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 80 / 768 * 100, 60px)
}

.header-drawer__children-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 12 / 768 * 100, 9px);
  border-bottom: solid 1px rgba(255, 255, 255, .2)
}

.header-drawer__children-link .txt-small-1 {
  color: #fff;
  transition: color .3s
}

.header-drawer__children-arrow {
  position: relative;
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 20 / 768 * 100, 15px);
  height: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 20 / 768 * 100, 15px);
  overflow: hidden
}

.header-drawer__children-icon {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%
}

.header-drawer__children-icon--1 {
  transform: translateX(0%);
  animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
}

.header-drawer__children-icon--2 {
  transform: translateX(-100%);
  animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both
}

.header-drawer__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 56 / 768 * 100, 42px)
}

.header-drawer__sns-icon {
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 56 / 768 * 100, 42px)
}

.header-drawer__copyright {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(0.9166666667rem,
      calc(1.1rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0286458333),
      1.65rem);
  display: block;
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 80 / 768 * 100, 60px);
  line-height: 1.0909090909;
  letter-spacing: .025em;
  color: #888;
  text-align: center
}

.header-drawer__item--sp {
  display: grid;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px)
}

.header-drawer__item--sp .header-drawer__link {
  background: #00338e;
  color: #fff
}

.footer {
  margin-left: calc(50% - var(--vw, 1vw)*50);
  margin-right: calc(50% - var(--vw, 1vw)*50);
  background: #00338e;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 20 / 768 * 100, 15px)
}

.footer .box-link {
  border: none
}

.footer .box-link__bg {
  top: -5%;
  height: 110%
}

.footer__inner {
  background: #333;
  position: relative;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 120 / 768 * 100, 90px);
  overflow: hidden
}

.footer__deco {
  position: absolute;
  z-index: 1
}

.footer__deco--1 {
  top: 0;
  right: 0
}

.footer__deco--2 {
  display: none
}

.footer__contents {
  position: relative;
  z-index: 2
}

.footer__catch {
  position: relative;
  color: #fff;
  text-align: right;
  white-space: nowrap
}

.footer__catch span {
  font-feature-settings: "palt"
}

.footer__logolink {
  display: block;
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 82 / 768 * 100, 61.5px)
}

.footer__logo {
  width: 148px;
  margin: 0 auto
}

.footer__name {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 32 / 768 * 100, 24px);
  color: #888;
  text-align: center;
  text-transform: uppercase
}

.footer__nav {
  display: none
}

.footer__nav--left {
  display: grid;
  row-gap: min(var(--vw, 1vw) * 32 / 1360 * 100, 40px)
}

.footer__link--nolink {
  pointer-events: none
}

.footer__link--nolink .circle-arrow {
  opacity: 0
}

.footer__bottom {
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 80 / 768 * 100, 60px)
}

.footer__children-link .txt-small-1 {
  color: #fff;
  transition: color .3s
}

.footer__children-icon--1 {
  transform: translateX(0%);
  animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
}

.footer__children-icon--2 {
  transform: translateX(-100%);
  animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both
}

.footer__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 56 / 768 * 100, 42px)
}

.footer__sns-icon {
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 56 / 768 * 100, 42px)
}

.footer__copyright {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(0.9166666667rem,
      calc(1.1rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0286458333),
      1.65rem);
  display: block;
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 80 / 768 * 100, 60px);
  line-height: 1.0909090909;
  letter-spacing: .025em;
  color: #888;
  text-align: center
}

.footer__nbk-link {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh))*56/768*100, 42px)
}

.footer__nbk-link__txt {
  display: block;
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh))*80/768*100, 60px);
  color: #fff
}

.footer__nbk-link__txt .txt-small-1 {
  color: #fff;
  transition: color .3s
}

.footer__nbk-link__txt .nbk-link__icon {
  display: inline;
  width: 1em;
  margin-left: .25em;
  transition: all .3s;
  opacity: 1
}

.side-nav {
  display: block;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 998
}

.side-nav .box-link {
  border: none
}

.side-nav__box {
  display: grid;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 4 / 768 * 100, 3px);
  grid-template-columns: repeat(2, 1fr)
}

.side-nav__link {
  display: block;
  background: #000;
  position: relative;
  padding: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100, 30px) min(min(var(--vw, 1vw), var(--svh, 1vh)) * 12 / 768 * 100, 9px);
  overflow: hidden;
  color: #fff;
  text-align: center
}

.side-nav__link:nth-of-type(3) {
  grid-area: 2/1/3/3
}

.side-nav__link--one {
  grid-area: 2/1/3/3
}

.side-nav__box--three {
  display: grid;
  grid-template-columns: repeat(3, 1fr)
}

.side-nav__box--three .side-nav__link:nth-of-type(3) {
  grid-area: auto
}

.side-nav__box--three .side-nav__link {
  display: flex;
  justify-content: center;
  align-items: center
}

.side-nav__txt {
  font-size: clamp(1.0833333333rem,
      calc(1.3rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0338541667),
      1.95rem);
  position: relative;
  font-weight: 700;
  line-height: 1.69;
  letter-spacing: 0;
  z-index: 2
}

.side-nav__txt::before {
  margin-top: calc((1 - 1.69)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.side-nav__txt::after {
  margin-bottom: calc((1 - 1.69)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

@-moz-document url-prefix() {}

.container {
  display: flex;
  justify-content: center;
  padding: 0 calc(min(var(--vw, 1vw), var(--svh, 1vh)) * 40 / 768 * 100)
}

.container__inner {
  width: 100%;
  max-width: calc((768px - 80px)*1.125)
}

.bg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  z-index: -100;
  -o-object-fit: cover;
  object-fit: cover
}

.hdg1 {
  font-size: clamp(2.6666666667rem,
      calc(3.2rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0833333333),
      4.8rem);
  line-height: 1.37;
  letter-spacing: 0
}

.hdg1::before {
  margin-top: calc((1 - 1.37)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg1::after {
  margin-bottom: calc((1 - 1.37)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg2 {
  font-size: clamp(2.5rem,
      calc(3rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.078125),
      4.5rem);
  line-height: 1.4;
  letter-spacing: 0
}

.hdg2::before {
  margin-top: calc((1 - 1.4)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg2::after {
  margin-bottom: calc((1 - 1.4)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg3 {
  font-size: clamp(2.1666666667rem,
      calc(2.6rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0677083333),
      3.9rem);
  line-height: 1.38;
  letter-spacing: 0
}

.hdg3::before {
  margin-top: calc((1 - 1.38)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg3::after {
  margin-bottom: calc((1 - 1.38)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg4 {
  font-size: clamp(1.6666666667rem,
      calc(2rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0520833333),
      3rem);
  line-height: 1.4;
  letter-spacing: 0
}

.hdg4::before {
  margin-top: calc((1 - 1.4)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg4::after {
  margin-bottom: calc((1 - 1.4)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg5 {
  font-size: clamp(1.5rem,
      calc(1.8rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.046875),
      2.7rem);
  line-height: 1.55;
  letter-spacing: 0
}

.hdg5::before {
  margin-top: calc((1 - 1.55)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg5::after {
  margin-bottom: calc((1 - 1.55)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg6 {
  font-size: clamp(1.1666666667rem,
      calc(1.4rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0364583333),
      2.1rem);
  line-height: 1.71;
  letter-spacing: 0
}

.hdg6::before {
  margin-top: calc((1 - 1.71)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg6::after {
  margin-bottom: calc((1 - 1.71)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt {
  font-size: clamp(1rem,
      calc(1.2rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.03125),
      1.8rem);
  line-height: 1.83;
  letter-spacing: 0
}

.txt::before {
  margin-top: calc((1 - 1.83)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt::after {
  margin-bottom: calc((1 - 1.83)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt-small-1 {
  font-size: clamp(0.9166666667rem,
      calc(1.1rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0286458333),
      1.65rem);
  font-weight: 500;
  line-height: 1.63;
  letter-spacing: 0
}

.txt-small-1::before {
  margin-top: calc((1 - 1.63)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt-small-1::after {
  margin-bottom: calc((1 - 1.63)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt-small-2 {
  font-size: clamp(0.8333333333rem,
      calc(1rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0260416667),
      1.5rem);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0
}

.txt-small-2::before {
  margin-top: calc((1 - 1.6)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt-small-2::after {
  margin-bottom: calc((1 - 1.6)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg1-en {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(4rem,
      calc(4.8rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.125),
      7.2rem);
  line-height: 1;
  letter-spacing: .025em
}

.hdg1-en::before {
  margin-top: calc((1 - 1)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg1-en::after {
  margin-bottom: calc((1 - 1)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg2-en {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(2.6666666667rem,
      calc(3.2rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0833333333),
      4.8rem);
  line-height: 1.37;
  letter-spacing: .025em
}

.hdg2-en::before {
  margin-top: calc((1 - 1.37)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg2-en::after {
  margin-bottom: calc((1 - 1.37)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg3-en {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(2rem,
      calc(2.4rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0625),
      3.6rem);
  line-height: 1.16;
  letter-spacing: .025em
}

.hdg3-en::before {
  margin-top: calc((1 - 1.16)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg3-en::after {
  margin-bottom: calc((1 - 1.16)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg4-en {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1.3333333333rem,
      calc(1.6rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0416666667),
      2.4rem);
  line-height: 1.25;
  letter-spacing: .025em
}

.hdg4-en::before {
  margin-top: calc((1 - 1.25)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg4-en::after {
  margin-bottom: calc((1 - 1.25)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg5-en {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1.1666666667rem,
      calc(1.4rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0364583333),
      2.1rem);
  line-height: 1.28;
  letter-spacing: .025em
}

.hdg5-en::before {
  margin-top: calc((1 - 1.28)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg5-en::after {
  margin-bottom: calc((1 - 1.28)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg6-en {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1rem,
      calc(1.2rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.03125),
      1.8rem);
  line-height: 1.16;
  letter-spacing: .025em
}

.hdg6-en::before {
  margin-top: calc((1 - 1.16)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.hdg6-en::after {
  margin-bottom: calc((1 - 1.16)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt-en-small {
  font-family: "Jost", sans-serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(0.9166666667rem,
      calc(1.1rem + (min(var(--vw, 1vw), var(--svh, 1vh)) * 100 - 384px) * 0.0286458333),
      1.65rem);
  line-height: 1.09;
  letter-spacing: .025em
}

.txt-en-small::before {
  margin-top: calc((1 - 1.09)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.txt-en-small::after {
  margin-bottom: calc((1 - 1.09)*.5em);
  content: "";
  display: block;
  width: 0;
  height: 0
}

.circle-arrow {
  display: grid;
  place-items: center;
  position: relative;
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 72 / 768 * 100, 54px);
  overflow: hidden;
  border-radius: 50%;
  z-index: 5;
  aspect-ratio: 1/1
}

.circle-arrow--small {
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 56 / 768 * 100, 42px)
}

.circle-arrow--white {
  background-color: #fff
}

.circle-arrow--white .circle-arrow__bg::before {
  background-color: #00338e
}

.circle-arrow--blue {
  background-color: #00338e
}

.circle-arrow--blue .circle-arrow__bg::before {
  background-color: #fff
}

.circle-arrow__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 120%;
  height: 100%;
  transition: transform .01s linear .2s
}

.circle-arrow__bg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateX(100%) skewX(30deg);
  transition: transform .3s ease
}

.circle-arrow__wrap {
  position: relative;
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 24 / 768 * 100, 18px);
  overflow: hidden;
  aspect-ratio: 1/1
}

.circle-arrow__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.circle-arrow__img:first-child {
  transform: translateX(0%);
  animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
}

.circle-arrow__img:last-child {
  transform: translateX(-100%);
  animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both
}

.sec {
  display: grid;
  gap: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 60 / 768 * 100, 45px) 0
}

.sec+.sec {
  margin-top: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 96 / 768 * 100, 72px)
}

.line {
  position: relative
}

.line--top {
  border-top: 1px solid #ccc
}

.line--top::before {
  top: 0;
  transform: translateY(-50%)
}

.line--bottom {
  border-bottom: 1px solid #00338e
}

.line--bottom::before {
  bottom: 0;
  transform: translateY(50%)
}

.line::before {
  content: "";
  background-color: #00338e;
  position: absolute;
  left: 0;
  width: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 120 / 768 * 100, 90px);
  height: min(min(var(--vw, 1vw), var(--svh, 1vh)) * 8 / 768 * 100, 6px)
}

@keyframes transformLeftCenter {
  0% {
    transform: translateX(-100%)
  }

  100% {
    transform: translateX(0)
  }
}

@keyframes transformCenterRight {
  0% {
    transform: translateX(0)
  }

  100% {
    transform: translateX(100%)
  }
}

.projectstory-index_movie {
  margin-top: 30px;
}

.projectstory-index_movie_youtube {
  text-align: center;
}

@media screen and (min-width: 960px) {
  .box-link {
    border-width: 2px
  }

  .br--sp::before {
    content: "";
    white-space: normal
  }

  .br--md::before {
    content: "\a";
    white-space: pre
  }

  .none-sp {
    display: block
  }

  .none-md {
    display: none
  }

  .header__contents {
    padding: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px) min(var(--vw, 1vw) * 56 / 1360 * 100, 70px) min(var(--vw, 1vw) * 20 / 1360 * 100, 25px) min(var(--vw, 1vw) * 20 / 1360 * 100, 25px)
  }

  .header__contents--fixed {
    left: calc(min(var(--vw, 1vw) * 56 / 1360 * 100, 70px) * -1);
    padding: 0
  }

  .header__logo {
    top: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px);
    left: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px);
    width: min(var(--vw, 1vw) * 220 / 1360 * 100, 275px);
    max-width: 232px
  }

  .header__nav {
    display: flex;
    align-items: center;
    gap: min(var(--vw, 1vw) * 18 / 1360 * 100, 22.5px)
  }

  .header__box {
    display: flex;
    gap: min(var(--vw, 1vw) * 18 / 1360 * 100, 22.5px)
  }

  .header__drawer {
    width: min(var(--vw, 1vw) * 64 / 1360 * 100, 80px);
    height: min(var(--vw, 1vw) * 64 / 1360 * 100, 80px)
  }

  .header__border {
    width: min(var(--vw, 1vw) * 24 / 1360 * 100, 30px);
    height: min(var(--vw, 1vw) * 10 / 1360 * 100, 12.5px);
    margin-top: min(var(--vw, 1vw) * 6 / 1360 * 100, 7.5px)
  }

  .header__contents--fixed .header__logo {
    top: min(var(--vw, 1vw) * 12 / 1360 * 100, 15px);
    left: min(var(--vw, 1vw) * 12 / 1360 * 100, 15px);
    width: 144px
  }

  .header__contents--fixed .header__nav,
  .header__contents--fixed .header__box {
    gap: min(var(--vw, 1vw) * 2 / 1360 * 100, 2.5px)
  }

  .header__contents--fixed .header__btn {
    height: min(var(--vw, 1vw) * 64 / 1360 * 100, 80px);
    padding: 0 min(var(--vw, 1vw) * 33 / 1360 * 100, 41.25px)
  }

  .header__contents--fixed .header__border {
    width: min(var(--vw, 1vw) * 16 / 1360 * 100, 20px);
    height: min(var(--vw, 1vw) * 14 / 1360 * 100, 17.5px)
  }

  .header-drawer .header__logo {
    top: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px);
    left: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px)
  }

  .header-drawer .txt {
    font-size: min(calc(1.6rem + 2 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.8rem)
  }

  .header-drawer .txt-small-1 {
    font-size: min(calc(1.4rem + 1.75 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.575rem)
  }

  .header-drawer__inner {
    padding: min(var(--vw, 1vw) * 120 / 1360 * 100, 150px) min(var(--vw, 1vw) * 120 / 1360 * 100, 150px) min(var(--vw, 1vw) * 20 / 1360 * 100, 25px) min(var(--vw, 1vw) * 40 / 1360 * 100, 50px)
  }

  .header-drawer__deco--2 {
    display: block;
    bottom: 0;
    right: 0
  }

  .header-drawer__scroll {
    padding: min(var(--vw, 1vw) * 10 / 1360 * 100, 12.5px) 0
  }

  .header-drawer__box {
    display: flex;
    justify-content: space-between;
    align-items: flex-end
  }

  .header-drawer__nav {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 70%;
    margin: 0;
    gap: min(var(--vw, 1vw) * 32 / 1360 * 100, 40px) min(var(--vw, 1vw) * 32 / 1360 * 100, 40px)
  }

  .header-drawer__nav--left,
  .header-drawer__nav--right {
    width: 100%
  }

  .header-drawer__nav--left {
    row-gap: min(var(--vw, 1vw) * 32 / 1360 * 100, 40px)
  }

  .header-drawer__nav--right {
    display: flex;
    flex-direction: column;
    gap: 0
  }

  .header-drawer__link {
    display: block;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    width: 100%;
    padding: min(var(--vw, 1vw) * 4 / 1360 * 100, 5px) min(var(--vw, 1vw) * 4 / 1360 * 100, 5px) min(var(--vw, 1vw) * 4 / 1360 * 100, 5px) min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .header-drawer__children {
    display: grid;
    margin-top: min(var(--vw, 1vw) * 28 / 1360 * 100, 35px);
    padding: 0 min(var(--vw, 1vw) * 18 / 1360 * 100, 22.5px);
    gap: min(var(--vw, 1vw) * 12 / 1360 * 100, 15px)
  }

  .header-drawer__bottom {
    margin-top: 0
  }

  .header-drawer__children-link {
    padding-bottom: min(var(--vw, 1vw) * 8 / 1360 * 100, 10px);
    border-bottom: solid 1px rgba(255, 255, 255, .2)
  }

  .header-drawer__children-arrow {
    position: relative;
    width: min(var(--vw, 1vw) * 10 / 1360 * 100, 12.5px);
    height: min(var(--vw, 1vw) * 10 / 1360 * 100, 12.5px);
    overflow: hidden
  }

  .header-drawer__sns {
    justify-content: flex-end;
    gap: min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .header-drawer__sns-icon {
    width: min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .header-drawer__copyright {
    font-size: min(calc(1.2rem + 1.5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.35rem);
    margin-top: min(var(--vw, 1vw) * 40 / 1360 * 100, 50px);
    line-height: 1.5;
    letter-spacing: .1em;
    text-align: right
  }

  .header-drawer__item--sp {
    display: none
  }

  .footer {
    padding: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px)
  }

  .footer__inner {
    padding: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px) min(var(--vw, 1vw) * 80 / 1360 * 100, 100px) min(var(--vw, 1vw) * 80 / 1360 * 100, 100px)
  }

  .footer__deco--1 {
    max-width: min(var(--vw, 1vw) * 1250 / 1360 * 100, 1562.5px)
  }

  .footer__deco--2 {
    display: block;
    bottom: 0;
    right: 0
  }

  .footer__head {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: flex-end
  }

  .footer__catch {
    left: min(var(--vw, 1vw) * 40 / 1360 * 100, 50px)
  }

  .footer__logolink {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0;
    -moz-column-gap: min(var(--vw, 1vw) * 40 / 1360 * 100, 50px);
    column-gap: min(var(--vw, 1vw) * 40 / 1360 * 100, 50px)
  }

  .footer__logo {
    width: 232px
  }

  .footer__name {
    margin-top: 0
  }

  .footer__box {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-top: min(var(--vw, 1vw) * 50 / 1360 * 100, 62.5px)
  }

  .footer__nav {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: min(var(--vw, 1vw) * 672 / 1360 * 100, 840px);
    gap: min(var(--vw, 1vw) * 32 / 1360 * 100, 40px) min(var(--vw, 1vw) * 32 / 1360 * 100, 40px)
  }

  .footer__nav--left,
  .footer__nav--right {
    width: 100%
  }

  .footer__link {
    display: block;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    width: 100%;
    padding: min(var(--vw, 1vw) * 4 / 1360 * 100, 5px) min(var(--vw, 1vw) * 4 / 1360 * 100, 5px) min(var(--vw, 1vw) * 4 / 1360 * 100, 5px) min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .footer__children {
    display: grid;
    margin-top: min(var(--vw, 1vw) * 28 / 1360 * 100, 35px);
    padding: 0 min(var(--vw, 1vw) * 18 / 1360 * 100, 22.5px);
    gap: min(var(--vw, 1vw) * 12 / 1360 * 100, 15px)
  }

  .footer__bottom {
    margin-top: 0
  }

  .footer__children-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: min(var(--vw, 1vw) * 8 / 1360 * 100, 10px);
    border-bottom: solid 1px rgba(255, 255, 255, .2)
  }

  .footer__children-arrow {
    position: relative;
    width: min(var(--vw, 1vw) * 10 / 1360 * 100, 12.5px);
    height: min(var(--vw, 1vw) * 10 / 1360 * 100, 12.5px);
    overflow: hidden
  }

  .footer__children-icon {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%
  }

  .footer__sns {
    justify-content: flex-end;
    gap: min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .footer__sns-icon {
    width: min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .footer__copyright {
    font-size: min(calc(1.2rem + 1.5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.35rem);
    margin-top: min(var(--vw, 1vw) * 40 / 1360 * 100, 50px);
    line-height: 1.5;
    letter-spacing: .1em;
    text-align: right
  }

  .footer__box--bottom {
    display: flex;
    margin-top: min(var(--vw, 1vw)*50/1360*100, 62.5px);
    gap: min(min(var(--vw, 1vw), var(--svh, 1vh))*56/768*100, 42px)
  }

  .footer__nbk-link__txt .txt-small-1 {
    font-size: min(1.4rem + 1.75*(var(--vw, 1vw)*100 - 1360px)/340, 1.575rem);
    line-height: 1.71
  }

  .side-nav {
    top: 50%;
    bottom: auto;
    left: auto;
    right: 0;
    transform: translateY(-50%);
    z-index: 999
  }

  .side-nav .box-link__bg {
    height: 125%
  }

  .side-nav .box-link__bg::before,
  .side-nav .box-link__bg::after {
    transform: translateY(125%) skewY(30deg)
  }

  .side-nav__box {
    display: flex;
    flex-direction: column;
    gap: 2px
  }

  .side-nav__link {
    min-width: min(var(--vw, 1vw) * 45 / 1360 * 100, 56.25px);
    padding: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px) min(var(--vw, 1vw) * 12 / 1360 * 100, 15px);
    text-align: left;
    writing-mode: vertical-rl
  }

  .side-nav__link:nth-of-type(3) {
    grid-area: auto
  }

  .side-nav__link--one {
    grid-area: auto
  }

  .side-nav__txt {
    font-size: min(calc(1.4rem + 1.75 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.575rem);
    line-height: 1.71
  }

  .side-nav__txt::before {
    margin-top: calc((1 - 1.71)*.5em)
  }

  .side-nav__txt::after {
    margin-bottom: calc((1 - 1.71)*.5em)
  }

  @-moz-document url-prefix() {
    .side-nav__link {
      max-width: min(var(--vw, 1vw) * 45 / 1360 * 100, 56.25px)
    }
  }

  .container {
    padding: 0 calc(var(--vw, 1vw) * 120 / 1360 * 100)
  }

  .container__inner {
    max-width: calc((1360px - 240px)*1.25)
  }

  .hdg1 {
    font-size: min(calc(5.6rem + 7 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        6.3rem);
    line-height: 1.42
  }

  .hdg1::before {
    margin-top: calc((1 - 1.42)*.5em)
  }

  .hdg1::after {
    margin-bottom: calc((1 - 1.42)*.5em)
  }

  .hdg2 {
    font-size: min(calc(4.8rem + 6 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        5.4rem);
    line-height: 1.5
  }

  .hdg2::before {
    margin-top: calc((1 - 1.5)*.5em)
  }

  .hdg2::after {
    margin-bottom: calc((1 - 1.5)*.5em)
  }

  .hdg3 {
    font-size: min(calc(4rem + 5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        4.5rem);
    line-height: 1.6
  }

  .hdg3::before {
    margin-top: calc((1 - 1.6)*.5em)
  }

  .hdg3::after {
    margin-bottom: calc((1 - 1.6)*.5em)
  }

  .hdg4 {
    font-size: min(calc(3.2rem + 4 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        3.6rem);
    line-height: 1.75
  }

  .hdg4::before {
    margin-top: calc((1 - 1.75)*.5em)
  }

  .hdg4::after {
    margin-bottom: calc((1 - 1.75)*.5em)
  }

  .hdg5 {
    font-size: min(calc(2.4rem + 3 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        2.7rem);
    line-height: 2
  }

  .hdg5::before {
    margin-top: calc((1 - 2)*.5em)
  }

  .hdg5::after {
    margin-bottom: calc((1 - 2)*.5em)
  }

  .hdg6 {
    font-size: min(calc(2rem + 2.5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        2.25rem);
    line-height: 2
  }

  .hdg6::before {
    margin-top: calc((1 - 2)*.5em)
  }

  .hdg6::after {
    margin-bottom: calc((1 - 2)*.5em)
  }

  .txt {
    font-size: min(calc(1.6rem + 2 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.8rem);
    line-height: 2
  }

  .txt::before {
    margin-top: calc((1 - 2)*.5em)
  }

  .txt::after {
    margin-bottom: calc((1 - 2)*.5em)
  }

  .txt-small-1 {
    font-size: min(calc(1.4rem + 1.75 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.575rem);
    line-height: 1.71
  }

  .txt-small-1::before {
    margin-top: calc((1 - 1.71)*.5em)
  }

  .txt-small-1::after {
    margin-bottom: calc((1 - 1.71)*.5em)
  }

  .txt-small-2 {
    font-size: min(calc(1.2rem + 1.5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.35rem);
    line-height: 1.66
  }

  .txt-small-2::before {
    margin-top: calc((1 - 1.66)*.5em)
  }

  .txt-small-2::after {
    margin-bottom: calc((1 - 1.66)*.5em)
  }

  .hdg1-en {
    font-size: min(calc(8rem + 10 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        9rem);
    line-height: 1.1
  }

  .hdg1-en::before {
    margin-top: calc((1 - 1.1)*.5em)
  }

  .hdg1-en::after {
    margin-bottom: calc((1 - 1.1)*.5em)
  }

  .hdg2-en {
    font-size: min(calc(6.4rem + 8 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        7.2rem);
    line-height: 1.12
  }

  .hdg2-en::before {
    margin-top: calc((1 - 1.12)*.5em)
  }

  .hdg2-en::after {
    margin-bottom: calc((1 - 1.12)*.5em)
  }

  .hdg3-en {
    font-size: min(calc(4rem + 5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        4.5rem);
    line-height: 1.2
  }

  .hdg3-en::before {
    margin-top: calc((1 - 1.2)*.5em)
  }

  .hdg3-en::after {
    margin-bottom: calc((1 - 1.2)*.5em)
  }

  .hdg4-en {
    font-size: min(calc(2.4rem + 3 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        2.7rem);
    line-height: 1.33
  }

  .hdg4-en::before {
    margin-top: calc((1 - 1.33)*.5em)
  }

  .hdg4-en::after {
    margin-bottom: calc((1 - 1.33)*.5em)
  }

  .hdg5-en {
    font-size: min(calc(2rem + 2.5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        2.25rem);
    line-height: 1.4
  }

  .hdg5-en::before {
    margin-top: calc((1 - 1.4)*.5em)
  }

  .hdg5-en::after {
    margin-bottom: calc((1 - 1.4)*.5em)
  }

  .hdg6-en {
    font-size: min(calc(1.6rem + 2 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.8rem);
    line-height: 1.5
  }

  .hdg6-en::before {
    margin-top: calc((1 - 1.5)*.5em)
  }

  .hdg6-en::after {
    margin-bottom: calc((1 - 1.5)*.5em)
  }

  .txt-en-small {
    font-size: min(calc(1.2rem + 1.5 * (var(--vw, 1vw) * 100 - 1360px) / 340),
        1.35rem);
    line-height: 1.66
  }

  .txt-en-small::before {
    margin-top: calc((1 - 1.66)*.5em)
  }

  .txt-en-small::after {
    margin-bottom: calc((1 - 1.66)*.5em)
  }

  .circle-arrow--xlarge {
    width: min(var(--vw, 1vw) * 64 / 1360 * 100, 80px)
  }

  .circle-arrow--xlarge .circle-arrow__wrap {
    width: min(var(--vw, 1vw) * 24 / 1360 * 100, 30px)
  }

  .circle-arrow--large {
    width: min(var(--vw, 1vw) * 56 / 1360 * 100, 70px)
  }

  .circle-arrow--large .circle-arrow__wrap {
    width: min(var(--vw, 1vw) * 20 / 1360 * 100, 25px)
  }

  .circle-arrow--medium {
    width: min(var(--vw, 1vw) * 48 / 1360 * 100, 60px)
  }

  .circle-arrow--medium .circle-arrow__wrap {
    width: min(var(--vw, 1vw) * 16 / 1360 * 100, 20px)
  }

  .circle-arrow--small {
    width: min(var(--vw, 1vw) * 32 / 1360 * 100, 40px)
  }

  .circle-arrow--small .circle-arrow__wrap {
    width: min(var(--vw, 1vw) * 12 / 1360 * 100, 15px)
  }

  .sec {
    gap: min(var(--vw, 1vw) * 56 / 1360 * 100, 70px) 0
  }

  .sec+.sec {
    margin-top: min(var(--vw, 1vw) * 80 / 1360 * 100, 100px)
  }

  .line::before {
    width: min(var(--vw, 1vw) * 80 / 1360 * 100, 100px);
    height: 5px
  }
}

@media screen and (any-hover: hover)and (min-width: 960px) {
  .header-drawer__children-link:hover .txt-small-1 {
    color: #888
  }

  .footer__children-link:hover .txt-small-1 {
    color: #888
  }

  .side-nav .box-link:hover .box-link__bg::before,
  .side-nav .box-link:hover .box-link__bg::after {
    transform: translateY(10%) skewY(30deg)
  }
}

@media(any-hover: hover) {
  .box-link:hover .box-link__bg {
    transform: rotate(180deg)
  }

  .box-link:hover .box-link__bg::before,
  .box-link:hover .box-link__bg::after {
    transform: translateX(10%) skewX(30deg)
  }

  .box-link:hover p,
  .box-link:hover span {
    color: #00338e
  }

  .box-link:hover.box-link--blue p,
  .box-link:hover.box-link--blue span,
  .box-link:hover.box-link--green p,
  .box-link:hover.box-link--green span {
    color: #fff
  }

  .header-drawer__link:hover .circle-arrow .circle-arrow__bg {
    transform: rotate(180deg)
  }

  .header-drawer__link:hover .circle-arrow .circle-arrow__bg::before {
    transform: translateX(10%) skewX(30deg);
    transition: transform .3s ease .2s
  }

  .header-drawer__link:hover .circle-arrow .circle-arrow__img:first-child {
    animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both
  }

  .header-drawer__link:hover .circle-arrow .circle-arrow__img:last-child {
    animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
  }

  .header-drawer__children-link:hover .header-drawer__children-icon--1 {
    animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    opacity: .2
  }

  .header-drawer__children-link:hover .header-drawer__children-icon--2 {
    animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
  }

  .footer__link:hover .circle-arrow .circle-arrow__bg {
    transform: rotate(180deg)
  }

  .footer__link:hover .circle-arrow .circle-arrow__bg::before {
    transform: translateX(10%) skewX(30deg);
    transition: transform .3s ease .2s
  }

  .footer__link:hover .circle-arrow .circle-arrow__img:first-child {
    animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both
  }

  .footer__link:hover .circle-arrow .circle-arrow__img:last-child {
    animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
  }

  .footer__children-link:hover .footer__children-icon--1 {
    animation: transformCenterRight .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    opacity: .2
  }

  .footer__children-link:hover .footer__children-icon--2 {
    animation: transformLeftCenter .3s cubic-bezier(0.25, 0.46, 0.45, 0.94) both .15s
  }
}