.clr-r {
  color: #c32929;
}

/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

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

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
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] {
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 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 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none; /* 1 */
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit; /* 2 */
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

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

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

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

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

legend {
  padding: 0;
}

/**
 * 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;
}

/**
 * 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;
}

/**
 * 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. Fix font inheritance.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Fix appearance for Firefox
 */
[type=number] {
  -moz-appearance: textfield;
}

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

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

html {
  font-size: 62.5%; /* 16px * 0.625 = 10px */
}

body {
  font-family: "Noto Sans JP", ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
  font-size: 1.4rem;
  font-weight: 500;
  color: #1E1E26;
  background-color: #3F3277;
  overflow-x: hidden;
}
@media screen and (min-width: 1025px) {
  body {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 1025px), screen and (min-width: 768px) and (max-width: 1024px) {
  body {
    font-size: 1.6rem;
  }
}
body.is-modal-open {
  overflow-y: hidden;
  overflow-x: hidden;
  position: fixed;
  width: 100%;
}

h1 {
  font-size: 4.4rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  h1 {
    font-size: 3rem;
  }
}

h2 {
  font-size: 4.4rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  h2 {
    font-size: 3rem;
  }
}

h3 {
  font-size: 3.2rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  h3 {
    font-size: 2.4rem;
  }
}

h4 {
  font-size: 2.4rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  h4 {
    font-size: 1.8rem;
  }
}

h5 {
  font-size: 2rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  h5 {
    font-size: 1.6rem;
  }
}

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

a {
  transition: color 0.2s;
}
@media (any-hover: hover) {
  a:hover {
    color: #BED514;
  }
}

.inner {
  max-width: 1100px;
  width: 90%;
  margin: 0 auto;
}

.pc {
  display: block;
}
@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}
@media screen and (max-width: 767px), screen and (min-width: 768px) and (max-width: 1024px) {
  .pc {
    display: none;
  }
}

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

.tb-pc {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .tb-pc {
    display: block;
  }
}

.tb-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .tb-sp {
    display: block;
  }
}
@media screen and (max-width: 767px), screen and (min-width: 768px) and (max-width: 1024px) {
  .tb-sp {
    display: block;
  }
}

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

.br-inline ::before {
  content: " ";
}
@media screen and (min-width: 1366px) {
  .br-inline::before {
    content: "\a";
  }
}

.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 6rem;
  padding: 0.8rem 4rem;
  transition: background-color 0.3s ease, color 0.3s ease;
  z-index: 100;
  background-color: transparent;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .header {
    padding: 0.8rem 2.4rem;
  }
}
.header__logo {
  width: 100%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .header__logo {
    max-width: 30.1rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px), screen and (min-width: 1025px) {
  .header__logo {
    max-width: 30.1rem;
  }
}
@media screen and (max-width: 767px) {
  .header__logo {
    max-width: 20.3rem;
  }
}
.header__logo__svg {
  min-height: 6.5rem;
}
@media screen and (max-width: 767px) {
  .header__logo__svg {
    min-height: 4rem;
  }
}
.header__nav {
  width: 100%;
  max-width: 60rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-image: linear-gradient(180deg, #FCFCFC, #D5D5E3);
    color: #1E1E26;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    max-width: none;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-image: linear-gradient(180deg, #FCFCFC, #D5D5E3);
    color: #1E1E26;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    max-width: none;
  }
}
@media screen and (max-width: 767px) {
  .header__nav {
    flex-direction: column;
  }
}
.header__nav ul {
  display: flex;
  align-items: center;
  gap: 4rem;
  white-space: nowrap;
  flex-shrink: 0;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul {
    flex-direction: column;
    align-items: baseline;
    justify-content: center;
    margin: auto;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul {
    flex-direction: column;
    align-items: baseline;
    justify-content: center;
    margin: auto;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul {
    min-height: 20.6rem;
  }
}
.header__nav ul li {
  font-weight: 700;
  line-height: 1.25;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul li {
    width: 100%;
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul li {
    width: 100%;
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul li {
    display: block;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(1) {
    gap: 3rem;
    border-left: 0.1rem solid #271671;
    padding-left: 3rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul:nth-child(1) {
    gap: 3rem;
    border-left: 0.1rem solid #271671;
    padding-left: 3rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(1) {
    margin-right: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .header__nav ul:nth-child(1) {
    margin-bottom: 5rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(1) li:last-child {
    display: none;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul:nth-child(1) li:last-child {
    display: none;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(1) li a {
    line-height: 1;
    gap: 2.4rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul:nth-child(1) li a {
    line-height: 1;
    gap: 2.4rem;
  }
}
.header__nav ul:nth-child(1) li a > span.font-en {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(1) li a > span.font-en {
    display: inline-block;
    font-size: 1.2rem;
    color: #271671;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul:nth-child(1) li a > span.font-en {
    display: inline-block;
    font-size: 1.2rem;
    color: #271671;
  }
}
.header__nav ul:nth-child(2) {
  display: none !important;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(2) {
    display: flex !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav ul:nth-child(2) {
    display: flex !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav ul:nth-child(2) {
    flex-direction: column-reverse;
    margin-left: 5rem;
    width: 100%;
    max-width: 24.5rem;
  }
  .header__nav ul:nth-child(2) li:nth-child(2) > img {
    max-width: 22rem;
    min-height: 5.238rem;
  }
}
@media screen and (max-width: 767px) {
  .header__nav ul:nth-child(2) {
    margin-top: 5rem;
    width: 100%;
    max-width: 24rem;
  }
  .header__nav ul:nth-child(2) li:nth-child(2) {
    text-align: center;
  }
  .header__nav ul:nth-child(2) li:nth-child(2) > img {
    max-width: 18rem;
    min-height: 4.286rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .header__nav__sp li:nth-child(2) {
    max-width: 22rem;
  }
}
@media screen and (max-width: 767px) {
  .header__nav__sp li:nth-child(2) {
    max-width: 20.3rem;
    min-height: 4rem;
    margin: auto;
  }
}
.header__nav__sp li:nth-child(2) a img {
  width: 100%;
}
@media (any-hover: hover) {
  .header__nav__sp li:nth-child(2) a:hover {
    opacity: 0.6;
    transition: all 0.2s ease;
  }
}
.header__nav__btn {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__nav__btn {
    display: flex;
    gap: 1.6rem;
    align-items: center;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__nav__btn {
    display: flex;
    gap: 1.6rem;
    align-items: center;
  }
}
.header__hamburger {
  display: none;
  position: relative;
  z-index: 1001;
  background: transparent;
  border: none;
  cursor: pointer;
  width: 100%;
  max-width: 4.4rem;
  height: 100%;
  max-height: 4.4rem;
  padding: 1.4rem 1rem;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header__hamburger {
    display: block;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header__hamburger {
    display: block;
  }
}
.header__hamburger span {
  display: block;
  width: 2.4rem;
  height: 0.2rem;
  background-color: currentColor;
  transition: all 0.3s ease;
  position: relative;
  top: -0.2rem;
}
.header__hamburger span:not(:last-child) {
  margin-bottom: 0.6rem;
}

.header.is-scrolled {
  background-color: #fff;
  color: #1E1E26;
  filter: drop-shadow(0 0.3rem 0.6rem rgba(0, 0, 0, 0.16));
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header.is-scrolled .header__hamburger {
    color: #fff;
    border: 0.1rem solid #707070;
    border-radius: 50%;
    background-image: linear-gradient(270deg, #5B5B8D, #0F0F29);
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header.is-scrolled .header__hamburger {
    color: #fff;
    border: 0.1rem solid #707070;
    border-radius: 50%;
    background-image: linear-gradient(270deg, #5B5B8D, #0F0F29);
  }
}

@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header.is-open .header__nav {
    opacity: 1;
    visibility: visible;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header.is-open .header__nav {
    opacity: 1;
    visibility: visible;
  }
}
.header.is-open .header__hamburger {
  color: #fff;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header.is-open .header__hamburger {
    border: 0.1rem solid #707070;
    border-radius: 50%;
    background-image: linear-gradient(270deg, #5B5B8D, #0F0F29);
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header.is-open .header__hamburger {
    border: 0.1rem solid #707070;
    border-radius: 50%;
    background-image: linear-gradient(270deg, #5B5B8D, #0F0F29);
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .header.is-open .header__hamburger span:nth-child(1) {
    transform: translateY(0.8rem) rotate(45deg);
  }
  .header.is-open .header__hamburger span:nth-child(2) {
    opacity: 0;
  }
  .header.is-open .header__hamburger span:nth-child(3) {
    transform: translateY(-0.8rem) rotate(-45deg);
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px), screen and (max-width: 767px) {
  .header.is-open .header__hamburger span:nth-child(1) {
    transform: translateY(0.8rem) rotate(45deg);
  }
  .header.is-open .header__hamburger span:nth-child(2) {
    opacity: 0;
  }
  .header.is-open .header__hamburger span:nth-child(3) {
    transform: translateY(-0.8rem) rotate(-45deg);
  }
}

@media (any-hover: hover) {
  .header__logo a:hover {
    color: inherit;
    opacity: 0.6;
    transition: all 0.2s ease;
  }
}
@media (any-hover: hover) {
  .header .header__nav ul:not(.header__nav__sp) li:not(:last-child) a:hover {
    color: #fff;
    opacity: 0.6;
    transition: all 0.2s ease;
  }
}

@media (any-hover: hover) {
  .header.is-open .header__nav ul:not(.header__nav__sp) li:not(:last-child) a:hover,
  .header.is-scrolled .header__nav ul:not(.header__nav__sp) li:not(:last-child) a:hover {
    color: #1e1e26;
    opacity: 0.6;
    transition: all 0.2s ease;
  }
}

.header__logo__svg .cls-1 {
  fill: #3d843f;
}
.header__logo__svg .cls-2 {
  fill: #cd9f31;
}
.header__logo__svg .cls-3 {
  fill: #5f3670;
}
.header__logo__svg .cls-5 {
  fill: #aa1d33;
}

.header:not(.is-scrolled) .header__logo__svg .cls-4 {
  fill: #fff;
}

.header.is-scrolled .header__logo__svg .cls-4 {
  fill: #221815;
}

main {
  display: grid;
  position: relative;
}

main > .bg-circle-container,
main > .main__inner {
  grid-area: 1/1;
}

.main__inner {
  position: relative;
}

.bg-circle-container {
  position: fixed;
  width: 50vw;
  height: 100vh;
  top: 0;
  right: 0;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .bg-circle-container {
    width: 100%;
  }
}

.bg-circle {
  width: 100%;
  border-radius: 50%;
  filter: blur(5rem);
  position: absolute;
  transition: opacity 0.3s ease-out;
  opacity: 1;
}
.bg-circle--green {
  max-width: 49.2rem;
  min-height: 49.2rem;
  background-image: linear-gradient(20deg, rgba(137, 152, 140, 0.43), rgba(85, 229, 113, 0.43));
  top: -12.4rem;
  right: -12.4rem;
}
.bg-circle--yellow {
  max-width: 43.5rem;
  min-height: 43.5rem;
  background-image: linear-gradient(20deg, rgba(208, 205, 176, 0.43), rgba(213, 207, 69, 0.43));
  top: 1.46vw;
  right: 30rem;
}
.bg-circle--red {
  max-width: 42.9rem;
  min-height: 42.9rem;
  background-image: linear-gradient(20deg, rgba(203, 100, 136, 0.43), rgba(62, 44, 142, 0.43));
  top: 18.3vw;
  right: 5rem;
}

.section {
  padding: 10rem 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .section {
    padding: 6rem 0;
  }
}
.section__inner {
  max-width: 120rem;
  margin-right: auto;
  margin-left: auto;
  width: 91.2%;
}
.section__inner__ttl {
  line-height: 1.25;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .section__inner__ttl {
    margin-top: 1.2rem;
  }
}
.section__inner__sub-ttl {
  line-height: 1.25;
  padding-left: 3.2rem;
}
@media screen and (max-width: 767px) {
  .section__inner__sub-ttl {
    padding-left: 2.4rem;
  }
}
.section__inner__item {
  margin-top: 4.8rem;
  width: 100%;
  max-width: 120rem;
}
@media screen and (max-width: 767px) {
  .section__inner__item {
    margin-top: 3.2rem;
  }
}
.section-hero {
  width: 100%;
  min-height: 76.8rem;
  padding: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-hero {
    min-height: clamp(100.3rem, 14.2rem + 112.109vw, 129rem);
  }
}
@media screen and (max-width: 767px) {
  .section-hero {
    min-height: clamp(84.4rem, 41.79rem + 109.257vw, 125.59rem);
  }
}
.section-hero .section__inner {
  max-width: 136.6rem;
}
.section-hero .section__inner__txt-container {
  margin-right: auto;
  width: 100%;
  max-width: 34.2rem;
  display: flex;
  flex-direction: column;
  position: absolute;
}
@media screen and (min-width: 1025px) {
  .section-hero .section__inner__txt-container {
    width: clamp(48.6rem, -7.309rem + 54.545vw, 67.2rem);
    max-width: 67.2rem;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-hero .section__inner__txt-container {
    width: clamp(68.8rem, 73.6rem - 6.25vw, 67.2rem);
    max-width: 68.8rem;
    top: 14.65vw;
  }
}
@media screen and (max-width: 767px) {
  .section-hero .section__inner__txt-container {
    gap: 2.4rem;
    top: 9rem;
  }
}
.section-hero .section__inner__ttl {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 0;
}
@media screen and (min-width: 1025px) {
  .section-hero .section__inner__ttl {
    font-size: clamp(4.2rem, 2.72rem + 1.45vw, 4.8rem);
  }
}
@media screen and (max-width: 767px) {
  .section-hero .section__inner__ttl {
    margin-top: 0;
    font-size: 2.4rem;
    order: 2;
  }
}
.section-hero .section__inner__item {
  margin-top: 3rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .section-hero .section__inner__item {
    margin-top: 0;
    order: 3;
  }
}
.section-hero .section__inner__item > h5 {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .section-hero .section__inner__item > h5 {
    font-size: 1.4rem;
  }
}
.section-hero .section__inner__item.label--yellow {
  max-width: 29.2rem;
  font-size: 2.2rem;
  line-height: 1.636;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .section-hero .section__inner__item.label--yellow {
    max-width: 22.6rem;
    font-size: 1.6rem;
    order: 1;
  }
}
.section-hero .section__inner__item + .section__inner__item {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .section-hero .section__inner__item + .section__inner__item {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .section-lead .section__inner__item {
    width: 91.2%;
  }
}
.section-lead .section__inner__item__lead {
  line-height: 1.5;
}
.section-lead .section__inner__item p {
  font-size: 1.8rem;
  line-height: 2;
  margin-top: 4.2rem;
}
@media screen and (max-width: 767px) {
  .section-lead .section__inner__item p {
    font-size: 1.4rem;
    margin-top: 1.2rem;
  }
}
.section-lead--message {
  width: 100%;
  padding: 8.8rem 0;
}
.section-lead--message .section__inner {
  width: 100%;
  max-width: 136.6rem;
  min-height: clamp(58.7rem, 41.266rem + 17.009vw, 64.5rem);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--message .section__inner {
    min-height: clamp(69rem, 90.6rem - 28.125vw, 61.8rem);
  }
}
@media screen and (max-width: 767px) {
  .section-lead--message .section__inner {
    min-height: clamp(66.2rem, 62.062rem + 10.61vw, 70.2rem);
  }
}
.section-lead--message .section__inner__item {
  width: 59.3vw;
  max-width: 81rem;
  margin: 0 auto;
  text-align: center;
  padding: 4.8rem 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--message .section__inner__item {
    width: clamp(60.8rem, -16rem + 100vw, 86.4rem);
    max-width: 86.4rem;
    padding: 8rem 0;
  }
}
@media screen and (max-width: 767px) {
  .section-lead--message .section__inner__item {
    width: clamp(34.2rem, 14.028rem + 51.724vw, 53.7rem);
    max-width: 53.7rem;
    padding: clamp(16.8rem, 9.352rem + 19.098vw, 24rem) 0;
  }
}
.section-lead--message .section__inner__item p {
  white-space: pre-wrap;
}
.section-lead--concept {
  width: 100%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--concept .section__inner {
    min-height: clamp(134.9rem, 68.6rem + 86.328vw, 157rem);
  }
}
@media screen and (max-width: 767px) {
  .section-lead--concept .section__inner {
    min-height: clamp(91.2rem, 66.683rem + 62.865vw, 114.9rem);
  }
}
.section-lead--concept .section__inner__txt-container {
  max-width: clamp(48.5rem, 13.933rem + 33.724vw, 60rem);
  margin-left: auto;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--concept .section__inner__txt-container {
    max-width: none;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px), screen and (max-width: 767px) {
  .section-lead--concept .section__inner__txt-container {
    max-width: none;
  }
}
@media screen and (min-width: 1025px) {
  .section-lead--concept .section__inner__txt-container .section__inner__item {
    max-width: clamp(46.8rem, 7.123rem + 38.71vw, 60rem);
  }
}
@media screen and (max-width: 767px) {
  .section-lead--concept .section__inner__item {
    width: 100%;
  }
}

#concept.section {
  margin-top: -0.1rem;
}

.curve-divider {
  width: 100%;
  line-height: 0;
}
.curve-divider svg {
  width: 100%;
  height: auto;
}

.footer {
  background-color: #2A2A40;
  color: #fff;
  padding: 4rem 0 3rem;
}
@media screen and (max-width: 767px) {
  .footer {
    padding: 2.4rem 0;
  }
}
.footer__inner {
  width: 91.2%;
  max-width: 120rem;
  margin-right: auto;
  margin-left: auto;
}
.footer__inner__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .footer__inner__item {
    flex-direction: column;
  }
}
.footer__inner__item--blue {
  background-color: rgba(91, 91, 141, 0.25);
  padding: 2.4rem 8.13% 2.4rem 4rem;
}
@media screen and (max-width: 767px) {
  .footer__inner__item--blue {
    padding: 2rem 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .footer__inner__item--links {
    flex-direction: column-reverse;
    gap: 4rem;
  }
}
.footer__inner__item__txt {
  width: 100%;
  max-width: 50.4rem;
}
@media screen and (max-width: 767px) {
  .footer__inner__item__txt {
    max-width: none;
  }
}
.footer__inner__item__txt img {
  width: 100%;
  max-width: 30.1rem;
  min-height: 6.5rem;
}
@media screen and (max-width: 767px) {
  .footer__inner__item__txt img {
    max-width: 20.3rem;
    min-height: 4rem;
  }
}
@media (any-hover: hover) {
  .footer__inner__item__txt a:hover {
    opacity: 0.6;
    transition: all 0.2s ease;
  }
}
.footer__inner__item__txt__address {
  line-height: 1.75;
  padding-top: 1.6rem;
}
.footer__inner__item__txt__address p:nth-child(2), .footer__inner__item__txt__address p:nth-child(3), .footer__inner__item__txt__address p:nth-child(4) {
  display: flex;
}
.footer__inner__item__txt__address p:nth-child(2) span:first-child, .footer__inner__item__txt__address p:nth-child(3) span:first-child, .footer__inner__item__txt__address p:nth-child(4) span:first-child {
  width: 100%;
  max-width: 5.6rem;
}
.footer__inner__item__btn {
  width: 100%;
  max-width: 40rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .footer__inner__item__btn {
    padding-left: 4rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px), screen and (min-width: 1025px) {
  .footer__inner__item__btn {
    padding-left: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .footer__inner__item__btn {
    max-width: 24rem;
    margin-top: 2rem;
  }
}
.footer__inner__item__nav__list {
  display: flex;
  gap: 4rem;
  font-weight: 400;
  line-height: 1.25;
}
.footer__inner__item__nav:nth-child(2) {
  display: flex;
  gap: 4rem;
}
@media screen and (max-width: 767px) {
  .footer__inner__item__nav:nth-child(2) {
    flex-direction: column;
    gap: 2rem;
    align-items: center;
  }
}
.footer__inner__item + .footer__inner__item {
  margin-top: 2.4rem;
}
.footer__copyright {
  display: block;
  width: 100%;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  border-top: 0.1rem solid #fff;
  padding-top: 1.2rem;
  margin-top: 2.4rem;
}
@media screen and (max-width: 767px) {
  .footer__copyright {
    font-size: 1.2rem;
  }
}

.btn {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  text-decoration: none;
  font-weight: bold;
  transition: all 0.3s ease;
  gap: 0.7rem;
}
.btn__text {
  text-align: center;
}
.btn__icon {
  display: block;
  mask-image: url("../img/icon_external_link.svg");
  -webkit-mask-image: url("../img/icon_external_link.svg");
  mask-size: contain;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  background-color: currentColor;
}
.btn--middium {
  padding: 1.7rem 4rem;
  max-width: 24.5rem;
  min-height: 6rem;
}
@media screen and (max-width: 767px) {
  .btn--middium {
    padding: 1.2rem 4rem;
    max-width: 24rem;
    min-height: 4.4rem;
  }
}
.btn--middium .btn__text {
  font-size: 1.8rem;
  width: 100%;
  max-width: 16.5rem;
}
@media screen and (max-width: 767px) {
  .btn--middium .btn__text {
    font-size: 1.4rem;
    max-width: 16rem;
  }
}
.btn--small {
  padding: 0.7rem 2.4rem 0.9rem;
  width: 15.2rem;
  max-width: 15.2rem;
  min-height: 3.6rem;
}
.btn--small .btn__text {
  font-size: 1.4rem;
  line-height: 1.25;
  width: 100%;
  max-width: 8.4rem;
}
.btn--large {
  padding: 1.7rem 4rem;
  max-width: 40rem;
  min-height: 6rem;
}
@media screen and (max-width: 767px) {
  .btn--large {
    padding: 1.2rem 4rem;
    max-width: 24rem;
    min-height: 4.4rem;
  }
}
.btn--large .btn__text {
  font-size: 1.8rem;
  width: 100%;
  max-width: 32rem;
}
@media screen and (max-width: 767px) {
  .btn--large .btn__text {
    font-size: 1.4rem;
    max-width: 16rem;
  }
}
.btn__icon--16 {
  width: 100%;
  max-width: 1.6rem;
  height: 1.6rem;
}
.btn__icon--12 {
  width: 100%;
  max-width: 1.2rem;
  height: 1.2rem;
}
.btn--white {
  background-color: #fff;
  color: #1e1e26;
  border: 0.1rem solid #1e1e26;
}
@media (any-hover: hover) {
  .btn--white:hover {
    background-color: #efeffc;
  }
}
.btn--white-external {
  background-image: linear-gradient(270deg, #fff, #fff);
  color: #1E1E26;
  border: 0.1rem solid #1e1e26;
  padding-right: 2rem;
}
@media (any-hover: hover) {
  .btn--white-external:hover {
    background-image: linear-gradient(270deg, #E2F749, #BED514);
    color: #1E1E26;
  }
}
.btn--blue-external {
  background: linear-gradient(270deg, #5b5b8d, #0f0f29);
  color: #fff;
  border: 0.1rem solid #1e1e26;
  padding-right: 2rem;
}
@media (any-hover: hover) {
  .btn--blue-external:hover {
    background-image: linear-gradient(270deg, #e2f749, #bed514);
    color: #1e1e26;
  }
}
.btn--red-external {
  background: linear-gradient(270deg, #c32929, #6f0000);
  color: #fff;
  border: 0.1rem solid #6f0000;
  padding-right: 2rem;
}
@media (any-hover: hover) {
  .btn--red-external:hover {
    background-image: linear-gradient(270deg, #efeffc, #dedee8);
    color: #1e1e26;
    border: 0.1rem solid #EFEFFC;
  }
}
.btn--red-external-humburger {
  background: linear-gradient(270deg, #c32929, #6f0000);
  color: #fff;
  border: 0.1rem solid #6f0000;
  padding-right: 2rem;
}
@media (any-hover: hover) {
  .btn--red-external-humburger:hover {
    background-image: linear-gradient(270deg, #efeffc, #dedee8);
    color: #1e1e26;
    border: 0.1rem solid #1e1e26;
  }
}

.btn--close {
  display: block;
  position: relative;
  width: 100%;
  max-width: 4.4rem;
  height: 100%;
  max-height: 4.4rem;
  border: 0.1rem solid #707070;
  border-radius: 50%;
  background-image: linear-gradient(270deg, #5B5B8D, #0F0F29);
}
.btn--close::before, .btn--close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2.4rem;
  height: 0.2rem;
  background: #fff;
}
.btn--close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.btn--close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.btn-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 51rem;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .btn-group {
    flex-direction: column;
    gap: 1.2rem;
    max-width: 24rem;
  }
}
@media screen and (max-width: 767px), screen and (min-width: 768px) and (max-width: 1024px) {
  .btn-group {
    flex-direction: column;
    gap: 1.2rem;
    max-width: 24rem;
  }
}
.btn-group .btn {
  max-width: calc(50% - 1rem);
  flex-basis: auto;
}
@media screen and (max-width: 767px) {
  .btn-group .btn {
    max-width: none;
  }
}
@media screen and (max-width: 767px), screen and (min-width: 768px) and (max-width: 1024px) {
  .btn-group .btn {
    max-width: none;
  }
}
.btn-group--modal {
  width: 100%;
  max-width: 51.1rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .btn-group--modal {
    max-width: 24rem;
    flex-direction: column-reverse;
  }
}

.link-external {
  color: #fff;
}
.link-external::after {
  content: "";
  display: inline-block;
  width: 1.2rem;
  height: 1.2rem;
  margin-left: 0.4rem;
  vertical-align: middle;
  mask-image: url("../img/icon_external_link.svg");
  -webkit-mask-image: url("../img/icon_external_link.svg");
  mask-size: contain;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  background-color: currentColor;
}

.accordion__item {
  border-top: 0.1rem solid #C9C9D3;
  border-bottom: 0.1rem solid #C9C9D3;
  background-color: rgba(255, 255, 255, 0.9);
}
.accordion__item__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.6rem 3rem;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .accordion__item__head {
    padding: 1.6rem;
  }
}
.accordion__item__head__inner {
  display: flex;
  align-items: flex-start;
}
.accordion__item__head__inner__txt {
  line-height: 1.8;
  margin-top: auto;
  margin-bottom: auto;
}
@media screen and (max-width: 767px) {
  .accordion__item__head__inner__txt {
    line-height: 1.5;
  }
}
.accordion__item__head__arrow {
  width: 5.6rem;
  height: 5.6rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .accordion__item__head__arrow {
    width: 4.8rem;
    height: 4.8rem;
  }
}
.accordion__item__head__arrow span {
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  border-bottom: 3px solid #3F3177;
  border-right: 3px solid #3F3177;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  transition: transform 0.5s;
}
.accordion__item__head.is-active .accordion__item__head__arrow span {
  transform: translate(-50%, -50%) rotate(-135deg);
}
.accordion__item__body {
  display: none;
  position: relative;
  padding: 1.6rem 3rem;
  border-top: none;
}
@media screen and (max-width: 767px) {
  .accordion__item__body {
    padding: 1.6rem;
  }
}
.accordion__item__body::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  display: inline-block;
  width: 100%;
  max-width: 114rem;
  height: 0.1rem;
  background-color: #C9C9D3;
}
.accordion__item__body__inner {
  display: flex;
  width: 100%;
  max-width: 114rem;
  align-items: flex-start;
}
.accordion__item__body__inner__txt {
  line-height: 1.5;
  margin-top: auto;
  margin-bottom: auto;
}
.accordion__item + .accordion__item {
  margin-top: 2rem;
}

.modal {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 100;
  padding: 1rem;
}
.modal__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  cursor: pointer;
}
.modal__box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  width: 90%;
  height: 91.67%;
  max-width: 121.5rem;
  overflow-y: auto;
  display: grid;
  z-index: 200;
}
.modal__btn-wrap {
  position: sticky;
  bottom: 0;
  align-self: end;
  padding: 3rem;
  background-image: linear-gradient(0deg, #fff, transparent);
  text-align: center;
  z-index: 250;
}
@media screen and (max-width: 767px) {
  .modal__btn-wrap .btn--blue-external {
    transform: translateY(60px);
    transition: all 0.3s ease;
  }
  .modal__btn-wrap .btn--blue-external.is-visible {
    transform: translateY(0);
  }
  .modal__btn-wrap .btn--white {
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s ease;
  }
  .modal__btn-wrap .btn--white.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
}
.modal__close-btn {
  position: sticky;
  top: 1.6rem;
  right: 1.6rem;
  margin-left: auto;
  z-index: 200;
}
.modal__inner {
  padding-bottom: 12rem;
}
@media screen and (max-width: 767px) {
  .modal__inner {
    padding-bottom: 14.8rem;
  }
}
.modal__close-btn, .modal__btn-wrap, .modal__inner {
  grid-row: 1;
  grid-column: 1;
}
.modal__head {
  display: flex;
  padding: 3.2rem 8rem 3.2rem clamp(4rem, 5.8vw, 8rem);
  background-color: #F5F5F8;
  align-items: flex-start;
  justify-content: space-between;
  gap: 4rem;
}
@media screen and (max-width: 767px) {
  .modal__head {
    padding: 3rem 2.4rem;
    flex-direction: column;
    gap: 0;
  }
}
.modal__head__img-block {
  max-width: 33.2rem;
  object-fit: cover;
  object-position: top;
}
@media screen and (max-width: 767px) {
  .modal__head__img-block {
    margin: 2.4rem auto 0;
  }
}
.modal__head__img-block.op-b {
  object-position: bottom;
}
.modal__head__txt-block {
  width: 100%;
  max-width: 66.8rem;
}
.modal__head__ttl {
  font-size: 2.6rem;
  color: #281671;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .modal__head__ttl {
    font-size: 2.2rem;
    max-width: 25rem;
  }
}
.modal__head__detail {
  line-height: 1.5;
  margin-top: 1.6rem;
}
.modal__head__detail__place {
  margin-top: 0.4rem;
}
.modal__head__detail__curriculum, .modal__head__detail__place {
  display: flex;
  gap: 3rem;
}
@media screen and (max-width: 767px) {
  .modal__head__detail__curriculum, .modal__head__detail__place {
    gap: 2rem;
  }
}
.modal__head__detail__curriculum p:first-child, .modal__head__detail__place p:first-child {
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}
.modal__head__item {
  margin-top: 1.2rem;
}
.modal__head__item p {
  line-height: 1.5;
}
.modal__content {
  padding: 6rem clamp(4rem, 5.8vw, 8rem) 0;
}
@media screen and (max-width: 767px) {
  .modal__content {
    padding: 4rem 2.4rem 0;
  }
}
.modal__content__ttl {
  line-height: 1;
  padding-left: 3.2rem;
}
@media screen and (max-width: 767px) {
  .modal__content__ttl {
    font-size: 1.8rem;
    padding-left: 2.8rem;
  }
}
.modal__content__table {
  margin-top: 2.4rem;
}
.modal__content__speaker {
  padding: 2.4rem;
}
.modal__content__speaker__item {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .modal__content__speaker__item {
    flex-direction: column-reverse;
    gap: 2rem;
  }
}
.modal__content__speaker__item--gray {
  display: block;
  background-color: rgba(238, 238, 238, 0.6);
  padding: 1.6rem;
}
.modal__content__speaker__item__img {
  width: 100%;
  max-width: 12rem;
}
.modal__content__speaker__item__txt {
  padding-left: 2.4rem;
}
@media screen and (max-width: 767px) {
  .modal__content__speaker__item__txt {
    padding-left: 0;
    margin-right: auto;
  }
}
.modal__content__speaker__item .index {
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .modal__content__speaker__item .index {
    font-size: 2rem;
  }
}
.modal__content__speaker__item .name {
  line-height: 2;
  padding-top: 2.4rem;
}
@media screen and (max-width: 767px) {
  .modal__content__speaker__item .name {
    padding-top: 1.6rem;
  }
}
.modal__content__speaker__item .name div {
  display: flex;
  gap: 4rem;
}
@media screen and (max-width: 767px) {
  .modal__content__speaker__item .name div {
    flex-direction: column;
    gap: 0;
  }
}
.modal__content__speaker__item .txt {
  font-size: 1.4rem;
  line-height: 2;
  padding-top: 1.6rem;
}
.modal__content__speaker__item + .modal__content__speaker__item {
  margin-top: 1.6rem;
}
@media screen and (max-width: 767px) {
  .modal__content__speaker__item + .modal__content__speaker__item {
    margin-top: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .modal__content .card--grid {
    padding: 2rem;
  }
}
.modal__head + .modal__content {
  padding-top: 4rem;
}

@media screen and (max-width: 767px) {
  table, tbody, tr, td, th {
    width: 100%;
    display: block;
  }
}
.table {
  width: 100%;
  border-top: 1px solid #C9C9D3;
  border-bottom: 1px solid #C9C9D3;
}
.table tr + tr {
  border-top: 1px solid #C9C9D3;
}
.table th {
  width: 30%;
  max-width: 31.2rem;
  height: 8.46%;
  padding: 1.6rem;
  vertical-align: middle;
  background-color: #F5F5F8;
}
@media screen and (max-width: 767px) {
  .table th {
    width: 100%;
    max-width: none;
  }
}
.table td {
  width: 70%;
  padding: 1.6rem;
  font-size: 1.4rem;
  line-height: 1.75;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
  .table td {
    width: 100%;
    padding-bottom: 2.4rem;
  }
}
.table__list {
  text-indent: -1.6rem;
  padding-left: 1.6rem;
}
.table__sub-list {
  margin-left: 1.4rem;
  padding-left: 0;
}
.table__sub-list li {
  position: relative;
  text-indent: -1.6rem;
  padding-left: 1.6rem;
}
.table__sub-list li::before {
  content: "-";
  width: 100%;
  max-width: 1.6rem;
  display: inline-block;
  text-indent: 0;
}
.table__schedule {
  display: flex;
  align-items: baseline;
}
.table__schedule .icon {
  padding: 0.2rem 1.3rem 0.2rem 1rem;
  background: linear-gradient(270deg, #2A2A40, #404062, #2A2A40);
  color: #fff;
  font-weight: 700;
  align-items: center;
}
.table__schedule .icon .day {
  font-size: 1.2rem;
  line-height: 1.167;
}
.table__schedule .icon .num {
  font-size: 1.6rem;
  line-height: 1;
  padding-left: 0.5rem;
}
.table__schedule .date {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
  padding-left: 0.6rem;
}
.table__ttl {
  font-weight: 500;
  line-height: 1.5;
}
.table__schedule + .table__ttl {
  padding-top: 0.8rem;
}

.ttl-circle {
  position: relative;
}
.ttl-circle::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto 0;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  border: 0.2rem solid #A38F20;
}
@media screen and (max-width: 767px) {
  .ttl-circle::before {
    width: 1.6rem;
    height: 1.6rem;
  }
}
.ttl-circle--yellow::before {
  background-color: #FFC84B;
}
.ttl-circle--green::before {
  background-color: #2AB266;
}
.ttl-circle--red::before {
  background-color: #F74251;
}
.ttl-circle--blue::before {
  background-color: #4663C6;
}

.icon-point {
  width: 100%;
  max-width: 10.6rem;
  padding: 0.3rem 1.2rem;
  background: linear-gradient(270deg, #2A2A40, #404062, #2A2A40);
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .icon-point {
    max-width: 10rem;
  }
}
.icon-point .point {
  font-size: 1.6rem;
  line-height: 1.25;
}
@media screen and (max-width: 767px) {
  .icon-point .point {
    font-size: 1.4rem;
  }
}
.icon-point .num {
  line-height: 1;
  padding-left: 0.8rem;
}

.icon-faq {
  position: relative;
  width: 5.6rem;
  height: 5.6rem;
  margin-right: 2rem;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .icon-faq {
    width: 4rem;
    height: 4rem;
    margin-right: 1.2rem;
  }
}
.icon-faq::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Mulish", sans-serif;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .icon-faq::before {
    font-size: 2.4rem;
  }
}
.icon-faq--q {
  background-color: #3F3178;
}
.icon-faq--q::before {
  content: "Q";
  color: #fff;
}
.icon-faq--a {
  background-color: #E2DEF5;
}
.icon-faq--a::before {
  content: "A";
  color: #3F3178;
}

.icon-external--12 {
  flex-shrink: 0;
  z-index: 1;
  mask-image: url("../img/icon_external_link.svg");
  -webkit-mask-image: url("../img/icon_external_link.svg");
  mask-size: contain;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  background-color: currentColor;
  color: currentColor;
  text-indent: 100%;
  overflow: hidden;
  width: 100%;
  max-width: 1.2rem;
  min-height: 1.2rem;
}
.icon-external--16 {
  flex-shrink: 0;
  z-index: 1;
  mask-image: url("../img/icon_external_link.svg");
  -webkit-mask-image: url("../img/icon_external_link.svg");
  mask-size: contain;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  background-color: currentColor;
  color: currentColor;
  text-indent: 100%;
  overflow: hidden;
  width: 100%;
  max-width: 1.6rem;
  min-height: 1.6rem;
}

a {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  flex-wrap: nowrap;
}

.label--yellow {
  background-image: linear-gradient(180deg, #D2DD7F, #D8F400);
  padding: 0.4rem 2.4rem;
  color: #1E1E26;
}

.icon-free {
  font-size: 1.2rem;
  line-height: 1.5;
}
.icon-free__main {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.icon-free__main div {
  width: 100%;
  max-width: 5.2rem;
  min-height: 2.4rem;
  text-align: center;
  background-color: #8641E5;
  border: 0.1rem solid #8641E5;
  border-radius: 0.4rem;
  padding: 0.2rem 1.1rem;
}
.icon-free__main div span {
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.icon-free__main span {
  color: #8641E5;
}
.icon-free__note {
  color: #666666;
  margin-top: 0.4rem;
}

.list-style {
  list-style: none;
}
.list-style li {
  position: relative;
  padding-left: 1.8rem;
  line-height: 1.5;
}
.list-style li::before {
  content: "";
  position: absolute;
  top: 0.8rem;
  left: 0;
  width: 100%;
  max-width: 0.6rem;
  height: 100%;
  max-height: 0.6rem;
  border-radius: 50%;
  background-color: #A38F20;
}
.list-style li + li {
  margin-top: 1.2rem;
}

.card-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4.39vw;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .card-list {
    justify-content: center;
    grid-template-columns: 1fr;
    gap: 3rem;
  }
}

.card {
  color: #1E1E26;
}
.card--curriculum {
  width: auto;
  min-height: 72rem;
  padding: 3rem;
  background-color: rgba(255, 255, 255, 0.9019607843);
  border: 0.1rem solid #C9C9D3;
}
@media screen and (max-width: 767px) {
  .card--curriculum {
    width: 100%;
    min-height: auto;
    padding: 2.4rem;
  }
}
.card--grid {
  background-image: linear-gradient(#EFEFF4 0.1rem, transparent 0.1rem), linear-gradient(to right, #EFEFF4 0.1rem, transparent 0.1rem);
  background-size: 2rem 2rem;
  background-color: #fff;
  background-position: -1.4rem 1.4rem;
  border: 0.1rem solid #C9C9D3;
  padding: 4rem;
}
@media screen and (max-width: 767px) {
  .card--grid {
    padding: 2.4rem 2.4rem 2.87rem;
  }
}
.card--grid + .card--grid {
  margin-top: 3.05rem;
}
.card__inner {
  display: flex;
}
.card__inner--2col {
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .card__inner--2col {
    flex-direction: column-reverse;
    align-items: center;
  }
}
.card__inner--2col__img {
  width: 100%;
  max-width: 24rem;
}
@media screen and (max-width: 767px) {
  .card__inner--2col__img {
    max-width: 34.2rem;
  }
}
.card__inner--2col__txt-block {
  padding-left: 4rem;
}
@media screen and (max-width: 767px) {
  .card__inner--2col__txt-block {
    padding-left: 0;
    padding-bottom: 2.4rem;
  }
}
.card__inner--2col__txt-block__ttl {
  line-height: 1.25;
}
.card__inner--2col__txt-block__txt {
  line-height: 2;
  padding-top: 2.4rem;
}
@media screen and (max-width: 767px) {
  .card__inner--2col__txt-block__txt {
    padding-top: 1.2rem;
  }
}
.card__inner--2col__txt-block h4 + h4 {
  padding-top: 2.4rem;
}
@media screen and (max-width: 767px) {
  .card__inner--2col__txt-block h4 + h4 {
    padding-top: 2rem;
  }
}
.card__inner--row {
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}
.card__inner--row__img {
  margin-left: auto;
  margin-right: auto;
}
.card__inner--row__img img {
  max-width: 51rem;
  aspect-ratio: 510/180;
  object-fit: cover;
  object-position: top;
}
.card__inner--row__img.op-b img {
  object-position: bottom;
}
.card__inner__ttl {
  line-height: 1.5;
  margin-top: 2rem;
}
.card__inner__txt {
  margin-top: 1.2rem;
}
.card__inner__txt p {
  line-height: 1.5;
}
.card__inner__txt p + p {
  margin-top: 0.4rem;
}
.card__inner__list {
  width: 100%;
  max-width: 49.3rem;
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .card__inner__list {
    max-width: none;
  }
}
.card__inner__btn {
  margin-top: auto;
}
@media screen and (max-width: 767px) {
  .card__inner__btn {
    margin-top: 2.4rem;
  }
}
@media screen and (max-width: 767px), screen and (min-width: 768px) and (max-width: 1024px) {
  .card__inner__btn {
    margin-top: 2.4rem;
  }
}

.section-color--blue {
  color: #fff;
}
.section-color--white {
  background-color: rgba(255, 255, 255, 0.9);
}
.section-color--white .section__inner__ttl {
  color: #281671;
}
.section-color--silver {
  background-image: radial-gradient(ellipse, #FCFCFC, #D5D5E3);
}
.section-color--silver .section__inner__ttl {
  color: #281671;
}

.section-hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  background-image: linear-gradient(180deg, #1A2540, transparent);
  z-index: -2;
}
.section-hero__img span {
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  transform: translateZ(0);
}
.section-hero__img span:nth-child(1) {
  background-image: url("../img/hero_miyagi.svg");
  width: 57.27vw;
  max-width: 78.2rem;
  aspect-ratio: 782/863;
  top: 0;
  right: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-hero__img span:nth-child(1) {
    width: 79.98vw;
    max-width: 81.9rem;
    aspect-ratio: 819/908;
    top: 39rem;
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  .section-hero__img span:nth-child(1) {
    width: 102.43vw;
    max-width: 78.567rem;
    aspect-ratio: 785.67/891.32;
    top: 36.3rem;
    left: clamp(-4.38rem, 0.006rem - 11.247vw, -8.62rem);
  }
}
@media screen and (min-width: 1920px) {
  .section-hero__img span:nth-child(1) {
    right: 50%;
    transform: translateX(100%);
  }
}
.section-hero__img span:nth-child(2) {
  background-image: url("../img/hero_sangakukan.png");
  background-image: url("../img/hero_sangakukan.webp");
  width: 46.83vw;
  max-width: 54.8rem;
  aspect-ratio: 1410/1548;
  top: 16rem;
  right: 3rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-hero__img span:nth-child(2) {
    width: 56.05vw;
    max-width: 57.4rem;
    top: clamp(51.6rem, 38.4rem + 17.187vw, 56rem);
    right: 2.93%;
  }
}
@media screen and (max-width: 767px) {
  .section-hero__img span:nth-child(2) {
    width: 70.4vw;
    max-width: 54rem;
    min-width: 32.6rem;
    top: 42.3rem;
    right: 2.4rem;
  }
}
@media screen and (min-width: 1920px) {
  .section-hero__img span:nth-child(2) {
    right: calc(50% - 30rem);
    transform: translateX(100%);
  }
}

.section-lead--message .section__inner {
  position: relative;
}
.section-lead--message .section__inner__bg {
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.section-lead--message .section__inner__bg--ring {
  background-image: url("../img/message_ring.svg");
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 102.4rem;
  min-height: 58.6rem;
}
@media screen and (max-width: 767px) {
  .section-lead--message .section__inner__bg--ring {
    background-image: url("../img/message_ring_sp.svg");
    min-height: 72.2rem;
  }
}
.section-lead--message .section__inner__bg--city {
  background-image: url("../img/message_city@2x.jpg");
  top: 0;
  left: 0;
}
.section-lead--message .section__inner__bg--speaker {
  background-image: url("../img/message_speaker@2x.jpg");
  top: 21.55%;
  right: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--message .section__inner__bg--speaker {
    top: auto;
    bottom: 5.86vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px), screen and (max-width: 767px) {
  .section-lead--message .section__inner__bg--speaker {
    top: auto;
    bottom: 5.86vw;
  }
}
.section-lead--message .section__inner__bg--conversation {
  background-image: url("../img/message_conversation@2x.jpg");
  bottom: 0;
  left: 33.75%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--message .section__inner__bg--conversation {
    left: 7.81vw;
  }
}
@media screen and (max-width: 767px) {
  .section-lead--message .section__inner__bg--conversation {
    left: 5.22vw;
  }
}
.section-lead--message .section__inner__bg--city, .section-lead--message .section__inner__bg--speaker, .section-lead--message .section__inner__bg--conversation {
  width: clamp(20rem, 1.965rem + 17.595vw, 26rem);
  max-width: 26rem;
  aspect-ratio: 260/130;
  filter: drop-shadow(0.3rem 0.3rem 2rem rgba(0, 0, 0, 0.4));
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--message .section__inner__bg--city, .section-lead--message .section__inner__bg--speaker, .section-lead--message .section__inner__bg--conversation {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .section-lead--message .section__inner__bg--city, .section-lead--message .section__inner__bg--speaker, .section-lead--message .section__inner__bg--conversation {
    width: clamp(12rem, 3.724rem + 21.22vw, 20rem);
    max-width: 20rem;
  }
}
.section-lead--message .section__inner__item {
  position: relative;
  z-index: 1;
}
.section-lead--message .section__inner__item::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%/54.38%;
  background-color: rgba(0, 0, 0, 0.2);
  filter: blur(5rem);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .section-lead--message .section__inner__item::before {
    height: auto;
    min-height: 40.3rem;
  }
}
.section-lead--concept {
  background-image: radial-gradient(ellipse 70% 45%, #FCFCFC, #D5D5E3);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.section-lead--concept::before {
  content: "";
  background-image: url("../img/concept_date-masamune@2x.png");
  width: 100%;
  max-width: 144rem;
  aspect-ratio: 1366/862;
  position: absolute;
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: left bottom;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .section-lead--concept::before {
    background-image: url("../img/concept_date-masamune_sp@2x.png");
    aspect-ratio: 1024/1024;
    background-size: contain;
    background-position: center;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px), screen and (max-width: 767px) {
  .section-lead--concept::before {
    background-image: url("../img/concept_date-masamune_sp@2x.png");
    aspect-ratio: 1024/1024;
    background-size: contain;
    background-position: center;
  }
}
@media screen and (min-width: 1920px) {
  .section-lead--concept::before {
    left: 50%;
    transform: translateX(-50%);
  }
}
.section-lead--concept .section__inner {
  position: relative;
}
.section-lead--concept .section__inner__ttl {
  color: #281671;
}

.font-en {
  font-family: "Mulish", sans-serif;
}
