@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
/*
  * Reset CSS
*/
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* list Remove default style */
ul,
ol {
  padding: 0;
  list-style: none;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Set core root defaults */
html {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizespeed;
  line-height: 1.5;
  width: 100%;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img {
  max-width: 100%;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

/* Natural flow and rhythm in articles by default */
article > * + * {
  margin-top: 1em;
}

/* フォームリセット */
input,
button,
textarea,
select {
  font: inherit;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
}

/* stylelint-disable */
textarea {
  resize: vertical;
}

/* stylelint-enable */
input[type=radio] {
  visibility: hidden;
}

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

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

/* mixin
------------------------------------------------------------*/
/* =====================
 * Baseスタイル
===================== */
:root,
:root[theme=Default] {
  --f-family-main: "Montserrat", "Noto Sans JP", sans-serif;
  --f-family-en: "Montserrat", sans-serif;
  --f-font-size: 16px;
  --f-line-height: 1.5;
  --f-letter-spacing: 0.06em;
  --f-weight-light: 300;
  --f-weight-regular: 400;
  --f-weight-medium: 500;
  --f-weight-semibold: 600;
  --f-weight-bold: 700;
  --f-weight-black: 900;
  --c-base: #3a3a3a;
  --c-white: #ffffff;
  --c-brand: #ae8148;
  --c-green: #279F87;
  --c-blue: #003893;
  --c-yellow: #fdef0e;
  --c-gray:#eeeeee;
  --c-base-rgb: 26, 26, 26;
  --c-blue-rgb: 97, 158, 208;
  --c-green-rgb: 39, 159, 135;
  --width-content:375px;
}

html {
  font-size: 16px;
}
@media (max-width: 1140px) {
  html {
    font-size: clamp(12px, 12px + 4 * (100vw - 768px) / 372, 16px);
  }
}
@media (max-width: 768px) {
  html {
    font-size: 16px;
  }
}
@media (max-width: 375px) {
  html {
    font-size: clamp(12px, 4.2666666667vw, 16px);
  }
}

body {
  font-family: var(--f-family-main);
  font-size: var(--f-font-size);
  font-weight: var(--f-weight-medium);
  line-height: var(--f-line-height);
  background-color: var(--c-white);
  color: var(--c-base);
  letter-spacing: var(--f-letter-spacing);
  overflow-wrap: break-word;
  word-break: break-all;
  position: relative;
  width: 100%;
  overflow-x: hidden;
  overscroll-behavior: none;
}

a {
  display: inline-block;
  color: inherit;
  cursor: pointer;
  text-decoration: none;
  transition: 0.3s;
}
a:hover, a:focus {
  opacity: 0.85;
}

button {
  transition: 0.3s;
}
button:hover, button:focus {
  opacity: 0.9;
}

.is-pc {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .is-pc {
    display: none !important;
  }
}

.is-tab {
  display: none !important;
}
@media screen and (max-width: 1279px) {
  .is-tab {
    display: block !important;
  }
}

.is-sp {
  display: none !important;
}
@media screen and (max-width: 1279px) {
  .is-sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .is-sp {
    display: block !important;
  }
}

/* container
------------------------------------------------------------*/
.body::before {
  content: "";
  display: block;
  background-image: url(../img/body-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center bottom;
  width: 100%;
  height: 100%;
  position: fixed;
  inset: 0;
  z-index: -1;
}
.body::after {
  content: "";
  position: fixed;
  inset: 0;
  background: linear-gradient(157.99deg, rgba(72, 180, 253, 0.9) 3.57%, rgba(31, 143, 218, 0.9) 15.2%, rgba(16, 68, 121, 0.9) 68.4%);
  z-index: -1;
}

.l-cta {
  position: fixed;
  bottom: 40px;
  right: calc((100vw - var(--width-content)) / 4);
  transform: translateX(50%);
  width: 380px;
}
@media screen and (max-width: 1279px) {
  .l-cta {
    display: none;
  }
}
.l-cta .c-cta__link {
  width: 360px;
}

.l-logo {
  position: fixed;
  top: 50%;
  left: calc((100vw - var(--width-content)) / 4);
  transform: translate(-50%, -50%);
  width: 360px;
}
@media screen and (max-width: 1279px) {
  .l-logo {
    display: none;
  }
}

.l-contents {
  max-width: var(--width-content);
  position: relative;
  margin-inline: auto;
  background-color: var(--c-white);
  transition: all 0.25s ease;
  box-shadow: 0px 0 12px 0px rgba(var(--c-base-rgb), 0.4);
}
@media screen and (max-width: 767px) {
  .l-contents {
    max-width: 100%;
  }
}

.l-menu {
  position: fixed;
  top: 64px;
  right: calc((100vw - var(--width-content)) / 4);
  transform: translateX(50%);
  width: 380px;
  height: auto;
  padding: 24px 40px;
  box-shadow: inset 0px 0px 16px rgba(var(--c-blue-rgb), 0.7);
  background-color: var(--c-white);
  border-radius: 8px;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
@media screen and (max-width: 1279px) {
  .l-menu {
    display: none;
  }
}
.l-menu__nav {
  position: relative;
  width: 100%;
  margin-top: 20px;
}
.l-menu__item {
  margin-top: 24px;
}
.l-menu__item:first-child {
  margin-top: 0;
}
.l-menu__decoration {
  position: relative;
  font-size: 0.75rem;
  line-height: 1;
  color: var(--c-white);
  background-color: var(--c-green);
  padding: 4px 12px;
}
.l-menu__decoration::before, .l-menu__decoration::after {
  content: "";
  display: inline-block;
  background-image: url(../img/corner-green.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 8px;
  height: auto;
  aspect-ratio: 1/3;
}
.l-menu__decoration::before {
  position: absolute;
  top: -1px;
  left: -6px;
}
.l-menu__decoration::after {
  position: absolute;
  top: 0;
  right: -6px;
  transform: scale(-1, -1);
}
.l-menu__item-link {
  position: relative;
  color: var(--c-blue);
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  gap: 8px;
  font-weight: var(--f-weight-semibold);
  transition: color 0.18s ease;
}
.l-menu__item-link:hover {
  color: var(--c-green);
}
.l-menu__item-link::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -16px;
  width: 8px;
  height: 8px;
  background-color: var(--c-green);
  border-radius: 50%;
  transform: translateY(-50%) scale(0.2);
  opacity: 0;
  transition: transform 0.22s ease, opacity 0.22s ease;
  will-change: transform, opacity;
}
.l-menu__item-link.is-active {
  color: var(--c-green);
}
.l-menu__item-link.is-active::before {
  transform: translateY(-50%) scale(1);
  opacity: 1;
  box-shadow: 0 0 8px rgba(var(--c-green-rgb), 0.6), 0 0 16px rgba(var(--c-green-rgb), 0.4);
}
.l-menu__item-jp {
  font-size: 1.125rem;
}
@media screen and (max-width: 767px) {
  .l-menu__item-jp {
    font-size: 1rem;
  }
}
.l-menu__item-line {
  background: #eaeaea;
  flex: 1;
  width: auto;
  height: 1px;
  max-width: 100%;
  position: relative;
  top: 1em;
}
.l-menu__item-en {
  font-size: 1rem;
}
@media screen and (max-width: 767px) {
  .l-menu__item-en {
    font-size: 0.875rem;
  }
}

.l-menu-sp__nav {
  display: none;
  background-color: var(--c-white);
  width: 100%;
  height: 100vh;
  position: absolute;
  top: 64px;
  left: 0;
  padding: 40px 32px 64px;
}

.l-hamburger {
  display: none;
}
@media screen and (max-width: 1279px) {
  .l-hamburger {
    position: relative;
    width: 40px;
    height: 28px;
    margin: 8px;
    cursor: pointer;
    display: inline-block;
    transition: all 0.5s;
    box-sizing: border-box;
  }
}
.l-hamburger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--c-blue);
  border-radius: 2px;
  display: inline-block;
  transition: all 0.5s;
  box-sizing: border-box;
}
.l-hamburger span:nth-of-type(1) {
  top: 0;
}
.l-hamburger span:nth-of-type(2) {
  top: 13px;
}
.l-hamburger span:nth-of-type(3) {
  bottom: 0;
}
.l-hamburger.js-hamburger-active span:nth-of-type(1) {
  transform: translateY(13px) rotate(-45deg);
}
.l-hamburger.js-hamburger-active span:nth-of-type(2) {
  opacity: 0;
}
.l-hamburger.js-hamburger-active span:nth-of-type(3) {
  transform: translateY(-13px) rotate(45deg);
}

/* components
------------------------------------------------------------*/
.ttl-sub {
  font-size: 1.625rem;
  color: var(--c-brand);
  font-family: var(--f-family-sub);
  padding-left: 0.25em;
  padding-bottom: 4px;
  border-bottom: solid 1px var(--c-brand);
  margin-bottom: 18px;
}

.c-sec__inner {
  padding-top: 64px;
  padding-bottom: 64px;
}
.c-sec__ttl {
  text-align: center;
}
.c-sec__ttl-en {
  font-size: 1rem;
  font-weight: var(--f-weight-bold);
}
.c-sec__ttl-jp {
  margin-top: 8px;
  font-size: 1.375rem;
  font-weight: var(--f-weight-bold);
}

.c-cta {
  margin-top: 48px;
  text-align: center;
}
.c-cta__balloon {
  display: inline-block;
  font-size: 1rem;
  font-weight: var(--f-weight-bold);
  line-height: 1;
  color: var(--c-blue);
  background-color: var(--c-yellow);
  padding: 4px 16px;
  border-radius: 2px;
  position: relative;
  top: 12px;
  animation: floatUpDown 2.5s ease-in-out infinite;
}
@keyframes floatUpDown {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
}
.c-cta__balloon::after {
  content: "";
  position: absolute;
  bottom: -12px;
  left: 0;
  right: 0;
  margin: auto;
  width: 0px;
  border: 6px solid transparent;
  border-top: 8px solid #FFE600;
}
.c-cta__link {
  display: inline-block;
  min-width: 300px;
  font-size: 1.375rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-white);
  line-height: 1;
  background-color: var(--c-green);
  border-radius: 8px;
  padding: 28px 28px;
  box-shadow: inset 0px 0px 8px rgba(255, 255, 255, 0.55);
}

.c-follow {
  display: none;
}
@media screen and (max-width: 1279px) {
  .c-follow {
    display: block;
    position: fixed;
    z-index: 1;
    bottom: 0;
    max-width: var(--width-content);
    margin-inline: auto;
    z-index: 1000;
    padding: 4px 0 12px;
    background-color: rgba(0, 0, 0, 0.8);
    text-align: center;
    opacity: 0;
    transform: translateY(12px);
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease;
  }
  .c-follow.is-show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
}
@media screen and (max-width: 767px) {
  .c-follow {
    max-width: 100%;
  }
}
.c-follow .c-cta {
  margin-top: 0;
}
.c-follow .c-cta__balloon {
  font-size: 0.875rem;
}
.c-follow .c-cta__link {
  font-size: 1.125rem;
  padding: 18px 28px;
}

/* header
------------------------------------------------------------*/
.c-header {
  position: relative;
  z-index: 100;
  display: flex;
  justify-content: space-between;
  width: 100%;
  padding: 12px 16px;
  height: 64px;
  background-color: var(--c-white);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.06);
}
@media screen and (max-width: 767px) {
  .c-header {
    position: fixed;
  }
}
.c-header__logo {
  width: 128px;
}

/* footer
------------------------------------------------------------*/
.c-footer {
  background-color: #1F77AA;
  padding: 24px;
  text-align: center;
  color: var(--c-white);
}
.c-footer__list {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-bottom: 24px;
}
.c-footer__link {
  display: block;
  font-size: 0.875rem;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.c-footer__copy {
  font-size: 0.625rem;
}

/* TOP
------------------------------------------------------------*/
.p-mv {
  position: relative;
  background-image: url(../img/mv_bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
}
.p-mv__inner {
  padding: 48px 0;
}
@media screen and (max-width: 767px) {
  .p-mv__inner {
    padding: 112px 0 48px;
  }
}
.p-mv__catch-txt {
  position: relative;
  font-size: 16px;
  font-weight: var(--f-weight-semibold);
  line-height: 27px;
  color: var(--c-white);
  text-align: center;
}
.p-mv__catch-txt span {
  position: relative;
  display: inline-block;
  background-color: var(--c-blue);
  padding: 0 8px;
  height: 27px;
}
.p-mv__catch-txt span::before, .p-mv__catch-txt span::after {
  content: "";
  display: inline-block;
  background-image: url(../img/corner-blue.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 10px;
  height: 27px;
}
.p-mv__catch-txt span::before {
  position: absolute;
  top: 0px;
  left: -8px;
}
.p-mv__catch-txt span::after {
  position: absolute;
  top: 0px;
  right: -8px;
  transform: scale(-1, -1);
}
.p-mv__catch-ttl {
  display: none;
  font-size: 1.5rem;
  font-weight: var(--f-weight-bold);
  color: var(--c-blue);
  text-align: center;
  padding: 0 8px;
  margin-top: 16px;
}
.p-mv__catch-ttl.is-default {
  display: block;
}
.p-mv__ttl {
  font-size: 1.125rem;
  font-weight: var(--f-weight-medium);
  text-align: center;
  margin-top: 24px;
  margin-bottom: 40px;
}
.p-mv__ttl-sub {
  font-size: 1rem;
  color: var(--c-green);
  text-align: center;
  margin-bottom: 8px;
}
.p-mv .c-cta {
  margin-top: 40px;
}

.p-about {
  position: relative;
  background: linear-gradient(180deg, rgba(13, 68, 122, 0.93) 29.33%, rgba(14, 109, 164, 0.93) 91.83%);
  padding-left: 16px;
  padding-right: 16px;
}
.p-about__ttl {
  color: var(--c-white);
  text-shadow: 0px 0px 4px rgba(255, 255, 255, 0.25);
}
.p-about__content {
  margin-top: 40px;
}
.p-about__txt {
  font-size: 0.875rem;
  text-align: center;
  color: var(--c-white);
  margin-top: 8px;
}
.p-about__txt:first-child {
  margin-top: 0;
}
.p-about__list {
  margin-top: 32px;
}
.p-about__item {
  background-color: var(--c-white);
  border-radius: 4px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-blue-rgb), 0.7);
  padding: 24px 16px;
  margin-top: 24px;
}
.p-about__item:first-child {
  margin-top: 0;
}
.p-about__item__ttl {
  font-size: 1.125rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-blue);
  text-align: center;
}
.p-about__item__txt {
  font-size: 0.875rem;
  text-align: center;
  margin-top: 8px;
}

.p-worries {
  position: relative;
  background-color: #f2f7fa;
  padding-left: 24px;
  padding-right: 24px;
}
.p-worries__ttl {
  color: var(--c-green);
}
.p-worries__content {
  margin-top: 40px;
}
.p-worries__list {
  margin-bottom: 32px;
}
.p-worries__list:first-child {
  margin-top: 0;
}
.p-worries__item {
  position: relative;
  font-size: 0.875rem;
  font-weight: var(--f-weight-semibold);
  background-color: var(--c-white);
  border-radius: 4px;
  padding: 16px 16px 16px 48px;
  margin-top: 16px;
}
.p-worries__item:first-child {
  margin-top: 0;
}
.p-worries__item::before {
  content: "";
  display: inline-block;
  background-image: url(../img/check.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 24px;
  height: auto;
  aspect-ratio: 7/6;
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}
.p-worries__txt {
  font-size: 0.875rem;
  font-weight: var(--f-weight-semibold);
  text-align: center;
  margin-bottom: 16px;
}
.p-worries__txt:first-child {
  margin-top: 0;
}
.p-worries__txt strong {
  font-size: 1.5rem;
  line-height: 2.2;
  font-weight: var(--f-weight-bold);
  color: var(--c-blue);
  border-bottom: solid 4px var(--c-yellow);
}

.p-service {
  position: relative;
  background: linear-gradient(180deg, rgba(13, 68, 122, 0.93) 29.33%, rgba(14, 109, 164, 0.93) 91.83%);
  padding-left: 16px;
  padding-right: 16px;
}
.p-service::before {
  content: "";
  display: inline-block;
  width: 120px;
  height: 20px;
  background-image: url(../img/service_decoration.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.p-service__ttl {
  color: var(--c-white);
  text-shadow: 0px 0px 4px rgba(255, 255, 255, 0.25);
}
.p-service__content {
  margin-top: 40px;
}
.p-service__ttl-sub {
  font-size: 1.125rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-white);
  text-align: center;
  margin-bottom: 24px;
}
.p-service__step__item {
  background-color: var(--c-white);
  border-radius: 4px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-blue-rgb), 0.7);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px 16px;
  margin-top: 16px;
}
.p-service__step__item:first-child {
  margin-top: 0;
}
.p-service__step__item__img {
  display: inline-block;
  width: 48px;
}
.p-service__step__item__info {
  flex: 1;
  color: var(--c-blue);
  font-weight: var(--f-weight-semibold);
}
.p-service__step__item__info-en {
  font-size: 0.75rem;
}
.p-service__step__item__info-ttl {
  font-size: 1rem;
}
.p-service__step__item__info-ttl strong {
  font-weight: var(--f-weight-semibold);
}
.p-service__step__item__info-txt {
  margin-top: 4px;
  font-size: 0.875rem;
  font-weight: var(--f-weight-medium);
  color: var(--c-base);
}
.p-service__result {
  margin-top: 64px;
}
.p-service__result__box {
  background-color: var(--c-white);
  padding: 24px 24px 24px;
  border-radius: 4px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-blue-rgb), 0.7);
}
.p-service__result__item dt {
  font-size: 1rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-white);
  background-color: var(--c-green);
  padding: 4px 8px;
  margin-top: 24px;
}
.p-service__result__item dt:first-child {
  margin-top: 0;
}
.p-service__result__item dd {
  margin-top: 8px;
}
.p-service__result__item li {
  position: relative;
  padding-left: 1em;
  font-size: 0.875rem;
}
.p-service__result__item li::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  background-color: var(--c-green);
  border-radius: 50%;
  position: relative;
  top: 50%;
  left: -4px;
  transform: translateY(-50%);
}
.p-service__result__more {
  position: relative;
  background-color: var(--c-white);
  margin-top: 32px;
  padding: 24px 16px 24px;
  border-radius: 4px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-green-rgb), 0.7);
}
.p-service__result__more-btn {
  display: inline-block;
  font-size: 0.875rem;
  text-align: center;
  line-height: 1;
  color: var(--c-green);
  border: solid 1px var(--c-green);
  background-color: var(--c-white);
  border-radius: 4px;
  padding: 8px 24px 8px 16px;
  position: absolute;
  bottom: -16px;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 2px 0 0 var(--c-green);
}
.p-service__result__more-btn::after {
  content: "";
  background-image: url(../img/more-plus-green.svg);
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
}
.p-service__result__more-btn:hover {
  opacity: 1;
  transform: translate(-50%, 4px);
  box-shadow: 0 4px 0 var(--c-white);
}
.p-service__result__more-btn.p-service__result__more-btn-is-active::after {
  transform: translateY(-50%) rotate(45deg);
}
.p-service__result__more-catch {
  font-size: 1rem;
  color: var(--c-green);
  text-align: center;
}
.p-service__result__more-list {
  display: none;
  padding-bottom: 24px;
}
.p-service__result__more-item {
  font-size: 0.75rem;
  font-weight: var(--f-weight-medium);
  padding: 12px 0;
  border-bottom: solid 1px var(--c-green);
}
.p-service__result__more-route {
  position: relative;
  margin-top: 8px;
  padding-left: 1.4em;
}
.p-service__result__more-route::before {
  content: "";
  display: inline-block;
  background-image: url(../img/check-green.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.1em;
  height: 1.1em;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.p-service__result__note {
  font-size: 0.875rem;
  color: var(--c-green);
  font-weight: var(--f-weight-medium);
  text-align: center;
  margin-top: 32px;
}

.p-results {
  background-color: var(--c-white);
  padding-left: 24px;
  padding-right: 24px;
}
.p-results__ttl {
  color: var(--c-blue);
}
.p-results__content {
  margin-top: 40px;
}
.p-results__card {
  background-color: #116EA6;
  box-shadow: inset 0px 0px 12px rgba(255, 255, 255, 0.4);
  border-radius: 8px;
  padding: 32px 16px;
  margin-top: 32px;
}
.p-results__card:first-child {
  margin-top: 0;
}
.p-results__card .p-results__txt:last-child {
  margin-bottom: 0;
}
.p-results__ttl-sub {
  font-size: 1.25rem;
  font-weight: var(--f-weight-semibold);
  text-align: center;
  background: linear-gradient(90deg, #CB8F2D 0%, #F7D444 36.54%, #FFEC9D 50.96%, #F7D641 64.42%, #CB8F2D 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}
.p-results__img {
  margin: 16px 0;
}
.p-results__txt {
  font-size: 0.875rem;
  text-align: justify;
  font-weight: var(--f-weight-regular);
  color: var(--c-white);
  margin-bottom: 0.5em;
}

.p-cases {
  background: linear-gradient(180deg, rgba(13, 68, 122, 0.93) 29.33%, rgba(14, 109, 164, 0.93) 91.83%);
}
.p-cases__ttl {
  color: var(--c-white);
  text-shadow: 0px 0px 4px rgba(255, 255, 255, 0.25);
}
.p-cases__content {
  margin-top: 40px;
}
.p-cases__ttl-sub {
  font-size: 1.125rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-white);
  text-align: center;
  margin-bottom: 24px;
}
.p-cases__company {
  margin-bottom: 64px;
}
.p-cases__company__box {
  position: relative;
  background-color: var(--c-white);
  border-radius: 4px;
  padding: 24px 18px 16px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-blue-rgb), 0.7);
}
.p-cases__company__name {
  font-size: 0.875rem;
  font-weight: var(--f-weight-semibold);
  line-height: 1;
  color: var(--c-white);
  position: absolute;
  top: -8px;
  left: 24px;
}
.p-cases__company__name span {
  background-color: var(--c-green);
  padding: 4px;
}
.p-cases__company__name::before, .p-cases__company__name::after {
  content: "";
  display: inline-block;
  background-image: url(../img/corner-green.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 9px;
  height: auto;
  aspect-ratio: 1/3;
}
.p-cases__company__name::before {
  position: absolute;
  top: -7px;
  left: -8px;
}
.p-cases__company__name::after {
  position: absolute;
  top: -6px;
  right: -8px;
  transform: scale(-1, -1);
}
.p-cases__company__list {
  position: relative;
  font-size: 0.875rem;
  font-weight: var(--f-weight-semibold);
}
.p-cases__company__item {
  position: relative;
  font-size: 0.75rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-blue);
  margin-top: 4px;
}
.p-cases__company__item:first-child {
  margin-top: 0;
}
.p-cases__company__item::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  background-color: var(--c-blue);
  border-radius: 50%;
  position: relative;
  top: 50%;
  left: -2px;
  transform: translateY(-50%);
}
.p-cases__graduate__card {
  background-color: var(--c-white);
  border-radius: 8px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-blue-rgb), 0.7);
  padding: 24px 16px;
  width: 100%;
  display: flex;
  flex-direction: column;
}
.p-cases__graduate__card__company {
  background-color: var(--c-green);
  padding: 12px 12px;
  font-size: 0.75rem;
  font-weight: var(--f-weight-semibold);
  text-align: center;
  line-height: 1;
  color: var(--c-white);
}
.p-cases__graduate__card__company span {
  display: block;
  font-size: 1rem;
  margin-top: 8px;
}
.p-cases__graduate__card__info {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
  margin-bottom: 12px;
}
.p-cases__graduate__card__info img {
  width: 80px;
}
.p-cases__graduate__card__info p {
  font-size: 0.875rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-green);
}
.p-cases__graduate__card__list {
  display: flex;
  align-items: center;
  padding: 12px 0;
  border-bottom: solid 1px var(--c-gray);
}
.p-cases__graduate__card__list dt {
  font-size: 0.75rem;
  font-weight: var(--f-weight-semibold);
  color: var(--c-blue);
  width: 110px;
}
.p-cases__graduate__card__list dd {
  font-size: 0.75rem;
  text-align: justify;
  flex: 1;
}
.p-cases__graduate__card__list.-column {
  flex-direction: column;
  align-items: flex-start;
  border-bottom: none;
  flex: 1;
}
.p-cases__graduate__card__list.-column dd {
  margin-top: 8px;
}
.p-cases .swiper {
  padding-bottom: 32px;
}
.p-cases .swiper-wrapper {
  align-items: stretch;
}
.p-cases .swiper-slide {
  height: auto;
  display: flex;
}
.p-cases .swiper-slide > .p-cases__graduate__card {
  height: 100%;
}

.p-flow {
  background-color: var(--c-white);
  padding-left: 24px;
  padding-right: 24px;
}
.p-flow__ttl {
  color: var(--c-green);
}
.p-flow__content {
  margin-top: 40px;
}
.p-flow__list {
  position: relative;
}
.p-flow__list .p-flow__item:first-child::before, .p-flow__list .p-flow__item:last-child::before {
  background-color: var(--c-green);
}
.p-flow__list::before {
  content: "";
  width: 1px;
  height: calc(100% - 155px);
  position: absolute;
  top: 80px;
  left: 23px;
  border: 1px dashed var(--c-green);
  z-index: 2;
  transform: translateX(-50%);
}
.p-flow__item {
  position: relative;
  padding: 24px 16px 24px 40px;
  border-radius: 8px;
  box-shadow: inset 0px 0px 8px rgba(var(--c-green-rgb), 0.7);
  margin-top: 24px;
}
.p-flow__item:first-child {
  margin-top: 0;
}
.p-flow__item::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-left: -8px;
  border-radius: 100%;
  background-color: var(--c-white);
  border: solid 1px var(--c-green);
  z-index: 2;
  position: absolute;
  top: 50%;
  left: 24px;
  transform: translateY(-50%);
}
.p-flow__number {
  font-size: 0.75rem;
  color: var(--c-green);
  font-weight: var(--f-weight-bold);
}
.p-flow__ttl-sub {
  font-size: 1rem;
  color: var(--c-green);
  font-weight: var(--f-weight-bold);
}
.p-flow__description {
  font-size: 0.875rem;
  margin-top: 8px;
}

.p-faq {
  background: linear-gradient(180deg, rgba(13, 68, 122, 0.93) 29.33%, rgba(14, 109, 164, 0.93) 91.83%);
  padding-left: 24px;
  padding-right: 24px;
}
.p-faq__ttl {
  color: var(--c-white);
  text-shadow: 0px 0px 4px rgba(255, 255, 255, 0.25);
}
.p-faq__content {
  margin-top: 40px;
}
.p-faq__box {
  color: var(--c-white);
  border: solid 2px var(--c-white);
  border-radius: 4px;
  background-color: rgba(255, 255, 255, 0.2);
  margin-top: 24px;
}
.p-faq__box:first-child {
  margin-top: 0;
}
.p-faq__question {
  position: relative;
  padding: 24px 40px;
  cursor: pointer;
}
.p-faq__question::before {
  content: "Q";
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}
.p-faq__question::after {
  content: "";
  background-image: url(../img/more-plus.svg);
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
}
.p-faq__question.is-active::after {
  content: "";
  background-image: url(../img/more-minus.svg);
  transform: translateY(-15%);
  height: 4px;
}
.p-faq__answer {
  display: none;
  font-size: 0.875rem;
  padding: 0 24px 24px;
}

.p-message {
  padding-left: 16px;
  padding-right: 16px;
  background-image: url(../img/message-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
}
.p-message__ttl {
  color: var(--c-white);
}
.p-message__ttl .c-sec__ttl-jp {
  font-size: 1.3125rem;
}
.p-message__content {
  margin-top: 40px;
}
.p-message__txt {
  font-size: 0.875rem;
  color: var(--c-white);
  text-align: center;
  margin-top: 16px;
  filter: drop-shadow(0px 0px 8px rgba(0, 0, 0, 0.6));
}
.p-message__txt:first-child {
  margin-top: 0;
}
.p-message__txt.-large {
  font-size: 0.9375rem;
  font-weight: var(--f-weight-semibold);
}

.swiper .swiper-slide {
  height: auto;
}
.swiper .swiper-button-prev,
.swiper .swiper-button-next {
  width: 32px;
  height: 32px;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
  border: solid 1px var(--c-blue);
}
.swiper .swiper-button-prev {
  left: 8px;
}
.swiper .swiper-button-next {
  right: 8px;
}
.swiper .swiper-button-prev::before,
.swiper .swiper-button-next::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--c-blue);
  border-right: 2px solid var(--c-blue);
  transform-origin: center;
}
.swiper .swiper-button-prev::before {
  transform: translate(-40%, -50%) rotate(-135deg);
}
.swiper .swiper-button-next::before {
  transform: translate(-60%, -50%) rotate(45deg);
}
.swiper .swiper-pagination {
  bottom: 0;
}
.swiper .swiper-pagination-bullet {
  background-color: var(--c-white);
}

.p-mv .swiper, .p-cases__company .swiper {
  padding-top: 16px;
}
.p-mv .swiper-button-prev, .p-cases__company .swiper-button-prev {
  top: calc(50% + 8px);
}
.p-mv .swiper-button-next, .p-cases__company .swiper-button-next {
  top: calc(50% + 8px);
}/*# sourceMappingURL=style.css.map */