@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap");
*,
*::before,
*::after {
  box-sizing: border-box;
}

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

ul[role=list],
ol[role=list] {
  list-style: none;
}

html:focus-within {
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  line-height: 1.5;
  text-rendering: optimizeSpeed;
}

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

img,
picture {
  display: block;
  max-width: 100%;
}

input,
button,
textarea,
select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
ul {
  margin: 0;
  padding: 0;
}
ul li {
  margin: 0;
  padding: 0;
  list-style: none;
}

@font-face {
  font-family: "iec-icons";
  font-style: normal;
  font-weight: normal;
  src: url("../fonts/iec-icons.eot?7q9k2t");
  src: url("../fonts/iec-icons.eot?7q9k2t#iefix") format("embedded-opentype"), url("../fonts/iec-icons.ttf?7q9k2t") format("truetype"), url("../fonts/iec-icons.woff?7q9k2t") format("woff"), url("../fonts/iec-icons.svg?7q9k2t#iec-icons") format("svg");
  font-display: block;
}
.form--textfield button::before, .form--textfield button, .form--select::before, .recommend::before, .recommend::after, .link__plan::after, .list__check li::before, .btn__toggle::after, .btn__disabled::after, .btn__outline::after, .btn__main::after, .btn::after, .carousel__ctrl--btn::after, .footer--totop::after, .header--nav ul li a.header--nav--mypage::after, [class^=icon-]::before,
[class*=" icon-"]::before {
  display: inline-flex;
  align-self: center;
  text-transform: none;
  font-family: "iec-icons" !important;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  line-height: inherit;
  speak: never;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

[class^=icon-],
[class*=" icon-"] {
  display: inline-flex;
}
[class^=icon-]::before,
[class*=" icon-"]::before {
  padding-right: 0.5em;
}
.__r[class^=icon-],
.__r[class*=" icon-"] {
  flex-direction: row-reverse;
}
.__r[class^=icon-]::before,
.__r[class*=" icon-"]::before {
  padding-right: 0;
  padding-left: 0.5em;
}

.icon-1:before {
  font-weight: bold;
  content: "\e900";
}

.icon-2:before {
  content: "\e901";
}

.icon-3:before {
  content: "\e902";
}

.icon-4:before {
  content: "\e903";
}

.icon-5:before {
  content: "\e904";
}

.icon-6:before {
  content: "\e905";
}

.icon-7:before {
  content: "\e906";
}

.icon-8:before {
  content: "\e907";
}

.icon-9:before {
  content: "\e908";
}

.icon-10:before {
  content: "\e909";
}

.link {
  background: -webkit-linear-gradient(0deg, #ff3895, #3c0b21);
  -webkit-background-clip: text;
          background-clip: text;
  color: #3c0b21;
  -webkit-text-fill-color: transparent;
}

.l--kv h1 {
  background: none;
  background-clip: unset;
  color: inherit;
  -webkit-text-fill-color: #fff;
}

html,
body {
  font-size: 16px;
  min-height: 100%;
  width: 100%;
  color: #2a3d52;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  line-height: 1.8em;
  scroll-behavior: unset;
}
@media (max-width: 560px) {
  html,
  body {
    font-size: 3.84vw;
  }
}

body {
  position: relative;
  background-color: #fff;
}
body a {
  color: #2a3d52;
  text-decoration: none;
}
body a:hover {
  text-decoration: underline;
}
body p,
body dd {
  margin: 0 0 1.2em 0;
  padding: 0;
  letter-spacing: 0.1em;
  line-height: 1.9em;
}
body dd {
  font-size: 14px;
}
@media (max-width: 560px) {
  body dd {
    font-size: 3.36vw;
  }
}
body p,
body li {
  font-size: 16px;
}
@media (max-width: 560px) {
  body p,
  body li {
    font-size: 3.84vw;
  }
}
body ol li {
  margin-bottom: 1em;
}
body big {
  font-size: 1.4em;
  font-weight: bold;
}
body p a,
body li a {
  text-decoration: underline;
}
body p a:hover,
body li a:hover {
  text-decoration: none;
}
body .__hide {
  display: none !important;
}

/* Layout */
body {
  position: relative;
  min-height: 100vh;
}

header,
footer,
main {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

main {
  overflow: hidden;
  margin-top: 60px;
}
main section {
  margin: 0 auto 100px auto;
}
main article {
  margin: 0 auto 100px auto;
  padding-bottom: 1px;
  max-width: 1000px;
  width: 100%;
}
@media screen and (max-width: 768px) {
  main article {
    margin-bottom: 50px;
    padding: 20px;
    max-width: none;
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  main article.l--box {
    padding: 55px 25px;
    border-radius: 0;
  }
}
main article.mb__half {
  margin-bottom: 75px;
}

.l--sec--blue, .l--sec--light, .l--sec {
  margin-bottom: 100px;
  padding: 100px 0;
  max-width: none;
}
@media screen and (max-width: 560px) {
  .l--sec--blue, .l--sec--light, .l--sec {
    padding: 2em 0;
  }
}
.l--sec--blue article, .l--sec--light article, .l--sec article {
  margin-bottom: 0;
}

.l--box__narrow, .l--box {
  margin-bottom: 30px;
  padding: 55px;
  border-radius: 15px;
  background-color: #f5f6f8;
}
@media screen and (max-width: 560px) {
  .l--box__narrow, .l--box {
    padding: 25px;
  }
}

.l--kv {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin: 0 0 80px 0;
  height: 300px;
  background-color: #ff3895;
  background-position: 50% 50%;
  background-size: cover;
  background-repeat: no-repeat;
}
.l--kv h1 {
  margin-bottom: 0;
  color: #fff;
  -webkit-text-fill-color: inherit;
}
.l--sec__mb0 {
  margin-bottom: 0;
}
.l--sec__large_break {
  margin-bottom: 150px;
}
.l--sec--light {
  background-color: #f5f6f8;
}
.l--inner_large {
  margin: 0 auto;
  padding-right: 15px;
  padding-left: 15px;
  max-width: 1200px;
  width: 100%;
}
.l--inner_wide {
  margin: 0 auto;
  max-width: 760px;
  width: 100%;
}
.l--inner {
  margin: 0 auto;
  max-width: 670px;
  width: 100%;
}
.l--inner_narrow {
  margin: 0 auto;
  max-width: 400px;
  width: 100%;
}
.l--cols__center {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.l--cols__center > * {
  width: 100%;
}
.l--box .l--box {
  background-color: #fff;
}
.l--box__narrow {
  padding: 2em;
}
.l--toggle {
  display: none;
  opacity: 0;
}
.l--toggle.show {
  display: block;
  animation-name: toggle_show;
  animation-duration: 0.5s;
  animation-timing-function: cubic-bezier(0.12, 0.33, 0.53, 0.85);
  animation-delay: 0.2s;
  animation-fill-mode: forwards;
}
.l--plan_toggle {
  display: none;
  opacity: 0;
}
.l--plan_toggle.show {
  display: block;
  animation-name: toggle_show;
  animation-duration: 0.5s;
  animation-timing-function: cubic-bezier(0.12, 0.33, 0.53, 0.85);
  animation-delay: 0.2s;
  animation-fill-mode: forwards;
}

@keyframes toggle_show {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.wp-video {
  width: 100% !important;
}
.wp-video video {
  width: 100% !important;
  height: auto !important;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 200;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  background-color: #000;
  transition: all 0.4s cubic-bezier(0.12, 0.91, 0.51, 1);
}
.header.hide {
  transform: translateY(-100%);
}
.header > section {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  height: 60px;
}
.header a {
  color: #fff;
  text-decoration: none;
  transition: filter 0.2s ease-out;
}
.header a:hover {
  filter: brightness(110%);
}
.header--logo {
  position: relative;
  z-index: 201;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  width: 23em;
}
.header--logo img {
  max-width: 230px;
  width: 100%;
}
.header--logo a {
  display: flex;
  align-items: center;
  justify-content: center;
}
.header--logo a span {
  display: block;
  padding-left: 2em;
  letter-spacing: 0.2em;
  font-weight: bold;
  line-height: 1.5em;
}
@media screen and (max-width: 560px) {
  .header--logo a span {
    padding-left: 1em;
    letter-spacing: 0.1em;
    font-size: 3.5vw;
  }
}
@media screen and (max-width: 560px) {
  .header--logo img {
    width: calc(100vw - 6em - 60px - 15px);
  }
}
.header--nav {
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: flex-end;
}
.header--nav--toggle-button {
  position: relative;
  z-index: 251;
  display: none !important;
  width: 60px;
  height: 60px;
}
@media screen and (max-width: 768px) {
  .header--nav--toggle-button {
    display: flex !important;
  }
}
.header--nav--toggle-button a {
  width: 60px;
}
.header--nav--toggle-button a span {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 40%;
  height: 2px;
  background-color: #fff;
  transition: all 0.2s;
  transform: translateX(-50%);
}
.header--nav--toggle-button a span:first-child {
  top: 37%;
}
.header--nav--toggle-button a span:last-child {
  top: 63%;
}
.header--nav ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0 60px;
  margin: 0;
  padding: 0;
  list-style: none;
  transition: all 0.2s ease-out;
}
@media screen and (max-width: 960px) {
  .header--nav ul {
    gap: 0 40px;
  }
}
@media screen and (max-width: 768px) {
  .header--nav ul {
    display: none;
  }
}
.header--nav ul li {
  display: block;
}
.header--nav ul li a {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.15em;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.2s ease-out;
}
.header--nav ul li a.header--nav--mypage {
  position: relative;
  padding: 0.2em 2em 0.2em 1em;
  border: 1px solid #fff;
  font-size: 0.9em;
  transition: all 0.1s ease-out;
}
.header--nav ul li a.header--nav--mypage:hover {
  background-color: #fff;
  color: #000;
}
.header--nav ul li a.header--nav--mypage small {
  display: inline-block;
  margin-right: 0.2em;
  font-size: 0.8em;
}
.header--nav ul li a.header--nav--mypage::after {
  content: "\e901";
  position: absolute;
  top: 50%;
  right: 0.6em;
  font-size: 0.8em;
  transform: translateY(-50%);
}

@media screen and (max-width: 768px) {
  .menu-open .header--nav ul {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 199;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
  }
  .menu-open .header--nav ul::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
    background-color: #000;
    animation: anim_nav_main_wrap 0.5s cubic-bezier(0.12, 0.91, 0.51, 1) 0s forwards;
    pointer-events: none;
  }
  .menu-open .header--nav ul li {
    display: block;
    padding: 1em 0;
    opacity: 0;
  }
  .menu-open .header--nav ul li:nth-child(1) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.06s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(2) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.12s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(3) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.18s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(4) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.24s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(5) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.3s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(6) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.36s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(7) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.42s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(8) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.48s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(9) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.54s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li:nth-child(10) {
    animation: anim_nav_main_list 1.2s cubic-bezier(0.12, 0.91, 0.51, 1) calc(0.6s + 0.3s) forwards;
  }
  .menu-open .header--nav ul li a {
    padding-top: 0.4em;
    padding-bottom: 0.4em;
    color: #fff;
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) and (max-width: 560px) {
  .menu-open .header--nav ul li a {
    font-size: 5vw;
  }
}
@media screen and (max-width: 768px) {
  .menu-open .header--nav ul li a.link--uline__white {
    background-position: left 90%;
    background-size: 0 2px;
  }
  .menu-open .header--nav ul li a.link--uline__white:hover {
    background-size: 100% 2px;
  }
  .menu-open .header--nav--toggle-button a {
    background-color: transparent;
  }
  .menu-open .header--nav--toggle-button a span {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    width: 40%;
    height: 2px;
    background-color: #fff;
    transition: all 0.2s;
  }
  .menu-open .header--nav--toggle-button a span:first-child {
    top: 53%;
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
  }
  .menu-open .header--nav--toggle-button a span:nth-child(2) {
    opacity: 0;
  }
  .menu-open .header--nav--toggle-button a span:last-child {
    bottom: 48%;
    transform: translateX(-50%) translateY(50%) rotate(-45deg);
  }
}

@keyframes anim_nav_main_wrap {
  0% {
    height: 0;
    opacity: 0.5;
  }
  100% {
    height: 100%;
    opacity: 1;
  }
}
@keyframes anim_nav_main_list {
  0% {
    opacity: 0;
    transform: translateY(1em);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.footer {
  position: sticky;
  top: 100vh;
}
.footer--main {
  position: relative;
  padding: 1.5em 0;
  background-color: #000;
  color: #ffffff;
  transition: all 0.2s ease-out;
}
.footer--main article {
  margin: 0 auto;
  max-width: 1000px;
}
.footer--main a {
  transition: all 0.2s ease-out;
}
.footer--main a:hover {
  text-decoration: underline;
}
.footer--main ul {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  margin: 0 0 1.5em 0;
  padding: 0 0 0 0;
}
@media screen and (max-width: 768px) {
  .footer--main ul {
    flex-direction: column;
    text-align: center;
  }
}
.footer--main ul,
.footer--main ul li {
  list-style: none;
}
.footer--main ul li {
  font-size: 14px;
  display: inline-block;
  margin: 0 1em 0 0;
  padding: 0 1em 0 0;
  border-right: 1px solid rgb(255, 255, 255);
}
@media (max-width: 560px) {
  .footer--main ul li {
    font-size: 3.36vw;
  }
}
@media screen and (max-width: 768px) {
  .footer--main ul li {
    margin: 0 auto;
    border-right: none;
  }
}
.footer--main ul li:last-child {
  border-right: none;
}
.footer--main ul a {
  padding: 0 0 0.3em 0;
  color: #ffffff;
  text-decoration: none;
  letter-spacing: 0.1em;
  line-height: 1.3em;
}
.footer--main--copy {
  margin: 0 0 0 0;
  padding: 0 15px;
  text-align: center;
  letter-spacing: 0.12em;
  font-size: 0.8rem;
}
.footer--totop {
  position: absolute;
  top: -2em;
  right: 2em;
  z-index: 1000;
  display: block;
  width: 70px;
  height: 70px;
  background-color: #f5f6f8;
  box-shadow: 4px 4px 10px 0 rgba(0, 0, 0, 0.3);
  opacity: 1;
  cursor: pointer;
  transition: all 0.2s ease-out;
}
@media screen and (max-width: 768px) {
  .footer--totop {
    top: -1.75em;
    width: 52.5px;
    height: 52.5px;
  }
}
.footer--totop.is-show {
  visibility: visible;
  opacity: 1;
}
.footer--totop:hover {
  background-color: #fff;
}
.footer--totop:hover::after {
  transform: translateY(-5px);
}
.footer--totop::after {
  content: "\e902";
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  margin: -0.5em 0 0 -0.5em;
  width: 0;
  height: 0;
  font-size: 35px;
  transition: all 0.2s ease-out;
}
@media screen and (max-width: 768px) {
  .footer--totop::after {
    font-size: 28px;
  }
}

.swiper {
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
.swiper.show {
  opacity: 1;
}
.swiper-wrapper {
  transition-timing-function: cubic-bezier(0.5, 0.1, 0.5, 0.9);
}

.carousel__ctrl--btn {
  position: absolute;
  top: 50%;
  z-index: 3;
  width: 70px;
  height: 70px;
  background: rgba(42, 61, 82, 0.2);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  color: #fff;
  cursor: pointer;
  transition: all 0.3s ease-out;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .carousel__ctrl--btn {
    display: none;
  }
}
.carousel__ctrl--btn:hover {
  background: rgba(42, 61, 82, 0.7);
}
.carousel__ctrl--btn::after {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size: 1.7em;
  transform: translate(-50%, -50%);
}
.carousel__ctrl--btn.__next {
  right: -100px;
}
@media screen and (max-width: 1200px) {
  .carousel__ctrl--btn.__next {
    right: 0;
  }
}
.carousel__ctrl--btn.__next::after {
  content: "\e901";
}
.carousel__ctrl--btn.__prev {
  left: -100px;
}
@media screen and (max-width: 1200px) {
  .carousel__ctrl--btn.__prev {
    left: 0;
  }
}
.carousel__ctrl--btn.__prev::after {
  content: "\e900";
}

.modal .overlay {
  transition: all 0.55s ease-out;
}
.modal--open {
  overflow: hidden;
}
.modal--active {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
}
.modal--active .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
}
.modal--active .overlay > article {
  position: absolute;
  top: 50%;
  left: 50%;
  padding: 50px 15px;
  max-height: 80vh;
  background-color: #f5f6f8;
  overflow-y: auto;
  visibility: hidden;
  opacity: 0;
  animation-name: modal_open;
  animation-duration: 0.4s;
  animation-timing-function: cubic-bezier(0.5, 0.1, 0.5, 0.9);
  animation-delay: 0.25s;
  animation-fill-mode: forwards;
}
.modal--active .modal--close {
  display: block;
  position: absolute;
  top: -30px;
  right: 0;
  width: 30px;
  height: 30px;
  background-color: #000;
}
.modal--close {
  display: none;
  cursor: pointer;
}

@keyframes modal_open {
  0% {
    opacity: 0;
    visibility: visible;
    transform: scale(0.95) translate(-52.5%, -52.5%);
  }
  100% {
    opacity: 1;
    visibility: visible;
    transform: scale(1) translate(-50%, -50%);
  }
}
/* Object */
h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  margin-bottom: 2em;
  color: #ff3895;
  letter-spacing: 0.1em;
  font-weight: 700;
  line-height: 1.5em;
}
h1.__dark,
h2.__dark,
h3.__dark,
h4.__dark,
h5.__dark,
h6.__dark {
  margin-bottom: 1em;
  color: #2a3d52;
}
h1.__dark small,
h2.__dark small,
h3.__dark small,
h4.__dark small,
h5.__dark small,
h6.__dark small {
  margin-bottom: 0.2em;
}
h1.__s,
h2.__s,
h3.__s,
h4.__s,
h5.__s,
h6.__s {
  margin-bottom: 0.5em;
  font-weight: 400;
  font-size: 24px;
}
@media (max-width: 560px) {
  h1.__s,
  h2.__s,
  h3.__s,
  h4.__s,
  h5.__s,
  h6.__s {
    font-size: 5.76vw;
  }
}
h1 small,
h2 small,
h3 small,
h4 small,
h5 small,
h6 small {
  display: block;
  margin-bottom: 0.8em;
  letter-spacing: 0.06em;
  font-size: 0.85rem;
}
h1 em,
h2 em,
h3 em,
h4 em,
h5 em,
h6 em {
  display: inline-block;
  margin-left: 1em;
  font-style: normal;
  font-size: 0.7em;
  font-weight: 700;
}

h1 {
  margin-bottom: 1em;
  font-size: 36px;
}
@media (max-width: 560px) {
  h1 {
    font-size: 8.64vw;
  }
}

h2 {
  margin-bottom: 1.5em;
  font-size: 36px;
}
@media (max-width: 560px) {
  h2 {
    font-size: 6vw;
  }
}

h3 {
  font-size: 24px;
}
@media (max-width: 560px) {
  h3 {
    font-size: 5.76vw;
  }
}

h4 {
  margin-bottom: 1em;
  font-size: 20px;
}
@media (max-width: 560px) {
  h4 {
    font-size: 4.8vw;
  }
}

h5 {
  margin-bottom: 1em;
  font-size: 18px;
}
@media (max-width: 560px) {
  h5 {
    font-size: 4.32vw;
  }
}

h6 {
  margin-bottom: 0.6em;
  color: #2a3d52;
  font-size: 16px;
}
@media (max-width: 560px) {
  h6 {
    font-size: 3.84vw;
  }
}

.article--head > article .article--tags li {
  font-size: 16px;
}
@media (max-width: 560px) {
  .article--head > article .article--tags li {
    font-size: 3.84vw;
  }
}

.h--section {
  margin: 2em 0 1em 0;
  padding: 0.5em 1em;
  background-color: #2a3d52;
  color: #fff;
  text-align: center;
}

.btn__toggle, .btn__disabled, .btn__outline, .btn__main, .btn {
  position: relative;
  display: block;
  padding: 1em 0;
  max-width: 25rem;
  width: 100%;
  background-color: #2a3d52;
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  color: #fff;
  text-align: center;
  text-decoration: none;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1.3em;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.12, 0.91, 0.51, 1);
}
@media screen and (max-width: 560px) {
  .btn__toggle, .btn__disabled, .btn__outline, .btn__main, .btn {
    max-width: none;
    width: 100%;
  }
}
.btn__toggle:hover, .btn__disabled:hover, .btn__outline:hover, .btn__main:hover, .btn:hover {
  box-shadow: 0 3px 5px 0 rgba(0, 0, 0, 0.25);
  transform: scale(1.02);
}
.btn__toggle:active, .btn__disabled:active, .btn__outline:active, .btn__main:active, .btn:active {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  transform: scale(1);
}
.btn__toggle::after, .btn__disabled::after, .btn__outline::after, .btn__main::after, .btn::after {
  content: "\e901";
  position: absolute;
  top: 50%;
  right: 1em;
  font-size: 1em;
  transition: all 0.4s cubic-bezier(0.12, 0.91, 0.51, 1);
  transform: translateY(-50%);
}
.btn__toggle, .btn__outline {
  padding: 1em 0;
  border: 1px solid #2a3d52;
  background-color: transparent;
  color: #2a3d52;
  font-size: 1rem;
}
.btn__toggle:hover, .btn__outline:hover {
  background-color: #2a3d52;
  box-shadow: none;
  color: #fff;
  transform: scale(1);
}
.btn__toggle:active, .btn__outline:active {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  transform: scale(1);
}

.btn__disabled {
  padding: 1em 0;
  border: none;
  background-color: #989898;
  color: #f5f6f8;
  font-size: 1rem;
  cursor: not-allowed;
}
.btn__disabled:hover {
  background-color: #989898;
  box-shadow: none;
  color: #f5f6f8;
  transform: scale(1);
}
.btn__disabled:active {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  transform: scale(1);
}
.btn__disabled::after {
  display: none;
}

.btn {
  text-decoration: none;
}
.btn__main {
  background-color: #ff3895;
}
.btn__outline {
  border-radius: 999px;
}
@media screen and (max-width: 768px) {
  .btn__outline {
    border: none;
    background-color: #979ea8;
    color: #fff;
  }
}
.btn__toggle {
  border-radius: 15px;
}
.btn__toggle::after {
  content: "\e903";
}
.btn__toggle .__hide {
  display: none;
}

.card--course {
  display: block;
  margin-bottom: 0.8em;
  transition: all 0.3s cubic-bezier(0.5, 0.1, 0.5, 0.9);
}
.card--course:hover {
  filter: brightness(110%);
}
.card--course figure {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16/8.5;
}
.card--course figure img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
  height: 100%;
  transition: all 0.3s cubic-bezier(0.5, 0.1, 0.5, 0.9);
}

.article--head > article .article--tags, .tags {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.4rem 0.5rem;
}
.article--head > article .article--tags > *, .tags > * {
  align-self: stretch;
}

.tags a {
  display: block;
  padding: 0.2em 1em;
  border: 1px solid #989898;
  border-radius: 999px;
  color: #989898;
  text-decoration: none;
  font-size: 0.7rem;
  line-height: 1.7em;
  transition: all 0.3s cubic-bezier(0.12, 0.91, 0.51, 1);
}
.tags a::before {
  content: "#";
  display: inline-block;
  margin-right: 2px;
}
.tags a:hover {
  background-color: rgba(152, 152, 152, 0.1);
}
.tags span {
  display: block;
  color: #989898;
  text-decoration: none;
  font-size: 0.7rem;
  line-height: 1.4em;
  transition: all 0.3s cubic-bezier(0.12, 0.91, 0.51, 1);
}
.tags span::before {
  content: "#";
  display: inline-block;
  margin-right: 2px;
}

.list__check, .list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.list__check li, .list li {
  margin-bottom: 0.75em;
}

.list__check {
  margin-bottom: 2em;
}
.list__check li {
  position: relative;
  padding-left: 2em;
  line-height: 1.5em;
}
.list__check li::before {
  content: "\e909";
  position: absolute;
  top: 0%;
  left: 0;
  font-size: 1.5em;
}
.list__disc {
  margin-left: 1em;
}
.list__disc li {
  margin-bottom: 0.5em;
  list-style: disc;
  line-height: 1.5em;
}

.link {
  position: relative;
  display: inline-block;
  cursor: pointer;
}
.link__plan {
  position: relative;
  display: inline-block;
  padding-right: 1.5em;
  color: #ff3895;
  text-decoration: none;
  letter-spacing: 0;
  font-size: 0.9em;
  font-weight: bold;
}
.link__plan:hover {
  text-decoration: underline;
}
.link__plan::after {
  content: "\e901";
  position: absolute;
  top: 50%;
  right: 0;
  font-size: 1.2em;
  transition: all 0.4s cubic-bezier(0.12, 0.91, 0.51, 1);
  transform: translateY(-50%);
}
.color__blue {
  color: #ff3895;
}
.color__green {
  color: #3c0b21;
}
.color__plan_personal {
  color: #ce0cd0;
}

.bg_color__gray {
  background-color: #f5f6f8;
}

.voice {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 50px;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 768px) {
  .voice {
    gap: 0 20px;
    margin-bottom: 1rem;
    padding: 20px 15px;
  }
}
.voice figure {
  overflow: hidden;
  width: 60px;
  aspect-ratio: 1;
}
@media screen and (max-width: 768px) {
  .voice figure {
    width: 40px;
  }
}
.voice figure img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  border-radius: 999px;
}
.voice--text {
  flex: 1;
}
.voice--text__profile {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .voice--text__profile {
    flex-direction: column;
  }
}
.voice--text__profile li {
  display: block;
  font-size: 0.8em;
  line-height: 1.6em;
}

.recommend {
  position: relative;
  padding: 60px 2em;
}
.recommend::before, .recommend::after {
  position: absolute;
  color: #ff3895;
  font-size: 50px;
  pointer-events: none;
}
.recommend::before {
  content: "\e907";
  top: -12.5px;
  left: 12.5px;
}
.recommend::after {
  content: "\e908";
  right: 12.5px;
  bottom: -12.5px;
}
@media screen and (max-width: 768px) {
  .recommend::after {
    display: none;
  }
}
.recommend dt {
  margin-bottom: 0.6em;
  min-height: 3em;
  text-align: center;
  font-weight: bold;
  line-height: 1.4em;
  font-size: 24px;
}
@media (max-width: 560px) {
  .recommend dt {
    font-size: 5.76vw;
  }
}
/* Form */
.form--search {
  display: block;
  padding: 90px 0;
}
.form--search article {
  margin-bottom: 0;
}
.form--search h3 {
  font-size: 1.8em;
}
@media screen and (max-width: 768px) {
  .form--search h3 {
    font-size: 1.5em;
  }
}
.form--search p.sp {
  margin-bottom: 0.5em;
}
.form--search button {
  border: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
@media screen and (max-width: 768px) {
  .form--search button {
    font-size: 1.19rem;
  }
}
.form--select {
  position: relative;
  display: block;
  margin-bottom: 0.5rem;
  width: 100%;
}
.form--select::before {
  content: "\e903";
  position: absolute;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  font-size: 1.3em;
  pointer-events: none;
}
.form--select select {
  padding: 1rem 3.6em 1rem 1em;
  width: 100%;
  height: 4rem;
  border: none;
  background-color: #fff;
  color: #2a3d52;
  font-size: 1.4rem;
  font-weight: bold;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.form--select select:focus {
  outline: none;
}
@media screen and (max-width: 768px) {
  .form--select select {
    font-size: 1.19rem;
  }
}
.form--textfield {
  position: relative;
  display: block;
  margin-bottom: 0.5rem;
  width: 100%;
}
.form--textfield input[type=text] {
  display: block;
  padding: 0 0 0 1em;
  width: 100%;
  height: 4rem;
  border: 1px solid #2a3d52;
  background-color: #fff;
  font-size: 1.4rem;
  transition: all 0.1s ease-out;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.form--textfield input[type=text]:focus, .form--textfield input[type=text]:hover {
  outline: none;
  background-color: rgba(42, 61, 82, 0.02);
}
.form--textfield input[type=text]::-webkit-input-placeholder {
  color: #c5c5c5;
}
.form--textfield button {
  content: "\e903";
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  border: none;
  background-color: #2a3d52;
  color: #fff;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.form--textfield button::before {
  content: "\e904";
  font-size: 1.3em;
  font-size: 2.4rem;
  pointer-events: none;
}

/* Utility */
@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
}

.img {
  width: 100%;
}

.align--left {
  text-align: left;
}
.align--center {
  text-align: center;
}
.align--right {
  text-align: right;
}
@media screen and (max-width: 560px) {
  .align--center p, .align--right p, .align--sp--left p {
    text-align: left;
  }
}
@media screen and (max-width: 560px) {
  .align--sp--left {
    text-align: left !important;
  }
}
@media screen and (max-width: 560px) {
  .align--sp--center {
    text-align: center !important;
  }
}

.block--center {
  margin-right: auto;
  margin-left: auto;
}

.fs__l {
  font-size: 1.2em;
}
.fs__l-ps::before, .fs__l-ps::after {
  font-size: 1.3em;
}
.fs__s {
  font-size: 0.8em;
}
.fs__s-ps::before, .fs__s-ps::after {
  font-size: 0.8em;
}

sup,
sub {
  font-size: 0.6rem;
}

.notes {
  letter-spacing: 0;
  font-size: 0.7rem;
}

.dis {
  opacity: 0.4 !important;
  pointer-events: none;
}

.mt-0 {
  margin-top: 0px !important;
}

.ml-0 {
  margin-left: 0px !important;
}

.mb-0 {
  margin-bottom: 0px !important;
}

.mr-0 {
  margin-right: 0px !important;
}

.pt-0 {
  padding-top: 0px !important;
}

.pl-0 {
  padding-left: 0px !important;
}

.pb-0 {
  padding-bottom: 0px !important;
}

.pr-0 {
  padding-right: 0px !important;
}

.mt-0em__min {
  margin-top: 0em !important;
}

.ml-0em__min {
  margin-left: 0em !important;
}

.mb-0em__min {
  margin-bottom: 0em !important;
}

.mr-0em__min {
  margin-right: 0em !important;
}

.pt-0em__min {
  padding-top: 0em !important;
}

.pl-0em__min {
  padding-left: 0em !important;
}

.pb-0em__min {
  padding-bottom: 0em !important;
}

.pr-0em__min {
  padding-right: 0em !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.ml-10 {
  margin-left: 10px !important;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.mr-10 {
  margin-right: 10px !important;
}

.pt-10 {
  padding-top: 10px !important;
}

.pl-10 {
  padding-left: 10px !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.pr-10 {
  padding-right: 10px !important;
}

.mt-1em__min {
  margin-top: 0.2em !important;
}

.ml-1em__min {
  margin-left: 0.2em !important;
}

.mb-1em__min {
  margin-bottom: 0.2em !important;
}

.mr-1em__min {
  margin-right: 0.2em !important;
}

.pt-1em__min {
  padding-top: 0.2em !important;
}

.pl-1em__min {
  padding-left: 0.2em !important;
}

.pb-1em__min {
  padding-bottom: 0.2em !important;
}

.pr-1em__min {
  padding-right: 0.2em !important;
}

.mt-20 {
  margin-top: 20px !important;
}

.ml-20 {
  margin-left: 20px !important;
}

.mb-20 {
  margin-bottom: 20px !important;
}

.mr-20 {
  margin-right: 20px !important;
}

.pt-20 {
  padding-top: 20px !important;
}

.pl-20 {
  padding-left: 20px !important;
}

.pb-20 {
  padding-bottom: 20px !important;
}

.pr-20 {
  padding-right: 20px !important;
}

.mt-2em__min {
  margin-top: 0.4em !important;
}

.ml-2em__min {
  margin-left: 0.4em !important;
}

.mb-2em__min {
  margin-bottom: 0.4em !important;
}

.mr-2em__min {
  margin-right: 0.4em !important;
}

.pt-2em__min {
  padding-top: 0.4em !important;
}

.pl-2em__min {
  padding-left: 0.4em !important;
}

.pb-2em__min {
  padding-bottom: 0.4em !important;
}

.pr-2em__min {
  padding-right: 0.4em !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.ml-30 {
  margin-left: 30px !important;
}

.mb-30 {
  margin-bottom: 30px !important;
}

.mr-30 {
  margin-right: 30px !important;
}

.pt-30 {
  padding-top: 30px !important;
}

.pl-30 {
  padding-left: 30px !important;
}

.pb-30 {
  padding-bottom: 30px !important;
}

.pr-30 {
  padding-right: 30px !important;
}

.mt-3em__min {
  margin-top: 0.6em !important;
}

.ml-3em__min {
  margin-left: 0.6em !important;
}

.mb-3em__min {
  margin-bottom: 0.6em !important;
}

.mr-3em__min {
  margin-right: 0.6em !important;
}

.pt-3em__min {
  padding-top: 0.6em !important;
}

.pl-3em__min {
  padding-left: 0.6em !important;
}

.pb-3em__min {
  padding-bottom: 0.6em !important;
}

.pr-3em__min {
  padding-right: 0.6em !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.ml-40 {
  margin-left: 40px !important;
}

.mb-40 {
  margin-bottom: 40px !important;
}

.mr-40 {
  margin-right: 40px !important;
}

.pt-40 {
  padding-top: 40px !important;
}

.pl-40 {
  padding-left: 40px !important;
}

.pb-40 {
  padding-bottom: 40px !important;
}

.pr-40 {
  padding-right: 40px !important;
}

.mt-4em__min {
  margin-top: 0.8em !important;
}

.ml-4em__min {
  margin-left: 0.8em !important;
}

.mb-4em__min {
  margin-bottom: 0.8em !important;
}

.mr-4em__min {
  margin-right: 0.8em !important;
}

.pt-4em__min {
  padding-top: 0.8em !important;
}

.pl-4em__min {
  padding-left: 0.8em !important;
}

.pb-4em__min {
  padding-bottom: 0.8em !important;
}

.pr-4em__min {
  padding-right: 0.8em !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.ml-50 {
  margin-left: 50px !important;
}

.mb-50 {
  margin-bottom: 50px !important;
}

.mr-50 {
  margin-right: 50px !important;
}

.pt-50 {
  padding-top: 50px !important;
}

.pl-50 {
  padding-left: 50px !important;
}

.pb-50 {
  padding-bottom: 50px !important;
}

.pr-50 {
  padding-right: 50px !important;
}

.mt-5em__min {
  margin-top: 1em !important;
}

.ml-5em__min {
  margin-left: 1em !important;
}

.mb-5em__min {
  margin-bottom: 1em !important;
}

.mr-5em__min {
  margin-right: 1em !important;
}

.pt-5em__min {
  padding-top: 1em !important;
}

.pl-5em__min {
  padding-left: 1em !important;
}

.pb-5em__min {
  padding-bottom: 1em !important;
}

.pr-5em__min {
  padding-right: 1em !important;
}

.mt-60 {
  margin-top: 60px !important;
}

.ml-60 {
  margin-left: 60px !important;
}

.mb-60 {
  margin-bottom: 60px !important;
}

.mr-60 {
  margin-right: 60px !important;
}

.pt-60 {
  padding-top: 60px !important;
}

.pl-60 {
  padding-left: 60px !important;
}

.pb-60 {
  padding-bottom: 60px !important;
}

.pr-60 {
  padding-right: 60px !important;
}

.mt-6em__min {
  margin-top: 1.2em !important;
}

.ml-6em__min {
  margin-left: 1.2em !important;
}

.mb-6em__min {
  margin-bottom: 1.2em !important;
}

.mr-6em__min {
  margin-right: 1.2em !important;
}

.pt-6em__min {
  padding-top: 1.2em !important;
}

.pl-6em__min {
  padding-left: 1.2em !important;
}

.pb-6em__min {
  padding-bottom: 1.2em !important;
}

.pr-6em__min {
  padding-right: 1.2em !important;
}

.mt-70 {
  margin-top: 70px !important;
}

.ml-70 {
  margin-left: 70px !important;
}

.mb-70 {
  margin-bottom: 70px !important;
}

.mr-70 {
  margin-right: 70px !important;
}

.pt-70 {
  padding-top: 70px !important;
}

.pl-70 {
  padding-left: 70px !important;
}

.pb-70 {
  padding-bottom: 70px !important;
}

.pr-70 {
  padding-right: 70px !important;
}

.mt-7em__min {
  margin-top: 1.4em !important;
}

.ml-7em__min {
  margin-left: 1.4em !important;
}

.mb-7em__min {
  margin-bottom: 1.4em !important;
}

.mr-7em__min {
  margin-right: 1.4em !important;
}

.pt-7em__min {
  padding-top: 1.4em !important;
}

.pl-7em__min {
  padding-left: 1.4em !important;
}

.pb-7em__min {
  padding-bottom: 1.4em !important;
}

.pr-7em__min {
  padding-right: 1.4em !important;
}

.mt-80 {
  margin-top: 80px !important;
}

.ml-80 {
  margin-left: 80px !important;
}

.mb-80 {
  margin-bottom: 80px !important;
}

.mr-80 {
  margin-right: 80px !important;
}

.pt-80 {
  padding-top: 80px !important;
}

.pl-80 {
  padding-left: 80px !important;
}

.pb-80 {
  padding-bottom: 80px !important;
}

.pr-80 {
  padding-right: 80px !important;
}

.mt-8em__min {
  margin-top: 1.6em !important;
}

.ml-8em__min {
  margin-left: 1.6em !important;
}

.mb-8em__min {
  margin-bottom: 1.6em !important;
}

.mr-8em__min {
  margin-right: 1.6em !important;
}

.pt-8em__min {
  padding-top: 1.6em !important;
}

.pl-8em__min {
  padding-left: 1.6em !important;
}

.pb-8em__min {
  padding-bottom: 1.6em !important;
}

.pr-8em__min {
  padding-right: 1.6em !important;
}

.mt-90 {
  margin-top: 90px !important;
}

.ml-90 {
  margin-left: 90px !important;
}

.mb-90 {
  margin-bottom: 90px !important;
}

.mr-90 {
  margin-right: 90px !important;
}

.pt-90 {
  padding-top: 90px !important;
}

.pl-90 {
  padding-left: 90px !important;
}

.pb-90 {
  padding-bottom: 90px !important;
}

.pr-90 {
  padding-right: 90px !important;
}

.mt-9em__min {
  margin-top: 1.8em !important;
}

.ml-9em__min {
  margin-left: 1.8em !important;
}

.mb-9em__min {
  margin-bottom: 1.8em !important;
}

.mr-9em__min {
  margin-right: 1.8em !important;
}

.pt-9em__min {
  padding-top: 1.8em !important;
}

.pl-9em__min {
  padding-left: 1.8em !important;
}

.pb-9em__min {
  padding-bottom: 1.8em !important;
}

.pr-9em__min {
  padding-right: 1.8em !important;
}

.mt-100 {
  margin-top: 100px !important;
}

.ml-100 {
  margin-left: 100px !important;
}

.mb-100 {
  margin-bottom: 100px !important;
}

.mr-100 {
  margin-right: 100px !important;
}

.pt-100 {
  padding-top: 100px !important;
}

.pl-100 {
  padding-left: 100px !important;
}

.pb-100 {
  padding-bottom: 100px !important;
}

.pr-100 {
  padding-right: 100px !important;
}

.mt-10em__min {
  margin-top: 2em !important;
}

.ml-10em__min {
  margin-left: 2em !important;
}

.mb-10em__min {
  margin-bottom: 2em !important;
}

.mr-10em__min {
  margin-right: 2em !important;
}

.pt-10em__min {
  padding-top: 2em !important;
}

.pl-10em__min {
  padding-left: 2em !important;
}

.pb-10em__min {
  padding-bottom: 2em !important;
}

.pr-10em__min {
  padding-right: 2em !important;
}

.mt-110 {
  margin-top: 110px !important;
}

.ml-110 {
  margin-left: 110px !important;
}

.mb-110 {
  margin-bottom: 110px !important;
}

.mr-110 {
  margin-right: 110px !important;
}

.pt-110 {
  padding-top: 110px !important;
}

.pl-110 {
  padding-left: 110px !important;
}

.pb-110 {
  padding-bottom: 110px !important;
}

.pr-110 {
  padding-right: 110px !important;
}

.mt-11em__min {
  margin-top: 2.2em !important;
}

.ml-11em__min {
  margin-left: 2.2em !important;
}

.mb-11em__min {
  margin-bottom: 2.2em !important;
}

.mr-11em__min {
  margin-right: 2.2em !important;
}

.pt-11em__min {
  padding-top: 2.2em !important;
}

.pl-11em__min {
  padding-left: 2.2em !important;
}

.pb-11em__min {
  padding-bottom: 2.2em !important;
}

.pr-11em__min {
  padding-right: 2.2em !important;
}

.mt-120 {
  margin-top: 120px !important;
}

.ml-120 {
  margin-left: 120px !important;
}

.mb-120 {
  margin-bottom: 120px !important;
}

.mr-120 {
  margin-right: 120px !important;
}

.pt-120 {
  padding-top: 120px !important;
}

.pl-120 {
  padding-left: 120px !important;
}

.pb-120 {
  padding-bottom: 120px !important;
}

.pr-120 {
  padding-right: 120px !important;
}

.mt-12em__min {
  margin-top: 2.4em !important;
}

.ml-12em__min {
  margin-left: 2.4em !important;
}

.mb-12em__min {
  margin-bottom: 2.4em !important;
}

.mr-12em__min {
  margin-right: 2.4em !important;
}

.pt-12em__min {
  padding-top: 2.4em !important;
}

.pl-12em__min {
  padding-left: 2.4em !important;
}

.pb-12em__min {
  padding-bottom: 2.4em !important;
}

.pr-12em__min {
  padding-right: 2.4em !important;
}

.mt-130 {
  margin-top: 130px !important;
}

.ml-130 {
  margin-left: 130px !important;
}

.mb-130 {
  margin-bottom: 130px !important;
}

.mr-130 {
  margin-right: 130px !important;
}

.pt-130 {
  padding-top: 130px !important;
}

.pl-130 {
  padding-left: 130px !important;
}

.pb-130 {
  padding-bottom: 130px !important;
}

.pr-130 {
  padding-right: 130px !important;
}

.mt-13em__min {
  margin-top: 2.6em !important;
}

.ml-13em__min {
  margin-left: 2.6em !important;
}

.mb-13em__min {
  margin-bottom: 2.6em !important;
}

.mr-13em__min {
  margin-right: 2.6em !important;
}

.pt-13em__min {
  padding-top: 2.6em !important;
}

.pl-13em__min {
  padding-left: 2.6em !important;
}

.pb-13em__min {
  padding-bottom: 2.6em !important;
}

.pr-13em__min {
  padding-right: 2.6em !important;
}

.mt-140 {
  margin-top: 140px !important;
}

.ml-140 {
  margin-left: 140px !important;
}

.mb-140 {
  margin-bottom: 140px !important;
}

.mr-140 {
  margin-right: 140px !important;
}

.pt-140 {
  padding-top: 140px !important;
}

.pl-140 {
  padding-left: 140px !important;
}

.pb-140 {
  padding-bottom: 140px !important;
}

.pr-140 {
  padding-right: 140px !important;
}

.mt-14em__min {
  margin-top: 2.8em !important;
}

.ml-14em__min {
  margin-left: 2.8em !important;
}

.mb-14em__min {
  margin-bottom: 2.8em !important;
}

.mr-14em__min {
  margin-right: 2.8em !important;
}

.pt-14em__min {
  padding-top: 2.8em !important;
}

.pl-14em__min {
  padding-left: 2.8em !important;
}

.pb-14em__min {
  padding-bottom: 2.8em !important;
}

.pr-14em__min {
  padding-right: 2.8em !important;
}

.mt-150 {
  margin-top: 150px !important;
}

.ml-150 {
  margin-left: 150px !important;
}

.mb-150 {
  margin-bottom: 150px !important;
}

.mr-150 {
  margin-right: 150px !important;
}

.pt-150 {
  padding-top: 150px !important;
}

.pl-150 {
  padding-left: 150px !important;
}

.pb-150 {
  padding-bottom: 150px !important;
}

.pr-150 {
  padding-right: 150px !important;
}

.mt-15em__min {
  margin-top: 3em !important;
}

.ml-15em__min {
  margin-left: 3em !important;
}

.mb-15em__min {
  margin-bottom: 3em !important;
}

.mr-15em__min {
  margin-right: 3em !important;
}

.pt-15em__min {
  padding-top: 3em !important;
}

.pl-15em__min {
  padding-left: 3em !important;
}

.pb-15em__min {
  padding-bottom: 3em !important;
}

.pr-15em__min {
  padding-right: 3em !important;
}

.mt-160 {
  margin-top: 160px !important;
}

.ml-160 {
  margin-left: 160px !important;
}

.mb-160 {
  margin-bottom: 160px !important;
}

.mr-160 {
  margin-right: 160px !important;
}

.pt-160 {
  padding-top: 160px !important;
}

.pl-160 {
  padding-left: 160px !important;
}

.pb-160 {
  padding-bottom: 160px !important;
}

.pr-160 {
  padding-right: 160px !important;
}

.mt-16em__min {
  margin-top: 3.2em !important;
}

.ml-16em__min {
  margin-left: 3.2em !important;
}

.mb-16em__min {
  margin-bottom: 3.2em !important;
}

.mr-16em__min {
  margin-right: 3.2em !important;
}

.pt-16em__min {
  padding-top: 3.2em !important;
}

.pl-16em__min {
  padding-left: 3.2em !important;
}

.pb-16em__min {
  padding-bottom: 3.2em !important;
}

.pr-16em__min {
  padding-right: 3.2em !important;
}

.mt-170 {
  margin-top: 170px !important;
}

.ml-170 {
  margin-left: 170px !important;
}

.mb-170 {
  margin-bottom: 170px !important;
}

.mr-170 {
  margin-right: 170px !important;
}

.pt-170 {
  padding-top: 170px !important;
}

.pl-170 {
  padding-left: 170px !important;
}

.pb-170 {
  padding-bottom: 170px !important;
}

.pr-170 {
  padding-right: 170px !important;
}

.mt-17em__min {
  margin-top: 3.4em !important;
}

.ml-17em__min {
  margin-left: 3.4em !important;
}

.mb-17em__min {
  margin-bottom: 3.4em !important;
}

.mr-17em__min {
  margin-right: 3.4em !important;
}

.pt-17em__min {
  padding-top: 3.4em !important;
}

.pl-17em__min {
  padding-left: 3.4em !important;
}

.pb-17em__min {
  padding-bottom: 3.4em !important;
}

.pr-17em__min {
  padding-right: 3.4em !important;
}

.mt-180 {
  margin-top: 180px !important;
}

.ml-180 {
  margin-left: 180px !important;
}

.mb-180 {
  margin-bottom: 180px !important;
}

.mr-180 {
  margin-right: 180px !important;
}

.pt-180 {
  padding-top: 180px !important;
}

.pl-180 {
  padding-left: 180px !important;
}

.pb-180 {
  padding-bottom: 180px !important;
}

.pr-180 {
  padding-right: 180px !important;
}

.mt-18em__min {
  margin-top: 3.6em !important;
}

.ml-18em__min {
  margin-left: 3.6em !important;
}

.mb-18em__min {
  margin-bottom: 3.6em !important;
}

.mr-18em__min {
  margin-right: 3.6em !important;
}

.pt-18em__min {
  padding-top: 3.6em !important;
}

.pl-18em__min {
  padding-left: 3.6em !important;
}

.pb-18em__min {
  padding-bottom: 3.6em !important;
}

.pr-18em__min {
  padding-right: 3.6em !important;
}

.mt-190 {
  margin-top: 190px !important;
}

.ml-190 {
  margin-left: 190px !important;
}

.mb-190 {
  margin-bottom: 190px !important;
}

.mr-190 {
  margin-right: 190px !important;
}

.pt-190 {
  padding-top: 190px !important;
}

.pl-190 {
  padding-left: 190px !important;
}

.pb-190 {
  padding-bottom: 190px !important;
}

.pr-190 {
  padding-right: 190px !important;
}

.mt-19em__min {
  margin-top: 3.8em !important;
}

.ml-19em__min {
  margin-left: 3.8em !important;
}

.mb-19em__min {
  margin-bottom: 3.8em !important;
}

.mr-19em__min {
  margin-right: 3.8em !important;
}

.pt-19em__min {
  padding-top: 3.8em !important;
}

.pl-19em__min {
  padding-left: 3.8em !important;
}

.pb-19em__min {
  padding-bottom: 3.8em !important;
}

.pr-19em__min {
  padding-right: 3.8em !important;
}

.mt-200 {
  margin-top: 200px !important;
}

.ml-200 {
  margin-left: 200px !important;
}

.mb-200 {
  margin-bottom: 200px !important;
}

.mr-200 {
  margin-right: 200px !important;
}

.pt-200 {
  padding-top: 200px !important;
}

.pl-200 {
  padding-left: 200px !important;
}

.pb-200 {
  padding-bottom: 200px !important;
}

.pr-200 {
  padding-right: 200px !important;
}

.mt-20em__min {
  margin-top: 4em !important;
}

.ml-20em__min {
  margin-left: 4em !important;
}

.mb-20em__min {
  margin-bottom: 4em !important;
}

.mr-20em__min {
  margin-right: 4em !important;
}

.pt-20em__min {
  padding-top: 4em !important;
}

.pl-20em__min {
  padding-left: 4em !important;
}

.pb-20em__min {
  padding-bottom: 4em !important;
}

.pr-20em__min {
  padding-right: 4em !important;
}

.mt-210 {
  margin-top: 210px !important;
}

.ml-210 {
  margin-left: 210px !important;
}

.mb-210 {
  margin-bottom: 210px !important;
}

.mr-210 {
  margin-right: 210px !important;
}

.pt-210 {
  padding-top: 210px !important;
}

.pl-210 {
  padding-left: 210px !important;
}

.pb-210 {
  padding-bottom: 210px !important;
}

.pr-210 {
  padding-right: 210px !important;
}

.mt-21em__min {
  margin-top: 4.2em !important;
}

.ml-21em__min {
  margin-left: 4.2em !important;
}

.mb-21em__min {
  margin-bottom: 4.2em !important;
}

.mr-21em__min {
  margin-right: 4.2em !important;
}

.pt-21em__min {
  padding-top: 4.2em !important;
}

.pl-21em__min {
  padding-left: 4.2em !important;
}

.pb-21em__min {
  padding-bottom: 4.2em !important;
}

.pr-21em__min {
  padding-right: 4.2em !important;
}

.mt-220 {
  margin-top: 220px !important;
}

.ml-220 {
  margin-left: 220px !important;
}

.mb-220 {
  margin-bottom: 220px !important;
}

.mr-220 {
  margin-right: 220px !important;
}

.pt-220 {
  padding-top: 220px !important;
}

.pl-220 {
  padding-left: 220px !important;
}

.pb-220 {
  padding-bottom: 220px !important;
}

.pr-220 {
  padding-right: 220px !important;
}

.mt-22em__min {
  margin-top: 4.4em !important;
}

.ml-22em__min {
  margin-left: 4.4em !important;
}

.mb-22em__min {
  margin-bottom: 4.4em !important;
}

.mr-22em__min {
  margin-right: 4.4em !important;
}

.pt-22em__min {
  padding-top: 4.4em !important;
}

.pl-22em__min {
  padding-left: 4.4em !important;
}

.pb-22em__min {
  padding-bottom: 4.4em !important;
}

.pr-22em__min {
  padding-right: 4.4em !important;
}

.mt-230 {
  margin-top: 230px !important;
}

.ml-230 {
  margin-left: 230px !important;
}

.mb-230 {
  margin-bottom: 230px !important;
}

.mr-230 {
  margin-right: 230px !important;
}

.pt-230 {
  padding-top: 230px !important;
}

.pl-230 {
  padding-left: 230px !important;
}

.pb-230 {
  padding-bottom: 230px !important;
}

.pr-230 {
  padding-right: 230px !important;
}

.mt-23em__min {
  margin-top: 4.6em !important;
}

.ml-23em__min {
  margin-left: 4.6em !important;
}

.mb-23em__min {
  margin-bottom: 4.6em !important;
}

.mr-23em__min {
  margin-right: 4.6em !important;
}

.pt-23em__min {
  padding-top: 4.6em !important;
}

.pl-23em__min {
  padding-left: 4.6em !important;
}

.pb-23em__min {
  padding-bottom: 4.6em !important;
}

.pr-23em__min {
  padding-right: 4.6em !important;
}

.mt-240 {
  margin-top: 240px !important;
}

.ml-240 {
  margin-left: 240px !important;
}

.mb-240 {
  margin-bottom: 240px !important;
}

.mr-240 {
  margin-right: 240px !important;
}

.pt-240 {
  padding-top: 240px !important;
}

.pl-240 {
  padding-left: 240px !important;
}

.pb-240 {
  padding-bottom: 240px !important;
}

.pr-240 {
  padding-right: 240px !important;
}

.mt-24em__min {
  margin-top: 4.8em !important;
}

.ml-24em__min {
  margin-left: 4.8em !important;
}

.mb-24em__min {
  margin-bottom: 4.8em !important;
}

.mr-24em__min {
  margin-right: 4.8em !important;
}

.pt-24em__min {
  padding-top: 4.8em !important;
}

.pl-24em__min {
  padding-left: 4.8em !important;
}

.pb-24em__min {
  padding-bottom: 4.8em !important;
}

.pr-24em__min {
  padding-right: 4.8em !important;
}

.mt-250 {
  margin-top: 250px !important;
}

.ml-250 {
  margin-left: 250px !important;
}

.mb-250 {
  margin-bottom: 250px !important;
}

.mr-250 {
  margin-right: 250px !important;
}

.pt-250 {
  padding-top: 250px !important;
}

.pl-250 {
  padding-left: 250px !important;
}

.pb-250 {
  padding-bottom: 250px !important;
}

.pr-250 {
  padding-right: 250px !important;
}

.mt-25em__min {
  margin-top: 5em !important;
}

.ml-25em__min {
  margin-left: 5em !important;
}

.mb-25em__min {
  margin-bottom: 5em !important;
}

.mr-25em__min {
  margin-right: 5em !important;
}

.pt-25em__min {
  padding-top: 5em !important;
}

.pl-25em__min {
  padding-left: 5em !important;
}

.pb-25em__min {
  padding-bottom: 5em !important;
}

.pr-25em__min {
  padding-right: 5em !important;
}

.mt-260 {
  margin-top: 260px !important;
}

.ml-260 {
  margin-left: 260px !important;
}

.mb-260 {
  margin-bottom: 260px !important;
}

.mr-260 {
  margin-right: 260px !important;
}

.pt-260 {
  padding-top: 260px !important;
}

.pl-260 {
  padding-left: 260px !important;
}

.pb-260 {
  padding-bottom: 260px !important;
}

.pr-260 {
  padding-right: 260px !important;
}

.mt-26em__min {
  margin-top: 5.2em !important;
}

.ml-26em__min {
  margin-left: 5.2em !important;
}

.mb-26em__min {
  margin-bottom: 5.2em !important;
}

.mr-26em__min {
  margin-right: 5.2em !important;
}

.pt-26em__min {
  padding-top: 5.2em !important;
}

.pl-26em__min {
  padding-left: 5.2em !important;
}

.pb-26em__min {
  padding-bottom: 5.2em !important;
}

.pr-26em__min {
  padding-right: 5.2em !important;
}

.mt-270 {
  margin-top: 270px !important;
}

.ml-270 {
  margin-left: 270px !important;
}

.mb-270 {
  margin-bottom: 270px !important;
}

.mr-270 {
  margin-right: 270px !important;
}

.pt-270 {
  padding-top: 270px !important;
}

.pl-270 {
  padding-left: 270px !important;
}

.pb-270 {
  padding-bottom: 270px !important;
}

.pr-270 {
  padding-right: 270px !important;
}

.mt-27em__min {
  margin-top: 5.4em !important;
}

.ml-27em__min {
  margin-left: 5.4em !important;
}

.mb-27em__min {
  margin-bottom: 5.4em !important;
}

.mr-27em__min {
  margin-right: 5.4em !important;
}

.pt-27em__min {
  padding-top: 5.4em !important;
}

.pl-27em__min {
  padding-left: 5.4em !important;
}

.pb-27em__min {
  padding-bottom: 5.4em !important;
}

.pr-27em__min {
  padding-right: 5.4em !important;
}

.mt-280 {
  margin-top: 280px !important;
}

.ml-280 {
  margin-left: 280px !important;
}

.mb-280 {
  margin-bottom: 280px !important;
}

.mr-280 {
  margin-right: 280px !important;
}

.pt-280 {
  padding-top: 280px !important;
}

.pl-280 {
  padding-left: 280px !important;
}

.pb-280 {
  padding-bottom: 280px !important;
}

.pr-280 {
  padding-right: 280px !important;
}

.mt-28em__min {
  margin-top: 5.6em !important;
}

.ml-28em__min {
  margin-left: 5.6em !important;
}

.mb-28em__min {
  margin-bottom: 5.6em !important;
}

.mr-28em__min {
  margin-right: 5.6em !important;
}

.pt-28em__min {
  padding-top: 5.6em !important;
}

.pl-28em__min {
  padding-left: 5.6em !important;
}

.pb-28em__min {
  padding-bottom: 5.6em !important;
}

.pr-28em__min {
  padding-right: 5.6em !important;
}

.mt-290 {
  margin-top: 290px !important;
}

.ml-290 {
  margin-left: 290px !important;
}

.mb-290 {
  margin-bottom: 290px !important;
}

.mr-290 {
  margin-right: 290px !important;
}

.pt-290 {
  padding-top: 290px !important;
}

.pl-290 {
  padding-left: 290px !important;
}

.pb-290 {
  padding-bottom: 290px !important;
}

.pr-290 {
  padding-right: 290px !important;
}

.mt-29em__min {
  margin-top: 5.8em !important;
}

.ml-29em__min {
  margin-left: 5.8em !important;
}

.mb-29em__min {
  margin-bottom: 5.8em !important;
}

.mr-29em__min {
  margin-right: 5.8em !important;
}

.pt-29em__min {
  padding-top: 5.8em !important;
}

.pl-29em__min {
  padding-left: 5.8em !important;
}

.pb-29em__min {
  padding-bottom: 5.8em !important;
}

.pr-29em__min {
  padding-right: 5.8em !important;
}

.mt-300 {
  margin-top: 300px !important;
}

.ml-300 {
  margin-left: 300px !important;
}

.mb-300 {
  margin-bottom: 300px !important;
}

.mr-300 {
  margin-right: 300px !important;
}

.pt-300 {
  padding-top: 300px !important;
}

.pl-300 {
  padding-left: 300px !important;
}

.pb-300 {
  padding-bottom: 300px !important;
}

.pr-300 {
  padding-right: 300px !important;
}

.mt-30em__min {
  margin-top: 6em !important;
}

.ml-30em__min {
  margin-left: 6em !important;
}

.mb-30em__min {
  margin-bottom: 6em !important;
}

.mr-30em__min {
  margin-right: 6em !important;
}

.pt-30em__min {
  padding-top: 6em !important;
}

.pl-30em__min {
  padding-left: 6em !important;
}

.pb-30em__min {
  padding-bottom: 6em !important;
}

.pr-30em__min {
  padding-right: 6em !important;
}

.w-10 {
  width: calc(10 * 1%);
}

.w-20 {
  width: calc(20 * 1%);
}

.w-30 {
  width: calc(30 * 1%);
}

.w-40 {
  width: calc(40 * 1%);
}

.w-50 {
  width: calc(50 * 1%);
}

.w-60 {
  width: calc(60 * 1%);
}

.w-70 {
  width: calc(70 * 1%);
}

.w-80 {
  width: calc(80 * 1%);
}

.w-90 {
  width: calc(90 * 1%);
}

.w-100 {
  width: calc(100 * 1%);
}

.col-1-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-1-nonegap > * {
  align-self: stretch;
  width: calc(100% - 0px);
}
@media screen and (max-width: 560px) {
  .col-1-nonegap {
    flex-direction: column;
  }
  .col-1-nonegap > * {
    width: 100%;
  }
}
.col-1-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 1 - 0px);
}
.col-1-nonegap:nth-last-child(-n+0) {
  flex-basis: calc(99.99% / 1 - 0px);
}

.col-1-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-1-narrow > * {
  align-self: stretch;
  width: calc(100% - 0px);
}
@media screen and (max-width: 560px) {
  .col-1-narrow {
    flex-direction: column;
  }
  .col-1-narrow > * {
    width: 100%;
  }
}
.col-1-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 1 - 5px);
}
.col-1-narrow:nth-last-child(-n+0) {
  flex-basis: calc(99.99% / 1 - 5px);
}

.col-1 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-1 > * {
  align-self: stretch;
  width: calc(100% - 0rem);
}
@media screen and (max-width: 560px) {
  .col-1 {
    flex-direction: column;
  }
  .col-1 > * {
    width: 100%;
  }
}
.col-1:after {
  content: "";
  flex-basis: calc(99.99% / 1 - 1.25rem);
}
.col-1:nth-last-child(-n+0) {
  flex-basis: calc(99.99% / 1 - 1.25rem);
}
.col-1.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-1.__onsp {
    flex-direction: row;
  }
  .col-1.__onsp > * {
    width: calc(100% - 0rem);
  }
}

.w-10 {
  width: calc(10 * 1%);
}

.col-2-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-2-nonegap > * {
  align-self: stretch;
  width: calc(50% - 0px);
}
@media screen and (max-width: 560px) {
  .col-2-nonegap {
    flex-direction: column;
  }
  .col-2-nonegap > * {
    width: 100%;
  }
}
.col-2-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 2 - 0px);
}
.col-2-nonegap:nth-last-child(-n+1) {
  flex-basis: calc(99.99% / 2 - 0px);
}

.col-2-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-2-narrow > * {
  align-self: stretch;
  width: calc(50% - 2.5px);
}
@media screen and (max-width: 560px) {
  .col-2-narrow {
    flex-direction: column;
  }
  .col-2-narrow > * {
    width: 100%;
  }
}
.col-2-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 2 - 5px);
}
.col-2-narrow:nth-last-child(-n+1) {
  flex-basis: calc(99.99% / 2 - 5px);
}

.col-2 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-2 > * {
  align-self: stretch;
  width: calc(50% - 0.625rem);
}
@media screen and (max-width: 560px) {
  .col-2 {
    flex-direction: column;
  }
  .col-2 > * {
    width: 100%;
  }
}
.col-2:after {
  content: "";
  flex-basis: calc(99.99% / 2 - 1.25rem);
}
.col-2:nth-last-child(-n+1) {
  flex-basis: calc(99.99% / 2 - 1.25rem);
}
.col-2.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-2.__onsp {
    flex-direction: row;
  }
  .col-2.__onsp > * {
    width: calc(50% - 0.625rem);
  }
}

.w-20 {
  width: calc(20 * 1%);
}

.col-3-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-3-nonegap > * {
  align-self: stretch;
  width: calc(33.3333333333% - 0px);
}
@media screen and (max-width: 560px) {
  .col-3-nonegap {
    flex-direction: column;
  }
  .col-3-nonegap > * {
    width: 100%;
  }
}
.col-3-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 3 - 0px);
}
.col-3-nonegap:nth-last-child(-n+2) {
  flex-basis: calc(99.99% / 3 - 0px);
}

.col-3-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-3-narrow > * {
  align-self: stretch;
  width: calc(33.3333333333% - 3.3333333333px);
}
@media screen and (max-width: 560px) {
  .col-3-narrow {
    flex-direction: column;
  }
  .col-3-narrow > * {
    width: 100%;
  }
}
.col-3-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 3 - 5px);
}
.col-3-narrow:nth-last-child(-n+2) {
  flex-basis: calc(99.99% / 3 - 5px);
}

.col-3 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-3 > * {
  align-self: stretch;
  width: calc(33.3333333333% - 0.8333333333rem);
}
@media screen and (max-width: 560px) {
  .col-3 {
    flex-direction: column;
  }
  .col-3 > * {
    width: 100%;
  }
}
.col-3:after {
  content: "";
  flex-basis: calc(99.99% / 3 - 1.25rem);
}
.col-3:nth-last-child(-n+2) {
  flex-basis: calc(99.99% / 3 - 1.25rem);
}
.col-3.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-3.__onsp {
    flex-direction: row;
  }
  .col-3.__onsp > * {
    width: calc(33.3333333333% - 0.8333333333rem);
  }
}

.w-30 {
  width: calc(30 * 1%);
}

.col-4-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-4-nonegap > * {
  align-self: stretch;
  width: calc(25% - 0px);
}
@media screen and (max-width: 560px) {
  .col-4-nonegap {
    flex-direction: column;
  }
  .col-4-nonegap > * {
    width: 100%;
  }
}
.col-4-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 4 - 0px);
}
.col-4-nonegap:nth-last-child(-n+3) {
  flex-basis: calc(99.99% / 4 - 0px);
}

.col-4-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-4-narrow > * {
  align-self: stretch;
  width: calc(25% - 3.75px);
}
@media screen and (max-width: 560px) {
  .col-4-narrow {
    flex-direction: column;
  }
  .col-4-narrow > * {
    width: 100%;
  }
}
.col-4-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 4 - 5px);
}
.col-4-narrow:nth-last-child(-n+3) {
  flex-basis: calc(99.99% / 4 - 5px);
}

.col-4 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-4 > * {
  align-self: stretch;
  width: calc(25% - 0.9375rem);
}
@media screen and (max-width: 560px) {
  .col-4 {
    flex-direction: column;
  }
  .col-4 > * {
    width: 100%;
  }
}
.col-4:after {
  content: "";
  flex-basis: calc(99.99% / 4 - 1.25rem);
}
.col-4:nth-last-child(-n+3) {
  flex-basis: calc(99.99% / 4 - 1.25rem);
}
.col-4.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-4.__onsp {
    flex-direction: row;
  }
  .col-4.__onsp > * {
    width: calc(25% - 0.9375rem);
  }
}

.w-40 {
  width: calc(40 * 1%);
}

.col-5-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-5-nonegap > * {
  align-self: stretch;
  width: calc(20% - 0px);
}
@media screen and (max-width: 560px) {
  .col-5-nonegap {
    flex-direction: column;
  }
  .col-5-nonegap > * {
    width: 100%;
  }
}
.col-5-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 5 - 0px);
}
.col-5-nonegap:nth-last-child(-n+4) {
  flex-basis: calc(99.99% / 5 - 0px);
}

.col-5-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-5-narrow > * {
  align-self: stretch;
  width: calc(20% - 4px);
}
@media screen and (max-width: 560px) {
  .col-5-narrow {
    flex-direction: column;
  }
  .col-5-narrow > * {
    width: 100%;
  }
}
.col-5-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 5 - 5px);
}
.col-5-narrow:nth-last-child(-n+4) {
  flex-basis: calc(99.99% / 5 - 5px);
}

.col-5 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-5 > * {
  align-self: stretch;
  width: calc(20% - 1rem);
}
@media screen and (max-width: 560px) {
  .col-5 {
    flex-direction: column;
  }
  .col-5 > * {
    width: 100%;
  }
}
.col-5:after {
  content: "";
  flex-basis: calc(99.99% / 5 - 1.25rem);
}
.col-5:nth-last-child(-n+4) {
  flex-basis: calc(99.99% / 5 - 1.25rem);
}
.col-5.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-5.__onsp {
    flex-direction: row;
  }
  .col-5.__onsp > * {
    width: calc(20% - 1rem);
  }
}

.w-50 {
  width: calc(50 * 1%);
}

.col-6-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-6-nonegap > * {
  align-self: stretch;
  width: calc(16.6666666667% - 0px);
}
@media screen and (max-width: 560px) {
  .col-6-nonegap {
    flex-direction: column;
  }
  .col-6-nonegap > * {
    width: 100%;
  }
}
.col-6-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 6 - 0px);
}
.col-6-nonegap:nth-last-child(-n+5) {
  flex-basis: calc(99.99% / 6 - 0px);
}

.col-6-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-6-narrow > * {
  align-self: stretch;
  width: calc(16.6666666667% - 4.1666666667px);
}
@media screen and (max-width: 560px) {
  .col-6-narrow {
    flex-direction: column;
  }
  .col-6-narrow > * {
    width: 100%;
  }
}
.col-6-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 6 - 5px);
}
.col-6-narrow:nth-last-child(-n+5) {
  flex-basis: calc(99.99% / 6 - 5px);
}

.col-6 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-6 > * {
  align-self: stretch;
  width: calc(16.6666666667% - 1.0416666667rem);
}
@media screen and (max-width: 560px) {
  .col-6 {
    flex-direction: column;
  }
  .col-6 > * {
    width: 100%;
  }
}
.col-6:after {
  content: "";
  flex-basis: calc(99.99% / 6 - 1.25rem);
}
.col-6:nth-last-child(-n+5) {
  flex-basis: calc(99.99% / 6 - 1.25rem);
}
.col-6.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-6.__onsp {
    flex-direction: row;
  }
  .col-6.__onsp > * {
    width: calc(16.6666666667% - 1.0416666667rem);
  }
}

.w-60 {
  width: calc(60 * 1%);
}

.col-7-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-7-nonegap > * {
  align-self: stretch;
  width: calc(14.2857142857% - 0px);
}
@media screen and (max-width: 560px) {
  .col-7-nonegap {
    flex-direction: column;
  }
  .col-7-nonegap > * {
    width: 100%;
  }
}
.col-7-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 7 - 0px);
}
.col-7-nonegap:nth-last-child(-n+6) {
  flex-basis: calc(99.99% / 7 - 0px);
}

.col-7-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-7-narrow > * {
  align-self: stretch;
  width: calc(14.2857142857% - 4.2857142857px);
}
@media screen and (max-width: 560px) {
  .col-7-narrow {
    flex-direction: column;
  }
  .col-7-narrow > * {
    width: 100%;
  }
}
.col-7-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 7 - 5px);
}
.col-7-narrow:nth-last-child(-n+6) {
  flex-basis: calc(99.99% / 7 - 5px);
}

.col-7 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-7 > * {
  align-self: stretch;
  width: calc(14.2857142857% - 1.0714285714rem);
}
@media screen and (max-width: 560px) {
  .col-7 {
    flex-direction: column;
  }
  .col-7 > * {
    width: 100%;
  }
}
.col-7:after {
  content: "";
  flex-basis: calc(99.99% / 7 - 1.25rem);
}
.col-7:nth-last-child(-n+6) {
  flex-basis: calc(99.99% / 7 - 1.25rem);
}
.col-7.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-7.__onsp {
    flex-direction: row;
  }
  .col-7.__onsp > * {
    width: calc(14.2857142857% - 1.0714285714rem);
  }
}

.w-70 {
  width: calc(70 * 1%);
}

.col-8-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-8-nonegap > * {
  align-self: stretch;
  width: calc(12.5% - 0px);
}
@media screen and (max-width: 560px) {
  .col-8-nonegap {
    flex-direction: column;
  }
  .col-8-nonegap > * {
    width: 100%;
  }
}
.col-8-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 8 - 0px);
}
.col-8-nonegap:nth-last-child(-n+7) {
  flex-basis: calc(99.99% / 8 - 0px);
}

.col-8-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-8-narrow > * {
  align-self: stretch;
  width: calc(12.5% - 4.375px);
}
@media screen and (max-width: 560px) {
  .col-8-narrow {
    flex-direction: column;
  }
  .col-8-narrow > * {
    width: 100%;
  }
}
.col-8-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 8 - 5px);
}
.col-8-narrow:nth-last-child(-n+7) {
  flex-basis: calc(99.99% / 8 - 5px);
}

.col-8 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-8 > * {
  align-self: stretch;
  width: calc(12.5% - 1.09375rem);
}
@media screen and (max-width: 560px) {
  .col-8 {
    flex-direction: column;
  }
  .col-8 > * {
    width: 100%;
  }
}
.col-8:after {
  content: "";
  flex-basis: calc(99.99% / 8 - 1.25rem);
}
.col-8:nth-last-child(-n+7) {
  flex-basis: calc(99.99% / 8 - 1.25rem);
}
.col-8.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-8.__onsp {
    flex-direction: row;
  }
  .col-8.__onsp > * {
    width: calc(12.5% - 1.09375rem);
  }
}

.w-80 {
  width: calc(80 * 1%);
}

.col-9-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-9-nonegap > * {
  align-self: stretch;
  width: calc(11.1111111111% - 0px);
}
@media screen and (max-width: 560px) {
  .col-9-nonegap {
    flex-direction: column;
  }
  .col-9-nonegap > * {
    width: 100%;
  }
}
.col-9-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 9 - 0px);
}
.col-9-nonegap:nth-last-child(-n+8) {
  flex-basis: calc(99.99% / 9 - 0px);
}

.col-9-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-9-narrow > * {
  align-self: stretch;
  width: calc(11.1111111111% - 4.4444444444px);
}
@media screen and (max-width: 560px) {
  .col-9-narrow {
    flex-direction: column;
  }
  .col-9-narrow > * {
    width: 100%;
  }
}
.col-9-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 9 - 5px);
}
.col-9-narrow:nth-last-child(-n+8) {
  flex-basis: calc(99.99% / 9 - 5px);
}

.col-9 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-9 > * {
  align-self: stretch;
  width: calc(11.1111111111% - 1.1111111111rem);
}
@media screen and (max-width: 560px) {
  .col-9 {
    flex-direction: column;
  }
  .col-9 > * {
    width: 100%;
  }
}
.col-9:after {
  content: "";
  flex-basis: calc(99.99% / 9 - 1.25rem);
}
.col-9:nth-last-child(-n+8) {
  flex-basis: calc(99.99% / 9 - 1.25rem);
}
.col-9.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-9.__onsp {
    flex-direction: row;
  }
  .col-9.__onsp > * {
    width: calc(11.1111111111% - 1.1111111111rem);
  }
}

.w-90 {
  width: calc(90 * 1%);
}

.col-10-nonegap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 0px;
}
.col-10-nonegap > * {
  align-self: stretch;
  width: calc(10% - 0px);
}
@media screen and (max-width: 560px) {
  .col-10-nonegap {
    flex-direction: column;
  }
  .col-10-nonegap > * {
    width: 100%;
  }
}
.col-10-nonegap:after {
  content: "";
  flex-basis: calc(99.99% / 10 - 0px);
}
.col-10-nonegap:nth-last-child(-n+9) {
  flex-basis: calc(99.99% / 10 - 0px);
}

.col-10-narrow {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 5px;
}
.col-10-narrow > * {
  align-self: stretch;
  width: calc(10% - 4.5px);
}
@media screen and (max-width: 560px) {
  .col-10-narrow {
    flex-direction: column;
  }
  .col-10-narrow > * {
    width: 100%;
  }
}
.col-10-narrow:after {
  content: "";
  flex-basis: calc(99.99% / 10 - 5px);
}
.col-10-narrow:nth-last-child(-n+9) {
  flex-basis: calc(99.99% / 10 - 5px);
}

.col-10 {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 1.25rem;
}
.col-10 > * {
  align-self: stretch;
  width: calc(10% - 1.125rem);
}
@media screen and (max-width: 560px) {
  .col-10 {
    flex-direction: column;
  }
  .col-10 > * {
    width: 100%;
  }
}
.col-10:after {
  content: "";
  flex-basis: calc(99.99% / 10 - 1.25rem);
}
.col-10:nth-last-child(-n+9) {
  flex-basis: calc(99.99% / 10 - 1.25rem);
}
.col-10.__stretch {
  justify-content: stretch;
}
@media screen and (max-width: 560px) {
  .col-10.__onsp {
    flex-direction: row;
  }
  .col-10.__onsp > * {
    width: calc(10% - 1.125rem);
  }
}

.w-100 {
  width: calc(100 * 1%);
}

.article main {
  position: relative;
}
.article--nav {
  position: absolute;
  left: 50%;
  z-index: 10;
  transform: translateX(-50%);
}
.article--nav.__head {
  top: 30px;
}
.article--nav.__foot {
  bottom: 30px;
}
.article--nav a {
  position: relative;
  text-decoration: none;
}
.article--nav a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: inline-block;
  width: 0%;
  border-bottom: 1px solid #2a3d52;
  transition: width 0.1s ease-out;
}
@media screen and (max-width: 768px) {
  .article--nav a {
    display: none;
  }
}
@media (hover: hover) {
  .article--nav a:hover::after {
    width: 100%;
  }
}
.article--head {
  background-color: #f5f6f8;
}
.article--head-kv > figure {
  display: flex;
  justify-content: center;
  overflow: hidden;
  margin: 0 auto;
  padding: 0;
  max-width: 1600px;
  width: 100%;
  aspect-ratio: 8/3;
}
@media screen and (max-width: 768px) {
  .article--head-kv > figure {
    aspect-ratio: unset;
  }
}
.article--head-kv > figure img {
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 768px) {
  .article--head-kv > figure img {
    max-width: none;
    max-height: none;
    width: 100%;
  }
}
.article--head > article {
  padding-top: 55px;
  padding-bottom: 100px;
}
@media screen and (max-width: 768px) {
  .article--head > article {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
.article--head > article .article--tags {
  flex: 1;
  margin-bottom: 1em;
  width: 100%;
}
.article--head > article .article--tags li {
  padding: 0.2em 1em;
  background-color: #fff;
  font-weight: bold;
  line-height: 1.3em;
}
.article--head > article .article--outline {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 80px;
}
@media screen and (max-width: 768px) {
  .article--head > article .article--outline {
    flex-direction: column;
  }
}
.article--head > article .article--outline__1 {
  flex: 1;
}
@media screen and (max-width: 768px) {
  .article--head > article .article--outline__1 {
    margin-bottom: 1rem;
    order: 2;
  }
}
.article--head > article .article--outline__2 {
  padding-top: 1em;
  width: 22em;
  border-top: 1px solid #2a3d52;
}
@media screen and (max-width: 768px) {
  .article--head > article .article--outline__2 {
    margin-bottom: 2em;
    width: 100%;
    border-top: none;
    order: 1;
  }
}
.article--head > article .article--outline__2 dl {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0 0.5em;
  margin-bottom: 2rem;
}
.article--head > article .article--outline__2 dl dt,
.article--head > article .article--outline__2 dl dd {
  margin-bottom: 0;
}
.article--head > article .article--outline__2 dl dt {
  margin-bottom: 0.5em;
  width: 7em;
}
.article--head > article .article--outline__2 dl dd {
  flex: calc(100% - 7em - 0.5em);
  font-size: 1.4em;
}
.article--head > article .article--outline__2 dl dd strong {
  display: inline-block;
  padding-right: 5px;
  letter-spacing: 0;
  font-size: 1.8em;
}
.article--head > article .article--outline__2 dl p {
  margin-bottom: 0.5em;
}
.article--head > article .article--outline__2 .notes {
  margin-bottom: 2rem;
  line-height: 1.4em;
}
.article--head > article .article--outline h2 {
  margin-bottom: 0.5em;
  font-size: 30px;
  line-height: 46px;
}
@media (max-width: 560px) {
  .article--head > article .article--outline h2 {
    font-size: 5.5vw;
    line-height: 1.6em;
  }
}
.article--head > article .article--outline .tags {
  gap: 15px 10px;
  margin-top: 60px;
  margin-bottom: 2em;
}
.article--reason {
  margin-bottom: 50px;
}
.article--reason dt {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 50px;
}
.article--reason dt img {
  display: block;
  margin-bottom: 10px;
  max-width: 420px;
}
@media screen and (max-width: 768px) {
  .article--reason dt {
    margin-bottom: 35px;
  }
  .article--reason dt img {
    max-width: 80%;
  }
}
.article--reason dd {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 2em;
  margin: 0;
  padding: 0 50px 50px 50px;
}
.article--reason dd figure {
  overflow: hidden;
  width: 60px;
}
.article--reason dd figure img {
  display: block;
  width: 100%;
}
.article--reason dd p {
  flex: 1;
  margin: 0;
}
.article--reason dd p strong {
  display: block;
  margin-bottom: 0.3em;
  font-size: 1.4em;
}
@media screen and (max-width: 768px) {
  .article--reason dd {
    flex-direction: column;
    padding: 0 0 50px 0;
  }
  .article--reason dd figure {
    position: absolute;
    top: 0;
    left: 0;
    width: 65px;
  }
  .article--reason dd p {
    flex: 1;
    margin: 0;
  }
  .article--reason dd p strong {
    display: flex;
    align-items: center;
    margin-bottom: 0.7em;
    padding-left: 80px;
    min-height: 65px;
    font-size: 1.4em;
  }
}
.article--reason dt,
.article--reason dd:last-child {
  border-bottom: 4px solid #ff3895;
}
.article .curriculum {
  margin-top: 100px;
  margin-bottom: 100px;
}
.article .curriculum > .l--box:first-child {
  position: relative;
  margin-bottom: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.article .curriculum > .l--box:first-child::after {
  content: "";
  position: absolute;
  bottom: 1px;
  left: 3px;
  display: block;
  width: calc(100% - 6px);
  height: 3px;
  border-radius: 3px;
  background-color: #fff;
}
.article .curriculum > .l--box:last-child {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.article .curriculum h3 {
  margin-bottom: 2em;
}
.article .curriculum h1.__plan_personal,
.article .curriculum h2.__plan_personal,
.article .curriculum h3.__plan_personal,
.article .curriculum h4.__plan_personal,
.article .curriculum h5.__plan_personal,
.article .curriculum h6.__plan_personal {
  display: block;
  margin: 0 auto 2em auto;
  padding: 0.3em 0;
  max-width: calc(66.6666666667% - 15px);
  border: 1px solid #ce0cd0;
  border-radius: 999px;
  color: #ce0cd0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .article .curriculum h1.__plan_personal,
  .article .curriculum h2.__plan_personal,
  .article .curriculum h3.__plan_personal,
  .article .curriculum h4.__plan_personal,
  .article .curriculum h5.__plan_personal,
  .article .curriculum h6.__plan_personal {
    max-width: 400px;
  }
}
.article .curriculum dt {
  display: flex;
  justify-content: center;
  margin-bottom: 1em;
  font-size: 1.7rem;
  font-weight: bold;
}
.article .curriculum dt strong {
  font-size: 3rem;
}
.article .curriculum dt img {
  height: 2em;
  text-align: center;
}
.article .curriculum dd {
  margin: 0;
  padding: 0 0;
}
.article .curriculum dd > ul,
.article .curriculum dd > p {
  margin: 0 0 3em 0;
  padding: 0;
}
.article .curriculum dd ul {
  list-style: none;
  counter-reset: li;
}
.article .curriculum dd ul li {
  position: relative;
  margin: 0 0 0.5em 0;
  padding: 0 0 0 1.8em;
  counter-increment: li;
  line-height: 1.5em;
}
.article .curriculum dd ul li::before {
  content: counter(li) ".";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 1.5em;
  height: 1.5em;
  text-align: center;
  font-weight: bold;
  line-height: 1.5em;
}
.article .curriculum--step {
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .article .curriculum--step {
    margin-bottom: 20px;
  }
}
.article .curriculum--step::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 50px;
  background-color: transparent;
  background-image: url("../images/icon_dots.svg");
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
}
.article .curriculum--step.__term::after {
  display: none;
}
@media screen and (max-width: 768px) {
  .article .curriculum--step h5 {
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  .article .curriculum--step--point {
    margin-bottom: 20px;
    padding: 20px 30px;
    border-radius: 15px;
    background-color: #fff;
  }
}
@media screen and (max-width: 768px) {
  .article .curriculum--step--point p:first-child {
    margin-bottom: 0.6em;
    border-bottom: 1px solid #2a3d52;
    text-align: left;
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .article .curriculum--step--point > .__plan_personal {
    border-bottom-color: #ce0cd0 !important;
    color: #ce0cd0;
  }
}
.article .curriculum--step--point--list {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 0 15px;
}
.article .curriculum--step--point--list > div {
  align-self: stretch;
}
.article .curriculum--step--point--list .l--box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px;
  width: calc(33.3333333333% - 15px);
  aspect-ratio: 6/5;
  border: 1px solid #fff;
  border-radius: 15px;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .article .curriculum--step--point--list .l--box {
    width: 175px;
  }
}
@media screen and (max-width: 560px) {
  .article .curriculum--step--point--list .l--box {
    flex-direction: row;
    justify-content: flex-start;
    margin-bottom: 0;
    padding: 10px 0;
    width: 100%;
    aspect-ratio: unset;
    border: none;
    border-radius: 0;
    background-color: transparent;
  }
}
.article .curriculum--step--point--list .l--box figure {
  overflow: hidden;
  margin-bottom: 1.5em;
  width: 2.5em;
  aspect-ratio: 1;
}
@media screen and (max-width: 560px) {
  .article .curriculum--step--point--list .l--box figure {
    margin-bottom: 0;
    aspect-ratio: unset;
  }
}
.article .curriculum--step--point--list .l--box figure img {
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
  height: 100%;
}
.article .curriculum--step--point--list .l--box p {
  margin: 0;
  padding: 0;
  text-align: center;
  font-weight: bold;
  line-height: 1.3em;
}
@media screen and (max-width: 560px) {
  .article .curriculum--step--point--list .l--box p {
    flex: 1;
    padding-left: 1.5em;
    text-align: left;
  }
}
.article .curriculum--step--point--list .l--box p small {
  letter-spacing: 0;
  font-size: 0.75em;
  font-weight: normal;
}
.article .curriculum--step--point--list .__plan_personal {
  border: 1px solid #ce0cd0;
  background-color: transparent;
}
.article .curriculum--step--point--list .__plan_personal,
.article .curriculum--step--point--list .__plan_personal p {
  color: #ce0cd0;
}
@media screen and (max-width: 768px) {
  .article .curriculum--step--point--list .__plan_personal {
    align-items: flex-start;
    border: none !important;
  }
}
.article .curriculum--step--point--list .hr__personal {
  display: none;
}
@media screen and (max-width: 768px) {
  .article .curriculum--step--point--list .hr__personal {
    display: block;
    margin: 15px auto;
    width: 100%;
    border: none;
    border-top: 4px dotted #ce0cd0 !important;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
  }
}
.article .curriculum--col-2 {
  gap: 0 60px;
}
.article .curriculum--col-2 > * {
  width: calc(50% - 60px);
}
@media screen and (max-width: 768px) {
  .article .curriculum--col-2 > * {
    width: 100%;
  }
  .article .curriculum--col-2 > * .inner {
    padding: 0 30px;
  }
}
@media screen and (max-width: 768px) {
  .article .curriculum--col-2 div:first-child {
    order: 2;
  }
  .article .curriculum--col-2 div:last-child {
    order: 1;
  }
}
.article .curriculum--col-2 .btn__outline {
  max-width: none;
}
.article .msg {
  margin-top: 100px;
  padding-top: 1.5em;
  border-top: 1px solid #2a3d52;
}
.article .msg--profile {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 25px;
  padding: 30px;
  border: 2px solid #2a3d52;
  border-radius: 30px;
}
@media screen and (max-width: 768px) {
  .article .msg--profile {
    flex-direction: column;
    justify-content: center;
  }
}
.article .msg--profile figure {
  display: block;
  overflow: hidden;
  width: 160px;
  aspect-ratio: 1;
}
@media screen and (max-width: 768px) {
  .article .msg--profile figure {
    margin: 0 auto 1em auto;
    width: 104px;
  }
}
.article .msg--profile figure img {
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.article .msg--profile > div {
  flex: 1;
}
.article .msg--profile p {
  font-size: 0.75em;
}
.article .msg--profile p strong {
  font-size: 1rem;
}
.article .msg--profile p:last-child {
  margin-bottom: 0;
}
.article .voice .__link {
  display: none;
}

.msg table {
  border-collapse: collapse;
}
.msg table th {
  white-space: nowrap;
}
.msg table th,
.msg table td {
  padding: 0.2em 0.5em;
  border: solid 1px #666;
}/*# sourceMappingURL=article.css.map */


/* 20240916 add */
.__is_close.btn__toggle::after {
  content: "\e902" !important;
}