@charset "UTF-8";
/* =======================
	Foundation
==========================*/
/*! destyle.css v1.0.13 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model */
body {
  margin: 0;
}

main {
  display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border: 0;
  border-top: 1px solid;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

img {
  border-style: none;
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

embed,
object,
iframe {
  border: 0;
  vertical-align: bottom;
}

/* Forms
   ========================================================================== */
button,
optgroup,
select {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

[type=checkbox] {
  /* 1 */
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

[type=radio] {
  /* 1 */
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  padding: 0; /* 1 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

.font-en {
  font-family: "Noto Sans", sans-serif;
  font-weight: 700;
}

@keyframes pathmove {
  0% {
    height: 0;
    top: 0;
    opacity: 0;
  }
  30% {
    height: 60%;
    opacity: 1;
  }
  100% {
    height: 0;
    top: 100%;
    opacity: 0;
  }
}
.animated {
  animation-duration: 1s;
  animation-fill-mode: both;
}
@keyframes fadeInUp {
  from {
    transform: translate3d(0, 3em, 0);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
.fadeInUp {
  animation-name: fadeInUp;
}

/*//////////////////////////////////////////////////////////////////////////*/
.evt {
  visibility: hidden;
}

/* * {
  outline: 1px solid rgba(255, 0, 0, 0.1);
}

section {
  outline: 2px solid rgba(0, 0, 255, 0.2);
} */

html,
body {
  width: 100%;
  overflow-x: hidden;
}

html {
  scroll-behavior: smooth;
}

:root {
  --header-h: 90px;
}

/* 実際の固定ヘッダー高に合わせて */
section[id] {
  scroll-margin-top: var(--header-h);
}

html {
  box-sizing: border-box;
  height: 100%;
  font-family: "Noto Sans JP", sans-serif;
  color: #252935;
  line-height: 1.6;
  letter-spacing: 0.01rem;
  list-style: none;
  text-decoration: none;
  /* 1rem = 100pxと定義 */
  font-size: 100px;
}

html *,
html *::before,
html *::after {
  box-sizing: inherit;
}
main {
  position: relative;
}

body {
  height: 100%;
  /*　基本のフォントサイズは16px */
  font-size: 0.16rem;
}

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

h2 {
  font-size: 0.36rem;
  font-weight: 600;
  text-align: center;
  color: #1F3B90;
  padding-bottom: 0.6rem;
}

/* =========================
    Responsive
========================= */
@media screen and (max-width: 1024px) {
  html {
      /* 1rem = 60pxと再定義 */
      font-size: 60px;
    }
  
    body {
      /* フォントサイズを少し小さく16pxに（60px * 0.3rem = 18px） */
      font-size: 0.3rem;
    }
  
    h1 {
      /* 見出しのサイズを少し小さく24pxに（60px * 0.4rem = 24px） */
      font-size: 0.4rem;
    }
  
    h2 {
      font-size: 0.34rem;
    }
  
    p {
      font-size: 0.3rem;
    }

    span {
      font-size: 0.36rem;
    }
}

@media screen and (max-width: 550px) {
  html {
    /* 1rem = 50pxと再定義 */
    font-size: 50px;
  }

  body {
    /* フォントサイズを少し小さく14pxに（50px * 0.28rem = 14px） */
    font-size: 0.3rem;
  }

  h1 {
    /* 見出しのサイズを少し小さく20pxに（50px * 0.4rem = 20px） */
    font-size: 0.4rem;
  }

  h2 {
    font-size: 0.4rem;
  }

  p {
    font-size: 0.3rem;
  }
}
/*//////////////////////////////////////////////////////////////////////////*/

/* ナビゲーション */
#header {
  width: 100%;
  height: 90px;
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
}

.inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  width: 100%;
  height: 90px;
}

.logo {
  width: 2rem;
  height: auto;
  object-fit: cover;
  margin-left: 0.3rem;
}
.nav_wrapper {
  display: flex;
  align-items: center;
  height: 90px;
  position: absolute;
  right: 0;
  gap: 0.2rem;
  max-width: 100%;
  overflow-x: clip;
}

.navlist {
  display: flex;
  justify-content: center;
  gap: 40px;
}
.nav a {
  font-weight: 400;
  color: #111;
  font-size: 0.16rem;
  transition: opacity 0.3s;
}

.nav a:hover {
  opacity: 0.7;
}

.header-cta {
  display: flex;
  align-items: center;
  overflow-x: hidden;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  padding: 0 24px;
  color: #fff;
  font-weight: 600;
  transition: opacity 0.3s;
  white-space: nowrap;
}
.btn:hover {
  opacity: 0.85;
}

.request {
  align-items: center;
  background: linear-gradient(180deg,
        rgba(254, 50, 45, 1) 0%,
        rgba(242, 171, 131, 1) 100%);
  display: inline-flex;
  gap: 0.1rem;
  height: 90px;
  justify-content: center;
  padding: 0.4rem 0.24rem;
}
.request img {
  width: 18px;
  height: auto;
  object-fit: cover;
}

.contact {
  align-items: center;
  background: linear-gradient(180deg,
      rgba(47, 110, 189, 1) 0%,
      rgba(93, 176, 236, 1) 100%);
  display: inline-flex;
  gap: 0.1rem;
  height: 90px;
  justify-content: center;
  padding: 0.4rem 0.24rem;
}
.contact img {
  width: 18px;
  height: auto;
  object-fit: cover;
}

/* =========================
   Responsive
========================= */
@media screen and (max-width: 1024px) {
  .nav ul {
    gap: 24px;
  }

  .nav a {
    font-size: 0.25rem;
  }

  .btn {
    padding: 0 0.18rem;
    font-size: 0.9rem;
  }
}
/* ================================
   スマホ版ナビゲーション
================================ */
@media screen and (max-width: 768px) {

  /* ハンバーガーボタン表示 */
  #header {
    height: 60px;
  }
  .inner {
    overflow: visible;
    height: 60px;
  }
  .logo {
    width: 2.4rem;
  }
  .nav_wrapper {
      height: 60px;
      right: 13vw;
  }
  .js-drawer {
    display: block;
    position: relative;
    right: 3vw;
    width: 30px;
    height: 20px;
    cursor: pointer;
    border: none;
    background: none;
    z-index: 1100;
  }

  .js-drawer span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #333;
    border-radius: 2px;
    transition: all 0.3s ease;
  }

  .js-drawer span:nth-child(1) {
    top: 0;
  }

  .js-drawer span:nth-child(2) {
    top: 9px;
  }

  .js-drawer span:nth-child(3) {
    bottom: 0;
  }

  /* 開閉時のアニメーション */
  .js-drawer.is-active-drawer span:nth-child(1) {
    transform: rotate(45deg);
    top: 9px;
  }

  .js-drawer.is-active-drawer span:nth-child(2) {
    opacity: 0;
  }

  .js-drawer.is-active-drawer span:nth-child(3) {
    transform: rotate(-45deg);
    bottom: 9px;
  }

  /* ナビゲーションメニュー（ドロワー） */
.nav {
    position: fixed;
    top: 0;
    right: 0;
    width: 75%;
    max-width: 300px;
    height: 100vh;
    background-color: rgba(255, 255, 255, 0.97);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.2rem;
    transform: translateX(100%);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.3s ease, opacity 0.3s ease;
    z-index: 1000;
  }

  /* メニュー展開時 */
  .nav.is-active {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* リストやリンク調整
  #globalnav li {
    list-style: none;
  }

  #globalnav a {
    display: block;
    color: #333;
    font-size: 1.1rem;
    text-decoration: none;
  } */

  /* メニュー開いた状態 */
  .nav.is-active {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }
  
  /* 中のリスト */
  .navlist {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    list-style: none;
    text-align: center;
  }
  
  .navlist a {
    color: #333;
    font-size: 0.3rem;
    text-decoration: none;
  }

  /* PCナビ非表示（もし必要なら） */
  header nav {
    display: none;
  }
  .btn span {
    display: none;
  }
.header-cta {
  height: 60px;
}
.request {
  width: 20vw;
  height: 60px;
}
.contact {
  width: 20vw;
  height: 60px;
}
}

/* =========================
  Responsive
========================= */


/* hero */

.hero_bg {
  width: 100%;
  height: 110svh;
  min-height: 110vh;
  position: relative;
  overflow: hidden;
  background-image: url(../../public/img/hero_bg.webp);
  background-size: cover;
  background-position: top;
  background-repeat: no-repeat;
  position: relative;
  padding: 10% 5% 0;
}
.hero_contents {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  max-width: 80vw;
  margin: 0 auto 0.4rem;
  width: 100%;
}
.maincopy {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.maincopy h1 {
  color: #1F3B90;
  font-family: "Noto Sans JP-Bold", Helvetica;
  font-size: 0.64rem;
  font-weight: 700;
  line-height: 1.5;
}
.fv_business {
  font-size: 0.54rem;
}
.AI {
  width: 100px;
  height: auto;
  object-fit: cover;
  padding: 0 0.1rem 0.2rem 0.04rem;
}
.maincopy p {
  font-family: "Noto Sans JP-Bold", Helvetica;
  font-weight: 600;
}
.maincopy_sub {
  font-size: 0.32rem;
  color: #1F3B90;
  vertical-align: middle;
  display: flex;
  align-items: center;  
  gap: 0.05rem;
}
.maincopy_sub img {
  width: 30px;
  height: auto;
  object-fit: contain;
}
.maincopy_sub span {
  font-size: 0.15rem;
}
.maincopy_sub_box {
  display: flex;
  align-items: end;
}
.mobile {
  display: none;
}
.subcopy_box {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.subcopy {
  display: flex;
  justify-content: flex-start;
  gap: 0.4rem;
}
.subcopy_group {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 245px;
  height: 74px;
  border: 1px solid #FE322D;
  text-align: center;
  font-weight: 600;
  border-radius: 5px;
  background-color: #FFF;
}
.name {
  color: #FFF;
  font-size: 0.16rem;
  text-align: center;
  margin-right: 18%;
}
.name span {
  font-size: 0.12rem;
}
.red {
  color: #FE322D;
  font-family: "Inter", sans-serif;
  font-size: 0.2rem;
}
.ai {
  color: #0A509F;
}
.kakeru {
  width: 36px;
  height: 35px;
  object-fit: cover;
}
.cta_mobile {
  display: flex;
  gap: 0.3rem;
}
.cta_area {
  display: flex;
  gap: 8%;
  justify-content: center;
  align-items: center;
  width: 80vw;
  height: 120px;
  margin: 0 auto;
  background-color: #FFF;
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35);
  border-radius: 5px;
}
.index_box {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.1rem;
}
.index {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
  height: 100px;
  color: #1F3B90;
  text-align: center;
  line-height: 1.4;
  /* background-color: #F4F3F3; */
  border-radius: 5px;
  font-size: 0.12rem;
}
.pc {
  display: block;
}
.index img {
  width: 32px;
  height: 64px;
  object-fit: cover;
}
.campain {
  width: 30vw;
  height: auto;
}
.campain_r {
  font-weight: 700;
}
.campain_s {
  width: 40vw;
  font-size: 0.4rem;
  font-weight: 600;
}
.campain_s span {
  background: linear-gradient(180deg,
      rgba(254, 50, 45, 1) 0%,
      rgba(242, 171, 131, 1) 100%);
  background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  color: transparent;
  font-family: "Inter", sans-serif;
}

.fv_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
  width: 22vw;
  height: 80px;
  font-size: 0.2rem;
  font-weight: 600;
  color: #FFF;
  background: linear-gradient(180deg,
        rgba(254, 50, 45, 1) 0%,
        rgba(242, 171, 131, 1) 100%);
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35);
  transition: .3s ease-in-out;
  border-radius: 5px;
}
.fv_btn:hover {
  box-shadow: unset;
  transform: translateY(4px);
}
.fv_btn a {
  width: 355px;
  height: 75px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.arrow {
  width: 9px;
  height: auto;
  object-fit: cover;
}
.icon_siryou {
  width: 18px;
  height: auto;
  object-fit: cover;
}
.fv_btn span {
  padding: 0 0.1rem 0 0.1rem;
}
/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px){
.hero_bg {
  height: auto;
  min-height: auto;
  background-size: cover;
  background-position: top;
  padding: 2rem 5% 0.4rem;
}
.hero_contents {
  margin: 0 0 0.4rem;;
}
.AI {
  width: 60px;
}
.cta_area {
  width: 90vw;
  margin: 0;
  border-radius: 5px;
}
.red {
  font-size: 0.3rem;
}
.subcopy_group {
  width: 25vw;
  height: 60px;
  border-radius: 5px;
}
.name {
  margin-right: 8%;
}
.cta_mobile {
  display: flex;
  align-items: center;
  flex-direction: row;
  gap: 0.2rem;
}
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.hero_bg {
  background-image: url(../../public/img/hero_bg_mobile.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  height: auto;
  padding: 2rem 0 0.4rem 4%;
}
.mobile {
  display: block;
}
.maincopy_sub img {
  width: 15px;
}
.maincopy_sub span {
  font-size: 0.2rem;
}
.subcopy_group {
  width: 50vw;
  height: 60px;
  border-radius: 5px;
}
.subcopy_group p {
  font-size: 0.24rem;
}
.maincopy {
  gap: 0.3rem;
  width: 95vw;
}
.cta_mobile {
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-start;
  gap: 0;
}
.kakeru {
  display: none;
}
.AI {
    width: 50px;
    height: auto;
    object-fit: cover;
    padding: 0 0.1rem 0.2rem 0.04rem;
  }
.maincopy p {
  font-size: 0.26rem;
}

.subcopy {
  gap: 0.1rem;
  flex-direction: column;
}
.red {
  font-size: 0.32rem;
}
.cta_area {
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
  height: auto;
  padding: 0.2rem;
}
.hero_contents {
  max-width: 90%;
  width: 100vw;
  height: auto;
  margin: 0;
  gap: 0.3rem;
}
.index p {
  font-size: 0.24rem;
}
.index img {
  width: 20px;
  height: auto;
  object-fit: cover;
}
.index {
  width: 80vw;
  height: 60px;
  border-radius: 5px;
}
.pc {
  display: none;
}
.kakeru {
  width: 20px;
  height: 20px;
  object-fit: cover;
}
.fv_btn {
  width: 80vw;
  height: 60px;
  border-radius: 5px;
}
.campain {
  width: 50vw;
}
.campain_r {
  font-size: 0.32rem;
  font-weight: 700;
  width: 80vw;
}
.campain_s {
  width: 80vw;
  font-size: 0.64rem;
  font-weight: 600;
}
.campain_s span {
  font-size: 0.64rem;
}
.subcopy_box {
  align-items: end;
}
.name {
  font-size: 0.3rem;
  margin-right: 11%;
}
.name span {
  font-size: 0.2rem;
}
}



/* problem */

.border_logo {
  display: flex;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.4rem 0 0.4rem;
  background-color: #FFF;
}
.border_logo img {
  width: 15vw;
  height: auto;
  object-fit: contain;
}
.problem {
  padding: 0 0 1rem;
  background-color: #F0F0F5;
}
.problem h2 {
  padding-top: 0.8rem;
}

.problem_list {
  max-width: 1100px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  /* margin-bottom: 100px; */
  gap: 0.24rem;
  margin: 0 auto;
}
.problem_list li {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding-top: 0.8rem;
  width: 40vw;
  height: 500px;
  background-color: #FAFAFA;
  border-radius: 10px;
}
.problem_list img {
  width: 264px;
  height: auto;
}
.list_title {
  width: 300px;
  height: 60px;
  font-size: 0.2rem;
  font-weight: 600;
  text-align: center;
  margin: 0.2rem 0 0.3rem 0;
}
.round {
  position: absolute;
  top: -30px;
  width: 100px;
  height: 100px;
  padding-top: 0.2rem;
  text-align: center;
  color: #FFF;
  border-radius: 50%;
  background: linear-gradient(180deg,
        rgba(47, 110, 189, 1) 0%,
        rgba(93, 176, 236, 1) 100%);
}
.round span {
  font-size: 0.28rem;
  font-weight: 600;
  font-family: "Inter", sans-serif;
}


/* =========================
  Responsive
========================= */
@media screen and (max-width: 1024px) {
  .problem h2 {
      padding: 0.8rem 0 1rem;
    }
  .round span {
    font-size: 0.4rem;
  }
  .list_title {
    font-size: 0.3rem;
  }
  .problem_list li {
    padding-top: 1.3rem;
  }
}


@media screen and (max-width: 768px){
  .border_logo img {
    width: 130px;
    height: auto;
    object-fit: contain;
  }
.problem h2 {
  padding: 0.8rem 0 1rem;
}
.problem_list {
  flex-direction: column;
  gap: 1rem;
}
.problem_list li {
  position: relative;
  width: 85vw;
  height: 400px;
  padding-top: 1rem;
}
.round {
  width: 70px;
  height: 70px;
  font-size: 0.24rem;
}
.round span {
  font-size: 0.4rem;
}
.list_title {
  font-size: 0.3rem;
  width: 230px;
}

}



/* concept */

.concept {
  width: 100%;
  height: auto;
}
.concept_area {
  background-image: url(../../public/img/concept_bg.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  height: auto;
  padding: 1rem 0;
  gap: 2rem;
  overflow-x: hidden;
} 
.x {
  width: 100vw;
  height: auto;
  object-fit: cover;
}
.education {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap:  0.5rem;
  width: 100%;
  height: auto;
  padding-bottom: 5%;
}
.education::before {
  content: "";
  position: absolute;
  top: -0.8rem;
  left: 0;
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.2);
  z-index: 0;
  pointer-events: none;
  user-select: none;
  overflow-x: hidden;
  max-width: 100%;
}
.education::before {
  content: "EDUCATION";
}
.education_txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: auto;
  height: auto;
  color: #FFF;
}
.education_txt ul li {
  display: flex;
  align-items: baseline;
  margin-top: 0.2rem;
}
.education_txt ul li span {
  font-size: 0.26rem;
}
.education_title {
  display: flex;
  gap: 0.24rem;
}
.education_title h3 {
  font-size: 0.28rem;
  font-weight: 600;
  color: #FFF;
}
.education_title h3 span {
color: #FE322D;
}
.concept_img {
  width: 400px;
  height: auto;
  object-fit: cover;
}
.desihally_point {
  width: 15vw;
  height: auto;
  object-fit: contain;
}
.check {
  width: 15px;
  height: auto;
  object-fit: contain;
  vertical-align: middle;
  margin-right: 0.1rem;
}
.influencer {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  height: auto;
}
.influencer::before {
  content: "";
  position: absolute;
  bottom: -0.6rem;
  right: 0;
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.2);
  z-index: 0;
  pointer-events: none;
  user-select: none;
  overflow-x: hidden;
  max-width: 100%;
}
.influencer::before {
  content: "INFLUENCER";
}
.influencer_txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0;
  width: auto;
  height: auto;
  color: #FFF;
}
.influencer_txt ul li {
  display: flex;
  margin-top: 0.2rem;
}
.influencer_txt ul li span {
  font-size: 0.26rem;
}
.influencer h3 {
  font-size: 0.28rem;
  font-weight: 600;
  color: #FFF;
}

.influencer h3 span {
  color: #FE322D;
}


/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px){

.concept_area {
    gap: 2.5rem;
    height: 70vh;
    padding: 1rem 0;
  }
.education {
  height: 30vh;
  justify-content: center;
  align-items: center;
}
.influencer_txt {
  width: 50vw;
  gap: 0.4rem;
  align-items: flex-start;
} 
.influencer {
  height: 30vh;
}
}
/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.concept_area {
  background-image: url(../../public/img/concept_bg_mobile.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  justify-content: space-evenly;
  gap: 4rem;
  height: auto;
  padding: 3rem 0;
}
.education_title {
  gap: 0.1rem;
}
.education_title h3 {
  font-size: 0.36rem;
}
.education::before {
  top: -1.3rem;
}
.desihally_point {
  width: 110px;
  height: auto;
  object-fit: contain;
}
.education_txt {
  width: 95%;
  gap: 0.4rem;
  align-items: flex-start;
}
.education_txt ul li {
  font-size: 0.24rem;
  align-items: baseline;
}
.education_txt ul li span {
  font-size: 0.38rem;
}
.influencer h3 {
  font-size: 0.4rem;
}
.influencer_txt {
  width: 95%;
  gap: 0.4rem;
  align-items: flex-start;
}
.influencer_txt span {
  font-size: 0.4rem;
}
.influencer::before {
  bottom: -1rem;
}
.influencer_txt ul li {
  font-size: 0.24rem;
}
.influencer_txt ul li span {
  font-size: 0.38rem;
}
.education {
  flex-direction: column;
  height: auto;
}
.influencer {
  flex-direction: column;
  height: auto;
}
.check {
  margin: 0 0.1rem 0;
}

}




/* solution */
.solution {
  padding: 1rem 0 1rem 0;
  background-color: #F0F0F5;
}

.solution_wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
}

.solution_list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
}

.solution_list li {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 356px;
  height: 500px;
  background-color: #FAFAFA;
  border-radius: 10px;
}

.solution_list img {
  width: 264px;
  height: 250px;
}

.solution_title {
  font-size: 0.22rem;
  font-weight: 600;
  color: #1F3B90;
  margin: 0.2rem 0 0.3rem 0;
}
.solution_txt {
  font-size: 0.16rem;
  font-weight: 600;
  margin: 0.2rem;
  text-align: center;
}

.plus {
  width: 40px;
  height: auto;
  object-fit: cover;
}

.workshop {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.3rem;
  background-color: #FFF;
  border-radius: 5px;
  max-width: 1100px;
  width: 70vw;
  height: auto;
  padding: 0.15rem 0.6rem;
}

.workshop::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 3px;
  background: linear-gradient(180deg,
      rgba(47, 110, 189, 1) 0%,
      rgba(93, 176, 236, 1) 100%);
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  z-index: 0;
}

.workshop img {
  width: 200px;
  height: auto;
  object-fit: cover;
}

.workshop_txtarea {
  display: flex;
  flex-direction: column;
  justify-content: left;
  gap: 0.2rem;
}

.workshop_txt {
  font-size: 0.24rem;
  font-weight: 500;
  color: #2267BC;
}

.workshop_txt span {
  background: linear-gradient(180deg,
      rgba(254, 50, 45, 1) 0%,
      rgba(242, 171, 131, 1) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

/* =========================
  Responsive
========================= */
@media screen and (max-width: 1024px){
.solution_title {
    font-size: 0.3rem;
  }
.solution_txt {
  font-size: 0.25rem;
}
.workshop_txt {
  font-size: 0.3rem;
}
}
@media screen and (max-width: 768px){
.solution_list {
  flex-direction: column;
}
.solution_list li {
  width: 85vw;
  height: auto;
  padding-top: 0.4rem;
}
.solution_title {
  font-size: 0.38rem;
}
.solution_txt {
  font-size: 0.3rem;
  margin: 0.5rem;
}
.workshop {
  flex-direction: column;
  padding: 0.6rem 0.4rem;
  width: 85vw;
}
.workshop_txt {
  font-size: 0.4rem;
}
.workshop_txt span {
  font-size: 0.4rem;
}
}



/* CTA */

.cta_section {
  background-color: #F0F0F5;
  position: relative;
  width: 100%;
  height: auto;
  padding-bottom: 1rem;
}
.cta_wrapper {
  background-image: url("../../public/img/cta_bg.webp");
  background-size: cover;
  background-position: 0;
  background-repeat: no-repeat;
  display: flex;
  justify-content: center;
  height: 70vh;
}
.cta_image {
  width: 40vw;
  height: auto;
  object-fit: contain;
}
.cta_section_txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0.3rem;
  width: 30%;
  height: auto;
  color: #FFF;
}
.cta_txt {
  width: 30vw;
  height: auto;
}
.cta_section_txt h3 {
  font-size: 0.32rem;
  font-weight: 600;
  color: #FFF;
}
/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px) {
.cta_wrapper {
  height: 30vh;
}
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.cta_wrapper {
  height: auto;
  flex-direction: column;
  align-items: center;
  background-size: cover;
  padding-top: 1rem;
  gap: 0.8rem;
}
.cta_section_txt {
  width: 80%;
}
.cta_section_txt h3 {
  font-size: 0.38rem;
}
.fv_btn span {
  font-size: 0.3rem;
}
.fv_btn a {
  gap: 0.18rem;
}
.cta_txt {
  width: 80vw;
}
.cta_image {
  width: 80vw;
  height: auto;
  object-fit: cover;
}

}


/* business */
.business {
  position: relative;
  background-color: #F0F0F5;
  padding: 0 0 1rem;
  overflow-x: hidden;
}
.business_subtitle {
  display: flex;
  justify-content: center;
  align-items: center;
}
.business_subtitle::before,
.business_subtitle::after {
  width: 2px;
  height: 28px;
  content: "";
  background-color: #1F3B90;
}
.business_subtitle::before {
  margin-right: 0.3rem;
  transform: rotate(-30deg);
}
.business_subtitle::after {
  margin-left: 0.3rem;
  transform: rotate(30deg);
}
.business img {
  width: 30px;
  height: auto;
  object-fit: cover;
}
.business ul li img {
  width: 50px;
  height: auto;
  object-fit: cover;
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translate(-50%, -50%);
  z-index: 50;
}
.business_list::before {
  content: "";
  width: 20%;
  height: 100%;
  background: linear-gradient(180deg,
        rgba(47, 110, 189, 1) 0%,
        rgba(93, 176, 236, 1) 100%);
  z-index: 1;
  border-radius: 8px 0 0 8px;
} 
.business p {
  text-align: center;
  font-size: 0.24rem;
  color: #1F3B90;
}
.business ul {
  max-width: 1100px;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.1rem;
  width: 70vw;
  height: 400px;
  margin: 0 auto;
}
.business_list {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 30vw;
  height: 80px;
  border: 1px solid #1F3B90;
  border-radius: 10px;
  background-color: #FFF;
}
.business_list p {
  padding-left: 0.2rem;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px) {
.business ul {
    flex-direction: column;
    height: auto;
  }
.business_list {
    width: 70vw;
  }
.business p {
  font-size: 0.3rem;
}
}


/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.business_subtitle::before,
.business_subtitle::after {
  width: 1px;
  height: 28px;
  content: "";
  background-color: #1F3B90;
}

.business_subtitle::before {
  margin-right: 0.3rem;
  transform: rotate(-30deg);
}

.business_subtitle::after {
  margin-left: 0.3rem;
  transform: rotate(30deg);
}
.business p {
  font-size: 0.3rem;
}
.business ul {
  flex-wrap: nowrap;
  height: auto;
}
.business ul li img {
  width: 40px;
}
.business_list {
  width: 70vw;
}
.business_list p {
  font-size: 0.3rem;
}
.business_list::before {
  width: 30%;
}
.business ul li img {
  left: 15%;
}
}


/* plan */
.plan {
  background-color: #F0F0F5;
  padding-bottom: 0.8rem;
}
.plan_title {
  background-image: url("../../public/img/plan_bg.webp");
  background-size: cover;
  background-position: 0;
  background-repeat: no-repeat;
  width: 100%;
  height: auto;
  padding-top: 0.5rem;
  padding-bottom: 0.6rem;
  color: #FFF;
  font-size: 0.36rem;
  font-weight: 700;
  text-align: center;
}

.plan_title img {
  width: 55px;
  height: auto;
  object-fit: cover;
}
.plan_list_area {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
  padding-top: 0.8rem;
}
.plan_list {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 10px;
  width: 200px;
  height: auto;
  background: #FFF;
  padding: 0.5rem 0.1rem 0.3rem;
}
.plan_icon {
  width: 90px;
  height: 90px;
  background: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}
.plan_list p {
  font-size: 0.2rem;
  font-weight: 600;
  color: #1F3B90;
  text-align: center;
}
.plan h4 {
  max-width: 1100px;
  width: 70%;
  height: auto;
  font-size: 0.24rem;
  font-weight: 600;
  text-align: center;
  color: #FFF;
  background: linear-gradient(180deg,
      rgba(47, 110, 189, 1) 0%,
      rgba(93, 176, 236, 1) 100%);
  border-radius: 5px;
  padding: 0.2rem 0.4rem;
  margin: 0.32rem auto;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px){
  .plan_list {
    padding: 1rem 0.1rem;
  }
.plan_list p {
  font-size: 0.25rem;
}
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.plan_list_area {
  flex-direction: column;
  gap: 0.4rem;
}
.plan_icon {
  position: static;
  margin: 0 15px 0 0;
  transform: none;
  width: 60px;
  height: 60px;
}
.plan_title {
  background-image: url("../../public/img/plan_bg_mobile.webp");
  background-size: cover;
  background-position: 0;
  background-repeat: no-repeat;
  height: auto;
  padding-top: 0.8rem;
  padding-bottom: 1rem;
}
.plan_title img {
  width: 40px;
  height: auto;
  object-fit: cover;
}
.plan_list {
  width: 70vw;
  flex-direction: row;
  height: auto;
  padding: 0.2rem 0;
}
.plan_list p {
  font-size: 0.3rem;
  width: 35vw;
  text-align: left;
}

}

.campain_area {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  max-width: 1100px;
  width: 70%;
  height: auto;
  background-color: #fff;
  border-top: 5px solid #1F3B90;
  margin: 0.4rem auto;
  padding: 0.4rem;
  text-align: center;
  border-radius: 5px;
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35);
  overflow-x: hidden;
}
.campain_box {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.campain_title {
  font-size: 0.2rem;
  font-weight: 600;
  text-align: left;
  color: #1F3B90;
  margin-bottom: 0.2rem;
}
.campain_illust {
  width: 300px;
  height: auto;
  object-fit: cover;
}
.price {
  font-size: 0.36rem;
  font-weight: 700;
  color: #FE322D;
  font-family: "Inter", sans-serif;
}
.note {
  color: #252935;
  font-size: 0.1rem;
}
.campain_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
  width: 250px;
  height: 60px;
  font-size: 0.16rem;
  font-weight: 600;
  border-radius: 50px;
  color: #FFF;
  margin-top: 0.2rem;
  background: linear-gradient(180deg,
          rgba(254, 50, 45, 1) 0%,
          rgba(242, 171, 131, 1) 100%);
}

.campain_btn {
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35); 
  transition: .3s ease-in-out;
}

.campain_btn a {
  width: 250px;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.1rem;
  /* box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35); */
  transition: .3s ease-in-out;
}

.campain_btn:hover {
  box-shadow: unset;
  transform: translateY(4px);
}


.campain_sub_area {
  max-width: 1100px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  text-align: center;
  font-size: 0.36rem;
  font-weight: 700;
  color: #1F3B90;
  margin: 0 auto;
}
.campain_sub_area img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}
.box_1 {
  width: 35%;
  height: auto;
  border: 2px solid #2267BC;
  background-color: #FFF;
  border-radius: 5px;
  padding: 3%;
  display: flex;
  flex-direction: column;
  gap: 2%;
}
.box_1 span {
  color: #FE322D;
  font-family: "Inter", sans-serif;
}

.box_2 {
  width: 35%;
  height: auto;
  border: 2px solid #2267BC;
  position: relative;
  padding: 3% 2% 6%;;
  border-radius: 5px;
  background-color: #FFF;
  display: flex;
  flex-direction: column;
  gap: 5%;
}

.box_2 span {
  font-size: 0.48rem;
  color: #FE322D;
  font-family: "Inter", sans-serif;
}
.top {
  font-size: 0.2rem;
  font-weight: 700;
  text-align: center;
  color: #1F3B90;
  background-color: #FFF;
  border-radius: 50px;
  border: 1px solid #1F3B90;
  padding: 0.08rem 0.1rem;
  margin-bottom: 0.02rem;
}
.option {
  position: absolute;
  top: -3vh;
}
.option_txt p {
  padding-bottom: 0.1rem;
}
.option_area {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  max-width: 1100px;
  width: 70%;
  height: auto;
  background-color: #fff;
  border-top: 5px solid #1F3B90;
  margin: 0.8rem auto;
  text-align: left;
  padding: 0.8rem 0.4rem;
  border-radius: 5px;
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35);
}
.option_img {
  width: 300px;
  height: auto;
  object-fit: cover;
}
.option_txt_title {
  font-size: 0.24rem;
  font-weight: 600;
  color: #1F3B90;
  margin-bottom: 0.2rem;
}
.option_txt_title span {
  background-image: linear-gradient(180deg,
      rgba(47, 110, 189, 0.7) 0%,
      rgba(93, 176, 236, 0.7) 100%);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 100% 6px;
}
.option_txt_title p {
  font-size: 0.16rem;
  color: #252935;
}
/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px){
  .box_1,.box_2 {
    width: 30%;
    height: auto;
    gap: 0.2rem;
  }
  .note {
    font-size: 0.2rem;
  }
  .campain_title {
    font-size: 0.28rem;
  }
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.campain_title {
    font-size: 0.34rem;
  }
.campain_area {
  width: 85vw;
  flex-direction: column-reverse;
}
.price {
  font-size: 0.48rem;
}
.note {
  font-size: 0.24rem;
  font-weight: 400;
}
.campain_box {
  font-size: 0.4rem;
}
.cam_btn {
  font-size: 0.3rem;
}
.option_area {
  width: 85vw;
  flex-direction: column;
}
.option_txt_title {
  font-size: 0.3rem;
}
.option_txt {
  width: 70vw;
}
.campain_sub_area {
  width: 85vw;
  flex-direction: column;
  gap: 0.2rem;
  margin: 0 auto;
}
.sub_txt {
  font-size: 0.4rem;
  line-height: 0.6rem;
}
.plan h4 {
  width: 85vw;
  font-size: 0.38rem;
}
.box_1,.box_2 {
  width: 85vw;
  height: auto;
  gap: 0.2rem;
}
.box_1 span {
  font-size: 0.46rem;
}
.top {
  font-size: 0.3rem;
  width: 60vw;
  margin: 0 auto;
}

}


/* curriculum */
.curriculum_title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-image: url("../../public/img/curriculum_bg.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  width: 100%;
  height: 400px;
  margin-bottom: 1rem;
  color: #FFF;
  font-size: 0.2rem;
  font-weight: 700;
  text-align: center;
}
.curriculum_title h2 {
  font-size: 0.3rem;
  text-align: center;
  color: #FFF;
  padding-bottom: 0.3rem;
}
.curriculum_title h2 span {
  font-size: 0.36rem;
  color: #FFF;
}
.curriculum_title p {
  font-weight: 500;
}
.number,.number_b {
  width: 20px;
  height: 20px;
  object-fit: cover;
  margin-right: 5px;
}

.text-area {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 1rem;
}
.kiso , .ouyou{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 492px;
  height: 840px;
  text-align: center;
  font-size: 0.24rem;
  font-weight: 600;
  padding-bottom: 0.8rem;
  gap: 0.2rem;
}
.kiso {
  background-color: #F0F7FF;
}
.kiso h3 {
  background-color: #2267BC;
  color: #FFF;
  width: 100%;
  padding: 0.1rem 0;
}
.kiso_title {
  color: #347BD3;
  font-size: 0.2rem;
  padding: 0.1rem 0;
}
.step {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 458px;
  height: auto;
  background-color: #FFF;
  gap: 0.2rem;
  padding-bottom: 0.4rem;
}
.step_k_txt li {
  font-size: 0.16rem;
  color: #252935;
  text-align: left;
  display: flex;
  align-items: center;
  font-weight: 500;
}

.step_k_title {
  background-color: #347BD3;
  font-size: 0.18rem;
  color: #FFF;
  width: 100%;
  padding: 0.08rem 0;
}
.step_k_time {
  font-size: 0.15rem;
  color: #A09365;
  border: 1px solid #A09365;
  padding: 0.05rem;
}
.step_k_point {
  font-size: 0.2rem;
  color: #347BD3;
}
.ouyou {
  background-color: #FFF9F4;
}
.ouyou h3 {
  width: 100%;
  background-color: #FF454A;
  color: #FFF;
  padding: 0.1rem 0;
}
.ouyou_title {
  color: #FF5856;
  font-size: 0.2rem;
}
.step_o_txt li {
  font-size: 0.16rem;
  color: #252935;
  text-align: left;
  display: flex;
  align-items: center;
  font-weight: 500;
}
.step_o_txt span {
  color: #FF454A;
  font-family: "Inter", sans-serif;
  padding-right: 3px;
}
.step_o_title {
  background-color: #FF454A;
  font-size: 0.18rem;
  color: #FFF;
  width: 100%;
  padding: 0.08rem 0;
}
.step_o_time {
  font-size: 0.15rem;
  color: #A09365;
  border: 1px solid #A09365;
  padding: 0.05rem;
}
.step_o_point {
  font-size: 0.2rem;
  color: #FF5856;
}
/* =========================
  Responsive
========================= */

@media screen and (max-width: 1024px) {
.curriculum_title h2 {
  font-size: 0.38rem;
}
.curriculum_title h2 span {
  font-size: 0.4rem;
}
.text-area {
    flex-direction: column;
  }
.kiso,
.ouyou {
  width: 80vw;
  height: auto;
  font-size: 0.38rem;
}
.kiso_title,
.ouyou_title {
  font-size: 0.3rem;
}

.step_k_txt li,
.step_o_txt li {
  align-items: center;
  font-size: 0.28rem;
}

.step_o_txt li:nth-child(2) {
  align-items: baseline;
}
.step_o_txt li:nth-child(6) {
  align-items: baseline;
}

.step_k_title,
.step_o_title {
  font-size: 0.28rem;
}

.step_k_time,
.step_o_time {
  font-size: 0.28rem;
}

.step_k_point,
.step_o_point {
  font-size: 0.3rem;
}
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
.text-area {
  flex-direction: column;
}
.kiso,
.ouyou {
  width: 90vw;
  height: auto;
  font-size: 0.38rem;
}
.curriculum img {
  width: 14px;
  height: 14px;
  object-fit: cover;
}
.kiso_title,.ouyou_title {
  font-size: 0.3rem;
}
.step_k_txt li,.step_o_txt li {
  align-items: center;
  font-size: 0.28rem;
}
.step_o_txt li:nth-child(2) {
  align-items: baseline;
}
.step_o_txt li:nth-child(6) {
  align-items: baseline;
}
.step_k_title,.step_o_title {
  font-size: 0.28rem;
}
.step_k_time,.step_o_time {
  font-size: 0.28rem;
}
.step_k_point,.step_o_point {
  font-size: 0.3rem;
}
.step {
  width: 85vw;
}
.number,.number_b {
  width: 14px;
  height: 14px;
  margin-right: 2px;
}
}

/* instructor */

.instructor {
  background-color: #F0F7FF;
}
.instructor_area {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  background-color: #FFF;
  max-width: 1400px;
  width: 80%;
  height: auto;
  margin: 0 auto;
  padding: 0.4rem 0;
}
.instructor_area img {
  width: 259px;
  height: 259px;
  object-fit: cover;
}
.instructor_name {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.2rem;
  font-size: 0.32rem;
  font-weight: 700;
  color: #1F3B90;
  padding: 0.16rem 0 0.32rem;
}
.instructor_name img {
  width: 230px;
  height: auto;
  object-fit: cover;
}
.instructor_company {
  background-color: #FFF;
  color: #1F3B90;
  font-size: 0.2rem;
  font-weight: 600;
  width: 80%;
  height: auto;
  margin: 0 auto;
  padding: 0.4rem 1.3rem 0.8rem;
}
.instructor_company p {
  border-bottom: 2px solid #1F3B90;
  margin-bottom: 0.2rem;
}
.instructor_move {
  text-align: center;
  font-size: 0.36rem;
  font-weight: 700;
  color: #1F3B90;
  padding: 0.8rem 0;
}
video {
  margin-top: 0.4rem;
  width: 70vw;
  height: auto;
}
.instructor_title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-image: url("../../public/img/curriculum_bg_2.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  width: 100%;
  height: 400px;
  margin-bottom: 1rem;
  color: #FFF;
  font-size: 0.2rem;
  font-weight: 700;
  text-align: center;
}

.instructor_title h2 {
  font-size: 0.36rem;
  text-align: center;
  color: #FFF;
  padding-bottom: 0.3rem;
}

.instructor_title p {
  font-weight: 500;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px) {
  .instructor_area {
    flex-direction: column;
    padding: 0.2rem 0.2rem 0.8rem;
    width: 90%;
  }

  .instructor_name {
    flex-direction: column;
    align-items: flex-start;
  }

  .curriculum_title {
    height: 300px;
    padding: 0 0.2rem;
  }

  .instructor_title {
    height: 270px;
    padding: 0 0.2rem;
  }

  .usutaku {
    font-size: 0.45rem;
  }

  .instructor_name img {
    width: 150px;
  }

  .instructor_company {
    padding: 0.2rem;
  }

  .instructor_company p {
    font-size: 0.38rem;
  }

.instructor_title p {
  font-weight: 400;
  font-size: 0.28rem;
}

  .instructor_title h2 {
    font-size: 0.38rem;
    padding-bottom: 0.4rem;
  }

  .instructor_title h2 span {
    font-size: 0.4rem;
  }

}

.efficiency {
  background-color: #F0F0F5;
  padding: 0 0 1rem;
}

.efficiency_box {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  max-width: 1200px;
  width: 82%;
  height: auto;
  text-align: center;
  font-size: 0.24rem;
  font-weight: 600;
  gap: 0.24rem;
  margin: 0.2rem auto 0;
}
.efficiency_case {
  position: absolute;
  top: -30px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.1rem;
  background-color: #347BD3;
  border-radius: 5px;
  color: #FFF;
  font-size: 0.15rem;
  width: 126px;
  height: auto;
}
.efficiency_case span {
  font-size: 0.32rem;
  font-family: "Inter", sans-serif;
}

.efficiency_box li {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  background-color: #FAFAFA;
  border-radius: 5px;
  width: 356px;
  height: auto;
  text-align: center;
  font-size: 0.24rem;
  font-weight: 600;
  padding: 0.4rem 0 0.4rem;
  gap: 0.2rem;
}
.illust {
  width: 268px;
  height: 185px;
  object-fit: contain;
}
.efficiency_txtbox {
  background-color: #FFF;
  width: 90%;
  height: auto;
  padding-bottom: 0.4rem;
}
.efficiency_title {
  font-size: 0.2rem;
  color: #1F3B90;
}
.efficiency_txt {
  display: flex;
  align-items: center;
  font-size: 0.16rem;
  font-weight: 400;
  color: #252935;
  text-align: left;
  margin-left: 0.1rem;
}
.number_e {
  width: 20px;
  height: 20px;
  object-fit: cover;
  margin-right: 5px;
}

.efficiency_be {
  background-color: #8E8E93;
  border-radius: 5px;
  font-size: 0.18rem;
  color: #FFF;
  width: 100%;
  padding: 0.08rem 0;
  margin-bottom: 0.2rem;
}
.efficiency_af {
  background-color: #FF4A4D;
  border-radius: 5px;
  font-size: 0.18rem;
  color: #FFF;
  width: 100%;
  padding: 0.08rem 0;
  margin-bottom: 0.2rem;
}

/* =========================
  Responsive
========================= */
@media screen and (max-width: 1024px){
.efficiency_case {
    top: -20px;
    font-size: 0.3rem;
    height: 40px;
  }

  .efficiency_case span {
    font-size: 0.38rem;
  }

  .efficiency_title {
    font-size: 0.3rem;
  }

  .efficiency_be,
  .efficiency_af {
    font-size: 0.3rem;
  }

  .efficiency_txt {
    font-size: 0.25rem;
  }
}
@media screen and (max-width: 768px) {
.efficiency_box {
  flex-direction: column;
  gap: 0.8rem;
  width: 356px;
}
.efficiency_case {
  top: -20px;
  font-size: 0.3rem;
  height: 40px;
}
.efficiency_case span {
  font-size: 0.38rem;
}
.efficiency_title {
  font-size: 0.38rem;
}
.efficiency_be,.efficiency_af {
  font-size: 0.34rem;
}
.efficiency_txt {
  font-size: 0.3rem;
}
.efficiency_box li {
  position: relative;
  height: auto;
}
.number_e {
  width: 14px;
  height: 14px; 
  margin-right: 2px;
  margin-top: 0;
}
}

/* flow */
.flow {
  padding: 1rem 0;
}
.flow h2 {
  padding-bottom: 0.5rem;
}

.flow_area {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1vw;
  margin: 0.5rem 0 0;
}
.flow_area_1 img {
  width: 100px;
  height: 100px;
  object-fit: contain;
}
.flow_area_2 img {
  width: 100px;
  height: 100px;
  object-fit: contain;
}
.flow_area_3 img {
  width: 100px;
  height: 100px;
  object-fit: contain;
}
.flow_area_4 img {
  width: 100px;
  height: 100px;
  object-fit: contain;
}

.flow_arow {
  width: 30px;
  height: 30px;
  object-fit: contain;
}
.flow_area_1 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
  width: 280px;
  height: 400px;
  border: 5px solid #4283CE;
  border-radius: 16px;
  padding: 0.8rem 0.2rem 0.4rem;
}
.flow_step_1 {
  position: absolute;
  top: -5vh;
  background-color: #4283CE;
  border-radius: 50%;
  width: 100px;
  height: 100px;
  color: #FFF;
  text-align: center;
  padding-top: 0.1rem;
}
.flow_step_1 span {
  font-family: "Inter",sans-serif;
  font-size: 0.36rem;
}
.flow_area_2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
  width: 280px;
  height: 400px;
  border: 5px solid #2C73C9;
  border-radius: 16px;
  padding: 0.8rem 0.2rem 0.4rem;
}
.flow_step_2 {
  position: absolute;
  top: -5vh;
  background-color: #2C73C9;
  border-radius: 50%;
  width: 100px;
  height: 100px;
  color: #FFF;
  text-align: center;
  padding-top: 0.1rem;
}
.flow_step_2 span {
  font-family: "Inter", sans-serif;
  font-size: 0.36rem;
}
.flow_area_3 {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: center;
  gap: 0.2rem;
  width: 280px;
  height: 400px;
  border: 5px solid #2368BC;
  border-radius: 16px;
  padding: 0.8rem 0.2rem 0.4rem;
}
.flow_step_3 {
  position: absolute;
  top: -5vh;
  background-color: #2368BC;
  border-radius: 50%;
  width: 100px;
  height: 100px;
  color: #FFF;
  text-align: center;
  padding-top: 0.1rem;
}

.flow_step_3 span {
  font-family: "Inter", sans-serif;
  font-size: 0.36rem;
}
.flow_area_4 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.2rem;
  width: 280px;
  height: 400px;
  border: 5px solid #0A509F;
  border-radius: 16px;
  padding: 0.8rem 0.2rem 0.4rem;
}
.flow_step_4 {
  position: absolute;
  top: -5vh;
  background-color: #0A509F;
  border-radius: 50%;
  width: 100px;
  height: 100px;
  color: #FFF;
  text-align: center;
  padding-top: 0.1rem;
}

.flow_step_4 span {
  font-family: "Inter", sans-serif;
  font-size: 0.36rem;
}

.flow_title {
  font-size: 0.28rem;
  font-weight: 600;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px) {
.flow_area {
  flex-direction: column;
  gap: 0.6rem;
}
.flow_title {
  font-size: 0.4rem;
}

.flow_area_1 {
  position: relative;
  height: 330px;
}
.flow_step_1 {
  width: 80px;
  height: 80px;
  padding-top: 0.2rem;
}
.flow_step_1 span,.flow_step_2 span,.flow_step_3 span,.flow_step_4 span {
  font-size: 0.5rem;
}
.flow_area_2 {
  position: relative;
  height: 330px;
  margin-top: 0.5rem;
}
.flow_step_2 {
  width: 80px;
  height: 80px;
  padding-top: 0.2rem;
}
.flow_area_3 {
  position: relative;
  height: 330px;
  margin-top: 0.5rem;
  justify-content: center;
}
.flow_step_3 {
  width: 80px;
  height: 80px;
  padding-top: 0.2rem;
}
.flow_area_4 {
  position: relative;
  height: 330px;
  margin-top: 0.5rem;
}
.flow_step_4 {
  width: 80px;
  height: 80px;
  padding-top: 0.2rem;
}
.flow_arow {
  transform: rotate(90deg);
}
}


/* FAQ */

.faq-section {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-color: #F0F0F5;
  padding-bottom: 1rem;
  width: 100%;
}

.faq-title {
  text-align: center;
  font-size: 0.36rem;
  font-weight: 700;
  color: #1c2a5f;
  margin-bottom: 0.4rem;
}

/* 各項目 */
.faq-item {
  max-width: 1100px;
  width: 70vw;
  background: #fff;
  border-radius: 8px;
  margin-bottom: 0.12rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* 質問部分 */
.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 0.28rem 0.2rem;
  font-weight: 500;
  line-height: 1.6;
  transition: background 0.3s, color 0.3s;
  position: relative;
}

.faq-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #1c2a5f;
  color: #fff;
  font-weight: bold;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 0.15rem;
  margin-right: 0.1rem;
  flex-shrink: 0;
}

.toggle-icon {
  font-size: 0.14rem;
  color: #555;
  margin-left: auto;
  transition: transform 0.3s, color 0.3s;
}

/* 回答部分 */
.faq-answer {
  max-height: 0;
  overflow: hidden;
  background: #f9f9f9;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding: 0 0.2rem;
}

.faq-answer p {
  margin: 0;
  padding: 0.16rem 0;
  font-size: 0.16rem;
  line-height: 1.8;
}

/* 開いたとき */
.faq-item.active .faq-question {
  background: #1c2a5f;
  color: #fff;
}

.faq-item.active .toggle-icon {
  color: #fff;
  transform: rotate(180deg);
}


.faq-item.active .faq-answer {
  max-height: 2rem;
  /* 内容量に合わせて調整 */
  padding: 0 0.2rem 0.16rem 0.2rem;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
  .faq-section {
    max-width: 100vw;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 1rem 0;
  }
  .faq-title {
    font-size: 0.38rem;
  }
  .faq-item {
    width: 90vw;
    margin: 0 auto 0.3rem;
  }
  .faq-icon {
    font-size: 0.28rem;
  }
  .faq-answer p {
    font-size: 0.28rem;
}
  .toggle-icon {
    font-size: 0.3rem;
  }
}


/* contact */
.section_contact_btn {
  background-image: url("../../public/img/section_contact_bg.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: auto;
  padding: 1rem 0;
}
.contact_wrapper {
  background-color: #FFF;
  max-width: 1100px;
  width: 80vw;
  margin: 0 auto;
  border-radius: 10px;
  text-align: center;
  font-size: 0.2rem;
  padding: 0.3rem;
}
.contact_wrapper h2 {
  padding: 0 0 0.2rem;
}
.contact-cta {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.4rem;
}
.contact_request {
  align-items: center;
  background: linear-gradient(180deg,
      rgba(254, 50, 45, 1) 0%,
      rgba(242, 171, 131, 1) 100%);
  display: inline-flex;
  gap: 0.1rem;
  height: 60px;
  justify-content: center;
  padding: 0.2rem 0.8rem;
  border-radius: 50px;
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35);
  transition: .3s ease-in-out;
  color: #FFF;
  font-weight: 600;
}
.contact_request:hover {
  box-shadow: unset;
  transform: translateY(4px);
}
.contact_contact {
  align-items: center;
    background: linear-gradient(180deg,
        rgba(47, 110, 189, 1) 0%,
        rgba(93, 176, 236, 1) 100%);
  display: inline-flex;
  gap: 0.1rem;
  height: 60px;
  justify-content: center;
  padding: 0.2rem 0.8rem;
  border-radius: 50px;
  box-shadow: 3px 6px 3px 0px rgba(131, 130, 130, 0.35);
  transition: .3s ease-in-out;
  color: #FFF;
  font-weight: 600;
}
.contact_contact:hover {
  box-shadow: unset;
  transform: translateY(4px);
}

.icon {
  width: 18px;
  height: auto;
  object-fit: cover;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
  .contact-cta {
    flex-direction: column;
  }
  .contact_wrapper {
    padding: 0.6rem;
  }
}


/* footer */
.footer {
  position: relative;
  background-color: #333333;
  color: #FFF;
  font-size: 0.16rem;
  width: 100vw;
  height: 20vh;
}
.footer_link {
  display: flex;
  justify-content: center;
  gap: 0.4rem;
  padding-top: 5vh;
}
a[target="_blank"] {
  color: #FFF;
  text-decoration: none;
  border-bottom: 1px solid #FFF;
  transition: 0.3s;
}

a[target="_blank"]:hover {
  opacity: 0.7;
}

.footer a:hover {
  opacity: 0.85;
}
small {
  position: absolute;
  right: 0;
  left: 0;
  bottom: 5vh;
  margin: 0 auto;
  text-align: center;
  font-size: 0.14rem;
}
.back-to-top {
  position: fixed;
  right: 20px;
  /* 画面右からの余白 */
  bottom: 24px;
  /* 画面下からの余白 */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #FFF;
  color: #1F3B90;
  text-decoration: none;
  font-size: 20px;
  line-height: 1;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  transition: transform .18s ease, opacity .18s ease, background .18s ease;
  opacity: 0.92;
  z-index: 9999;
  visibility: hidden;
}
.back-to-top img {
  width: 20px;
  height: auto;
  object-fit: cover;
}
/* スクロール後に表示される */
.back-to-top.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* ホバー時の効果 */
.back-to-top:hover {
  background: #F4F3F3;
  transform: translateY(-3px);
}



/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px){
  .footer {
    font-size: 0.28rem;
  }
}


/* contact page */

.section_contact {
  width: 70vw;
  margin: 0 auto;
}
.section_contact h2 {
  padding-top: 2rem;
}

/* =========================
  Responsive
========================= */

@media screen and (max-width: 768px) {
.section_contact {
    width: 100%;
    margin: 0 auto;
  }
}
