@charset "UTF-8";
.u-text-heading-main {
  font-size: 48px;
  line-height: 1.5;
  font-weight: 700;
}
:lang(ja) .u-text-heading-main {
  letter-spacing: 0.2em;
}
:lang(en) .u-text-heading-main {
  letter-spacing: 0.1em;
}
@media (max-width: 1199.9px) {
  .u-text-heading-main {
    font-size: 28px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-heading-main {
    font-size: 28px;
  }
  :lang(ja) .u-text-heading-main {
    letter-spacing: 0.1em;
  }
}

.u-text-heading-sub {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 700;
}
:lang(ja) .u-text-heading-sub {
  letter-spacing: 0.1em;
}
:lang(en) .u-text-heading-sub {
  letter-spacing: 0.04em;
}
@media (max-width: 1199.9px) {
  .u-text-heading-sub {
    font-size: 16px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-heading-sub {
    font-size: 14px;
  }
}

.u-text-heading-xl {
  font-size: 48px;
  line-height: 1.5;
  font-weight: 700;
}
:lang(ja) .u-text-heading-xl {
  letter-spacing: 0.05em;
}
:lang(en) .u-text-heading-xl {
  letter-spacing: 0.15em;
}
@media (max-width: 1199.9px) {
  .u-text-heading-xl {
    font-size: 32px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-heading-xl {
    font-size: 20px;
  }
}

.u-text-heading-md {
  font-size: 24px;
  line-height: 1.5;
  font-weight: 700;
}
:lang(ja) .u-text-heading-md {
  letter-spacing: 0.05em;
}
:lang(en) .u-text-heading-md {
  letter-spacing: 0.1em;
}
@media (max-width: 1199.9px) {
  .u-text-heading-md {
    font-size: 22px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-heading-md {
    font-size: 20px;
  }
}

.u-text-text-lg {
  font-size: 20px;
  line-height: 1.6;
  font-weight: 400;
}
:lang(ja) .u-text-text-lg {
  letter-spacing: 0.05em;
}
:lang(en) .u-text-text-lg {
  letter-spacing: 0.075em;
}
@media (max-width: 1199.9px) {
  .u-text-text-lg {
    font-size: 19px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-text-lg {
    font-size: 18px;
  }
}

.u-text-text-md {
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
}
:lang(ja) .u-text-text-md {
  letter-spacing: 0.05em;
}
:lang(en) .u-text-text-md {
  letter-spacing: 0.075em;
}
@media (max-width: 1199.9px) {
  .u-text-text-md {
    font-size: 15px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-text-md {
    font-size: 14px;
  }
}

.u-text-text-sm {
  font-size: 14px;
  line-height: 1.6;
  font-weight: 500;
}
:lang(ja) .u-text-text-sm {
  letter-spacing: 0.05em;
}
:lang(en) .u-text-text-sm {
  letter-spacing: 0.075em;
}
@media (max-width: 1199.9px) {
  .u-text-text-sm {
    font-size: 13px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-text-sm {
    font-size: 12px;
  }
}

.u-text-text-xs {
  font-size: 12px;
  line-height: 1.6;
  font-weight: 400;
}
:lang(ja) .u-text-text-xs {
  letter-spacing: 0.05em;
}
:lang(en) .u-text-text-xs {
  letter-spacing: 0.075em;
}
@media (max-width: 1199.9px) {
  .u-text-text-xs {
    font-size: 11px;
  }
}
@media (max-width: 1023.9px) {
  .u-text-text-xs {
    font-size: 10px;
  }
}

/* ============================================
   1. セクション見出し (.c-section-header)
   ============================================ */
.c-section-header {
  margin-bottom: 32px;
  text-align: left;
}
@media (max-width: 1199px) {
  .c-section-header {
    margin-bottom: 28px;
  }
}
@media (max-width: 1023px) {
  .c-section-header {
    margin-bottom: 24px;
  }
}
.c-section-header.--center {
  text-align: center;
}
.c-section-header.--center .c-section-header__main::before {
  content: "";
  display: inline-block;
  width: 40px;
  height: 10px;
  background-color: #FBBE00;
  vertical-align: middle;
  margin-right: 10px;
  position: relative;
  top: -3px;
}
@media (max-width: 767px) {
  .c-section-header.--center .c-section-header__main::before {
    width: 20px;
    height: 4px;
    margin-right: 5px;
  }
}
.c-section-header.--center .dash-white::before {
  background-color: #fff;
}

/* 小見出し（日本語） */
.c-section-header__sub {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 700;
}
:lang(ja) .c-section-header__sub {
  letter-spacing: 0.1em;
}
:lang(en) .c-section-header__sub {
  letter-spacing: 0.04em;
}
@media (max-width: 1199.9px) {
  .c-section-header__sub {
    font-size: 16px;
  }
}
@media (max-width: 1023.9px) {
  .c-section-header__sub {
    font-size: 14px;
  }
}
.c-section-header__sub {
  display: block;
  font-weight: bold;
  margin-bottom: 12px;
  color: #1E2324;
}
@media (max-width: 767px) {
  .c-section-header__sub {
    margin-bottom: 5px;
  }
}

/* メイン見出し（英語） */
.c-section-header__main {
  font-size: 48px;
  line-height: 1.5;
  font-weight: 700;
}
:lang(ja) .c-section-header__main {
  letter-spacing: 0.2em;
}
:lang(en) .c-section-header__main {
  letter-spacing: 0.1em;
}
@media (max-width: 1199.9px) {
  .c-section-header__main {
    font-size: 28px;
  }
}
@media (max-width: 1023.9px) {
  .c-section-header__main {
    font-size: 28px;
  }
  :lang(ja) .c-section-header__main {
    letter-spacing: 0.1em;
  }
}
.c-section-header__main {
  display: inline-block;
  color: #1D2088;
  font-family: "Outfit", sans-serif;
  font-weight: bold;
  letter-spacing: 0.1em;
}
.c-section-header__main::after {
  content: "";
  display: inline-block;
  width: 40px;
  height: 10px;
  background-color: #FBBE00;
  vertical-align: middle;
  margin-left: 10px;
  position: relative;
  top: -3px;
}
@media (max-width: 767px) {
  .c-section-header__main::after {
    width: 20px;
    height: 4px;
    margin-left: 5px;
  }
}
.c-section-header__main.dash-white::after {
  background-color: #fff;
}
@media (max-width: 767px) {
  .c-section-header__main {
    font-size: 28px;
  }
}

/* ============================================
   2. アニメーション装飾 (Scroll Reveal)
   ============================================ */
.bgappearTrigger,
.bgLRextendTrigger {
  opacity: 0;
}

.bgextend {
  position: relative;
  overflow: hidden;
  opacity: 0;
  animation: bgextendAnimeBase 1s forwards;
}

@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.bgLRextend::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #1D2088;
  animation: bgLRextendAnime 1s forwards;
}

@keyframes bgLRextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
.bgappear {
  opacity: 0;
  animation: bgextendAnimeSecond 1s 0.6s forwards;
}

@keyframes bgextendAnimeSecond {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/* ============================================
   3. 共通ボタン (.c-button)
   ============================================ */
.more-btn {
  text-align: center;
}

.c-button {
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 360px;
  max-width: 100%;
  height: 70px;
  border-radius: 35px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
  transition: all 0.3s;
  border: 3px solid transparent;
}
.c-button .arrow, .c-button__icon {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-family: "Noto Sans JP", sans-serif;
}
.c-button--white {
  background-color: #fff;
  color: #1D2088;
  border-color: #1D2088;
}
.c-button--white:hover {
  background-color: #1D2088;
  color: #fff;
}
.c-button--yellow {
  background-color: #FBBE00;
  color: #1E2324;
  border-color: #FBBE00;
}
.c-button--yellow:hover {
  background-color: #fff;
}
.c-button--navy {
  background-color: #1D2088;
  color: #fff;
  border-color: #1D2088;
}
.c-button--navy:hover {
  background-color: #fff;
  color: #1D2088;
}
@media (max-width: 767px) {
  .c-button {
    width: 100%;
    max-width: 260px;
    height: 52px;
    font-size: 14px;
  }
  .c-button .arrow, .c-button__icon {
    right: 15px;
  }
}

/* ボタン色バリエーション */
.btn-white {
  background-color: #fff;
  color: #1D2088;
  border: 3px solid #1D2088;
}

.btn-white:hover {
  background-color: #1D2088;
  color: #fff;
}

.btn-navy {
  background-color: #1D2088;
  color: #fff;
  border: 3px solid #1D2088;
}

.btn-navy:hover {
  background-color: #fff;
  color: #1D2088;
}

.btn-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #1D2088;
  color: #fff;
  text-decoration: none;
  padding: 15px 50px;
  border-radius: 50px;
  font-weight: bold;
  min-width: 280px;
  position: relative;
  transition: opacity 0.3s;
}

.btn-more:hover {
  opacity: 0.8;
}

.btn-more::after {
  content: "→";
  position: absolute;
  right: 25px;
}

/* ============================================
   共通変数定義 (もし他のファイルにない場合)
   ============================================ */
body {
  margin: 0;
  font-family: "Noto Sans JP", sans-serif;
  background-color: #F2F4F8;
  color: #1E2324;
}

@media only screen and (min-width: 768px) and (max-width: 1280px) {
  body {
    zoom: 0.8;
  }
}
section {
  overflow: hidden;
}

img {
  width: 100%;
}

.pc {
  display: block;
}

.pc-tab {
  display: block;
}

.sp {
  display: none;
}

.tab-only {
  display: none;
}

.sp-only {
  display: none;
}

@media only screen and (max-width: 980px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  .tab-only {
    display: block;
  }
}
@media only screen and (max-width: 680px) {
  .pc-tab {
    display: none;
  }
  .sp-only {
    display: block;
  }
  .tab-only {
    display: none;
  }
}
main {
  padding-top: 100px;
}

@media only screen and (max-width: 1200px) {
  main {
    padding-top: 90px;
  }
}
@media only screen and (max-width: 980px) {
  main {
    padding-top: 83px;
  }
}
@media only screen and (max-width: 680px) {
  main {
    padding-top: 45px;
  }
}
.section-inner {
  max-width: 1180px;
  width: 100%;
  margin: auto;
}

@media only screen and (max-width: 1250px) {
  .section-inner {
    padding: 0 20px;
  }
}
.fade_in, .fade_in_section {
  opacity: 0;
}

.fade_in {
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-name: fadeInAnime;
}

@keyframes fadeInAnime {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.text-white {
  color: #fff;
}

.text-yellow {
  color: #FBBE00;
}

/* ============================================
   KV セクション
   ============================================ */
.kv-section {
  position: relative;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

.kv-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  height: 100%;
  padding-top: 45px;
  padding-bottom: 90px;
}

.kv-container {
  display: flex;
  justify-content: space-between;
  gap: 40px;
}

/* --- 1. Text Area --- */
.kv-text-area {
  width: 40%;
  position: relative;
  z-index: 10;
}

.kv-main-copy {
  font-family: "Outfit", sans-serif;
  font-size: 72px;
  font-weight: bold;
  line-height: 1.05;
  letter-spacing: 0.1em;
  color: #1E2324;
  margin-bottom: 20px;
}

.kv-main-copy span.text-blue {
  color: #1D2088;
}

.kv-main-copy span.text-yellow {
  color: #FBBE00;
}

/* 親要素：文字を分解する箱。透明度は設定しない */
.js-kv-animate {
  display: inline-block;
  opacity: 1; /* ここを1にするか、記述を消す */
  transform: none; /* 親ごと動かさない */
}

/* 1文字ずつの初期状態 */
.char {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  letter-spacing: 0.05em;
}

/* クラスがついた時：ここで初めて表示される */
.char.is-active {
  opacity: 1;
  transform: translateY(0);
}

/* 半角スペースが詰まらないように幅を持たせる */
.char.is-space {
  width: 0.3em;
}

/* 単語のレイアウト微調整（必要に応じて） */
.kv-main-copy {
  overflow: hidden; /* 文字が下から出てくる際、はみ出しを隠すなら追加 */
}

.kv-sub-copy {
  font-size: 24px;
  font-weight: bold;
  color: #1D2088;
  margin: 0 0 20px;
  line-height: 1.5;
}

.kv-lead {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.8;
  margin: 0 0 40px;
}

/* --- 2. Puzzle Area --- */
.kv-puzzle-area {
  width: 55%;
  aspect-ratio: 4/3;
  position: relative;
}

/* パズル共通スタイル */
.puzzle-item {
  position: absolute;
  border-radius: 10px;
  filter: drop-shadow(0 10px 15px rgba(0, 0, 0, 0.1));
  animation: floatPuzzle 4s ease-in-out infinite;
}

.puzzle-item img {
  width: 100%;
  height: auto;
  display: block;
  /* 簡易的にパズルっぽく見せる装飾 */
  -webkit-mask-image: radial-gradient(circle at center, black 100%, transparent 100%);
          mask-image: radial-gradient(circle at center, black 100%, transparent 100%);
}

/* 8個のパズル配置 (PC) - ランダム配置 */
.p1 {
  top: -10.67%;
  width: 40.37%;
  left: 1.74%;
  animation-delay: 0s;
}

.p2 {
  top: -4.27%;
  right: 6.07%;
  width: 23.4%;
}

.p3 {
  top: 60.61%;
  right: 29.8%;
  width: 23.78%;
  animation-delay: 1.5s;
}

.p4 {
  top: 36.21%;
  right: -3.67%;
  width: 27.73%;
  animation-delay: 2.5s;
}

.p5 {
  top: 37.12%;
  left: -5%;
  width: 17.33%;
  animation-delay: 0.8s;
}

.p6 {
  top: 14.49%;
  left: 41.58%;
  width: 34.65%;
  animation-delay: 1.2s;
}

.p7 {
  top: 63.37%;
  left: 1.74%;
  width: 30.32%;
  animation-delay: 3s;
}

.p8 {
  top: 77%;
  right: 5.6%;
  width: 15.59%;
  animation-delay: 2s;
}

/* ふわふわアニメーション */
@keyframes floatPuzzle {
  0%, 100% {
    transform: translateY(0) rotate(var(--rot, 0deg));
  }
  50% {
    transform: translateY(-20px) rotate(var(--rot, 0deg));
  }
}
/* --- 3. Button Area --- */
.kv-btn-area-pc {
  display: flex;
  flex-direction: column;
  gap: 15px;
  max-width: 400px;
  z-index: 2;
}

.kv-btn-area-sp {
  display: none;
}

.kv-btn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 25px;
  border-radius: 50px;
  text-decoration: none;
  font-weight: bold;
  font-size: 15px;
  transition: transform 0.2s;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.kv-btn:hover {
  transform: translateY(-3px);
}

/* --- 4. Slider Area --- */
.kv-slider-area {
  /* PC: 右下に配置 */
  position: absolute;
  bottom: 40px;
  right: 40px;
  max-width: 420px;
  width: 45%;
  background: #fff;
  border-radius: 10px;
  padding: 15px;
  box-shadow: 0 4px 20px 0 rgba(29, 32, 136, 0.05);
  z-index: 10;
}

@media screen and (min-width: 1441px) {
  .kv-text-area {
    width: 47%;
  }
  .kv-puzzle-area {
    width: 50%;
  }
  .kv-inner {
    max-width: 1440px;
  }
  .kv-main-copy {
    font-size: 92px;
  }
  .kv-sub-copy {
    font-size: 32px;
  }
  .kv-lead {
    font-size: 20px;
  }
  .kv-slider-area {
    right: 0;
  }
}
.slider-window {
  overflow: hidden;
  width: 100%;
}

.slider-track {
  display: flex;
  transition: transform 0.5s ease-in-out;
}

.slide-item {
  min-width: 100%; /* 1つずつ表示 */
}

.slide-item-link {
  display: flex;
  gap: 15px;
  align-items: center;
}

.slide-item-link:hover .slide-title {
  text-decoration: underline;
}

.slide-thumb img {
  width: 100px;
  aspect-ratio: 20/11;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 6px;
}

.slide-content time {
  font-size: 11px;
  color: #1D2088;
  font-weight: bold;
  display: block;
  margin-bottom: 4px;
}

.slide-title {
  font-size: 13px;
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.slider-dots {
  position: absolute;
  bottom: -20px;
  right: 0;
  left: 0;
  margin: auto;
  display: flex;
  justify-content: center;
  gap: 20px;
}

.dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #ddd;
  border: none;
  cursor: pointer;
  padding: 0;
}

.dot.active {
  background-color: #1D2088;
}

@media screen and (min-width: 1441px) {
  .p1 {
    top: -55px;
    width: 285px;
    left: 10px;
    animation-delay: 0s;
  }
  .p2 {
    top: -28px;
    right: 82px;
    width: 135px;
    animation-delay: 0.5s;
  }
  .p3 {
    top: 335px;
    right: 290px;
    width: 195px;
    animation-delay: 1.5s;
    transform: rotate(10deg);
  }
  .p4 {
    top: 200px;
    right: 25px;
    width: 185px;
    animation-delay: 2.5s;
    transform: rotate(20deg);
  }
  .p5 {
    top: 220px;
    left: -30px;
    width: 90px;
    animation-delay: 0.8s;
    transform: rotate(-15deg);
  }
  .p6 {
    top: 125px;
    left: 255px;
    width: 205px;
    animation-delay: 1.2s;
    transform: rotate(-5deg);
  }
  .p7 {
    bottom: 0;
    left: 0px;
    width: 175px;
    animation-delay: 3s;
    transform: rotate(-5deg);
  }
  .p8 {
    bottom: 75px;
    right: 85px;
    width: 95px;
    animation-delay: 2s;
    transform: rotate(25deg);
  }
}
/* --- Responsive (SP) --- */
@media screen and (max-width: 1280px) {
  .kv-inner {
    padding-top: 25px;
    padding-bottom: 25px;
  }
  .p1 {
    top: -6%;
  }
  .p2 {
    top: 0;
  }
}
@media screen and (max-width: 1250px) {
  .p2 {
    top: -5%;
    right: -3%;
  }
  .p4 {
    right: -2%;
  }
  .kv-inner {
    padding-right: 40px;
  }
  .kv-slider-area {
    right: 20px;
  }
}
@media screen and (max-width: 980px) {
  .kv-main-copy {
    font-size: 48px;
  }
}
@media screen and (max-width: 768px) {
  .kv-section {
    padding-top: 25px;
    padding-bottom: 40px;
    min-height: unset;
    padding-bottom: 20px;
  }
  .kv-inner {
    display: flex;
    flex-direction: column;
    padding: 0 20px;
  }
  .kv-container {
    flex-direction: column;
    gap: 0;
    padding: 0 10px;
  }
  /* 順序の制御 (B案) */
  .kv-text-area {
    order: 1;
  }
  .kv-puzzle-area {
    order: 2;
  }
  .kv-btn-area {
    order: 3;
  }
  .kv-slider-area {
    order: 4;
  }
  .kv-btn-area-pc {
    display: none;
  }
  .kv-btn-area-sp {
    margin-top: -40px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: center;
  }
  .kv-btn-area-sp .c-button {
    max-width: 280px;
    height: 52px;
  }
  /* 1. Text */
  .kv-text-area {
    width: 100%;
    padding-top: 0;
    text-align: left;
  }
  .kv-main-copy {
    font-size: 40px;
    margin-bottom: 15px;
  }
  .kv-sub-copy {
    font-size: 20px;
    margin-bottom: 16px;
    letter-spacing: 0.1em;
    line-height: 1.6;
  }
  .kv-lead {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 0;
  }
  /* 2. Puzzle (SP用配置) */
  .kv-puzzle-area {
    position: relative;
    height: auto;
    width: 100%;
    margin-top: 10px;
    aspect-ratio: 167/105;
  }
  @keyframes floatPuzzle {
    0%, 100% {
      transform: translateY(0) rotate(var(--rot, 0deg));
    }
    50% {
      transform: translateY(-10px) rotate(var(--rot, 0deg));
    }
  }
  .p1 {
    left: -5.15%;
    width: 30.28%;
  }
  .p2 {
    top: 0;
    width: 16.68%;
    left: 42.39%;
  }
  .p3 {
    top: 4.82%;
    right: 3.64%;
    width: 26.35%;
  }
  .p4 {
    top: 38.53%;
    left: 39.37%;
    width: 24.23%;
  }
  .p5 {
    top: 43.35%;
    left: 20.29%;
    width: 12.12%;
  }
  .p6 {
    left: unset;
    top: 45.98%;
    right: -10.46%;
    width: 24.23%;
  }
  .p7 {
    top: 62.61%;
    left: -3.64%;
    width: 22.11%;
  }
  .p8 {
    top: 45.76%;
    right: 13.63%;
    width: 15.75%;
  }
  /* 3. Buttons */
  .kv-btn-area {
    width: 100%;
    max-width: 100%;
    margin-bottom: 40px;
  }
  .kv-btn {
    width: 100%;
    box-sizing: border-box;
  }
  /* 4. Slider */
  .kv-slider-area {
    position: relative;
    bottom: auto;
    right: auto;
    width: 100%;
    padding: 20px 10px;
    margin: auto;
  }
  .slide-item-link {
    gap: 10px;
  }
}
/* ============================================
   SERVICE セクション
   ============================================ */
.service-section {
  position: relative;
  overflow: hidden; /* 背景文字のはみ出し防止 */
}

.service-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 40px; /* 左右の余白 */
  position: relative;
  z-index: 2;
}

/* --- 背景の流れる文字 --- */
.bg-scroll-text {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  z-index: 0;
  opacity: 0.5;
  pointer-events: none;
}

.scroll-track {
  display: flex;
  white-space: nowrap;
  animation: scrollText 10s linear infinite;
}

.scroll-track span {
  font-family: "Outfit", sans-serif;
  font-weight: 700;
  font-size: 200px;
  line-height: 1;
  color: #fff;
  -webkit-text-stroke: 2px #FBBE00; /* 白抜きの文字 */
  margin-right: 100px;
}

@keyframes scrollText {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
/* --- タイトルスタイル (共通) --- */
.sub-ja {
  font-size: 14px;
  font-weight: bold;
  margin: 0;
  letter-spacing: 0.1em;
}

.main-en {
  font-family: "Outfit", sans-serif;
  font-size: 36px;
  color: #1D2088;
  margin: 5px 0 0;
  display: flex;
  align-items: center;
  gap: 15px;
}

.main-en .dash {
  display: block;
  width: 30px;
  height: 4px;
  background-color: #FBBE00; /* 黄色のライン */
}

/* --- レイアウト構成 (Grid) --- */
.service-container {
  position: relative;
  display: flex;
  /* 左カラム固定幅(例:300px) + 隙間 + 右カラム(残り) */
  gap: 60px;
}

/* --- 左カラム (サイドバー) --- */
.service-sidebar {
  width: 30%;
}

.sidebar-sticky {
  position: relative;
  z-index: 10;
  height: 100%;
  width: 100%;
}

/* パズルの浮遊アニメーション */
.puzzle-deco {
  position: absolute;
  width: 80px;
}

.puzzle-deco img {
  width: 100%;
  height: auto;
}

.puzzle-1 {
  top: 390px;
  top: 33.35%;
  left: 20px;
  animation: servicefloatPuzzle 4s ease-in-out infinite;
}

.puzzle-2 {
  top: 790px;
  top: 67.56%;
  right: 0px;
  animation: servicefloatPuzzle 5s ease-in-out infinite 0.5s;
}

.puzzle-3 {
  bottom: 25px;
  bottom: 2.14%;
  left: 50px;
  animation: servicefloatPuzzle 4.5s ease-in-out infinite 1s;
}

@keyframes servicefloatPuzzle {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
}
/* --- 右カラム (カードリスト) --- */
.service-main {
  width: 70%;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

/* --- カード共通スタイル --- */
.service-card {
  border-radius: 50px;
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 30px;
  transition: transform 0.3s;
}

.service-card-link {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 50px 40px;
}

.service-card:hover {
  transform: translateY(-5px) !important;
}

.service-card.card-green {
  padding: 50px 40px;
}

.service-card.card-green:hover {
  transform: unset !important;
}

.service-card.card-green .link-item {
  transition: transform 0.3s;
}

.service-card.card-green .link-item:hover {
  transform: translateY(-5px) !important;
}

.card-orange {
  background-color: #FF7043;
}

.card-green {
  background-color: #00BFA5;
}

.card-blue {
  background-color: #4facfe;
}

.card-content {
  flex: 1;
  width: 60%;
}

.card-image {
  max-width: 240px;
  width: 40%;
  flex-shrink: 0;
}

.service-card.card-green .card-content {
  width: 100%;
}

.card-image img {
  width: 100%;
  border-radius: 30px;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1/1;
}

/* カード内部テキスト */
.card-header {
  margin-bottom: 18px;
}

.card-num {
  display: block;
  font-family: "Outfit", sans-serif;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.card-num span {
  font-family: "Noto Sans JP", sans-serif;
}

.card-title-en {
  position: relative;
  font-family: "Outfit", sans-serif;
  font-size: 32px;
  margin: 0;
  line-height: 1;
  font-weight: 700;
  margin-top: 6px;
}

.card-catch {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.075em;
  margin: 0 0 15px;
}

.card-desc {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin: 0 0 25px;
}

/* ボタン類 */
.card-arrow-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  background-color: #fff;
  color: #FF7043;
  border-radius: 50%;
  text-decoration: none;
  font-weight: bold;
}

.card-arrow-btn img {
  width: 24px;
}

.card-orange .card-arrow-btn {
  color: #FF7043;
}

.card-blue .card-arrow-btn {
  color: #4facfe;
}

.card-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.link-item {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  font-size: 20px;
  line-height: 3;
  letter-spacing: 0.1em;
  width: -moz-fit-content;
  width: fit-content;
}

.link-item:hover {
  text-decoration: underline;
}

.link-item .link-text {
  text-decoration: underline;
}

.icon-circle {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  background-color: #fff;
  color: var(--color-green);
  border-radius: 50%;
  font-size: 16px;
}

.icon-circle img {
  width: 24px;
}

/* SP用タイトル */
.sp-section-title {
  display: none;
  text-align: center;
  margin-bottom: 40px;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}

.sp-section-title .main-en {
  justify-content: center;
}

/* SP対応 (Service) */
@media screen and (max-width: 1100px) {
  .service-section .c-section-header {
    margin-bottom: 0;
  }
  .sp-section-title {
    margin-bottom: 24px;
  }
  .service-container {
    gap: 20px;
  }
  .service-card {
    flex-direction: column;
    gap: 20px;
  }
  .service-card.card-green,
  .service-card-link {
    padding: 30px 24px;
  }
  .card-image {
    margin: 0 auto 32px;
  }
  .card-image.pc {
    display: none;
  }
  .card-image.sp {
    display: block;
  }
  .card-image {
    width: 100%;
    max-width: unset;
    margin-bottom: 20px;
  }
  .card-image img {
    aspect-ratio: unset;
    height: auto;
    border-radius: 30px;
    aspect-ratio: 29/18;
  }
  .card-body {
    text-align: right;
  }
  .card-body .card-catch,
  .card-body .card-desc {
    text-align: left;
  }
  .icon-circle,
  .card-arrow-btn {
    width: 40px;
    height: 40px;
  }
}
@media screen and (max-width: 680px) {
  .service-inner {
    padding: 0 20px;
  }
  .service-sidebar {
    display: none;
  }
  .sp-section-title {
    display: flex;
  }
  .service-container {
    grid-template-columns: 1fr;
  }
  .scroll-track span {
    font-size: 100px;
  }
  .service-main {
    width: 100%;
    gap: 30px;
  }
  .service-card.card-green,
  .service-card-link {
    padding: 30px;
  }
  .card-num {
    font-size: 14px;
    font-weight: bold;
    line-height: 1.6;
    letter-spacing: 0.1em;
    margin-bottom: 0;
  }
  .card-body .card-desc {
    margin-bottom: 15px;
  }
  .card-arrow-btn img {
    width: 18px;
  }
  .icon-circle {
    width: 32px;
    height: 32px;
  }
  .icon-circle img {
    width: 18px;
  }
  .link-item {
    font-size: 14px;
  }
  .card-title-en {
    font-size: 28px;
    line-height: 1.6;
  }
  .card-title-en svg {
    width: auto;
    height: 30px;
  }
  .card-catch {
    font-size: 20px;
  }
  .card-arrow-btn {
    width: 32px;
    height: 32px;
  }
}
/* ============================================
   サービススライダー
   ============================================ */
.top-service-slider-sec {
  padding: 135px 0;
}

.top-service-slider {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.top-service-slider-track {
  display: flex;
  will-change: transform;
}

.top-service-slide-item {
  margin: 0 15px;
  width: 315px;
  box-sizing: border-box;
}

.top-service-slide-item img {
  width: 100%;
  border-radius: 16px;
  display: block;
}

@media only screen and (max-width: 980px) {
  .top-service-slide-item {
    width: 250px;
  }
}
@media only screen and (max-width: 680px) {
  .top-service-slide-item {
    width: 215px;
  }
}
/* ============================================
   APPROACH セクション (Bento Grid)
   ============================================ */
.approach-section {
  display: flex;
  gap: 24px;
  width: 100%;
  max-width: 1180px; /* inner幅に合わせました */
  margin: 0 auto;
}

.approach-section .column {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.approach-section .content-box {
  border-radius: 30px;
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.blue-bg {
  background-color: #1D2088;
  color: #fff;
  height: calc(53% - 0px);
}

.yellow-bg {
  background-color: #FBBE00;
  color: #1E2324;
  height: calc(61% - 0px);
}

.approach-section .content-box.blue-bg {
  padding: 73px 40px;
}

.approach-section .content-box.yellow-bg {
  padding: 60px 40px;
}

.approach-section-header__sub {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: 12px;
}

.approach-section-header__main {
  font-size: 32px;
  font-weight: bold;
  font-family: "Outfit", sans-serif;
  line-height: 1.6;
  letter-spacing: 0.2em;
  margin-top: 12px;
  margin-bottom: 12px;
}

.approach-section .image-box-1 {
  position: relative;
  height: 47%;
  max-height: 315px;
  border-radius: 30px;
  overflow: hidden;
}

.approach-section .image-box-2 {
  position: relative;
  height: 39%;
  max-height: 255px;
  border-radius: 30px;
  overflow: hidden;
}

.approach-section .image-box-1 img,
.approach-section .image-box-2 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  animation: zoomInOut 10s ease-in-out infinite;
}

@keyframes zoomInOut {
  0%, to {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}
.approach-section .sub-title {
  font-size: 14px;
  margin-bottom: 10px;
}

.approach-section .main-title {
  font-size: 32px;
  margin-bottom: 20px;
  color: #FBBE00;
}

.approach-section .desc {
  line-height: 1.8;
}

.approach-section .step-item {
  display: flex;
  gap: 15px;
  margin-bottom: 20px;
}

.approach-section .step-item:last-child {
  margin-bottom: 0;
}

.approach-section .step-num {
  font-family: "Outfit", sans-serif;
  font-size: 48px;
  font-weight: bold;
  color: #1D2088;
  letter-spacing: 0.1em;
  line-height: 0.7;
}

.approach-section .step-text h3 {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 10px;
  letter-spacing: 0.1em;
  color: #1D2088;
}

@media screen and (max-width: 1250px) {
  .approach-section {
    padding-left: 20px;
    padding-right: 20px;
  }
}
/* SP対応 (Approach) */
@media screen and (max-width: 768px) {
  .approach-section {
    flex-direction: column;
  }
  .approach-section .column {
    gap: 25px;
  }
  .column {
    width: 100%;
  }
  .approach-section-header__sub {
    font-size: 14px;
  }
  .approach-section-header__main {
    font-size: 28px;
    letter-spacing: 0.1em;
  }
  .approach-section .right-col {
    flex-direction: column-reverse;
  }
  .approach-section .content-box.blue-bg {
    padding: 40px;
  }
  .approach-section .content-box.yellow-bg {
    padding: 40px 30px;
  }
  .approach-section .step-item {
    gap: 30px;
  }
  .approach-section .step-num {
    font-size: 34px;
    line-height: 1;
  }
  .approach-section .step-text h3 {
    font-weight: bold;
    margin-bottom: 10px;
  }
  .image-box {
    flex-grow: 0;
    height: 250px;
  }
}
/* ============================================
   TOPクライアント
   ============================================ */
.top-clients {
  background-color: #fff;
  border-radius: 60px;
  text-align: right;
}

.top-clients-container {
  display: flex;
  flex-wrap: wrap;
  gap: 30px 20px; /* 縦 横 */
}

.top-clients-item {
  width: calc((100% - 100px) / 6);
}

.top-clients-note {
  margin-top: 10px;
  display: inline-block;
  text-align: right;
  font-size: 14px;
  line-height: 1.5;
}

@media only screen and (max-width: 980px) {
  .top-clients-item {
    width: calc((100% - 60px) / 4);
  }
}
@media only screen and (max-width: 680px) {
  .top-clients .section-inner {
    padding: 0 25px;
  }
  .top-clients-item {
    width: calc((100% - 40px) / 3);
  }
}
/* ============================================
   TOP実績  セクション
   ============================================ */
.top-works {
  padding: 120px 0;
  overflow: hidden;
}

.top-works .slick-center {
  transition: 0.4s;
}

.top-works .slick-track {
  display: flex;
}

.top-works .slick-slide {
  width: 360px;
  height: auto;
  display: flex;
}

.works-slider .prev-arrow,
.works-slider .next-arrow {
  display: none;
}

.works-progress {
  max-width: 800px;
  width: calc(100% - 40px);
  height: 3px;
  background: #fff;
  margin: 32px auto;
  overflow: hidden;
}

.works-progress .bar {
  height: 100%;
  width: 0;
  background: #1D2088;
  transition: 0.4s;
}

.top-works .slick-list {
  overflow: visible;
}

.works-item {
  width: 360px;
  transition: transform 0.3s;
}

.works-item-link {
  display: flex;
  flex-direction: column;
  border-radius: 30px;
  height: 100%;
  overflow: hidden;
  box-shadow: 0 4px 20px 0 rgba(29, 32, 136, 0.05);
  margin: 0 10px;
}

.works-item:hover {
  transform: translateY(-5px) !important;
  z-index: 10;
}

.works-item-img img {
  aspect-ratio: 34/19;
  -o-object-fit: cover;
     object-fit: cover;
}

.works-item-info {
  flex: 1;
  background-color: #fff;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.works-item-cat-list {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  gap: 10px;
}

.works-item-cat {
  display: block;
  border: 2px solid;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.15;
  border-radius: 30px;
}

.works-item-title {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.5;
  color: #1E2324;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.works-item-client {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #1D2088;
}

@media only screen and (max-width: 980px) {
  .top-works {
    padding: 90px 0;
  }
  .top-works-slider-container {
    position: relative;
    padding-bottom: 70px;
  }
  .works-slider .prev-arrow,
  .works-slider .next-arrow {
    display: block;
  }
  .top-works-slider-container .works-slider {
    position: static;
  }
  .works-slider .slick-center {
    opacity: 1;
  }
  .works-item {
    max-width: 320px;
  }
  .prev-arrow,
  .next-arrow {
    position: absolute;
    bottom: 24px;
    left: 20px;
    width: 45px;
    height: 45px;
    border: none;
    z-index: 10;
    cursor: pointer;
    background-size: cover;
  }
  .next-arrow {
    left: 75px;
  }
  .prev-arrow {
    background-image: url("../img/common/prev-arrow.webp");
  }
  .next-arrow {
    background-image: url("../img/common//next-arrow.webp");
  }
}
@media only screen and (max-width: 680px) {
  .top-works {
    padding: 60px 0;
  }
  .works-item {
    max-width: 290px;
  }
  .works-progress {
    width: 76.85%;
    margin: 24px auto;
  }
}
/* ============================================
   CTA(サービス資料をダウンロード)  セクション
   ============================================ */
.cta-section {
  width: 100%;
  box-sizing: border-box;
  gap: 32px;
}
@media (max-width: 1199.9px) {
  .cta-section {
    gap: 28px;
  }
}
@media (max-width: 1023.9px) {
  .cta-section {
    gap: 24px;
  }
}

.cta-container {
  margin: 0 auto;
  background-color: #1D2088;
  border-radius: 50px;
  position: relative;
  padding: 80px 40px;
  text-align: center;
  overflow: hidden;
}

/* --- コンテンツ --- */
.cta-content {
  position: relative;
  z-index: 2; /* パズルより前面に */
  color: #fff;
  gap: 32px;
}
@media (max-width: 1199.9px) {
  .cta-content {
    gap: 28px;
  }
}
@media (max-width: 1023.9px) {
  .cta-content {
    gap: 24px;
  }
}

.cta-title {
  font-size: 28px;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 32px;
}

.cta-title .text-yellow {
  color: #FBBE00;
}

.cta-desc {
  margin-bottom: 32px;
}

/* --- ボタン --- */
.cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  color: #1D2088;
  border: 2px solid #1D2088;
  text-decoration: none;
  padding: 20px 60px;
  border-radius: 50px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.1em;
  transition: all 0.3s;
  gap: 15px;
}

.cta-btn:hover {
  background-color: #1D2088;
  color: #fff;
  border: 2px solid #fff;
}

.cta-btn .arrow {
  font-family: sans-serif;
  font-weight: bold;
}

/* --- 装飾パズル --- */
.cta-decorations {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none; /* クリックを邪魔しない */
}

.cta-puzzle {
  position: absolute;
}

.cta-puzzle img {
  display: block;
  width: 100%;
  height: auto;
  /* 簡易的なシャドウ */
  filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.2));
}

/* === PC配置 === */
/* 1. 青パズル (左上) */
.p-blue {
  top: 56px;
  left: 46px;
  max-width: 90px;
  width: 6.25vw;
}

/* 2. オレンジ画像 (右上) */
.p-orange-img {
  top: 35px;
  right: 35px;
  max-width: 170px;
  width: 11.81vw;
}

/* 3. 緑画像 (左下) */
.p-green-img {
  bottom: 25px;
  left: 70px;
  max-width: 210px;
  width: 14.59vw;
}

/* 4. オレンジ (右下) */
.p-orange {
  bottom: 30px;
  right: 50px;
  max-width: 140px;
  width: 9.72vw;
}

/* === SP対応 === */
@media screen and (max-width: 768px) {
  .cta-section.u-section-sm {
    padding: 0;
  }
  .cta-container {
    padding: 90px 0 100px;
    border-radius: 24px;
  }
  .cta-title {
    font-size: 20px;
    line-height: 1.6;
    margin-bottom: 25px;
  }
  .cta-desc {
    font-size: 14px;
    margin-bottom: 25px;
  }
  .cta-btn {
    padding: 15px 10px;
    font-size: 14px;
    max-width: 280px;
    width: 100%; /* 幅いっぱいに */
    justify-content: right;
    gap: 10px;
  }
  /* --- SPでのパズル配置変更 --- */
  /* 1. 青パズル: 左下へ移動 (緑画像の上) */
  .p-blue {
    top: auto;
    bottom: 70px;
    left: 10px;
    width: 35px;
    transform: rotate(-30deg);
  }
  /* 2. オレンジ画像: 右上 (少し小さく) */
  .p-orange-img {
    top: 15px;
    right: 45px;
    width: 60px;
  }
  /* 3. 緑画像: 左下 (メイン) */
  .p-green-img {
    bottom: 15px;
    left: 45px;
    width: 60px;
    transform: rotate(-30deg);
  }
  /* 4. オレンジ: 右上へ移動 (オレンジ画像の下) */
  .p-orange {
    top: 45px;
    bottom: auto;
    right: 10px;
    width: 55px;
  }
}
/* ============================================
   TOPコラム セクション
   ============================================ */
.top-column {
  overflow: hidden;
}

.top-column .slick-list {
  overflow: visible;
}

.top-column .slick-track {
  display: flex;
}

.top-column .slick-slide {
  height: auto;
}

.column-list {
  max-width: 1180px;
  display: flex;
  justify-content: space-between;
  margin: 32px auto;
}

.column-item {
  width: calc(33.3333333333% - 15px);
}

.column-item-link {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 30px;
  overflow: hidden;
  text-decoration: none;
  color: #1E2324;
  height: 100%;
  transition: transform 0.3s;
  box-shadow: 0 4px 20px 0 rgba(29, 32, 136, 0.05);
}

.column-item-link:hover {
  transform: translateY(-5px) !important;
}

.column-item-link:hover {
  opacity: 0.6;
}

.column-img img {
  aspect-ratio: 19/12;
  -o-object-fit: cover;
     object-fit: cover;
}

.column-info {
  padding: 24px 20px 20px;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.column-item-cat-list {
  display: flex;
  align-items: start;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 15px;
}

.column-item-cat {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 30px;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.1em;
  border: 2px solid;
}

.cat-orange {
  color: #FF7043;
  border-color: #FF7043;
}

.cat-blue {
  color: #4facfe;
  border-color: #4facfe;
}

.cat-green {
  color: #00BFA5;
  border-color: #00BFA5;
}

.cat-yellow {
  color: #FBBE00;
  border-color: #FBBE00;
}

.cat-navy {
  color: #1D2088;
  border-color: #1D2088;
}

.cat-black {
  color: #1E2324;
  border-color: #1E2324;
}

.column-title {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #1E2324;
  margin-bottom: 15px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.column-date {
  margin-top: auto;
  font-family: "Outfit", sans-serif;
  font-weight: bold;
  line-height: 1.5;
  color: #1D2088;
  letter-spacing: 0.075em !important;
}

@media only screen and (max-width: 1250px) {
  .top-column-list-container {
    padding: 0 20px;
  }
}
@media only screen and (max-width: 980px) {
  .top-column {
    padding: 90px 0;
  }
  .top-column-list-container {
    position: relative;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 70px;
  }
  .top-column-list-container .column-list {
    position: static;
  }
  .column-slider .slick-center {
    opacity: 1;
  }
  .column-item {
    max-width: 300px;
  }
  .column-item {
    margin: 0 10px;
    width: 300px;
  }
  .slick-initialized.column-list {
    display: block;
  }
  .column-info {
    padding: 25px 15px 15px;
  }
  .column-date {
    font-size: 12px;
  }
  .column-progress {
    max-width: 800px;
    width: calc(100% - 40px);
    height: 3px;
    background: #fff;
    margin: 24px auto;
    overflow: hidden;
  }
  .column-progress-bar {
    width: 0;
    height: 100%;
    background: #1D2088;
    transition: 0.4s;
  }
}
@media only screen and (max-width: 680px) {
  .top-column {
    padding: 60px 0;
  }
  .column-progress {
    width: 76.85%;
  }
  .column-item {
    width: 270px;
  }
}
/* ============================================
   TOPお知らせ セクション
   ============================================ */
.top-news {
  background-color: #fff;
  border-radius: 50px;
}

.news-list {
  list-style: none;
}

.top-news .news-list {
  max-width: 800px;
  width: 100%;
  margin: auto;
}

/* 基本設定 */
.news-section {
  padding: 60px 20px;
  background-color: #fff; /* 背景色は適宜調整してください */
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}

.news-container {
  max-width: 800px;
  margin: 0 auto;
}

/* リスト部分 */
.news-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.news-item {
  border-bottom: 1px solid #ddd;
}

.news-link {
  display: flex;
  align-items: center;
  padding: 15px 10px;
  text-decoration: none;
  color: #1E2324;
  transition: background-color 0.3s;
}

.news-link:hover {
  opacity: 0.6;
}

.news-date {
  font-weight: bold;
  color: #1D2088;
  width: 95px;
  flex-shrink: 0;
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.075em !important;
}

.news-text {
  flex-grow: 1;
}

.news-footer {
  text-align: center;
  margin-top: 40px;
}

/* --- スマートフォン用設定 (768px以下) --- */
@media screen and (max-width: 850px) {
  .news-container {
    padding: 0 20px;
  }
}
@media screen and (max-width: 768px) {
  .top-news .news-list {
    margin-bottom: 25px;
  }
  .news-link {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 15px 10px;
  }
  .news-date {
    width: auto;
    font-size: 12px;
  }
  .news-text {
    font-size: 16px;
    text-decoration: underline;
  }
}
/* ============================================
   COMPANY セクション
   ============================================ */
.company-section {
  padding: 100px 0;
  width: 100%;
  /* 背景色が必要ならここ (例: 薄いグレーなど) */
}

.company-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

/* フレックスコンテナ */
.company-container {
  display: flex;
  align-items: center; /* 上下中央揃え */
  justify-content: flex-start; /* 左寄せ */
  position: relative;
}

/* --- ① 左側：テキストボックス --- */
.company-text-box {
  background-color: #fff;
  border-radius: 50px;
  padding: 80px 100px 80px 80px; /* 右側に余裕を持たせる（画像が来るから） */
  width: 65%;
  flex-shrink: 0; /* 縮まないようにする */
  position: relative;
  z-index: 1; /* 画像より下 */
}

.company-header-pc {
  margin-bottom: 32px;
}

.company-header-sp {
  margin-bottom: 32px;
}

.company-header-sp {
  display: none;
}

.title-company {
  color: #1D2088;
  font-weight: 700;
  margin-top: 5px;
  display: flex;
  align-items: center;
  gap: 15px;
}

.title-company .dash {
  display: block;
  width: 40px;
  height: 5px;
  background-color: #FBBE00;
}

.company-desc {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: 40px;
  text-align: justify;
}

.company-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #1D2088;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  padding: 18px 60px;
  border-radius: 50px;
  font-size: 16px;
  transition: opacity 0.3s, transform 0.3s;
  gap: 20px;
}

.company-btn:hover {
  opacity: 0.9;
  transform: translateY(-3px);
}

/* --- ② 右側：画像エリア --- */
.company-image-box {
  width: 42.5%;
  height: 100%;
  margin-left: -50px;
  position: absolute;
  right: 0;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}

.puzzle-main-img {
  width: 350px;
}

.puzzle-main-img img {
  width: 100%;
  height: auto;
  filter: drop-shadow(10px 10px 20px rgba(0, 0, 0, 0.1)); /* 浮いているような影 */
  transform: rotate(2deg); /* 少し傾けるとパズルっぽい動きが出るかも（お好みで） */
}

/* 装飾パズル（画像ボックス基準で配置） */
.puzzle-deco {
  position: absolute;
}

.puzzle-deco img {
  width: 100%;
  height: auto;
}

.p-comp-blue {
  top: 70px;
  left: 40px;
  width: 125px;
  animation: floatPuzzle 5s ease-in-out infinite;
}

.p-comp-green {
  bottom: 70px;
  left: 20px;
  width: 120px;
  animation: floatPuzzle 4s ease-in-out infinite 1s;
}

.p-comp-orange {
  top: 165px;
  right: -15px;
  width: 130px;
  animation: floatPuzzle 6s ease-in-out infinite 0.5s;
}

@media screen and (max-width: 1440px) and (min-width: 768px) {
  .puzzle-main-img {
    width: 70%;
  }
  .p-comp-blue {
    top: 12.87%;
    left: 7.98%;
    width: 24.93%;
    animation: floatPuzzle 5s ease-in-out infinite;
  }
  .p-comp-green {
    bottom: 12.87%;
    left: 3.99%;
    width: 23.93%;
    animation: floatPuzzle 4s ease-in-out infinite 1s;
  }
  .p-comp-orange {
    top: 30.34%;
    right: -3%;
    width: 25.93%;
    animation: floatPuzzle 6s ease-in-out infinite 0.5s;
  }
}
/* --- SP対応 --- */
@media screen and (max-width: 768px) {
  .company-section.u-section-sm {
    padding: 60px 0;
  }
  .company-container {
    flex-direction: column; /* 縦積み */
    align-items: stretch;
  }
  /* テキストボックス */
  .company-text-box {
    width: 100%; /* 幅いっぱい */
    padding: 60px 40px 170px;
    border-radius: 24px;
    box-sizing: border-box;
    text-align: center; /* 中央揃え */
  }
  /* タイトル：SPでは中央揃え＆両サイド棒線 */
  .company-header-pc {
    display: none;
  }
  .company-header-sp {
    display: block;
  }
  .title-company {
    justify-content: center;
  }
  /* SPのみ左側にも棒線を疑似的に追加するなどJSなしでやるなら */
  /* ここではシンプルに右の棒線を維持しつつ中央配置にしています */
  .company-desc {
    text-align: left;
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 150%;
  }
  .company-btn {
    width: 100%;
    box-sizing: border-box;
  }
  /* 画像ボックス */
  .company-image-box {
    position: relative;
    width: 100%;
    margin-left: 0; /* マージンリセット */
    margin-top: -110px; /* SPでも少し縦に重ねる（お好みで） */
    /* 重ねたくない場合は margin-top: 30px; */
  }
  .puzzle-main-img img {
    max-width: 220px;
    margin: 0 auto;
    display: block;
  }
  .p-comp-blue {
    top: -30px;
    left: 10%;
    width: 80px;
  }
  .p-comp-green {
    bottom: -10px;
    left: 0;
    width: 60px;
  }
  .p-comp-orange {
    top: 50%;
    right: -20px;
    width: 70px;
  }
}
/* ============================================
   CONTACT セクション
   ============================================ */
.contact-section {
  padding: 100px 0;
  width: 100%;
}

.contact-inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

.contact-box {
  background-color: #FBBE00; /* 黄色背景 */
  border-radius: 40px;
  padding: 60px 40px;
  text-align: center;
  position: relative;
  /* overflow: hidden; はしない（パズルをはみ出させるため） */
}

/* --- コンテンツ --- */
.contact-content {
  position: relative;
  z-index: 2; /* パズルより手前に */
}

/* タイトル周り */
.contact-header {
  margin-bottom: 40px;
}

.contact-header .sub-ja {
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 10px;
  color: #1E2324;
}

.title-contact {
  color: #1D2088;
  font-weight: 700;
  justify-content: center; /* 中央揃え */
}

.title-contact .dash {
  background-color: #fff; /* ここの線は白 */
  width: 30px;
  height: 4px;
  display: block;
}

/* 本文 */
.contact-body {
  margin-bottom: 32px;
}

.contact-lead {
  font-size: 28px;
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 20px;
  color: #1D2088;
}

.contact-desc {
  font-size: 15px;
  line-height: 1.8;
}

/* アクションボタン */
.contact-actions {
  display: flex;
  justify-content: center;
  gap: 30px;
  margin-bottom: 32px;
}

.contact-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 20px 40px;
  border-radius: 50px;
  text-decoration: none;
  font-weight: bold;
  font-size: 16px;
  transition: transform 0.2s, opacity 0.2s;
  width: 320px; /* PCでの幅固定 */
  box-sizing: border-box;
  gap: 15px;
}

.contact-btn:hover {
  transform: translateY(-3px);
  opacity: 0.9;
}

/* お問い合わせ情報 */
.contact-info {
  color: #1E2324;
  font-weight: 500;
  line-height: 1.5;
}

.info-tel {
  font-family: "Outfit", sans-serif;
}

.info-tel a {
  text-decoration: none;
  color: inherit;
  pointer-events: none; /* PCではリンク無効化 */
}

/* --- 装飾パズル配置 (PC) --- */
/* 右上エリア */
.p-cont-top-orange {
  top: -40px;
  right: 120px;
  width: 80px;
  z-index: 1;
  --rot: 15deg;
  animation: contactfloatPuzzle 5s ease-in-out infinite;
}

.p-cont-top-blue {
  top: 60px;
  right: -30px;
  width: 90px;
  --rot: -10deg;
  animation: contactfloatPuzzle 6s ease-in-out infinite 0.5s;
}

/* 左下エリア */
.p-cont-btm-green {
  bottom: 50px;
  left: -40px;
  width: 100px;
  --rot: 20deg;
  animation: contactfloatPuzzle 5.5s ease-in-out infinite 1s;
}

.p-cont-btm-orange {
  bottom: -30px;
  left: 80px;
  width: 70px;
  --rot: -15deg;
  animation: contactfloatPuzzle 4.5s ease-in-out infinite 0.2s;
}

@keyframes contactfloatPuzzle {
  0%, 100% {
    transform: translateY(0) rotate(var(--rot, 0deg));
  }
  50% {
    transform: translateY(-20px) rotate(var(--rot, 0deg));
  }
}
/* --- SP対応 --- */
@media screen and (max-width: 768px) {
  .contact-section.u-section-sm {
    padding: 60px 0;
  }
  .contact-box {
    padding: 75px 20px 105px;
    border-radius: 30px;
  }
  .contact-header {
    margin-bottom: 32px;
  }
  .contact-body {
    margin-bottom: 32px;
  }
  .contact-lead {
    font-size: 18px;
    text-align: center;
  }
  /* ボタン縦積み */
  .contact-actions {
    flex-direction: column;
    align-items: center;
    gap: 15px;
    width: 100%;
    margin-bottom: 24px;
  }
  .contact-btn {
    width: 100%;
    padding: 16px 20px;
    font-size: 14px;
  }
  /* 電話番号リンク有効化 */
  .info-note,
  .info-hours,
  .info-tel {
    font-size: 14px;
    font-weight: 500;
  }
  .info-tel a {
    pointer-events: auto;
  }
  /* パズル配置調整 (SP) */
  .p-cont-top-orange {
    top: -30px;
    right: 60px;
    width: 60px;
  }
  .p-cont-top-blue {
    top: 20px;
    right: 15px;
    width: 70px;
  }
  .p-cont-btm-green {
    bottom: -20px;
    left: 40px;
    width: 80px;
  }
  .p-cont-btm-orange {
    bottom: -60px;
    left: 0px;
    width: 60px;
  }
}
#header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  background-color: #F2F4F8;
  width: 100%;
}

.header-inner {
  display: flex;
  align-items: center;
  margin: 0 auto;
  max-width: 1440px;
  padding: 20px 18px;
  width: 100%;
}

.header-logo {
  margin-right: auto;
  max-width: 200px;
  width: 20%;
}
.header-logo-img {
  display: flex;
  align-items: center;
  cursor: default;
}
.header-logo-img:hover {
  opacity: 0.6;
}
.header-logo-img img {
  display: block;
  max-width: 100%;
}

/* PCナビゲーション */
.header-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 80%;
  gap: 40px;
}
.header-nav nav {
  display: flex;
  gap: 25px;
}
.header-nav nav ul {
  display: flex;
  align-items: center;
  justify-content: space-between;
  list-style: none;
}
.header-nav nav ul li {
  position: relative;
}
.header-nav nav ul li a, .header-nav nav ul li .no_link {
  display: block;
  padding: 20px 10px;
  color: #1E2324;
  font-size: 16px;
  line-height: 1.4;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-decoration: none;
}
.header-nav nav ul li a span, .header-nav nav ul li .no_link span {
  position: relative;
}
.header-nav nav ul li a span::after, .header-nav nav ul li .no_link span::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 2px;
  background: #1D2088;
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 0.3s;
}
.header-nav nav ul li a:hover span::after, .header-nav nav ul li .no_link:hover span::after {
  transform: scaleX(1);
}
.header-nav nav ul li.has_child::before {
  content: "";
  position: absolute;
  right: 15px;
  top: 49%;
  width: 8px;
  height: 8px;
  border-top: 2px solid #1D2088;
  border-right: 2px solid #1D2088;
  transform: translateY(-50%) rotate(135deg);
}
.header-nav nav ul li.has_child .no_link {
  padding-right: 30px;
  cursor: default;
}
.header-nav nav ul li.has_child {
  /* 第2階層 */
}
.header-nav nav ul li.has_child ul {
  display: block;
  position: absolute;
  left: 0;
  top: 100%;
  z-index: 4;
  background: #fff;
  width: 250px;
  visibility: hidden;
  opacity: 0;
  transition: all 0.3s;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}
.header-nav nav ul li.has_child ul li a {
  padding: 15px 20px;
  border-bottom: 1px solid #eee;
}
.header-nav nav ul li.has_child ul li a:hover {
  background: #f9f9f9;
}
.header-nav nav ul li.has_child:hover > ul {
  visibility: visible;
  opacity: 1;
}

/* お問い合わせ・資料請求ボタン */
.header-contact-container {
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 360px;
}

.header-download-link,
.header-contact-link {
  display: block;
  padding: 14px 26px;
  font-size: 16px;
  font-weight: bold;
  border: 2px solid;
  border-radius: 30px;
  text-decoration: none;
  text-align: center;
  transition: all 0.3s;
  white-space: nowrap;
}

.header-download-link {
  border-color: #1D2088;
  background-color: #fff;
  color: #1D2088;
  letter-spacing: 0.1em;
  border: 3px solid #1D2088;
}
.header-download-link:hover {
  background-color: #1D2088;
  color: #fff;
  border: 3px solid #fff;
}

.header-contact-link {
  border-color: #FBBE00;
  background-color: #FBBE00;
  color: #1E2324;
  border: 3px solid #FBBE00;
}
.header-contact-link:hover {
  background-color: #fff;
  color: #1E2324;
  border: 3px solid #FBBE00;
}

.header-copyright {
  color: #fff;
}

/* ============================
   レスポンシブ
   ============================ */
@media only screen and (max-width: 1300px) {
  .header-nav {
    gap: 15px;
  }
  .header-nav nav ul li a, .header-nav nav ul li .no_link {
    font-size: 14px;
  }
}
/* ハンバーガーメニュー表示切り替え */
@media only screen and (min-width: 1201px) {
  .header_logo_menu {
    display: none;
  }
}
@media only screen and (max-width: 1200px) {
  .header-nav {
    display: none;
  }
  /* ハンバーガーボタン本体 */
  #nav-open {
    position: fixed;
    z-index: 10000;
    top: 25px;
    right: 15px;
    cursor: pointer;
    width: 60px;
    height: 50px;
  }
  #nav-open span {
    display: inline-block;
    position: absolute;
    left: 14px;
    width: 45%;
    height: 2px;
    background-color: #1D2088;
    border-radius: 2px;
    transition: all 0.4s;
  }
  #nav-open span:nth-of-type(1) {
    top: 15px;
  }
  #nav-open span:nth-of-type(2) {
    top: 23px;
  }
  #nav-open span:nth-of-type(3) {
    top: 31px;
  }
  /* チェック時（メニュー展開時）のスタイル */
  #nav-input:checked ~ #nav-open span {
    background-color: #fff;
  }
  #nav-input:checked ~ #nav-open span:nth-of-type(1) {
    transform: translateY(8px) rotate(-45deg);
    width: 50%;
    left: 18px;
  }
  #nav-input:checked ~ #nav-open span:nth-of-type(2) {
    opacity: 0;
  }
  #nav-input:checked ~ #nav-open span:nth-of-type(3) {
    transform: translateY(-8px) rotate(45deg);
    width: 50%;
    left: 18px;
  }
  #nav-input:checked ~ #nav-content {
    transform: translateX(0%);
  }
  #nav-input:checked ~ #nav-close {
    display: block;
    opacity: 0.5;
  }
  #nav-close {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: black;
    z-index: 99;
  }
  /* スマホメニュー中身 */
  #nav-content {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 100vh;
    background: #1D2088;
    transform: translateX(-100%);
    transition: transform 0.4s ease-in-out;
    overflow-y: auto;
    padding-top: 80px;
  }
  #nav-content #g-nav-list ul {
    list-style: none;
    padding: 0;
  }
  #nav-content .header_nav_menu_item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }
  #nav-content .header_nav_section_menu_title,
  #nav-content .header_nav_menu_item_link {
    display: block;
    padding: 20px 30px;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    position: relative;
  }
  #nav-content {
    /* Details/Summary アコーディオン */
  }
  #nav-content .header_nav_section_menu summary {
    list-style: none;
  }
  #nav-content .header_nav_section_menu summary::-webkit-details-marker {
    display: none;
  }
  #nav-content .header_nav_section_menu summary::before {
    content: "";
    position: absolute;
    right: 30px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: translateY(-70%) rotate(45deg);
    transition: transform 0.3s;
  }
  #nav-content .header_nav_section_menu[open] summary::before {
    transform: translateY(-20%) rotate(225deg);
  }
  #nav-content {
    /* 第2階層（スマホ） */
  }
  #nav-content .header_nav_sub_menu {
    background: rgba(255, 255, 255, 0.1);
  }
  #nav-content .header_nav_sub_menu .header_nav_sub_menu_item_link {
    display: block;
    padding: 15px 40px;
    color: #fff;
    font-size: 14px;
    text-decoration: none;
  }
  #nav-content .header-contact-container {
    flex-direction: column;
    padding: 30px;
    max-width: 100%;
  }
  #nav-content .header-contact-container .header-download, #nav-content .header-contact-container .header-contact {
    width: 100%;
  }
}
@media only screen and (max-width: 980px) {
  .header-logo {
    width: 30%;
  }
  #nav-open {
    top: 22px;
  }
}
@media only screen and (max-width: 680px) {
  .header-inner {
    padding: 10px;
  }
  .header-logo {
    width: 95px;
  }
  #nav-open {
    top: 0px;
    right: 5px;
  }
  #nav-open span:nth-of-type(1) {
    top: 14px;
  }
  #nav-open span:nth-of-type(2) {
    top: 22px;
  }
  #nav-open span:nth-of-type(3) {
    top: 29px;
  }
  #nav-open span {
    width: 50%;
  }
  #nav-open {
    top: 0;
    right: 5px;
  }
}
/*
  ----------------
  Footer
  ----------------
*/
footer {
  padding: 72px 0 32px;
}

footer .in {
  margin: auto;
  max-width: 1120px;
}

@media (max-width: 768px) {
  footer .in {
    width: 100%;
  }
  footer .in__logo {
    margin: 0 auto 56px;
  }
}
footer .in__logo a {
  display: inline-block;
}

footer .in__logo__img {
  width: 221px;
}

footer .in__nav {
  display: flex;
  flex-flow: row nowrap;
}

@media (max-width: 768px) {
  footer .in__nav {
    flex-flow: row wrap;
    justify-content: center;
  }
}
footer .in__box:first-of-type {
  width: 226px;
}

@media (max-width: 768px) {
  footer .in__box:first-of-type {
    width: 260px;
  }
}
footer .in__box:nth-of-type(2) {
  width: 180px;
}

@media (max-width: 768px) {
  footer .in__box:nth-of-type(2) {
    width: 260px;
  }
}
footer .in__box:nth-of-type(3) {
  width: 168px;
}

@media (max-width: 768px) {
  footer .in__box:nth-of-type(3) {
    width: 260px;
  }
}
footer .in__box + * {
  margin-left: 32px;
}

@media (max-width: 768px) {
  footer .in__box + * {
    margin: 24px 0 0;
  }
}
footer .in__list {
  margin: 0 auto;
  width: 100%;
}

footer .in__list + * {
  margin: 48px auto 0;
}

@media (max-width: 768px) {
  footer .in__list + * {
    margin: 32px auto 0;
  }
}
footer .in__list--heading {
  font-weight: 700;
  margin-bottom: 24px;
}

footer .in__list li:nth-of-type(n+2) {
  font-size: 12px;
  padding-left: 16px;
  position: relative;
}

footer .in__list li:nth-of-type(n+2):before {
  background: url(../img/common/icon-arrow-footer.svg) no-repeat 0 0/100% auto;
  bottom: 0;
  content: "";
  height: 8px;
  left: 0;
  margin: auto;
  position: absolute;
  top: 0;
  width: 8px;
}

footer .in__list li:nth-of-type(n+2) + * {
  margin-top: 12px;
}

footer .copyright {
  font-family: Roboto, sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  margin: 40px auto 32px;
  text-align: center;
}

@media (max-width: 768px) {
  footer .copyright {
    margin: 72px auto 120px;
  }
}
footer .pmark {
  margin: 40px 0 0;
  text-align: center;
}

footer .pmark img {
  height: 80px;
  width: 80px;
}

@media (max-width: 768px) {
  footer .pmark img {
    height: 60px;
    width: 60px;
  }
}
.pc-only-inline-block {
  display: inline-block;
}
@media all and (max-width : 768px) {
  .pc-only-inline-block {
    display: none;
  }
}

/*** FlexBox ***/
.flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-content: space-between;
}
@media all and (max-width : 768px) {
  .flex {
    align-items: center;
    justify-content: center;
  }
}
.flex.nowrap {
  flex-wrap: nowrap;
}
@media all and (max-width : 768px) {
  .flex.inherit {
    justify-content: space-between;
    align-content: space-between;
    align-items: stretch;
  }
}
.flex.jcA {
  justify-content: space-around;
}
.flex.jcE {
  justify-content: flex-end;
}
@media all and (max-width : 768px) {
  .flex.sp-jcA {
    justify-content: space-around;
  }
}
.flex.jcC {
  justify-content: center;
}
.flex.fS {
  justify-content: flex-start;
}
.flex.fE {
  justify-content: flex-end;
}
@media all and (max-width : 768px) {
  .flex.sp-fS {
    justify-content: flex-start;
  }
}
.flex.aiC {
  align-items: center;
}
.flex.aiE {
  align-items: flex-end;
}
.flex.aifS {
  align-items: flex-start;
}
@media all and (max-width : 768px) {
  .flex.sp-aifS {
    align-items: flex-start;
  }
}
.flex.row-re {
  flex-direction: row-reverse;
}
@media all and (max-width : 768px) {
  .flex.sp-row-re {
    flex-direction: row-reverse;
  }
}
@media all and (max-width : 768px) {
  .flex.sp-reverse {
    flex-direction: column-reverse;
  }
}
@media all and (max-width : 768px) {
  .flex.sp-sB {
    justify-content: space-between;
  }
}
.flex.gap10 {
  gap: 10px;
}
@media all and (max-width : 768px) {
  .flex.gap10 {
    gap: 5px;
  }
}
.flex.gap20 {
  gap: 20px;
}
@media all and (max-width : 768px) {
  .flex.gap20 {
    gap: 10px;
  }
}
.flex.gap30 {
  gap: 30px;
}
@media all and (max-width : 768px) {
  .flex.gap30 {
    gap: 15px;
  }
}
.flex.gap40 {
  gap: 40px;
}
@media all and (max-width : 768px) {
  .flex.gap40 {
    gap: 15px;
  }
}
.flex.gap50 {
  gap: 50px;
}
@media all and (max-width : 768px) {
  .flex.gap50 {
    gap: 15px;
  }
}
.flex.gap60 {
  gap: 60px;
}
@media all and (max-width : 768px) {
  .flex.gap60 {
    gap: 15px;
  }
}
.flex.gather::after {
  content: "";
  display: block;
  width: 30%;
}
.flex.gather::before {
  content: "";
  display: block;
  width: 25%;
  order: 1;
}
.flex.gather::after {
  content: "";
  display: block;
  width: 25%;
}

@media all and (max-width : 768px) {
  .sp-flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-content: space-around;
  }
}

body {
  margin: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1.5;
  background-color: #F2F4F8;
}

.u-section-lg {
  padding-top: 120px;
  padding-bottom: 120px;
}
@media (max-width: 1023px) {
  .u-section-lg {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
@media (max-width: 767px) {
  .u-section-lg {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.u-section-sm {
  padding-top: 80px;
  padding-bottom: 80px;
}
@media (max-width: 1023px) {
  .u-section-sm {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
@media (max-width: 767px) {
  .u-section-sm {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.l-inner, .l-inner--narrow {
  width: 100%;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 30px;
  padding-right: 30px;
  box-sizing: border-box;
}
@media (max-width: 1023.9px) {
  .l-inner, .l-inner--narrow {
    padding-left: 20px;
    padding-right: 20px;
  }
}

.l-inner--narrow {
  max-width: 980px;
}/*# sourceMappingURL=style.css.map */