@charset "UTF-8";
/* ==== RESET CSS ==== */
/* Box sizing */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin and padding */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
dl,
dd,
ol,
ul,
figure,
hr,
fieldset,
legend,
button,
input,
textarea,
select {
  margin: 0;
  padding: 0;
}

/* Remove list styles */
ul,
ol {
  list-style: none;
}

/* Remove quotes from blockquote/quotes */
blockquote,
q {
  quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
  content: "";
  content: none;
}

/* Reset headings */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/* Reset links */
a {
  color: inherit;
  text-decoration: none;
}

/* Reset form elements */
button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
  background: none;
  border: none;
  outline: none;
}

/* Remove default button styles */
button {
  cursor: pointer;
  background-color: transparent;
}

/* Set basic body style */
html,
body {
  line-height: 1.5;
  font-family: sans-serif;
  background-color: #fff;
  color: #000;
}

/* Images, video, etc */
img,
video {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Table */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

html {
  font-size: 16px;
}

body {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.08em;
  color: #333333;
  background-color: #fcfaf5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "palt";
}

b {
  font-weight: normal;
}

.mincho {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
}

.h1--section {
  margin-bottom: 6rem;
}
.h1--section .title-ja {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  font-size: 2.2rem;
  color: #2c3e50;
  letter-spacing: 0.15rem;
}
@media (min-width: 768px) {
  .h1--section .title-ja {
    font-size: 3rem;
  }
}
.h1--section .title-en {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  letter-spacing: 0.2rem;
  font-size: 1.1rem;
  text-transform: uppercase;
  color: #c6a47e;
}
@media (min-width: 768px) {
  .h1--section .title-en {
    font-size: 1.4rem;
  }
}
.h1--section .title-en.home {
  color: #8a7d70;
}
.h1--section .title-en.concept {
  color: #e2938e;
}
.h1--section .title-en.os {
  color: #e0a36a;
}
.h1--section .title-en.curriculum {
  color: #d9b85c;
}
.h1--section .title-en.certification {
  color: #a3b77a;
}
.h1--section .title-en.community {
  color: #7eb8a6;
}
.h1--section .title-en.outputs {
  color: #78a9c3;
}
.h1--section .title-en.practice {
  color: #8a96bd;
}
.h1--section .title-en.service {
  color: #a88cb8;
}
.h1--section .title-en.target {
  color: #c889a9;
}
.h1--section .title-en.caution {
  color: #9d8d82;
}
.h1--section .title-en.consultation {
  color: #c6a47e;
}

.h2--section {
  margin-bottom: 6rem;
}
.h2--section .title-ja {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  font-size: 2rem;
  color: #2c3e50;
  letter-spacing: 0.15rem;
}
.h2--section .title-en {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  text-transform: uppercase;
  letter-spacing: 0.2rem;
}
.h2--section .title-en.home {
  color: #8a7d70;
}
.h2--section .title-en.concept {
  color: #e2938e;
}
.h2--section .title-en.os {
  color: #e0a36a;
}
.h2--section .title-en.curriculum {
  color: #d9b85c;
}
.h2--section .title-en.certification {
  color: #a3b77a;
}
.h2--section .title-en.community {
  color: #7eb8a6;
}
.h2--section .title-en.outputs {
  color: #78a9c3;
}
.h2--section .title-en.practice {
  color: #8a96bd;
}
.h2--section .title-en.service {
  color: #a88cb8;
}
.h2--section .title-en.target {
  color: #c889a9;
}
.h2--section .title-en.caution {
  color: #9d8d82;
}
.h2--section .title-en.consultation {
  color: #c6a47e;
}
.h2--section .title-en.sec-01 {
  color: #e2938e;
}
.h2--section .title-en.sec-02 {
  color: #e0a36a;
}
.h2--section .title-en.sec-03 {
  color: #d9b85c;
}
.h2--section .title-en.sec-04 {
  color: #a3b77a;
}
.h2--section .title-en.sec-05 {
  color: #7eb8a6;
}
.h2--section .title-en.sec-06 {
  color: #78a9c3;
}
.h2--section .title-en.sec-07 {
  color: #8a96bd;
}
.h2--section .title-en.sec-08 {
  color: #a88cb8;
}
.h2--section .title-en.sec-09 {
  color: #c889a9;
}
.h2--section .title-en.sec-10 {
  color: #9d8d82;
}
.h2--section .title-en.sec-11 {
  color: #c6a47e;
}

@keyframes moveRight {
  0% {
    opacity: 0;
    transform: translateX(40px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes moveUp {
  0% {
    opacity: 0;
    transform: translateY(40px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.animation {
  overflow: hidden;
}

.anime-x-row,
.anime-y-row {
  opacity: 0;
  visibility: hidden;
  will-change: transform, opacity;
}

.anime-x-row.active {
  animation: moveRight 1s ease-out forwards;
  visibility: visible;
}

.anime-y-row.active {
  animation: moveUp 1.5s ease-out forwards;
  visibility: visible;
}

.wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

.footer {
  flex-shrink: 0;
}

.main {
  flex: 1;
  padding-bottom: 3rem;
}

.section--fixed {
  width: 100%;
  height: 100dvh;
  z-index: 1;
}
.section--content {
  margin-bottom: 6rem;
}
@media (min-width: 768px) {
  .section--content {
    width: 1280px;
    margin-left: auto;
    margin-right: auto;
  }
}
.section--body {
  padding-bottom: 3rem;
}
.section--body p {
  margin-bottom: 1rem;
}
.section--body b {
  display: inline;
  font-weight: normal;
  text-decoration: none;
  padding: 0 0.5rem;
  background: linear-gradient(transparent 80%, rgba(198, 164, 126, 0.4) 80%);
}
.section--body.flex {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (min-width: 768px) {
  .section--body.flex {
    flex-direction: row;
  }
  .section--body.flex .flex-content {
    flex: 1;
  }
  .section--body.flex .flex-img {
    width: 40%;
  }
}
.section--home:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--home:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #8a7d70;
}
.section--home b {
  background: linear-gradient(transparent 80%, rgba(138, 125, 112, 0.4) 80%);
}
.section--concept:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--concept:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #e2938e;
}
.section--concept b {
  background: linear-gradient(transparent 80%, rgba(226, 147, 142, 0.4) 80%);
}
.section--os:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--os:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #e0a36a;
}
.section--os b {
  background: linear-gradient(transparent 80%, rgba(224, 163, 106, 0.4) 80%);
}
.section--curriculum:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--curriculum:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #d9b85c;
}
.section--curriculum b {
  background: linear-gradient(transparent 80%, rgba(217, 184, 92, 0.4) 80%);
}
.section--certification:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--certification:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #a3b77a;
}
.section--certification b {
  background: linear-gradient(transparent 80%, rgba(163, 183, 122, 0.4) 80%);
}
.section--community:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--community:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #7eb8a6;
}
.section--community b {
  background: linear-gradient(transparent 80%, rgba(126, 184, 166, 0.4) 80%);
}
.section--outputs:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--outputs:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #78a9c3;
}
.section--outputs b {
  background: linear-gradient(transparent 80%, rgba(120, 169, 195, 0.4) 80%);
}
.section--practice:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--practice:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #8a96bd;
}
.section--practice b {
  background: linear-gradient(transparent 80%, rgba(138, 150, 189, 0.4) 80%);
}
.section--service:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--service:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #a88cb8;
}
.section--service b {
  background: linear-gradient(transparent 80%, rgba(168, 140, 184, 0.4) 80%);
}
.section--target:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--target:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #c889a9;
}
.section--target b {
  background: linear-gradient(transparent 80%, rgba(200, 137, 169, 0.4) 80%);
}
.section--caution:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--caution:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #9d8d82;
}
.section--caution b {
  background: linear-gradient(transparent 80%, rgba(157, 141, 130, 0.4) 80%);
}
.section--consultation:not(:first-child) {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--consultation:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #c6a47e;
}
.section--consultation b {
  background: linear-gradient(transparent 80%, rgba(198, 164, 126, 0.4) 80%);
}
.section--01 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--01::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #e2938e;
}
.section--01 b {
  background: linear-gradient(transparent 80%, rgba(226, 147, 142, 0.4) 80%);
}
.section--02 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--02::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #e0a36a;
}
.section--02 b {
  background: linear-gradient(transparent 80%, rgba(224, 163, 106, 0.4) 80%);
}
.section--03 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--03::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #d9b85c;
}
.section--03 b {
  background: linear-gradient(transparent 80%, rgba(217, 184, 92, 0.4) 80%);
}
.section--04 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--04::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #a3b77a;
}
.section--04 b {
  background: linear-gradient(transparent 80%, rgba(163, 183, 122, 0.4) 80%);
}
.section--05 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--05::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #7eb8a6;
}
.section--05 b {
  background: linear-gradient(transparent 80%, rgba(126, 184, 166, 0.4) 80%);
}
.section--06 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--06::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #78a9c3;
}
.section--06 b {
  background: linear-gradient(transparent 80%, rgba(120, 169, 195, 0.4) 80%);
}
.section--07 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--07::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #8a96bd;
}
.section--07 b {
  background: linear-gradient(transparent 80%, rgba(138, 150, 189, 0.4) 80%);
}
.section--08 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--08::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #a88cb8;
}
.section--08 b {
  background: linear-gradient(transparent 80%, rgba(168, 140, 184, 0.4) 80%);
}
.section--09 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--09::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #c889a9;
}
.section--09 b {
  background: linear-gradient(transparent 80%, rgba(200, 137, 169, 0.4) 80%);
}
.section--10 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--10::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #9d8d82;
}
.section--10 b {
  background: linear-gradient(transparent 80%, rgba(157, 141, 130, 0.4) 80%);
}
.section--11 {
  position: relative;
  padding-top: 6rem;
  border-top: 1px #eee solid;
}
.section--11::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 120px;
  height: 3px;
  background-color: #c6a47e;
}
.section--11 b {
  background: linear-gradient(transparent 80%, rgba(198, 164, 126, 0.4) 80%);
}

@media (max-width: 767px) {
  .mb-width {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  flex-shrink: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  z-index: 1000;
  background-color: rgba(252, 250, 245, 0.7);
}
@media (min-width: 768px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
  }
}
.header--left {
  width: 300px;
}
.header--logo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.header--logo-img {
  width: 64px;
}
.header--right {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.header--right-top {
  display: none;
}
@media (min-width: 768px) {
  .header--right-top {
    display: block;
    position: relative;
    justify-content: flex-end;
    margin-bottom: 0.5rem;
    width: auto;
  }
  .header--right-top > div a {
    display: block;
  }
}

.header-menu--menu > ul > li {
  position: relative;
  padding-left: 1.5rem;
}
.header-menu--menu > ul > li::before {
  position: absolute;
  content: "";
  left: 0;
  top: 50%;
  width: 0.6rem;
  height: 0.6rem;
  transform: translateY(-50%);
  transition: 0.3s;
}
.header-menu--menu > ul > li.home::before {
  background-color: #8a7d70;
}
.header-menu--menu > ul > li.concept::before {
  background-color: #e2938e;
}
.header-menu--menu > ul > li.os::before {
  background-color: #e0a36a;
}
.header-menu--menu > ul > li.curriculum::before {
  background-color: #d9b85c;
}
.header-menu--menu > ul > li.certification::before {
  background-color: #a3b77a;
}
.header-menu--menu > ul > li.community::before {
  background-color: #7eb8a6;
}
.header-menu--menu > ul > li.outputs::before {
  background-color: #78a9c3;
}
.header-menu--menu > ul > li.practice::before {
  background-color: #8a96bd;
}
.header-menu--menu > ul > li.service::before {
  background-color: #a88cb8;
}
.header-menu--menu > ul > li.target::before {
  background-color: #c889a9;
}
.header-menu--menu > ul > li.caution::before {
  background-color: #9d8d82;
}
.header-menu--menu > ul > li.consultation::before {
  background-color: #c6a47e;
}
.header-menu--menu > ul > li a {
  display: inline-block;
  transition: 0.3s;
}
.header-menu--menu > ul > li:hover a {
  opacity: 0.7;
}
.header-menu--menu > ul > li:hover::before {
  transform: translate(5px, -50%);
}

@media (max-width: 767px) {
  .header-menu {
    position: fixed;
    width: 100%;
    height: 100dvh;
    top: 0;
    right: -100%;
    transition: 0.2s;
    display: flex;
    flex-direction: column;
    z-index: 999;
    transition: 0.5s;
    background-color: #fcfaf5;
  }
  .header-menu.menu-active {
    right: 0;
  }
  .header-menu--header {
    display: flex;
    justify-content: flex-end;
    border-bottom: 1px rgba(51, 51, 51, 0.1) dotted;
    padding: 1rem;
  }
  .header-menu--body {
    padding: 1rem;
  }
  .header-menu--menu > ul {
    display: flex;
    flex-direction: column;
  }
  .header-menu--menu > ul li a {
    display: block;
    padding: 0.5rem;
    border-bottom: 1px rgba(51, 51, 51, 0.1) dotted;
  }
  .open-button,
  .close-button {
    font-size: 1.4rem;
    line-height: 1.2rem;
  }
}
@media (min-width: 768px) {
  .header-menu--menu > ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 2rem;
    font-size: 0.8rem;
  }
  .open-button,
  .close-button {
    display: none;
  }
}
.index--hero {
  position: relative;
  overflow: hidden;
  height: 100%;
}
.index--hero-bg {
  position: relative;
  width: 100%;
  height: 100%;
  top: 0;
  overflow: hidden;
  display: flex;
  justify-content: flex-end;
}
.index--hero-bg img {
  position: absolute;
  width: auto;
  height: 100%;
  right: -15%;
  opacity: 0.1;
}
.index--hero-inner {
  position: absolute;
  grid-template-columns: 3fr 1fr;
  display: grid;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 0.5rem;
}
@media (min-width: 768px) {
  .index--hero-inner {
    grid-template-columns: 1fr 1fr;
    padding: 1rem 3rem;
  }
}
.index--hero-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  letter-spacing: 0.25rem;
}
.index--hero-left h1 {
  font-size: 6cqi;
  letter-spacing: 0.25rem;
  color: #2c3e50;
}
@media (min-width: 768px) {
  .index--hero-left h1 {
    font-size: 4.3cqi;
  }
}
.index--hero-left .hero-title--ja {
  font-size: 4.8cqi;
}
@media (min-width: 768px) {
  .index--hero-left .hero-title--ja {
    font-size: 2.5cqi;
  }
}
.index--hero-left .hero-title--subtitle {
  font-size: 2.5cqi;
}
@media (min-width: 768px) {
  .index--hero-left .hero-title--subtitle {
    font-size: 1.2cqi;
  }
}
.index--hero-right {
  display: flex;
  justify-content: center;
  align-items: center;
}
.index--hero-right .hero-content--text {
  writing-mode: vertical-rl;
  font-feature-settings: initial;
  font-size: 4cqh;
}
@media (min-width: 768px) {
  .index--hero-right .hero-content--text {
    font-size: 4.5cqh;
  }
}
.index .ul-panel-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media (min-width: 768px) {
  .index .ul-panel-list {
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
  }
}
.index .ul-panel-list > li {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: #2c3e50;
  cursor: pointer;
  transition: 0.5s;
  padding: 1rem 0.5rem;
}
@media (min-width: 768px) {
  .index .ul-panel-list > li {
    aspect-ratio: 3/2;
    padding: auto;
  }
}
.index .ul-panel-list > li.home {
  background-color: #8a7d70;
}
.index .ul-panel-list > li.concept {
  background-color: #e2938e;
}
.index .ul-panel-list > li.os {
  background-color: #e0a36a;
}
.index .ul-panel-list > li.curriculum {
  background-color: #d9b85c;
}
.index .ul-panel-list > li.certification {
  background-color: #a3b77a;
}
.index .ul-panel-list > li.community {
  background-color: #7eb8a6;
}
.index .ul-panel-list > li.outputs {
  background-color: #78a9c3;
}
.index .ul-panel-list > li.practice {
  background-color: #8a96bd;
}
.index .ul-panel-list > li.service {
  background-color: #a88cb8;
}
.index .ul-panel-list > li.target {
  background-color: #c889a9;
}
.index .ul-panel-list > li.caution {
  background-color: #9d8d82;
}
.index .ul-panel-list > li.consultation {
  background-color: #c6a47e;
}
.index .ul-panel-list > li:hover {
  opacity: 0.8;
}

.index-foot {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.index-foot--title {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #2c3e50;
  font-size: 8cqi;
  margin-bottom: 3rem;
}
@media (min-width: 768px) {
  .index-foot--title {
    font-size: 2.8rem;
  }
}
.index-foot--description {
  margin-bottom: 3rem;
}

.footer-btn {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  display: none;
}
@media (min-width: 768px) {
  .footer-btn {
    left: auto;
    right: 0;
    width: auto;
  }
}
@media (min-width: 768px) {
  .footer-btn--inner {
    display: flex;
  }
}
.footer-btn--inner ul {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px #ffffff solid;
}
@media (min-width: 768px) {
  .footer-btn--inner ul {
    border-left: 1px #ffffff solid;
  }
}
.footer-btn--inner ul li {
  font-size: 0.8rem;
  flex: 1;
}
@media (min-width: 768px) {
  .footer-btn--inner ul li {
    flex: auto;
  }
}
.footer-btn--inner ul li > * {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  background-color: #d4b572;
  color: #2c3e50;
  padding: 1rem 1rem;
  cursor: pointer;
}
@media (min-width: 768px) {
  .footer-btn--inner ul li > * {
    padding: 0.5rem 1rem;
  }
}
.footer-btn--inner ul li > *.primary {
  background-color: #2c3e50;
  color: #ffffff;
}
.footer-btn--inner ul li:not(:last-child) {
  border-right: 1px #ffffff solid;
}

.footer {
  position: relative;
  border-top: 1px #eee solid;
  padding: 6rem 1rem 10rem 1rem;
  background-color: rgba(157, 141, 130, 0.05);
}
@media (min-width: 768px) {
  .footer {
    padding: 6rem 6rem;
  }
}
.footer--bg {
  position: absolute;
  display: block;
  overflow: hidden;
  padding-top: 1rem;
  top: 0;
  width: 100%;
  height: 100%;
  left: 0%;
}
@media (min-width: 768px) {
  .footer--bg {
    top: 0;
    width: 50%;
    height: 100%;
    left: -10%;
    transform: none;
  }
}
.footer--bg img {
  height: auto;
  width: 100%;
  object-fit: contain;
  opacity: 0.1;
}
.footer--menu {
  display: none;
}
@media (min-width: 768px) {
  .footer--menu {
    display: block;
    margin-bottom: 3rem;
  }
}
.footer--menu > dl {
  display: flex;
  justify-content: flex-end;
  gap: 6rem;
}
.footer--menu > dl > div > dt {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  font-weight: 600;
  color: #2c3e50;
  font-size: 1.3rem;
  margin-bottom: 1rem;
}
.footer--menu > dl > div > dd {
  font-size: 0.8rem;
}
.footer .copyright {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-size: 0.8rem;
}
@media (min-width: 768px) {
  .footer .copyright {
    flex-direction: row;
    gap: 1rem;
    justify-content: flex-end;
  }
}

.ul-list {
  text-align: left;
  padding: 2rem;
  margin: 2rem 0;
  background-color: rgba(198, 164, 126, 0.05);
}
.ul-list--card {
  margin: auto;
  height: 100%;
}
.ul-list > li {
  position: relative;
  padding-left: 1.5rem;
}
.ul-list > li::before {
  position: absolute;
  content: "";
  left: 0;
  top: 1em;
  transform: translateY(-50%);
  width: 0.5em;
  height: 0.5em;
  border-radius: 50%;
  background-color: #c6a47e;
}
.ul-list--home {
  background-color: rgba(138, 125, 112, 0.05);
}
.ul-list--home > li::before {
  background-color: #8a7d70;
}
.ul-list--concept {
  background-color: rgba(226, 147, 142, 0.05);
}
.ul-list--concept > li::before {
  background-color: #e2938e;
}
.ul-list--os {
  background-color: rgba(224, 163, 106, 0.05);
}
.ul-list--os > li::before {
  background-color: #e0a36a;
}
.ul-list--curriculum {
  background-color: rgba(217, 184, 92, 0.05);
}
.ul-list--curriculum > li::before {
  background-color: #d9b85c;
}
.ul-list--certification {
  background-color: rgba(163, 183, 122, 0.05);
}
.ul-list--certification > li::before {
  background-color: #a3b77a;
}
.ul-list--community {
  background-color: rgba(126, 184, 166, 0.05);
}
.ul-list--community > li::before {
  background-color: #7eb8a6;
}
.ul-list--outputs {
  background-color: rgba(120, 169, 195, 0.05);
}
.ul-list--outputs > li::before {
  background-color: #78a9c3;
}
.ul-list--practice {
  background-color: rgba(138, 150, 189, 0.05);
}
.ul-list--practice > li::before {
  background-color: #8a96bd;
}
.ul-list--service {
  background-color: rgba(168, 140, 184, 0.05);
}
.ul-list--service > li::before {
  background-color: #a88cb8;
}
.ul-list--target {
  background-color: rgba(200, 137, 169, 0.05);
}
.ul-list--target > li::before {
  background-color: #c889a9;
}
.ul-list--caution {
  background-color: rgba(157, 141, 130, 0.05);
}
.ul-list--caution > li::before {
  background-color: #9d8d82;
}
.ul-list--consultation {
  background-color: rgba(198, 164, 126, 0.05);
}
.ul-list--consultation > li::before {
  background-color: #c6a47e;
}
.ul-list--sec-01 {
  background-color: rgba(226, 147, 142, 0.05);
}
.ul-list--sec-01 > li::before {
  background-color: #e2938e;
}
.ul-list--sec-02 {
  background-color: rgba(224, 163, 106, 0.05);
}
.ul-list--sec-02 > li::before {
  background-color: #e0a36a;
}
.ul-list--sec-03 {
  background-color: rgba(217, 184, 92, 0.05);
}
.ul-list--sec-03 > li::before {
  background-color: #d9b85c;
}
.ul-list--sec-04 {
  background-color: rgba(163, 183, 122, 0.05);
}
.ul-list--sec-04 > li::before {
  background-color: #a3b77a;
}
.ul-list--sec-05 {
  background-color: rgba(126, 184, 166, 0.05);
}
.ul-list--sec-05 > li::before {
  background-color: #7eb8a6;
}
.ul-list--sec-06 {
  background-color: rgba(120, 169, 195, 0.05);
}
.ul-list--sec-06 > li::before {
  background-color: #78a9c3;
}
.ul-list--sec-07 {
  background-color: rgba(138, 150, 189, 0.05);
}
.ul-list--sec-07 > li::before {
  background-color: #8a96bd;
}
.ul-list--sec-08 {
  background-color: rgba(168, 140, 184, 0.05);
}
.ul-list--sec-08 > li::before {
  background-color: #a88cb8;
}
.ul-list--sec-09 {
  background-color: rgba(200, 137, 169, 0.05);
}
.ul-list--sec-09 > li::before {
  background-color: #c889a9;
}
.ul-list--sec-10 {
  background-color: rgba(157, 141, 130, 0.05);
}
.ul-list--sec-10 > li::before {
  background-color: #9d8d82;
}
.ul-list--sec-11 {
  background-color: rgba(198, 164, 126, 0.05);
}
.ul-list--sec-11 > li::before {
  background-color: #c6a47e;
}
@media (min-width: 768px) {
  .ul-list--flex {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .ul-list--flex > li {
    width: 50%;
  }
}

.process--flex {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  gap: 1rem;
  padding-bottom: 3rem;
}
.process--flex::-webkit-scrollbar {
  display: none;
}
@media (min-width: 768px) {
  .process--flex {
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
  }
}
.process--flex > * {
  flex: 1;
}
@media (min-width: 768px) {
  .process--flex-2col .process--card {
    flex: none;
    width: calc(50% - 1rem);
  }
}
@media (min-width: 768px) {
  .process--flex-3col .process--card {
    flex: none;
    width: calc((100% - 6rem) / 3);
  }
}
.process--card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem;
  background: rgba(255, 255, 255, 0.5);
  box-shadow: 2px 2px 3px rgba(102, 102, 102, 0.1);
  flex: 0 0 90%;
  scroll-snap-align: center;
  border-top: 4px solid;
  border-top-color: rgba(198, 164, 126, 0.4);
}
.process--card strong {
  color: #c6a47e;
}
@media (min-width: 768px) {
  .process--card {
    flex: 1;
    scroll-snap-type: none;
  }
}
.process--card .process--num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.4rem;
  margin-bottom: 1rem;
  display: inline-block;
  color: #c6a47e;
  border-bottom: 1px solid #c6a47e;
}
.process--card .process--title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  margin-bottom: 1rem;
}
.process--card.home {
  border-top-color: rgba(138, 125, 112, 0.4);
}
.process--card.home .process--num {
  color: #8a7d70;
  border-bottom: 1px solid #8a7d70;
}
.process--card .process--title.home {
  color: #8a7d70;
}
.process--card.concept {
  border-top-color: rgba(226, 147, 142, 0.4);
}
.process--card.concept .process--num {
  color: #e2938e;
  border-bottom: 1px solid #e2938e;
}
.process--card .process--title.concept {
  color: #e2938e;
}
.process--card.os {
  border-top-color: rgba(224, 163, 106, 0.4);
}
.process--card.os .process--num {
  color: #e0a36a;
  border-bottom: 1px solid #e0a36a;
}
.process--card .process--title.os {
  color: #e0a36a;
}
.process--card.curriculum {
  border-top-color: rgba(217, 184, 92, 0.4);
}
.process--card.curriculum .process--num {
  color: #d9b85c;
  border-bottom: 1px solid #d9b85c;
}
.process--card .process--title.curriculum {
  color: #d9b85c;
}
.process--card.certification {
  border-top-color: rgba(163, 183, 122, 0.4);
}
.process--card.certification .process--num {
  color: #a3b77a;
  border-bottom: 1px solid #a3b77a;
}
.process--card .process--title.certification {
  color: #a3b77a;
}
.process--card.community {
  border-top-color: rgba(126, 184, 166, 0.4);
}
.process--card.community .process--num {
  color: #7eb8a6;
  border-bottom: 1px solid #7eb8a6;
}
.process--card .process--title.community {
  color: #7eb8a6;
}
.process--card.outputs {
  border-top-color: rgba(120, 169, 195, 0.4);
}
.process--card.outputs .process--num {
  color: #78a9c3;
  border-bottom: 1px solid #78a9c3;
}
.process--card .process--title.outputs {
  color: #78a9c3;
}
.process--card.practice {
  border-top-color: rgba(138, 150, 189, 0.4);
}
.process--card.practice .process--num {
  color: #8a96bd;
  border-bottom: 1px solid #8a96bd;
}
.process--card .process--title.practice {
  color: #8a96bd;
}
.process--card.service {
  border-top-color: rgba(168, 140, 184, 0.4);
}
.process--card.service .process--num {
  color: #a88cb8;
  border-bottom: 1px solid #a88cb8;
}
.process--card .process--title.service {
  color: #a88cb8;
}
.process--card.target {
  border-top-color: rgba(200, 137, 169, 0.4);
}
.process--card.target .process--num {
  color: #c889a9;
  border-bottom: 1px solid #c889a9;
}
.process--card .process--title.target {
  color: #c889a9;
}
.process--card.caution {
  border-top-color: rgba(157, 141, 130, 0.4);
}
.process--card.caution .process--num {
  color: #9d8d82;
  border-bottom: 1px solid #9d8d82;
}
.process--card .process--title.caution {
  color: #9d8d82;
}
.process--card.consultation {
  border-top-color: rgba(198, 164, 126, 0.4);
}
.process--card.consultation .process--num {
  color: #c6a47e;
  border-bottom: 1px solid #c6a47e;
}
.process--card .process--title.consultation {
  color: #c6a47e;
}
.process--card.sec-01 {
  border-top-color: rgba(226, 147, 142, 0.4);
}
.process--card.sec-01 .process--num {
  color: #e2938e;
  border-bottom: 1px solid #e2938e;
}
.process--card.sec-02 {
  border-top-color: rgba(224, 163, 106, 0.4);
}
.process--card.sec-02 .process--num {
  color: #e0a36a;
  border-bottom: 1px solid #e0a36a;
}
.process--card.sec-03 {
  border-top-color: rgba(217, 184, 92, 0.4);
}
.process--card.sec-03 .process--num {
  color: #d9b85c;
  border-bottom: 1px solid #d9b85c;
}
.process--card.sec-04 {
  border-top-color: rgba(163, 183, 122, 0.4);
}
.process--card.sec-04 .process--num {
  color: #a3b77a;
  border-bottom: 1px solid #a3b77a;
}
.process--card.sec-05 {
  border-top-color: rgba(126, 184, 166, 0.4);
}
.process--card.sec-05 .process--num {
  color: #7eb8a6;
  border-bottom: 1px solid #7eb8a6;
}
.process--card.sec-06 {
  border-top-color: rgba(120, 169, 195, 0.4);
}
.process--card.sec-06 .process--num {
  color: #78a9c3;
  border-bottom: 1px solid #78a9c3;
}
.process--card.sec-07 {
  border-top-color: rgba(138, 150, 189, 0.4);
}
.process--card.sec-07 .process--num {
  color: #8a96bd;
  border-bottom: 1px solid #8a96bd;
}
.process--card.sec-08 {
  border-top-color: rgba(168, 140, 184, 0.4);
}
.process--card.sec-08 .process--num {
  color: #a88cb8;
  border-bottom: 1px solid #a88cb8;
}
.process--card.sec-09 {
  border-top-color: rgba(200, 137, 169, 0.4);
}
.process--card.sec-09 .process--num {
  color: #c889a9;
  border-bottom: 1px solid #c889a9;
}
.process--card.sec-10 {
  border-top-color: rgba(157, 141, 130, 0.4);
}
.process--card.sec-10 .process--num {
  color: #9d8d82;
  border-bottom: 1px solid #9d8d82;
}
.process--card.sec-11 {
  border-top-color: rgba(198, 164, 126, 0.4);
}
.process--card.sec-11 .process--num {
  color: #c6a47e;
  border-bottom: 1px solid #c6a47e;
}
.process--header {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.process--body {
  flex: 1;
  font-size: 0.9rem;
  width: 100%;
}
.process--body.aleft {
  text-align: left;
}
.process--body.acenter {
  text-align: center;
}
@media (min-width: 768px) {
  .process--footer img {
    margin: 0 auto;
    max-width: 300px;
  }
}
@media (min-width: 768px) {
  .process--certification .process--card {
    flex: none;
    width: calc(50% - 1rem);
  }
}

.card {
  display: flex;
  flex-direction: column;
  gap: 3rem 2rem;
}
@media (min-width: 768px) {
  .card--2col {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .card--2col .card-row {
    width: calc(50% - 1rem);
  }
}
@media (min-width: 768px) {
  .card--4col {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .card--4col .card-row {
    width: calc(25% - 2rem);
  }
}
.card .card-row {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  padding: 3rem 1rem;
  box-shadow: 2px 2px 3px rgba(102, 102, 102, 0.1);
}
@media (min-width: 768px) {
  .card .card-row {
    padding: 2rem;
  }
}
.card .card-row .card-header {
  margin-bottom: 1rem;
}
.card .card-row .card-body {
  flex: 1;
}
.card .card-row.home {
  background-color: rgba(138, 125, 112, 0.05);
  border-top: 4px #8a7d70 solid;
}
.card .card-row.home .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #8a7d70;
  line-height: 1;
}
.card .card-row.concept {
  background-color: rgba(226, 147, 142, 0.05);
  border-top: 4px #e2938e solid;
}
.card .card-row.concept .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #e2938e;
  line-height: 1;
}
.card .card-row.os {
  background-color: rgba(224, 163, 106, 0.05);
  border-top: 4px #e0a36a solid;
}
.card .card-row.os .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #e0a36a;
  line-height: 1;
}
.card .card-row.curriculum {
  background-color: rgba(217, 184, 92, 0.05);
  border-top: 4px #d9b85c solid;
}
.card .card-row.curriculum .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #d9b85c;
  line-height: 1;
}
.card .card-row.certification {
  background-color: rgba(163, 183, 122, 0.05);
  border-top: 4px #a3b77a solid;
}
.card .card-row.certification .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #a3b77a;
  line-height: 1;
}
.card .card-row.community {
  background-color: rgba(126, 184, 166, 0.05);
  border-top: 4px #7eb8a6 solid;
}
.card .card-row.community .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #7eb8a6;
  line-height: 1;
}
.card .card-row.outputs {
  background-color: rgba(120, 169, 195, 0.05);
  border-top: 4px #78a9c3 solid;
}
.card .card-row.outputs .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #78a9c3;
  line-height: 1;
}
.card .card-row.practice {
  background-color: rgba(138, 150, 189, 0.05);
  border-top: 4px #8a96bd solid;
}
.card .card-row.practice .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #8a96bd;
  line-height: 1;
}
.card .card-row.service {
  background-color: rgba(168, 140, 184, 0.05);
  border-top: 4px #a88cb8 solid;
}
.card .card-row.service .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #a88cb8;
  line-height: 1;
}
.card .card-row.target {
  background-color: rgba(200, 137, 169, 0.05);
  border-top: 4px #c889a9 solid;
}
.card .card-row.target .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #c889a9;
  line-height: 1;
}
.card .card-row.caution {
  background-color: rgba(157, 141, 130, 0.05);
  border-top: 4px #9d8d82 solid;
}
.card .card-row.caution .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #9d8d82;
  line-height: 1;
}
.card .card-row.consultation {
  background-color: rgba(198, 164, 126, 0.05);
  border-top: 4px #c6a47e solid;
}
.card .card-row.consultation .card-num {
  font-family: "EB Garamond", "Yu Mincho", "游明朝", serif;
  font-style: italic;
  font-size: 2.2rem;
  color: #c6a47e;
  line-height: 1;
}

.ul-panel {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1rem;
  width: 100%;
}
@media (min-width: 768px) {
  .ul-panel {
    gap: 2rem;
  }
}
.ul-panel > li {
  width: calc((100% - 2rem) / 2);
}
@media (min-width: 768px) {
  .ul-panel > li {
    width: calc((100% - 8rem) / 5);
  }
}
.ul-panel > li > a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  font-size: 0.9rem;
  transition: 0.5s;
}
.ul-panel > li.home > a {
  background-color: #8a7d70;
}
.ul-panel > li.home > a:hover {
  background-color: rgb(150.168, 138, 125.832);
}
.ul-panel > li.concept > a {
  background-color: #e2938e;
}
.ul-panel > li.concept > a:hover {
  background-color: rgb(228.9, 157.8, 153.3);
}
.ul-panel > li.os > a {
  background-color: #e0a36a;
}
.ul-panel > li.os > a:hover {
  background-color: rgb(227.1, 172.2, 120.9);
}
.ul-panel > li.curriculum > a {
  background-color: #d9b85c;
}
.ul-panel > li.curriculum > a:hover {
  background-color: rgb(220.8, 191.1, 108.3);
}
.ul-panel > li.certification > a {
  background-color: #a3b77a;
}
.ul-panel > li.certification > a:hover {
  background-color: rgb(172.2, 190.2, 135.3);
}
.ul-panel > li.community > a {
  background-color: #7eb8a6;
}
.ul-panel > li.community > a:hover {
  background-color: rgb(138.9, 191.1, 174.9);
}
.ul-panel > li.outputs > a {
  background-color: #78a9c3;
}
.ul-panel > li.outputs > a:hover {
  background-color: rgb(133.5, 177.6, 201);
}
.ul-panel > li.practice > a {
  background-color: #8a96bd;
}
.ul-panel > li.practice > a:hover {
  background-color: rgb(149.7, 160.5, 195.6);
}
.ul-panel > li.service > a {
  background-color: #a88cb8;
}
.ul-panel > li.service > a:hover {
  background-color: rgb(176.7, 151.5, 191.1);
}
.ul-panel > li.target > a {
  background-color: #c889a9;
}
.ul-panel > li.target > a:hover {
  background-color: rgb(205.5, 148.8, 177.6);
}
.ul-panel > li.caution > a {
  background-color: #9d8d82;
}
.ul-panel > li.caution > a:hover {
  background-color: rgb(166.8, 152.4, 142.5);
}
.ul-panel > li.consultation > a {
  background-color: #c6a47e;
}
.ul-panel > li.consultation > a:hover {
  background-color: rgb(203.7, 173.1, 138.9);
}
.ul-panel > li.sec-01 > a {
  background-color: #e2938e;
}
.ul-panel > li.sec-01 > a:hover {
  background-color: rgb(228.9, 157.8, 153.3);
}
.ul-panel > li.sec-02 > a {
  background-color: #e0a36a;
}
.ul-panel > li.sec-02 > a:hover {
  background-color: rgb(227.1, 172.2, 120.9);
}
.ul-panel > li.sec-03 > a {
  background-color: #d9b85c;
}
.ul-panel > li.sec-03 > a:hover {
  background-color: rgb(220.8, 191.1, 108.3);
}
.ul-panel > li.sec-04 > a {
  background-color: #a3b77a;
}
.ul-panel > li.sec-04 > a:hover {
  background-color: rgb(172.2, 190.2, 135.3);
}
.ul-panel > li.sec-05 > a {
  background-color: #7eb8a6;
}
.ul-panel > li.sec-05 > a:hover {
  background-color: rgb(138.9, 191.1, 174.9);
}
.ul-panel > li.sec-06 > a {
  background-color: #78a9c3;
}
.ul-panel > li.sec-06 > a:hover {
  background-color: rgb(133.5, 177.6, 201);
}
.ul-panel > li.sec-07 > a {
  background-color: #8a96bd;
}
.ul-panel > li.sec-07 > a:hover {
  background-color: rgb(149.7, 160.5, 195.6);
}
.ul-panel > li.sec-08 > a {
  background-color: #a88cb8;
}
.ul-panel > li.sec-08 > a:hover {
  background-color: rgb(176.7, 151.5, 191.1);
}
.ul-panel > li.sec-09 > a {
  background-color: #c889a9;
}
.ul-panel > li.sec-09 > a:hover {
  background-color: rgb(205.5, 148.8, 177.6);
}
.ul-panel > li.sec-10 > a {
  background-color: #9d8d82;
}
.ul-panel > li.sec-10 > a:hover {
  background-color: rgb(166.8, 152.4, 142.5);
}
.ul-panel > li.sec-11 > a {
  background-color: #c6a47e;
}
.ul-panel > li.sec-11 > a:hover {
  background-color: rgb(203.7, 173.1, 138.9);
}

.flow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  margin-bottom: 3rem;
}
.flow--row {
  position: relative;
  padding: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 90%;
}
@media (min-width: 768px) {
  .flow--row {
    width: 33%;
  }
}
.flow--row:not(:last-child)::after {
  position: absolute;
  bottom: -2rem;
  left: 50%;
  transform: translateX(-50%);
  content: "▼";
  color: #7f8c8d;
}
.flow--row.sec-01 {
  background-color: #e2938e;
}
.flow--row.sec-01:hover {
  background-color: rgb(228.9, 157.8, 153.3);
}
.flow--row.sec-02 {
  background-color: #e0a36a;
}
.flow--row.sec-02:hover {
  background-color: rgb(227.1, 172.2, 120.9);
}
.flow--row.sec-03 {
  background-color: #d9b85c;
}
.flow--row.sec-03:hover {
  background-color: rgb(220.8, 191.1, 108.3);
}
.flow--row.sec-04 {
  background-color: #a3b77a;
}
.flow--row.sec-04:hover {
  background-color: rgb(172.2, 190.2, 135.3);
}
.flow--row.sec-05 {
  background-color: #7eb8a6;
}
.flow--row.sec-05:hover {
  background-color: rgb(138.9, 191.1, 174.9);
}
.flow--row.sec-06 {
  background-color: #78a9c3;
}
.flow--row.sec-06:hover {
  background-color: rgb(133.5, 177.6, 201);
}
.flow--row.sec-07 {
  background-color: #8a96bd;
}
.flow--row.sec-07:hover {
  background-color: rgb(149.7, 160.5, 195.6);
}
.flow--row.sec-08 {
  background-color: #a88cb8;
}
.flow--row.sec-08:hover {
  background-color: rgb(176.7, 151.5, 191.1);
}
.flow--row.sec-09 {
  background-color: #c889a9;
}
.flow--row.sec-09:hover {
  background-color: rgb(205.5, 148.8, 177.6);
}
.flow--row.sec-10 {
  background-color: #9d8d82;
}
.flow--row.sec-10:hover {
  background-color: rgb(166.8, 152.4, 142.5);
}
.flow--row.sec-11 {
  background-color: #c6a47e;
}
.flow--row.sec-11:hover {
  background-color: rgb(203.7, 173.1, 138.9);
}

.page {
  padding-top: 3rem;
}
.page--h1 {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  font-size: 3rem;
  color: #2c3e50;
}
.page--h1-en {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  text-transform: uppercase;
}
.page .ul-panel-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media (min-width: 768px) {
  .page .ul-panel-list {
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
  }
}
.page .ul-panel-list > li {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: #2c3e50;
  cursor: pointer;
  transition: 0.5s;
  padding: 1rem 0.5rem;
}
@media (min-width: 768px) {
  .page .ul-panel-list > li {
    aspect-ratio: 3/2;
    padding: auto;
  }
}
.page .ul-panel-list > li.sec-01 {
  background-color: #e2938e;
}
.page .ul-panel-list > li.sec-02 {
  background-color: #e0a36a;
}
.page .ul-panel-list > li.sec-03 {
  background-color: #d9b85c;
}
.page .ul-panel-list > li.sec-04 {
  background-color: #a3b77a;
}
.page .ul-panel-list > li.sec-05 {
  background-color: #7eb8a6;
}
.page .ul-panel-list > li.sec-06 {
  background-color: #78a9c3;
}
.page .ul-panel-list > li.sec-07 {
  background-color: #8a96bd;
}
.page .ul-panel-list > li.sec-08 {
  background-color: #a88cb8;
}
.page .ul-panel-list > li.sec-09 {
  background-color: #c889a9;
}
.page .ul-panel-list > li.sec-10 {
  background-color: #9d8d82;
}
.page .ul-panel-list > li.sec-11 {
  background-color: #c6a47e;
}
.page .ul-panel-list > li:hover {
  opacity: 0.8;
}
.page--catch {
  display: flex;
  flex-direction: column;
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS Serif", serif;
  color: #2c3e50;
  font-size: 5.8cqi;
  line-height: 2.2;
  margin-bottom: 3rem;
  padding: 0 1rem;
  border-left: 1px #c6a47e solid;
}
@media (min-width: 768px) {
  .page--catch {
    font-size: 2.2rem;
    padding: 0 2rem;
  }
}
.page--catch.sec-01 {
  border-left: 1px #e2938e solid;
}
.page--catch.sec-02 {
  border-left: 1px #e0a36a solid;
}
.page--catch.sec-03 {
  border-left: 1px #d9b85c solid;
}
.page--catch.sec-04 {
  border-left: 1px #a3b77a solid;
}
.page--catch.sec-05 {
  border-left: 1px #7eb8a6 solid;
}
.page--catch.sec-06 {
  border-left: 1px #78a9c3 solid;
}
.page--catch.sec-07 {
  border-left: 1px #8a96bd solid;
}
.page--catch.sec-08 {
  border-left: 1px #a88cb8 solid;
}
.page--catch.sec-09 {
  border-left: 1px #c889a9 solid;
}
.page--catch.sec-10 {
  border-left: 1px #9d8d82 solid;
}
.page--catch.sec-11 {
  border-left: 1px #c6a47e solid;
}

.breadcrumbs {
  padding: 1rem 0;
  font-size: 0.8rem;
  line-height: 1.2rem;
  color: #7f8c8d;
}
.breadcrumbs > ol {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.breadcrumbs > ol > li {
  position: relative;
  padding-left: 1rem;
}
.breadcrumbs > ol > li::before {
  position: absolute;
  content: " / ";
  left: 0;
}
.breadcrumbs > ol > li a {
  display: inline-block;
  transition: 0.5s;
  border-bottom: 1px #ccc dotted;
}
.breadcrumbs > ol > li a:hover {
  background-color: #ddd;
}

.ul-btn {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 2rem;
  padding: 1rem 0;
}
@media (min-width: 768px) {
  .ul-btn {
    flex-direction: row;
  }
}
.ul-btn--center {
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) {
  .ul-btn--right {
    justify-content: flex-end;
  }
}

.btn {
  display: flex;
  align-items: center;
  justify-content: center;
  outline-offset: -2px;
  outline: #fff 1px dashed;
  padding: 0.5rem 1rem;
  cursor: pointer;
  transition: 0.5s;
}
.btn--header {
  outline-offset: -2px;
  outline: #fff 1px dashed;
  background-color: #2c3e50;
  color: #ffffff;
  padding: 0.5rem 1rem;
  cursor: pointer;
  transition: 0.5s;
}
@media (min-width: 768px) {
  .btn--header {
    display: inline-block;
    padding: 0.25rem 1rem;
  }
}
.btn--header:hover {
  background-color: rgb(57.6967741935, 81.3, 104.9032258065);
}
.btn--primary {
  background-color: #2c3e50;
  color: #ffffff;
}
.btn--primary:hover {
  background-color: rgb(57.6967741935, 81.3, 104.9032258065);
}
.btn--secondary {
  background-color: #8a7d70;
  color: #ffffff;
}
.btn--secondary:hover {
  background-color: rgb(150.168, 138, 125.832);
}
.btn > .lucide:last-child {
  margin-left: 1rem;
}

/*# sourceMappingURL=main.css.map */
