:root {
  --side-padding: clamp(2rem, calc(1.6rem + 1vw), 2.5rem);
  --side-padding-sp: clamp(1.0256410256410255rem, calc((0rem) + 5.12821vw), 1.25rem);
  --content-max-width: clamp(72rem, calc(57.6rem + 36vw), 90rem);
}
:root {
  --color-black: #000000;
  --color-key: #4065A2;
  --color-key-text: #0058FF;
  --color-key-text-dark: #00205b;
  --color-border: #D4D4D4;
}
:root {
  --base-font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  --en-font-family: "neue-haas-grotesk-display", sans-serif;
}
:root{
  --leading-trim: calc((1em - 1lh) / 2);
}
:root {
  --easing-cubic-out: cubic-bezier(0.23, 1, 0.32, 1);
  --easing-cubic-in: cubic-bezier(0.42, 0, 1, 1);
  --easing-cubic-in-out: cubic-bezier(0.42, 0, 0.58, 1);
  --easing-cubic-out-in: cubic-bezier(0.23, 1, 0.32, 1);
  --easing-quad-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --easing-quad-in: cubic-bezier(0.16, 1, 0.3, 1);
  --easing-quad-in-out: cubic-bezier(0.42, 0, 0.58, 1);
  --easing-quad-out-in: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --easing-quart-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --easing-quart-in: cubic-bezier(0.16, 1, 0.3, 1);
  --easing-quart-in-out: cubic-bezier(0.42, 0, 0.58, 1);
  --easing-quart-out-in: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --easing-quint-out: cubic-bezier(0.23, 1, 0.32, 1);
  --easing-quint-in: cubic-bezier(0.64, 0, 0.78, 0);
  --easing-quint-in-out: cubic-bezier(0.86, 0, 0.07, 1);
  --easing-quint-out-in: cubic-bezier(0.77, 0, 0.17, 1);
  --easing-expo-out: cubic-bezier(0.19, 1, 0.22, 1);
  --easing-expo-in: cubic-bezier(0.95, 0.05, 0.79, 0.03);
  --easing-expo-in-out: cubic-bezier(1, 0, 0, 1);
  --easing-expo-out-in: cubic-bezier(0, 0, 0, 1);
  --easing-circ-out: cubic-bezier(0.075, 0.82, 0.165, 1);
  --easing-circ-in: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --easing-circ-in-out: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --easing-circ-out-in: cubic-bezier(0.075, 0.82, 0.165, 1);
}
:root {
  --z-index-global-logo: 80;
  --z-index-global-nav: 90;
  --z-index-global-nav-toggle: 100;
  --z-index-curtain: 200;
}
/*! Yaku Han JP v4.1.1 (OFL-1.1 AND MIT) by Qrac | Type: YakuHanJPs - Based on Noto Sans JP */
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 100;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-Thin.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-ExtraLight.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-Light.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-Regular.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-Medium.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-SemiBold.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-Bold.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-ExtraBold.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/assets/font/YakuHanJPs/YakuHanJPs-Black.woff2) format("woff2");
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f,
    U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b,
    U+ff5d;
}
.pc-head .btn-area{
  display: none !important;
}
/* .pc-head .menu-box{
  display: none !important;
} */
/* .pc-head .subaru-box{
  display: none !important;
} */
.pc-head .logo-box{
  top: 50%;
  width: 247px;
  transform: translateY(-50%);
}
.pc-head .logo-box a{
  display: block;
}
.pc-fixed .logo-box img{
  margin-block-start: 0 !important;
}
/* .sp-header .sp-nav{
  display: none !important;
} */
.sp-header .logo-box{
  display: flex;
  align-items: center;
  width: 206px;
  height: 100%;
}
.sp-header .logo-box a{
  display: block;
}
.sp-header .logo-box a img{
  width: 100%;
  height: auto !important;
  vertical-align: top;
}
/* .nav-slider{
  display: none !important;
} */
.com-footer {
  display: none !important;
}
.sp-footer{
  display: none !important;
}
.nav-slider-anchor-link{
  display: block;
  color: #4065a2;
  font-size: 14px;
  font-weight: bold;
  text-decoration: none;
  border-bottom: 1px solid #d6d6d6;
  padding: 15px;
  background-color: #f4f4f4;
}
.nav-slider-anchor-link::after{
    float: right;
    padding-right: 15px;
    font-family: FontAwesome;
    font-size: 18px;
    color: #333;
    content: "\f107";
  }
.c-slw-hero {
  position: relative;
}
@media (width <= 768px) {
.c-slw-hero__image{
    aspect-ratio: 375 / 500;
}
  }
.c-slw-hero__image img{
  width: 100%;
}
@media (width > 768px) {
.c-slw-hero__image img{
    height: auto;
}
  }
@media (width <= 768px) {
.c-slw-hero__image img{
    height: 100%;
    object-fit: cover;
}
  }
.c-slw-hero__caption {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
@media (width > 768px) {
.c-slw-hero__caption {
    padding-inline: 10.5rem;
}
  }
@media (width <= 768px) {
.c-slw-hero__caption {
    padding-inline: 1.5625rem;
}
  }
.c-slw-hero__caption-inner {
  display: flex;
  flex-direction: column;
  gap: 3.125rem;
  max-width: 1104px;
  height: 100%;
  margin-inline: auto;
  color: #fff;
  box-sizing: border-box;
}
@media (width > 768px) {
.c-slw-hero__caption-inner {
    justify-content: center;
}
  }
@media (width <= 768px) {
.c-slw-hero__caption-inner {
    justify-content: space-between;
    padding-block-start: 3.125rem;
    padding-block-end: 1.25rem;
}
  }
.c-slw-hero__title{
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  margin-block-end: 0;
}
.c-slw-hero__title-en {
  display: block;
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0;
}
@media (width <= 926px) {
.c-slw-hero__title-en {
    font-size: 1.875rem;
}
  }
@media (width > 926px) {
.c-slw-hero__title-en {
    font-size: 3.75vw;
}
  }
@media (width > 1440px) {
.c-slw-hero__title-en {
    font-size: 3.375rem;
}
  }
.c-slw-hero__title-ja {
  display: block;
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-weight: 700;
  line-height: 120%;
  letter-spacing: 0;
}
@media (width <= 926px) {
.c-slw-hero__title-ja {
    font-size: 4.5rem;
}
  }
@media (width > 926px) {
.c-slw-hero__title-ja {
    font-size: 6.25rem;
}
  }
@media (width > 1440px) {
.c-slw-hero__title-ja {
    font-size: 4.5rem;
}
  }
.c-slw-hero__lead {
  margin-block-end: 0;
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
}
@media (width <= 926px) {
.c-slw-hero__lead {
    font-size: 0.75rem;
}
  }
@media (width > 926px) {
.c-slw-hero__lead {
    font-size: 0.9722222222222222vw;
}
  }
@media (width > 1440px) {
.c-slw-hero__lead {
    font-size: 0.875rem;
}
  }
.c-slw-inner {
  max-width: 1100px;
  margin-inline: auto;
  box-sizing: border-box;
}
.c-slw-container {
  box-sizing: border-box;
}
@media (width > 768px) {
.c-slw-container {
    padding-inline: 2.5rem;
}
  }
@media (width <= 768px) {
.c-slw-container {
    padding-inline: 1.25rem;
}
  }
.c-slw-section-title {
  position: relative;
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-weight: 400;
  line-height: 188%;
  letter-spacing: 0.06em;
}
@media (width > 768px) {
.c-slw-section-title {
    padding-block-end: 1.25rem;
    font-size: 1.5rem;
}
  }
@media (width <= 768px) {
.c-slw-section-title {
    padding-block-end: 0.6875rem;
    font-size: 1.125rem;
}
  }
.c-slw-section-title::after {
  display: block;
  width: 2.5rem;
  height: 0.125rem;
  background-color: #4065A2;
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}
@media (width > 1440px) {
.c-slw-section-title::after {
    width: 2.5rem;
    height: 0.125rem;
}
  }
@media (width <= 768px) {
.c-slw-section-title::after {
    width: 1.875rem;
    height: 0.0625rem;
}
  }
.c-slw-section-title__main {
  display: block;
  text-align: center;
}
.c-slw-section{
  position: relative;
}
@media (width > 768px) {
.c-slw-section.has-margin-block-start{
    margin-block-start: 5rem;
    scroll-padding-top: 60px;
}
  }
@media (width <= 768px) {
.c-slw-section.has-margin-block-start{
    margin-block-start: 3.125rem;
    scroll-padding-top: 80px;
}
  }
@media (width > 768px) {
.c-slw-section__body {
    margin-block-start: 3rem;
}
  }
@media (width <= 768px) {
.c-slw-section__body {
    margin-block-start: 2.5rem;
}
  }
.c-slw-button{
  display: inline-block;
  padding: 1.25rem 1.5625rem;
  background-color: #0058FF;
  color: #fff;
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 178%;
  letter-spacing: 0;
  text-align: center;
  text-decoration: none !important;
  transition: opacity 0.3s ease;
  box-sizing: border-box;
  transition: background-color 0.3s ease;
}
.c-slw-button:hover{
  background-color: #00205b;
}
.c-slw-button:focus-visible{
  outline: 2px solid #00205b;
  outline-offset: 2px;
}
@media (width > 768px) {
.c-slw-main{
    padding-block-end: 6.25rem;
}
  }
@media (width <= 768px) {
.c-slw-main{
    padding-block-end: 3.125rem;
}
  }
.u-slw-anchor-target{
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
@media (width > 768px) {
.u-slw-anchor-target{
    top: -60px;
    scroll-margin-top: 60px;
}
  }
@media (width <= 768px) {
.u-slw-anchor-target{
    top: -80px;
    scroll-margin-top: 80px;
}
  }
.p-slw-home{
  color: #000000;
  letter-spacing: 0;
}
.p-slw-home__about-image {
  border-radius: 0.5rem;
  overflow: hidden;
}
.p-slw-home__about-image img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.p-slw-home__about-text {
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-weight: 400;
  line-height: 178%;
}
@media (width <= 768px) {
.p-slw-home__about-text {
    margin-block-start: 1.25rem;
    font-size: 0.9375rem;
}
  }
@media (width > 768px) {
.p-slw-home__about-text {
    margin-block-start: 1rem;
    font-size: 0.875rem;
}
  }
.p-slw-home__about-text p{
  margin-block-end: 0;
}
.p-slw-home__message-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media (width <= 768px) {
.p-slw-home__message-inner {
    flex-direction: column-reverse;
    gap: 1rem;
}
  }
.p-slw-home__message-image {
  border-radius: 0.5rem;
  overflow: hidden;
}
@media (width > 768px) {
.p-slw-home__message-image {
    width: 49.09%;
}
  }
.p-slw-home__message-image img{
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.p-slw-home__message-text{
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 178%;
  letter-spacing: 0;
}
@media (width > 768px) {
.p-slw-home__message-text{
    width: 42.45%;
}
  }
.p-slw-home__message-text p{
  margin-block-end: 0;
  font-size: inherit;
}
.p-slw-home__message-text p + p{
  margin-block-start: 1lh;
}
.p-slw-home__name-image img{
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.p-slw-home__name-text{
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-weight: 400;
  line-height: 178%;
  letter-spacing: 0;
}
@media (width <= 768px) {
.p-slw-home__name-text{
    margin-block-start: 1rem;
    font-size: 0.9375rem;
}
  }
@media (width > 768px) {
.p-slw-home__name-text{
    margin-block-start: 1.25rem;
    font-size: 0.875rem;
}
  }
.p-slw-home__name-text p{
  margin-block-end: 0;
  font-size: inherit;
}
.p-slw-home__company-info{
  width: 100%;
  margin-block-end: 0;
  font-family: YakuHanJPs, "neue-haas-grotesk-display", sans-serif;
  font-size: 0.875rem;
  line-height: 178%;
  letter-spacing: 0;
}
.p-slw-home__company-info{
  border-block: 1px solid #D4D4D4;
}
.p-slw-home__company-info th{
  min-width: 6.25rem;
  white-space: nowrap;
  color: #0058FF;
}
.p-slw-home__company-info th,
.p-slw-home__company-info td{
  padding: 1.25rem 0.75rem;
}
.p-slw-home__company-info p {
  margin-block-end: 0;
}
.p-slw-home__company-info tr + tr th,
.p-slw-home__company-info tr + tr td{
  border-top: 1px solid #D4D4D4;
}
.p-slw-home__company-address{
  display: flex;
}
@media (width > 768px) {
.p-slw-home__company-address{
    gap: 0.625rem;
}
  }
@media (width <= 768px) {
.p-slw-home__company-address{
    flex-direction: column;
}
  }
.p-slw-home__company-address a{
  color: #4065A2;
}
.p-slw-home__contact{
  width: 100%;
  max-width: 17.375rem;
  margin-inline: auto;
}
.p-slw-home__contact .c-slw-button{
  width: 100%;
}
.u-slw-visually-hidden{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
@media (width <= 926px) {
.u-slw-pc-only {
    display: none !important;
}
  }
@media (width > 926px) {
.u-slw-sp-only {
    display: none !important;
}
  }



