@charset "UTF-8";
/* mixin var
-----------------------------------------------------*/
/* reset
-----------------------------------------------------*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
}

img {
  vertical-align: top;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  -webkit-font-smoothing: antialiased;
}

body {
  line-height: 1;
}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
  display: block;
}

ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

a {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted #000;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #E0E0E0;
  margin: 0;
  padding: 0;
}

/* html
-----------------------------------------------------*/
html {
  overflow: auto;
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  color: #242424;
  font-size: 1.6rem;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", sans-serif;
  line-height: 1.7;
  font-weight: 400;
  overflow-wrap: break-word;
  word-break: break-word;
  overflow: hidden;
  position: relative;
}
@media (max-width: 1199px) {
  body {
    font-size: 1.4rem;
  }
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

/* link
-----------------------------------------------------*/
a {
  text-decoration: none;
  color: #242424;
}
a {
  transition: 0.3s linear;
  box-sizing: border-box;
}
a:hover {
  opacity: 0.7;
}

/*flex
-----------------------------------------------------*/
.flex {
  display: flex;
}
@media (max-width: 1600px) {
  .flex-xxxl {
    display: flex !important;
  }
}
@media (max-width: 1399px) {
  .flex-xxl {
    display: flex !important;
  }
}
@media (max-width: 1199px) {
  .flex-xl {
    display: flex !important;
  }
}
@media (max-width: 991px) {
  .flex-lg {
    display: flex !important;
  }
}
@media (max-width: 767px) {
  .flex-md {
    display: flex !important;
  }
}
@media (max-width: 575px) {
  .flex-sm {
    display: flex !important;
  }
}

.justify-start {
  justify-content: start;
}
@media (max-width: 1600px) {
  .justify-start-xxxl {
    justify-content: start !important;
  }
}
@media (max-width: 1399px) {
  .justify-start-xxl {
    justify-content: start !important;
  }
}
@media (max-width: 1199px) {
  .justify-start-xl {
    justify-content: start !important;
  }
}
@media (max-width: 991px) {
  .justify-start-lg {
    justify-content: start !important;
  }
}
@media (max-width: 767px) {
  .justify-start-md {
    justify-content: start !important;
  }
}
@media (max-width: 575px) {
  .justify-start-sm {
    justify-content: start !important;
  }
}

.justify-center {
  justify-content: center;
}
@media (max-width: 1600px) {
  .justify-center-xxxl {
    justify-content: center !important;
  }
}
@media (max-width: 1399px) {
  .justify-center-xxl {
    justify-content: center !important;
  }
}
@media (max-width: 1199px) {
  .justify-center-xl {
    justify-content: center !important;
  }
}
@media (max-width: 991px) {
  .justify-center-lg {
    justify-content: center !important;
  }
}
@media (max-width: 767px) {
  .justify-center-md {
    justify-content: center !important;
  }
}
@media (max-width: 575px) {
  .justify-center-sm {
    justify-content: center !important;
  }
}

.justify-between {
  justify-content: space-between;
}
@media (max-width: 1600px) {
  .justify-between-xxxl {
    justify-content: space-between !important;
  }
}
@media (max-width: 1399px) {
  .justify-between-xxl {
    justify-content: space-between !important;
  }
}
@media (max-width: 1199px) {
  .justify-between-xl {
    justify-content: space-between !important;
  }
}
@media (max-width: 991px) {
  .justify-between-lg {
    justify-content: space-between !important;
  }
}
@media (max-width: 767px) {
  .justify-between-md {
    justify-content: space-between !important;
  }
}
@media (max-width: 575px) {
  .justify-between-sm {
    justify-content: space-between !important;
  }
}

.justify-around {
  justify-content: space-around;
}
@media (max-width: 1600px) {
  .justify-around-xxxl {
    justify-content: space-around !important;
  }
}
@media (max-width: 1399px) {
  .justify-around-xxl {
    justify-content: space-around !important;
  }
}
@media (max-width: 1199px) {
  .justify-around-xl {
    justify-content: space-around !important;
  }
}
@media (max-width: 991px) {
  .justify-around-lg {
    justify-content: space-around !important;
  }
}
@media (max-width: 767px) {
  .justify-around-md {
    justify-content: space-around !important;
  }
}
@media (max-width: 575px) {
  .justify-around-sm {
    justify-content: space-around !important;
  }
}

.justify-end {
  justify-content: end;
}
@media (max-width: 1600px) {
  .justify-end-xxxl {
    justify-content: end !important;
  }
}
@media (max-width: 1399px) {
  .justify-end-xxl {
    justify-content: end !important;
  }
}
@media (max-width: 1199px) {
  .justify-end-xl {
    justify-content: end !important;
  }
}
@media (max-width: 991px) {
  .justify-end-lg {
    justify-content: end !important;
  }
}
@media (max-width: 767px) {
  .justify-end-md {
    justify-content: end !important;
  }
}
@media (max-width: 575px) {
  .justify-end-sm {
    justify-content: end !important;
  }
}

.align-items-start {
  align-items: flex-start;
}
@media (max-width: 1600px) {
  .align-items-start-xxxl {
    align-items: flex-start !important;
  }
}
@media (max-width: 1399px) {
  .align-items-start-xxl {
    align-items: flex-start !important;
  }
}
@media (max-width: 1199px) {
  .align-items-start-xl {
    align-items: flex-start !important;
  }
}
@media (max-width: 991px) {
  .align-items-start-lg {
    align-items: flex-start !important;
  }
}
@media (max-width: 767px) {
  .align-items-start-md {
    align-items: flex-start !important;
  }
}
@media (max-width: 575px) {
  .align-items-start-sm {
    align-items: flex-start !important;
  }
}

.align-items-center {
  align-items: center;
}
@media (max-width: 1600px) {
  .align-items-center-xxxl {
    align-items: center !important;
  }
}
@media (max-width: 1399px) {
  .align-items-center-xxl {
    align-items: center !important;
  }
}
@media (max-width: 1199px) {
  .align-items-center-xl {
    align-items: center !important;
  }
}
@media (max-width: 991px) {
  .align-items-center-lg {
    align-items: center !important;
  }
}
@media (max-width: 767px) {
  .align-items-center-md {
    align-items: center !important;
  }
}
@media (max-width: 575px) {
  .align-items-center-sm {
    align-items: center !important;
  }
}

.align-items-end {
  align-items: flex-end;
}
@media (max-width: 1600px) {
  .align-items-end-xxxl {
    align-items: flex-end !important;
  }
}
@media (max-width: 1399px) {
  .align-items-end-xxl {
    align-items: flex-end !important;
  }
}
@media (max-width: 1199px) {
  .align-items-end-xl {
    align-items: flex-end !important;
  }
}
@media (max-width: 991px) {
  .align-items-end-lg {
    align-items: flex-end !important;
  }
}
@media (max-width: 767px) {
  .align-items-end-md {
    align-items: flex-end !important;
  }
}
@media (max-width: 575px) {
  .align-items-end-sm {
    align-items: flex-end !important;
  }
}

.flex-wrap {
  flex-wrap: wrap;
}
@media (max-width: 1600px) {
  .flex-wrap-xxxl {
    flex-wrap: wrap !important;
  }
}
@media (max-width: 1399px) {
  .flex-wrap-xxl {
    flex-wrap: wrap !important;
  }
}
@media (max-width: 1199px) {
  .flex-wrap-xl {
    flex-wrap: wrap !important;
  }
}
@media (max-width: 991px) {
  .flex-wrap-lg {
    flex-wrap: wrap !important;
  }
}
@media (max-width: 767px) {
  .flex-wrap-md {
    flex-wrap: wrap !important;
  }
}
@media (max-width: 575px) {
  .flex-wrap-sm {
    flex-wrap: wrap !important;
  }
}

.flex-nowrap {
  flex-wrap: nowrap;
}
@media (max-width: 1600px) {
  .flex-nowrap-xxxl {
    flex-wrap: nowrap !important;
  }
}
@media (max-width: 1399px) {
  .flex-nowrap-xxl {
    flex-wrap: nowrap !important;
  }
}
@media (max-width: 1199px) {
  .flex-nowrap-xl {
    flex-wrap: nowrap !important;
  }
}
@media (max-width: 991px) {
  .flex-nowrap-lg {
    flex-wrap: nowrap !important;
  }
}
@media (max-width: 767px) {
  .flex-nowrap-md {
    flex-wrap: nowrap !important;
  }
}
@media (max-width: 575px) {
  .flex-nowrap-sm {
    flex-wrap: nowrap !important;
  }
}

/*font-size
-----------------------------------------------------*/
.fs-10 {
  font-size: 1rem;
}

.fs-11 {
  font-size: 1.1rem;
}

.fs-12 {
  font-size: 1.2rem;
}

.fs-13 {
  font-size: 1.3rem;
}

.fs-14 {
  font-size: 1.4rem;
}

.fs-15 {
  font-size: 1.5rem;
}

.fs-16 {
  font-size: 1.6rem;
}

.fs-17 {
  font-size: 1.7rem;
}

.fs-18 {
  font-size: 1.8rem;
}

.fs-19 {
  font-size: 1.9rem;
}

.fs-20 {
  font-size: 2rem;
}

.fs-21 {
  font-size: 2.1rem;
}

.fs-22 {
  font-size: 2.2rem;
}

.fs-23 {
  font-size: 2.3rem;
}

.fs-24 {
  font-size: 2.4rem;
}

.fs-25 {
  font-size: 2.5rem;
}

.fs-26 {
  font-size: 2.6rem;
}

.fs-27 {
  font-size: 2.7rem;
}

.fs-28 {
  font-size: 2.8rem;
}

.fs-29 {
  font-size: 2.9rem;
}

.fs-30 {
  font-size: 3rem;
}

.fs-31 {
  font-size: 3.1rem;
}

.fs-32 {
  font-size: 3.2rem;
}

.fs-33 {
  font-size: 3.3rem;
}

.fs-34 {
  font-size: 3.4rem;
}

.fs-35 {
  font-size: 3.5rem;
}

.fs-36 {
  font-size: 3.6rem;
}

.fs-37 {
  font-size: 3.7rem;
}

.fs-38 {
  font-size: 3.8rem;
}

.fs-39 {
  font-size: 3.9rem;
}

.fs-40 {
  font-size: 4rem;
}

.fs-41 {
  font-size: 4.1rem;
}

.fs-42 {
  font-size: 4.2rem;
}

.fs-43 {
  font-size: 4.3rem;
}

.fs-44 {
  font-size: 4.4rem;
}

.fs-45 {
  font-size: 4.5rem;
}

.fs-46 {
  font-size: 4.6rem;
}

.fs-47 {
  font-size: 4.7rem;
}

.fs-48 {
  font-size: 4.8rem;
}

.fs-49 {
  font-size: 4.9rem;
}

.fs-50 {
  font-size: 5rem;
}

@media (max-width: 1600px) {
  .fs-10-xxxl {
    font-size: 1rem;
  }
  .fs-11-xxxl {
    font-size: 1.1rem;
  }
  .fs-12-xxxl {
    font-size: 1.2rem;
  }
  .fs-13-xxxl {
    font-size: 1.3rem;
  }
  .fs-14-xxxl {
    font-size: 1.4rem;
  }
  .fs-15-xxxl {
    font-size: 1.5rem;
  }
  .fs-16-xxxl {
    font-size: 1.6rem;
  }
  .fs-17-xxxl {
    font-size: 1.7rem;
  }
  .fs-18-xxxl {
    font-size: 1.8rem;
  }
  .fs-19-xxxl {
    font-size: 1.9rem;
  }
  .fs-20-xxxl {
    font-size: 2rem;
  }
  .fs-21-xxxl {
    font-size: 2.1rem;
  }
  .fs-22-xxxl {
    font-size: 2.2rem;
  }
  .fs-23-xxxl {
    font-size: 2.3rem;
  }
  .fs-24-xxxl {
    font-size: 2.4rem;
  }
  .fs-25-xxxl {
    font-size: 2.5rem;
  }
  .fs-26-xxxl {
    font-size: 2.6rem;
  }
  .fs-27-xxxl {
    font-size: 2.7rem;
  }
  .fs-28-xxxl {
    font-size: 2.8rem;
  }
  .fs-29-xxxl {
    font-size: 2.9rem;
  }
  .fs-30-xxxl {
    font-size: 3rem;
  }
  .fs-31-xxxl {
    font-size: 3.1rem;
  }
  .fs-32-xxxl {
    font-size: 3.2rem;
  }
  .fs-33-xxxl {
    font-size: 3.3rem;
  }
  .fs-34-xxxl {
    font-size: 3.4rem;
  }
  .fs-35-xxxl {
    font-size: 3.5rem;
  }
  .fs-36-xxxl {
    font-size: 3.6rem;
  }
  .fs-37-xxxl {
    font-size: 3.7rem;
  }
  .fs-38-xxxl {
    font-size: 3.8rem;
  }
  .fs-39-xxxl {
    font-size: 3.9rem;
  }
  .fs-40-xxxl {
    font-size: 4rem;
  }
  .fs-41-xxxl {
    font-size: 4.1rem;
  }
  .fs-42-xxxl {
    font-size: 4.2rem;
  }
  .fs-43-xxxl {
    font-size: 4.3rem;
  }
  .fs-44-xxxl {
    font-size: 4.4rem;
  }
  .fs-45-xxxl {
    font-size: 4.5rem;
  }
  .fs-46-xxxl {
    font-size: 4.6rem;
  }
  .fs-47-xxxl {
    font-size: 4.7rem;
  }
  .fs-48-xxxl {
    font-size: 4.8rem;
  }
  .fs-49-xxxl {
    font-size: 4.9rem;
  }
  .fs-50-xxxl {
    font-size: 5rem;
  }
}
@media (max-width: 1399px) {
  .fs-10-xxl {
    font-size: 1rem;
  }
  .fs-11-xxl {
    font-size: 1.1rem;
  }
  .fs-12-xxl {
    font-size: 1.2rem;
  }
  .fs-13-xxl {
    font-size: 1.3rem;
  }
  .fs-14-xxl {
    font-size: 1.4rem;
  }
  .fs-15-xxl {
    font-size: 1.5rem;
  }
  .fs-16-xxl {
    font-size: 1.6rem;
  }
  .fs-17-xxl {
    font-size: 1.7rem;
  }
  .fs-18-xxl {
    font-size: 1.8rem;
  }
  .fs-19-xxl {
    font-size: 1.9rem;
  }
  .fs-20-xxl {
    font-size: 2rem;
  }
  .fs-21-xxl {
    font-size: 2.1rem;
  }
  .fs-22-xxl {
    font-size: 2.2rem;
  }
  .fs-23-xxl {
    font-size: 2.3rem;
  }
  .fs-24-xxl {
    font-size: 2.4rem;
  }
  .fs-25-xxl {
    font-size: 2.5rem;
  }
  .fs-26-xxl {
    font-size: 2.6rem;
  }
  .fs-27-xxl {
    font-size: 2.7rem;
  }
  .fs-28-xxl {
    font-size: 2.8rem;
  }
  .fs-29-xxl {
    font-size: 2.9rem;
  }
  .fs-30-xxl {
    font-size: 3rem;
  }
  .fs-31-xxl {
    font-size: 3.1rem;
  }
  .fs-32-xxl {
    font-size: 3.2rem;
  }
  .fs-33-xxl {
    font-size: 3.3rem;
  }
  .fs-34-xxl {
    font-size: 3.4rem;
  }
  .fs-35-xxl {
    font-size: 3.5rem;
  }
  .fs-36-xxl {
    font-size: 3.6rem;
  }
  .fs-37-xxl {
    font-size: 3.7rem;
  }
  .fs-38-xxl {
    font-size: 3.8rem;
  }
  .fs-39-xxl {
    font-size: 3.9rem;
  }
  .fs-40-xxl {
    font-size: 4rem;
  }
  .fs-41-xxl {
    font-size: 4.1rem;
  }
  .fs-42-xxl {
    font-size: 4.2rem;
  }
  .fs-43-xxl {
    font-size: 4.3rem;
  }
  .fs-44-xxl {
    font-size: 4.4rem;
  }
  .fs-45-xxl {
    font-size: 4.5rem;
  }
  .fs-46-xxl {
    font-size: 4.6rem;
  }
  .fs-47-xxl {
    font-size: 4.7rem;
  }
  .fs-48-xxl {
    font-size: 4.8rem;
  }
  .fs-49-xxl {
    font-size: 4.9rem;
  }
  .fs-50-xxl {
    font-size: 5rem;
  }
}
@media (max-width: 1199px) {
  .fs-10-xl {
    font-size: 1rem;
  }
  .fs-11-xl {
    font-size: 1.1rem;
  }
  .fs-12-xl {
    font-size: 1.2rem;
  }
  .fs-13-xl {
    font-size: 1.3rem;
  }
  .fs-14-xl {
    font-size: 1.4rem;
  }
  .fs-15-xl {
    font-size: 1.5rem;
  }
  .fs-16-xl {
    font-size: 1.6rem;
  }
  .fs-17-xl {
    font-size: 1.7rem;
  }
  .fs-18-xl {
    font-size: 1.8rem;
  }
  .fs-19-xl {
    font-size: 1.9rem;
  }
  .fs-20-xl {
    font-size: 2rem;
  }
  .fs-21-xl {
    font-size: 2.1rem;
  }
  .fs-22-xl {
    font-size: 2.2rem;
  }
  .fs-23-xl {
    font-size: 2.3rem;
  }
  .fs-24-xl {
    font-size: 2.4rem;
  }
  .fs-25-xl {
    font-size: 2.5rem;
  }
  .fs-26-xl {
    font-size: 2.6rem;
  }
  .fs-27-xl {
    font-size: 2.7rem;
  }
  .fs-28-xl {
    font-size: 2.8rem;
  }
  .fs-29-xl {
    font-size: 2.9rem;
  }
  .fs-30-xl {
    font-size: 3rem;
  }
  .fs-31-xl {
    font-size: 3.1rem;
  }
  .fs-32-xl {
    font-size: 3.2rem;
  }
  .fs-33-xl {
    font-size: 3.3rem;
  }
  .fs-34-xl {
    font-size: 3.4rem;
  }
  .fs-35-xl {
    font-size: 3.5rem;
  }
  .fs-36-xl {
    font-size: 3.6rem;
  }
  .fs-37-xl {
    font-size: 3.7rem;
  }
  .fs-38-xl {
    font-size: 3.8rem;
  }
  .fs-39-xl {
    font-size: 3.9rem;
  }
  .fs-40-xl {
    font-size: 4rem;
  }
  .fs-41-xl {
    font-size: 4.1rem;
  }
  .fs-42-xl {
    font-size: 4.2rem;
  }
  .fs-43-xl {
    font-size: 4.3rem;
  }
  .fs-44-xl {
    font-size: 4.4rem;
  }
  .fs-45-xl {
    font-size: 4.5rem;
  }
  .fs-46-xl {
    font-size: 4.6rem;
  }
  .fs-47-xl {
    font-size: 4.7rem;
  }
  .fs-48-xl {
    font-size: 4.8rem;
  }
  .fs-49-xl {
    font-size: 4.9rem;
  }
  .fs-50-xl {
    font-size: 5rem;
  }
}
@media (max-width: 991px) {
  .fs-10-lg {
    font-size: 1rem;
  }
  .fs-11-lg {
    font-size: 1.1rem;
  }
  .fs-12-lg {
    font-size: 1.2rem;
  }
  .fs-13-lg {
    font-size: 1.3rem;
  }
  .fs-14-lg {
    font-size: 1.4rem;
  }
  .fs-15-lg {
    font-size: 1.5rem;
  }
  .fs-16-lg {
    font-size: 1.6rem;
  }
  .fs-17-lg {
    font-size: 1.7rem;
  }
  .fs-18-lg {
    font-size: 1.8rem;
  }
  .fs-19-lg {
    font-size: 1.9rem;
  }
  .fs-20-lg {
    font-size: 2rem;
  }
  .fs-21-lg {
    font-size: 2.1rem;
  }
  .fs-22-lg {
    font-size: 2.2rem;
  }
  .fs-23-lg {
    font-size: 2.3rem;
  }
  .fs-24-lg {
    font-size: 2.4rem;
  }
  .fs-25-lg {
    font-size: 2.5rem;
  }
  .fs-26-lg {
    font-size: 2.6rem;
  }
  .fs-27-lg {
    font-size: 2.7rem;
  }
  .fs-28-lg {
    font-size: 2.8rem;
  }
  .fs-29-lg {
    font-size: 2.9rem;
  }
  .fs-30-lg {
    font-size: 3rem;
  }
  .fs-31-lg {
    font-size: 3.1rem;
  }
  .fs-32-lg {
    font-size: 3.2rem;
  }
  .fs-33-lg {
    font-size: 3.3rem;
  }
  .fs-34-lg {
    font-size: 3.4rem;
  }
  .fs-35-lg {
    font-size: 3.5rem;
  }
  .fs-36-lg {
    font-size: 3.6rem;
  }
  .fs-37-lg {
    font-size: 3.7rem;
  }
  .fs-38-lg {
    font-size: 3.8rem;
  }
  .fs-39-lg {
    font-size: 3.9rem;
  }
  .fs-40-lg {
    font-size: 4rem;
  }
  .fs-41-lg {
    font-size: 4.1rem;
  }
  .fs-42-lg {
    font-size: 4.2rem;
  }
  .fs-43-lg {
    font-size: 4.3rem;
  }
  .fs-44-lg {
    font-size: 4.4rem;
  }
  .fs-45-lg {
    font-size: 4.5rem;
  }
  .fs-46-lg {
    font-size: 4.6rem;
  }
  .fs-47-lg {
    font-size: 4.7rem;
  }
  .fs-48-lg {
    font-size: 4.8rem;
  }
  .fs-49-lg {
    font-size: 4.9rem;
  }
  .fs-50-lg {
    font-size: 5rem;
  }
}
@media (max-width: 767px) {
  .fs-10-md {
    font-size: 1rem;
  }
  .fs-11-md {
    font-size: 1.1rem;
  }
  .fs-12-md {
    font-size: 1.2rem;
  }
  .fs-13-md {
    font-size: 1.3rem;
  }
  .fs-14-md {
    font-size: 1.4rem;
  }
  .fs-15-md {
    font-size: 1.5rem;
  }
  .fs-16-md {
    font-size: 1.6rem;
  }
  .fs-17-md {
    font-size: 1.7rem;
  }
  .fs-18-md {
    font-size: 1.8rem;
  }
  .fs-19-md {
    font-size: 1.9rem;
  }
  .fs-20-md {
    font-size: 2rem;
  }
  .fs-21-md {
    font-size: 2.1rem;
  }
  .fs-22-md {
    font-size: 2.2rem;
  }
  .fs-23-md {
    font-size: 2.3rem;
  }
  .fs-24-md {
    font-size: 2.4rem;
  }
  .fs-25-md {
    font-size: 2.5rem;
  }
  .fs-26-md {
    font-size: 2.6rem;
  }
  .fs-27-md {
    font-size: 2.7rem;
  }
  .fs-28-md {
    font-size: 2.8rem;
  }
  .fs-29-md {
    font-size: 2.9rem;
  }
  .fs-30-md {
    font-size: 3rem;
  }
  .fs-31-md {
    font-size: 3.1rem;
  }
  .fs-32-md {
    font-size: 3.2rem;
  }
  .fs-33-md {
    font-size: 3.3rem;
  }
  .fs-34-md {
    font-size: 3.4rem;
  }
  .fs-35-md {
    font-size: 3.5rem;
  }
  .fs-36-md {
    font-size: 3.6rem;
  }
  .fs-37-md {
    font-size: 3.7rem;
  }
  .fs-38-md {
    font-size: 3.8rem;
  }
  .fs-39-md {
    font-size: 3.9rem;
  }
  .fs-40-md {
    font-size: 4rem;
  }
  .fs-41-md {
    font-size: 4.1rem;
  }
  .fs-42-md {
    font-size: 4.2rem;
  }
  .fs-43-md {
    font-size: 4.3rem;
  }
  .fs-44-md {
    font-size: 4.4rem;
  }
  .fs-45-md {
    font-size: 4.5rem;
  }
  .fs-46-md {
    font-size: 4.6rem;
  }
  .fs-47-md {
    font-size: 4.7rem;
  }
  .fs-48-md {
    font-size: 4.8rem;
  }
  .fs-49-md {
    font-size: 4.9rem;
  }
  .fs-50-md {
    font-size: 5rem;
  }
}
@media (max-width: 575px) {
  .fs-10-sm {
    font-size: 1rem;
  }
  .fs-11-sm {
    font-size: 1.1rem;
  }
  .fs-12-sm {
    font-size: 1.2rem;
  }
  .fs-13-sm {
    font-size: 1.3rem;
  }
  .fs-14-sm {
    font-size: 1.4rem;
  }
  .fs-15-sm {
    font-size: 1.5rem;
  }
  .fs-16-sm {
    font-size: 1.6rem;
  }
  .fs-17-sm {
    font-size: 1.7rem;
  }
  .fs-18-sm {
    font-size: 1.8rem;
  }
  .fs-19-sm {
    font-size: 1.9rem;
  }
  .fs-20-sm {
    font-size: 2rem;
  }
  .fs-21-sm {
    font-size: 2.1rem;
  }
  .fs-22-sm {
    font-size: 2.2rem;
  }
  .fs-23-sm {
    font-size: 2.3rem;
  }
  .fs-24-sm {
    font-size: 2.4rem;
  }
  .fs-25-sm {
    font-size: 2.5rem;
  }
  .fs-26-sm {
    font-size: 2.6rem;
  }
  .fs-27-sm {
    font-size: 2.7rem;
  }
  .fs-28-sm {
    font-size: 2.8rem;
  }
  .fs-29-sm {
    font-size: 2.9rem;
  }
  .fs-30-sm {
    font-size: 3rem;
  }
  .fs-31-sm {
    font-size: 3.1rem;
  }
  .fs-32-sm {
    font-size: 3.2rem;
  }
  .fs-33-sm {
    font-size: 3.3rem;
  }
  .fs-34-sm {
    font-size: 3.4rem;
  }
  .fs-35-sm {
    font-size: 3.5rem;
  }
  .fs-36-sm {
    font-size: 3.6rem;
  }
  .fs-37-sm {
    font-size: 3.7rem;
  }
  .fs-38-sm {
    font-size: 3.8rem;
  }
  .fs-39-sm {
    font-size: 3.9rem;
  }
  .fs-40-sm {
    font-size: 4rem;
  }
  .fs-41-sm {
    font-size: 4.1rem;
  }
  .fs-42-sm {
    font-size: 4.2rem;
  }
  .fs-43-sm {
    font-size: 4.3rem;
  }
  .fs-44-sm {
    font-size: 4.4rem;
  }
  .fs-45-sm {
    font-size: 4.5rem;
  }
  .fs-46-sm {
    font-size: 4.6rem;
  }
  .fs-47-sm {
    font-size: 4.7rem;
  }
  .fs-48-sm {
    font-size: 4.8rem;
  }
  .fs-49-sm {
    font-size: 4.9rem;
  }
  .fs-50-sm {
    font-size: 5rem;
  }
}
.lh-1 {
  line-height: 1.1 !important;
}

.lh-2 {
  line-height: 1.2 !important;
}

.lh-3 {
  line-height: 1.3 !important;
}

.lh-4 {
  line-height: 1.4 !important;
}

.lh-5 {
  line-height: 1.5 !important;
}

.lh-6 {
  line-height: 1.6 !important;
}

.lh-7 {
  line-height: 1.7 !important;
}

.lh-8 {
  line-height: 1.8 !important;
}

.lh-9 {
  line-height: 1.9 !important;
}

.lh-10 {
  line-height: 2 !important;
}

.lh-11 {
  line-height: 2.1 !important;
}

.lh-12 {
  line-height: 2.2 !important;
}

.lh-13 {
  line-height: 2.3 !important;
}

.lh-14 {
  line-height: 2.4 !important;
}

.lh-15 {
  line-height: 2.5 !important;
}

@media (max-width: 1600px) {
  .lh-1-xxxl {
    line-height: 1.1 !important;
  }
  .lh-2-xxxl {
    line-height: 1.2 !important;
  }
  .lh-3-xxxl {
    line-height: 1.3 !important;
  }
  .lh-4-xxxl {
    line-height: 1.4 !important;
  }
  .lh-5-xxxl {
    line-height: 1.5 !important;
  }
  .lh-6-xxxl {
    line-height: 1.6 !important;
  }
  .lh-7-xxxl {
    line-height: 1.7 !important;
  }
  .lh-8-xxxl {
    line-height: 1.8 !important;
  }
  .lh-9-xxxl {
    line-height: 1.9 !important;
  }
  .lh-10-xxxl {
    line-height: 2 !important;
  }
  .lh-11-xxxl {
    line-height: 2.1 !important;
  }
  .lh-12-xxxl {
    line-height: 2.2 !important;
  }
  .lh-13-xxxl {
    line-height: 2.3 !important;
  }
  .lh-14-xxxl {
    line-height: 2.4 !important;
  }
  .lh-15-xxxl {
    line-height: 2.5 !important;
  }
}
@media (max-width: 1399px) {
  .lh-1-xxl {
    line-height: 1.1 !important;
  }
  .lh-2-xxl {
    line-height: 1.2 !important;
  }
  .lh-3-xxl {
    line-height: 1.3 !important;
  }
  .lh-4-xxl {
    line-height: 1.4 !important;
  }
  .lh-5-xxl {
    line-height: 1.5 !important;
  }
  .lh-6-xxl {
    line-height: 1.6 !important;
  }
  .lh-7-xxl {
    line-height: 1.7 !important;
  }
  .lh-8-xxl {
    line-height: 1.8 !important;
  }
  .lh-9-xxl {
    line-height: 1.9 !important;
  }
  .lh-10-xxl {
    line-height: 2 !important;
  }
  .lh-11-xxl {
    line-height: 2.1 !important;
  }
  .lh-12-xxl {
    line-height: 2.2 !important;
  }
  .lh-13-xxl {
    line-height: 2.3 !important;
  }
  .lh-14-xxl {
    line-height: 2.4 !important;
  }
  .lh-15-xxl {
    line-height: 2.5 !important;
  }
}
@media (max-width: 1199px) {
  .lh-1-xl {
    line-height: 1.1 !important;
  }
  .lh-2-xl {
    line-height: 1.2 !important;
  }
  .lh-3-xl {
    line-height: 1.3 !important;
  }
  .lh-4-xl {
    line-height: 1.4 !important;
  }
  .lh-5-xl {
    line-height: 1.5 !important;
  }
  .lh-6-xl {
    line-height: 1.6 !important;
  }
  .lh-7-xl {
    line-height: 1.7 !important;
  }
  .lh-8-xl {
    line-height: 1.8 !important;
  }
  .lh-9-xl {
    line-height: 1.9 !important;
  }
  .lh-10-xl {
    line-height: 2 !important;
  }
  .lh-11-xl {
    line-height: 2.1 !important;
  }
  .lh-12-xl {
    line-height: 2.2 !important;
  }
  .lh-13-xl {
    line-height: 2.3 !important;
  }
  .lh-14-xl {
    line-height: 2.4 !important;
  }
  .lh-15-xl {
    line-height: 2.5 !important;
  }
}
@media (max-width: 991px) {
  .lh-1-lg {
    line-height: 1.1 !important;
  }
  .lh-2-lg {
    line-height: 1.2 !important;
  }
  .lh-3-lg {
    line-height: 1.3 !important;
  }
  .lh-4-lg {
    line-height: 1.4 !important;
  }
  .lh-5-lg {
    line-height: 1.5 !important;
  }
  .lh-6-lg {
    line-height: 1.6 !important;
  }
  .lh-7-lg {
    line-height: 1.7 !important;
  }
  .lh-8-lg {
    line-height: 1.8 !important;
  }
  .lh-9-lg {
    line-height: 1.9 !important;
  }
  .lh-10-lg {
    line-height: 2 !important;
  }
  .lh-11-lg {
    line-height: 2.1 !important;
  }
  .lh-12-lg {
    line-height: 2.2 !important;
  }
  .lh-13-lg {
    line-height: 2.3 !important;
  }
  .lh-14-lg {
    line-height: 2.4 !important;
  }
  .lh-15-lg {
    line-height: 2.5 !important;
  }
}
@media (max-width: 767px) {
  .lh-1-md {
    line-height: 1.1 !important;
  }
  .lh-2-md {
    line-height: 1.2 !important;
  }
  .lh-3-md {
    line-height: 1.3 !important;
  }
  .lh-4-md {
    line-height: 1.4 !important;
  }
  .lh-5-md {
    line-height: 1.5 !important;
  }
  .lh-6-md {
    line-height: 1.6 !important;
  }
  .lh-7-md {
    line-height: 1.7 !important;
  }
  .lh-8-md {
    line-height: 1.8 !important;
  }
  .lh-9-md {
    line-height: 1.9 !important;
  }
  .lh-10-md {
    line-height: 2 !important;
  }
  .lh-11-md {
    line-height: 2.1 !important;
  }
  .lh-12-md {
    line-height: 2.2 !important;
  }
  .lh-13-md {
    line-height: 2.3 !important;
  }
  .lh-14-md {
    line-height: 2.4 !important;
  }
  .lh-15-md {
    line-height: 2.5 !important;
  }
}
@media (max-width: 575px) {
  .lh-1-sm {
    line-height: 1.1 !important;
  }
  .lh-2-sm {
    line-height: 1.2 !important;
  }
  .lh-3-sm {
    line-height: 1.3 !important;
  }
  .lh-4-sm {
    line-height: 1.4 !important;
  }
  .lh-5-sm {
    line-height: 1.5 !important;
  }
  .lh-6-sm {
    line-height: 1.6 !important;
  }
  .lh-7-sm {
    line-height: 1.7 !important;
  }
  .lh-8-sm {
    line-height: 1.8 !important;
  }
  .lh-9-sm {
    line-height: 1.9 !important;
  }
  .lh-10-sm {
    line-height: 2 !important;
  }
  .lh-11-sm {
    line-height: 2.1 !important;
  }
  .lh-12-sm {
    line-height: 2.2 !important;
  }
  .lh-13-sm {
    line-height: 2.3 !important;
  }
  .lh-14-sm {
    line-height: 2.4 !important;
  }
  .lh-15-sm {
    line-height: 2.5 !important;
  }
}
/*utility
-----------------------------------------------------*/
img {
  max-width: 100%;
  height: auto;
}

ol {
  padding-left: 1em;
}

.float-l {
  float: left;
}

.float-r {
  float: right;
}

.en, .c-heading-set__en, .c-heading-overlay__en, .c-flow__heading::before, .c-profile__name-en, .mod-toggle dt::before, .footer-etc__heading-en, .page-header__en, .p-top-hero__scroll-text, .p-top-news__heading-en, .p-top-news__heading-jp, .p-top-points__num {
  font-family: "Libre Baskerville", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  text-transform: uppercase;
}

/* 明朝系 */
.mincho, .c-heading-set__jp, .c-heading-dark__num, .c-heading-dark__text, .c-heading-overlay__jp, .c-heading-text-set__main, .c-heading-line, .c-flow__heading, .c-achievements__heading, .c-profile__company, .c-profile__name, .c-cta-banner__point, .c-cta-banner__heading, .header, .footer-etc__heading-jp, .footer, .page-header__jp, .single-head h1, .cat-header, .p-top-hero, .p-top-points__heading, .p-about-message__heading, .p-course-intro__header-main {
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-weight: 400;
}

/* ゴシック系 */
.gothic, .wpcf7-form button,
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=url],
.wpcf7-form input[type=tel],
.wpcf7-form input[type=password],
.wpcf7-form textarea,
.wpcf7-form input[type=submit],
.wpcf7-form input[type=button],
.wpcf7-form input[type=reset], .p-top-hero__circle-date {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 400;
}

em {
  font-style: normal;
  font-weight: bold;
}

.line {
  background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #BDA703 0%) repeat scroll 0 0;
}

.indent-list {
  text-indent: -1em;
  padding-left: 1em;
}

.disc-list {
  list-style: disc;
  padding-left: 1.5em;
}

.color-main {
  color: #003366 !important;
}

.color-sub {
  color: #BDA703 !important;
}

.color-white {
  color: #fff;
}

.bg-main {
  background: #003366;
}

.bg-sub {
  background: #BDA703;
}

.bg-gray {
  background: #F9F9F9;
}

.border {
  border: 1px solid;
}

.bold, .c-btn, .c-heading-set__jp, .c-heading-dark__text, .c-heading-simple, .c-heading-overlay__jp, .c-heading-text-set__main, .c-heading-line, .c-flow__heading, .c-achievements__heading, .c-profile__company, .c-profile__name, .c-cta-banner__point, .c-cta-banner__heading, .c-cta-banner__btn, .c-category-nav a, .c-check-list__item, .c-list-bordered__item, .mod-toggle dt, .wpcf7-form table th, .header-btn li, .nav-pc__gnav, .footer-etc__heading-jp, .footer__nav-group > li > a, .page-header__jp, .single-head h1, .cat-header, .post-cat li, .p-top-hero__catch-main, .p-top-hero__catch-sub, .p-top-hero__cta-text, .p-top-news__heading-jp, .p-top-schedule__button, .p-top-schedule__cta-text, .p-top-points__heading, .p-top-course__attention dt, .p-top-voice__text, .p-about-message__heading, .p-archive-voice__heading, .p-course-intro__header-sub, .p-course-intro__header-main {
  font-weight: bold;
  font-weight: 700;
}

.semibold, .c-heading-dark__num, .header__main-title, .footer__main-title {
  font-weight: 600;
}

.normal {
  font-weight: normal;
}

.underline {
  text-decoration: underline !important;
}

.indent {
  padding-left: 1.5rem;
  text-indent: -1.5rem;
}

.radius-pill, .c-category-nav a, .p-top-points__num {
  border-radius: 50px;
}

.radius-small, .c-btn, .c-achievements__label, .header-btn li a, #pup, .post-cat li, .p-voice-cat li {
  border-radius: 4px;
}

.align-l {
  text-align: left;
}
@media (max-width: 1600px) {
  .align-l-xxxl {
    text-align: left !important;
  }
}
@media (max-width: 1399px) {
  .align-l-xxl {
    text-align: left !important;
  }
}
@media (max-width: 1199px) {
  .align-l-xl {
    text-align: left !important;
  }
}
@media (max-width: 991px) {
  .align-l-lg {
    text-align: left !important;
  }
}
@media (max-width: 767px) {
  .align-l-md {
    text-align: left !important;
  }
}
@media (max-width: 575px) {
  .align-l-sm {
    text-align: left !important;
  }
}

.align-c {
  text-align: center;
}
@media (max-width: 1600px) {
  .align-c-xxxl {
    text-align: center !important;
  }
}
@media (max-width: 1399px) {
  .align-c-xxl {
    text-align: center !important;
  }
}
@media (max-width: 1199px) {
  .align-c-xl {
    text-align: center !important;
  }
}
@media (max-width: 991px) {
  .align-c-lg {
    text-align: center !important;
  }
}
@media (max-width: 767px) {
  .align-c-md {
    text-align: center !important;
  }
}
@media (max-width: 575px) {
  .align-c-sm {
    text-align: center !important;
  }
}

.align-r {
  text-align: right;
}
@media (max-width: 1600px) {
  .align-r-xxxl {
    text-align: right !important;
  }
}
@media (max-width: 1399px) {
  .align-r-xxl {
    text-align: right !important;
  }
}
@media (max-width: 1199px) {
  .align-r-xl {
    text-align: right !important;
  }
}
@media (max-width: 991px) {
  .align-r-lg {
    text-align: right !important;
  }
}
@media (max-width: 767px) {
  .align-r-md {
    text-align: right !important;
  }
}
@media (max-width: 575px) {
  .align-r-sm {
    text-align: right !important;
  }
}

.v-align-top {
  vertical-align: top !important;
}

.v-align-middle {
  vertical-align: middle !important;
}

.pos-r {
  position: relative;
}

.box-shadow {
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
}

.block {
  display: block;
}
@media (max-width: 1600px) {
  .block-xxxl {
    display: block !important;
  }
}
@media (max-width: 1399px) {
  .block-xxl {
    display: block !important;
  }
}
@media (max-width: 1199px) {
  .block-xl {
    display: block !important;
  }
}
@media (max-width: 991px) {
  .block-lg {
    display: block !important;
  }
}
@media (max-width: 767px) {
  .block-md {
    display: block !important;
  }
}
@media (max-width: 575px) {
  .block-sm {
    display: block !important;
  }
}

.none {
  display: none;
}
@media (max-width: 1600px) {
  .none-xxxl {
    display: none !important;
  }
}
@media (max-width: 1399px) {
  .none-xxl {
    display: none !important;
  }
}
@media (max-width: 1199px) {
  .none-xl {
    display: none !important;
  }
}
@media (max-width: 991px) {
  .none-lg {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .none-md {
    display: none !important;
  }
}
@media (max-width: 575px) {
  .none-sm {
    display: none !important;
  }
}

.inline-block {
  display: inline-block;
}
@media (max-width: 1600px) {
  .inline-block-xxxl {
    display: inline-block !important;
  }
}
@media (max-width: 1399px) {
  .inline-block-xxl {
    display: inline-block !important;
  }
}
@media (max-width: 1199px) {
  .inline-block-xl {
    display: inline-block !important;
  }
}
@media (max-width: 991px) {
  .inline-block-lg {
    display: inline-block !important;
  }
}
@media (max-width: 767px) {
  .inline-block-md {
    display: inline-block !important;
  }
}
@media (max-width: 575px) {
  .inline-block-sm {
    display: inline-block !important;
  }
}

.inline {
  display: inline;
}
@media (max-width: 1600px) {
  .inline-xxxl {
    display: inline !important;
  }
}
@media (max-width: 1399px) {
  .inline-xxl {
    display: inline !important;
  }
}
@media (max-width: 1199px) {
  .inline-xl {
    display: inline !important;
  }
}
@media (max-width: 991px) {
  .inline-lg {
    display: inline !important;
  }
}
@media (max-width: 767px) {
  .inline-md {
    display: inline !important;
  }
}
@media (max-width: 575px) {
  .inline-sm {
    display: inline !important;
  }
}

/* margin padding gap
-----------------------------------------------------*/
.mt-0 {
  margin-top: 0rem !important;
}

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

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

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

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

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

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

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

.mx-0 {
  margin-left: 0rem !important;
  margin-right: 0rem !important;
}

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

.my-0 {
  margin-top: 0rem !important;
  margin-bottom: 0rem !important;
}

.py-0 {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
}

.mt-5 {
  margin-top: 0.5rem !important;
}

.pt-5 {
  padding-top: 0.5rem !important;
}

.mb-5 {
  margin-bottom: 0.5rem !important;
}

.pb-5 {
  padding-bottom: 0.5rem !important;
}

.ml-5 {
  margin-left: 0.5rem !important;
}

.pl-5 {
  padding-left: 0.5rem !important;
}

.mr-5 {
  margin-right: 0.5rem !important;
}

.pr-5 {
  padding-right: 0.5rem !important;
}

.mx-5 {
  margin-left: 0.5rem !important;
  margin-right: 0.5rem !important;
}

.px-5 {
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}

.my-5 {
  margin-top: 0.5rem !important;
  margin-bottom: 0.5rem !important;
}

.py-5 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

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

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

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

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

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

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

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

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

.mx-10 {
  margin-left: 1rem !important;
  margin-right: 1rem !important;
}

.px-10 {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

.my-10 {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

.py-10 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.mt-15 {
  margin-top: 1.5rem !important;
}

.pt-15 {
  padding-top: 1.5rem !important;
}

.mb-15 {
  margin-bottom: 1.5rem !important;
}

.pb-15 {
  padding-bottom: 1.5rem !important;
}

.ml-15 {
  margin-left: 1.5rem !important;
}

.pl-15 {
  padding-left: 1.5rem !important;
}

.mr-15 {
  margin-right: 1.5rem !important;
}

.pr-15 {
  padding-right: 1.5rem !important;
}

.mx-15 {
  margin-left: 1.5rem !important;
  margin-right: 1.5rem !important;
}

.px-15 {
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}

.my-15 {
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}

.py-15 {
  padding-top: 1.5rem !important;
  padding-bottom: 1.5rem !important;
}

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

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

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

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

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

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

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

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

.mx-20 {
  margin-left: 2rem !important;
  margin-right: 2rem !important;
}

.px-20 {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
}

.my-20 {
  margin-top: 2rem !important;
  margin-bottom: 2rem !important;
}

.py-20 {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}

.mt-25 {
  margin-top: 2.5rem !important;
}

.pt-25 {
  padding-top: 2.5rem !important;
}

.mb-25 {
  margin-bottom: 2.5rem !important;
}

.pb-25 {
  padding-bottom: 2.5rem !important;
}

.ml-25 {
  margin-left: 2.5rem !important;
}

.pl-25 {
  padding-left: 2.5rem !important;
}

.mr-25 {
  margin-right: 2.5rem !important;
}

.pr-25 {
  padding-right: 2.5rem !important;
}

.mx-25 {
  margin-left: 2.5rem !important;
  margin-right: 2.5rem !important;
}

.px-25 {
  padding-left: 2.5rem !important;
  padding-right: 2.5rem !important;
}

.my-25 {
  margin-top: 2.5rem !important;
  margin-bottom: 2.5rem !important;
}

.py-25 {
  padding-top: 2.5rem !important;
  padding-bottom: 2.5rem !important;
}

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

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

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

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

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

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

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

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

.mx-30 {
  margin-left: 3rem !important;
  margin-right: 3rem !important;
}

.px-30 {
  padding-left: 3rem !important;
  padding-right: 3rem !important;
}

.my-30 {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}

.py-30 {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}

.mt-35 {
  margin-top: 3.5rem !important;
}

.pt-35 {
  padding-top: 3.5rem !important;
}

.mb-35 {
  margin-bottom: 3.5rem !important;
}

.pb-35 {
  padding-bottom: 3.5rem !important;
}

.ml-35 {
  margin-left: 3.5rem !important;
}

.pl-35 {
  padding-left: 3.5rem !important;
}

.mr-35 {
  margin-right: 3.5rem !important;
}

.pr-35 {
  padding-right: 3.5rem !important;
}

.mx-35 {
  margin-left: 3.5rem !important;
  margin-right: 3.5rem !important;
}

.px-35 {
  padding-left: 3.5rem !important;
  padding-right: 3.5rem !important;
}

.my-35 {
  margin-top: 3.5rem !important;
  margin-bottom: 3.5rem !important;
}

.py-35 {
  padding-top: 3.5rem !important;
  padding-bottom: 3.5rem !important;
}

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

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

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

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

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

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

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

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

.mx-40 {
  margin-left: 4rem !important;
  margin-right: 4rem !important;
}

.px-40 {
  padding-left: 4rem !important;
  padding-right: 4rem !important;
}

.my-40 {
  margin-top: 4rem !important;
  margin-bottom: 4rem !important;
}

.py-40 {
  padding-top: 4rem !important;
  padding-bottom: 4rem !important;
}

.mt-45 {
  margin-top: 4.5rem !important;
}

.pt-45 {
  padding-top: 4.5rem !important;
}

.mb-45 {
  margin-bottom: 4.5rem !important;
}

.pb-45 {
  padding-bottom: 4.5rem !important;
}

.ml-45 {
  margin-left: 4.5rem !important;
}

.pl-45 {
  padding-left: 4.5rem !important;
}

.mr-45 {
  margin-right: 4.5rem !important;
}

.pr-45 {
  padding-right: 4.5rem !important;
}

.mx-45 {
  margin-left: 4.5rem !important;
  margin-right: 4.5rem !important;
}

.px-45 {
  padding-left: 4.5rem !important;
  padding-right: 4.5rem !important;
}

.my-45 {
  margin-top: 4.5rem !important;
  margin-bottom: 4.5rem !important;
}

.py-45 {
  padding-top: 4.5rem !important;
  padding-bottom: 4.5rem !important;
}

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

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

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

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

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

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

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

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

.mx-50 {
  margin-left: 5rem !important;
  margin-right: 5rem !important;
}

.px-50 {
  padding-left: 5rem !important;
  padding-right: 5rem !important;
}

.my-50 {
  margin-top: 5rem !important;
  margin-bottom: 5rem !important;
}

.py-50 {
  padding-top: 5rem !important;
  padding-bottom: 5rem !important;
}

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

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

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

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

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

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

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

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

.mx-60 {
  margin-left: 6rem !important;
  margin-right: 6rem !important;
}

.px-60 {
  padding-left: 6rem !important;
  padding-right: 6rem !important;
}

.my-60 {
  margin-top: 6rem !important;
  margin-bottom: 6rem !important;
}

.py-60 {
  padding-top: 6rem !important;
  padding-bottom: 6rem !important;
}

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

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

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

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

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

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

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

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

.mx-70 {
  margin-left: 7rem !important;
  margin-right: 7rem !important;
}

.px-70 {
  padding-left: 7rem !important;
  padding-right: 7rem !important;
}

.my-70 {
  margin-top: 7rem !important;
  margin-bottom: 7rem !important;
}

.py-70 {
  padding-top: 7rem !important;
  padding-bottom: 7rem !important;
}

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

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

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

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

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

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

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

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

.mx-80 {
  margin-left: 8rem !important;
  margin-right: 8rem !important;
}

.px-80 {
  padding-left: 8rem !important;
  padding-right: 8rem !important;
}

.my-80 {
  margin-top: 8rem !important;
  margin-bottom: 8rem !important;
}

.py-80 {
  padding-top: 8rem !important;
  padding-bottom: 8rem !important;
}

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

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

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

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

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

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

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

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

.mx-90 {
  margin-left: 9rem !important;
  margin-right: 9rem !important;
}

.px-90 {
  padding-left: 9rem !important;
  padding-right: 9rem !important;
}

.my-90 {
  margin-top: 9rem !important;
  margin-bottom: 9rem !important;
}

.py-90 {
  padding-top: 9rem !important;
  padding-bottom: 9rem !important;
}

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

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

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

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

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

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

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

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

.mx-100 {
  margin-left: 10rem !important;
  margin-right: 10rem !important;
}

.px-100 {
  padding-left: 10rem !important;
  padding-right: 10rem !important;
}

.my-100 {
  margin-top: 10rem !important;
  margin-bottom: 10rem !important;
}

.py-100 {
  padding-top: 10rem !important;
  padding-bottom: 10rem !important;
}

@media (max-width: 1600px) {
  .mt-0-xxxl {
    margin-top: 0rem !important;
  }
  .pt-0-xxxl {
    padding-top: 0rem !important;
  }
  .mb-0-xxxl {
    margin-bottom: 0rem !important;
  }
  .pb-0-xxxl {
    padding-bottom: 0rem !important;
  }
  .ml-0-xxxl {
    margin-left: 0rem !important;
  }
  .pl-0-xxxl {
    padding-left: 0rem !important;
  }
  .mr-0-xxxl {
    margin-right: 0rem !important;
  }
  .pr-0-xxxl {
    padding-right: 0rem !important;
  }
  .mx-0-xxxl {
    margin-left: 0rem !important;
    margin-right: 0rem !important;
  }
  .px-0-xxxl {
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
  .my-0-xxxl {
    margin-top: 0rem !important;
    margin-bottom: 0rem !important;
  }
  .py-0-xxxl {
    padding-top: 0rem !important;
    padding-bottom: 0rem !important;
  }
  .mt-5-xxxl {
    margin-top: 0.5rem !important;
  }
  .pt-5-xxxl {
    padding-top: 0.5rem !important;
  }
  .mb-5-xxxl {
    margin-bottom: 0.5rem !important;
  }
  .pb-5-xxxl {
    padding-bottom: 0.5rem !important;
  }
  .ml-5-xxxl {
    margin-left: 0.5rem !important;
  }
  .pl-5-xxxl {
    padding-left: 0.5rem !important;
  }
  .mr-5-xxxl {
    margin-right: 0.5rem !important;
  }
  .pr-5-xxxl {
    padding-right: 0.5rem !important;
  }
  .mx-5-xxxl {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .px-5-xxxl {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .my-5-xxxl {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .py-5-xxxl {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .mt-10-xxxl {
    margin-top: 1rem !important;
  }
  .pt-10-xxxl {
    padding-top: 1rem !important;
  }
  .mb-10-xxxl {
    margin-bottom: 1rem !important;
  }
  .pb-10-xxxl {
    padding-bottom: 1rem !important;
  }
  .ml-10-xxxl {
    margin-left: 1rem !important;
  }
  .pl-10-xxxl {
    padding-left: 1rem !important;
  }
  .mr-10-xxxl {
    margin-right: 1rem !important;
  }
  .pr-10-xxxl {
    padding-right: 1rem !important;
  }
  .mx-10-xxxl {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .px-10-xxxl {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .my-10-xxxl {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .py-10-xxxl {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .mt-15-xxxl {
    margin-top: 1.5rem !important;
  }
  .pt-15-xxxl {
    padding-top: 1.5rem !important;
  }
  .mb-15-xxxl {
    margin-bottom: 1.5rem !important;
  }
  .pb-15-xxxl {
    padding-bottom: 1.5rem !important;
  }
  .ml-15-xxxl {
    margin-left: 1.5rem !important;
  }
  .pl-15-xxxl {
    padding-left: 1.5rem !important;
  }
  .mr-15-xxxl {
    margin-right: 1.5rem !important;
  }
  .pr-15-xxxl {
    padding-right: 1.5rem !important;
  }
  .mx-15-xxxl {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .px-15-xxxl {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .my-15-xxxl {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .py-15-xxxl {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .mt-20-xxxl {
    margin-top: 2rem !important;
  }
  .pt-20-xxxl {
    padding-top: 2rem !important;
  }
  .mb-20-xxxl {
    margin-bottom: 2rem !important;
  }
  .pb-20-xxxl {
    padding-bottom: 2rem !important;
  }
  .ml-20-xxxl {
    margin-left: 2rem !important;
  }
  .pl-20-xxxl {
    padding-left: 2rem !important;
  }
  .mr-20-xxxl {
    margin-right: 2rem !important;
  }
  .pr-20-xxxl {
    padding-right: 2rem !important;
  }
  .mx-20-xxxl {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .px-20-xxxl {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .my-20-xxxl {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .py-20-xxxl {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .mt-25-xxxl {
    margin-top: 2.5rem !important;
  }
  .pt-25-xxxl {
    padding-top: 2.5rem !important;
  }
  .mb-25-xxxl {
    margin-bottom: 2.5rem !important;
  }
  .pb-25-xxxl {
    padding-bottom: 2.5rem !important;
  }
  .ml-25-xxxl {
    margin-left: 2.5rem !important;
  }
  .pl-25-xxxl {
    padding-left: 2.5rem !important;
  }
  .mr-25-xxxl {
    margin-right: 2.5rem !important;
  }
  .pr-25-xxxl {
    padding-right: 2.5rem !important;
  }
  .mx-25-xxxl {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
  }
  .px-25-xxxl {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
  }
  .my-25-xxxl {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
  }
  .py-25-xxxl {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  .mt-30-xxxl {
    margin-top: 3rem !important;
  }
  .pt-30-xxxl {
    padding-top: 3rem !important;
  }
  .mb-30-xxxl {
    margin-bottom: 3rem !important;
  }
  .pb-30-xxxl {
    padding-bottom: 3rem !important;
  }
  .ml-30-xxxl {
    margin-left: 3rem !important;
  }
  .pl-30-xxxl {
    padding-left: 3rem !important;
  }
  .mr-30-xxxl {
    margin-right: 3rem !important;
  }
  .pr-30-xxxl {
    padding-right: 3rem !important;
  }
  .mx-30-xxxl {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .px-30-xxxl {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .my-30-xxxl {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .py-30-xxxl {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .mt-35-xxxl {
    margin-top: 3.5rem !important;
  }
  .pt-35-xxxl {
    padding-top: 3.5rem !important;
  }
  .mb-35-xxxl {
    margin-bottom: 3.5rem !important;
  }
  .pb-35-xxxl {
    padding-bottom: 3.5rem !important;
  }
  .ml-35-xxxl {
    margin-left: 3.5rem !important;
  }
  .pl-35-xxxl {
    padding-left: 3.5rem !important;
  }
  .mr-35-xxxl {
    margin-right: 3.5rem !important;
  }
  .pr-35-xxxl {
    padding-right: 3.5rem !important;
  }
  .mx-35-xxxl {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
  }
  .px-35-xxxl {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
  .my-35-xxxl {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
  }
  .py-35-xxxl {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }
  .mt-40-xxxl {
    margin-top: 4rem !important;
  }
  .pt-40-xxxl {
    padding-top: 4rem !important;
  }
  .mb-40-xxxl {
    margin-bottom: 4rem !important;
  }
  .pb-40-xxxl {
    padding-bottom: 4rem !important;
  }
  .ml-40-xxxl {
    margin-left: 4rem !important;
  }
  .pl-40-xxxl {
    padding-left: 4rem !important;
  }
  .mr-40-xxxl {
    margin-right: 4rem !important;
  }
  .pr-40-xxxl {
    padding-right: 4rem !important;
  }
  .mx-40-xxxl {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .px-40-xxxl {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .my-40-xxxl {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .py-40-xxxl {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .mt-45-xxxl {
    margin-top: 4.5rem !important;
  }
  .pt-45-xxxl {
    padding-top: 4.5rem !important;
  }
  .mb-45-xxxl {
    margin-bottom: 4.5rem !important;
  }
  .pb-45-xxxl {
    padding-bottom: 4.5rem !important;
  }
  .ml-45-xxxl {
    margin-left: 4.5rem !important;
  }
  .pl-45-xxxl {
    padding-left: 4.5rem !important;
  }
  .mr-45-xxxl {
    margin-right: 4.5rem !important;
  }
  .pr-45-xxxl {
    padding-right: 4.5rem !important;
  }
  .mx-45-xxxl {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
  }
  .px-45-xxxl {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }
  .my-45-xxxl {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
  .py-45-xxxl {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .mt-50-xxxl {
    margin-top: 5rem !important;
  }
  .pt-50-xxxl {
    padding-top: 5rem !important;
  }
  .mb-50-xxxl {
    margin-bottom: 5rem !important;
  }
  .pb-50-xxxl {
    padding-bottom: 5rem !important;
  }
  .ml-50-xxxl {
    margin-left: 5rem !important;
  }
  .pl-50-xxxl {
    padding-left: 5rem !important;
  }
  .mr-50-xxxl {
    margin-right: 5rem !important;
  }
  .pr-50-xxxl {
    padding-right: 5rem !important;
  }
  .mx-50-xxxl {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
  }
  .px-50-xxxl {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
  .my-50-xxxl {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
  }
  .py-50-xxxl {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
  .mt-60-xxxl {
    margin-top: 6rem !important;
  }
  .pt-60-xxxl {
    padding-top: 6rem !important;
  }
  .mb-60-xxxl {
    margin-bottom: 6rem !important;
  }
  .pb-60-xxxl {
    padding-bottom: 6rem !important;
  }
  .ml-60-xxxl {
    margin-left: 6rem !important;
  }
  .pl-60-xxxl {
    padding-left: 6rem !important;
  }
  .mr-60-xxxl {
    margin-right: 6rem !important;
  }
  .pr-60-xxxl {
    padding-right: 6rem !important;
  }
  .mx-60-xxxl {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
  }
  .px-60-xxxl {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
  }
  .my-60-xxxl {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
  }
  .py-60-xxxl {
    padding-top: 6rem !important;
    padding-bottom: 6rem !important;
  }
  .mt-70-xxxl {
    margin-top: 7rem !important;
  }
  .pt-70-xxxl {
    padding-top: 7rem !important;
  }
  .mb-70-xxxl {
    margin-bottom: 7rem !important;
  }
  .pb-70-xxxl {
    padding-bottom: 7rem !important;
  }
  .ml-70-xxxl {
    margin-left: 7rem !important;
  }
  .pl-70-xxxl {
    padding-left: 7rem !important;
  }
  .mr-70-xxxl {
    margin-right: 7rem !important;
  }
  .pr-70-xxxl {
    padding-right: 7rem !important;
  }
  .mx-70-xxxl {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
  }
  .px-70-xxxl {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
  }
  .my-70-xxxl {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
  }
  .py-70-xxxl {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
  }
  .mt-80-xxxl {
    margin-top: 8rem !important;
  }
  .pt-80-xxxl {
    padding-top: 8rem !important;
  }
  .mb-80-xxxl {
    margin-bottom: 8rem !important;
  }
  .pb-80-xxxl {
    padding-bottom: 8rem !important;
  }
  .ml-80-xxxl {
    margin-left: 8rem !important;
  }
  .pl-80-xxxl {
    padding-left: 8rem !important;
  }
  .mr-80-xxxl {
    margin-right: 8rem !important;
  }
  .pr-80-xxxl {
    padding-right: 8rem !important;
  }
  .mx-80-xxxl {
    margin-left: 8rem !important;
    margin-right: 8rem !important;
  }
  .px-80-xxxl {
    padding-left: 8rem !important;
    padding-right: 8rem !important;
  }
  .my-80-xxxl {
    margin-top: 8rem !important;
    margin-bottom: 8rem !important;
  }
  .py-80-xxxl {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
  }
  .mt-90-xxxl {
    margin-top: 9rem !important;
  }
  .pt-90-xxxl {
    padding-top: 9rem !important;
  }
  .mb-90-xxxl {
    margin-bottom: 9rem !important;
  }
  .pb-90-xxxl {
    padding-bottom: 9rem !important;
  }
  .ml-90-xxxl {
    margin-left: 9rem !important;
  }
  .pl-90-xxxl {
    padding-left: 9rem !important;
  }
  .mr-90-xxxl {
    margin-right: 9rem !important;
  }
  .pr-90-xxxl {
    padding-right: 9rem !important;
  }
  .mx-90-xxxl {
    margin-left: 9rem !important;
    margin-right: 9rem !important;
  }
  .px-90-xxxl {
    padding-left: 9rem !important;
    padding-right: 9rem !important;
  }
  .my-90-xxxl {
    margin-top: 9rem !important;
    margin-bottom: 9rem !important;
  }
  .py-90-xxxl {
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
  }
  .mt-100-xxxl {
    margin-top: 10rem !important;
  }
  .pt-100-xxxl {
    padding-top: 10rem !important;
  }
  .mb-100-xxxl {
    margin-bottom: 10rem !important;
  }
  .pb-100-xxxl {
    padding-bottom: 10rem !important;
  }
  .ml-100-xxxl {
    margin-left: 10rem !important;
  }
  .pl-100-xxxl {
    padding-left: 10rem !important;
  }
  .mr-100-xxxl {
    margin-right: 10rem !important;
  }
  .pr-100-xxxl {
    padding-right: 10rem !important;
  }
  .mx-100-xxxl {
    margin-left: 10rem !important;
    margin-right: 10rem !important;
  }
  .px-100-xxxl {
    padding-left: 10rem !important;
    padding-right: 10rem !important;
  }
  .my-100-xxxl {
    margin-top: 10rem !important;
    margin-bottom: 10rem !important;
  }
  .py-100-xxxl {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}
@media (max-width: 1399px) {
  .mt-0-xxl {
    margin-top: 0rem !important;
  }
  .pt-0-xxl {
    padding-top: 0rem !important;
  }
  .mb-0-xxl {
    margin-bottom: 0rem !important;
  }
  .pb-0-xxl {
    padding-bottom: 0rem !important;
  }
  .ml-0-xxl {
    margin-left: 0rem !important;
  }
  .pl-0-xxl {
    padding-left: 0rem !important;
  }
  .mr-0-xxl {
    margin-right: 0rem !important;
  }
  .pr-0-xxl {
    padding-right: 0rem !important;
  }
  .mx-0-xxl {
    margin-left: 0rem !important;
    margin-right: 0rem !important;
  }
  .px-0-xxl {
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
  .my-0-xxl {
    margin-top: 0rem !important;
    margin-bottom: 0rem !important;
  }
  .py-0-xxl {
    padding-top: 0rem !important;
    padding-bottom: 0rem !important;
  }
  .mt-5-xxl {
    margin-top: 0.5rem !important;
  }
  .pt-5-xxl {
    padding-top: 0.5rem !important;
  }
  .mb-5-xxl {
    margin-bottom: 0.5rem !important;
  }
  .pb-5-xxl {
    padding-bottom: 0.5rem !important;
  }
  .ml-5-xxl {
    margin-left: 0.5rem !important;
  }
  .pl-5-xxl {
    padding-left: 0.5rem !important;
  }
  .mr-5-xxl {
    margin-right: 0.5rem !important;
  }
  .pr-5-xxl {
    padding-right: 0.5rem !important;
  }
  .mx-5-xxl {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .px-5-xxl {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .my-5-xxl {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .py-5-xxl {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .mt-10-xxl {
    margin-top: 1rem !important;
  }
  .pt-10-xxl {
    padding-top: 1rem !important;
  }
  .mb-10-xxl {
    margin-bottom: 1rem !important;
  }
  .pb-10-xxl {
    padding-bottom: 1rem !important;
  }
  .ml-10-xxl {
    margin-left: 1rem !important;
  }
  .pl-10-xxl {
    padding-left: 1rem !important;
  }
  .mr-10-xxl {
    margin-right: 1rem !important;
  }
  .pr-10-xxl {
    padding-right: 1rem !important;
  }
  .mx-10-xxl {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .px-10-xxl {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .my-10-xxl {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .py-10-xxl {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .mt-15-xxl {
    margin-top: 1.5rem !important;
  }
  .pt-15-xxl {
    padding-top: 1.5rem !important;
  }
  .mb-15-xxl {
    margin-bottom: 1.5rem !important;
  }
  .pb-15-xxl {
    padding-bottom: 1.5rem !important;
  }
  .ml-15-xxl {
    margin-left: 1.5rem !important;
  }
  .pl-15-xxl {
    padding-left: 1.5rem !important;
  }
  .mr-15-xxl {
    margin-right: 1.5rem !important;
  }
  .pr-15-xxl {
    padding-right: 1.5rem !important;
  }
  .mx-15-xxl {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .px-15-xxl {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .my-15-xxl {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .py-15-xxl {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .mt-20-xxl {
    margin-top: 2rem !important;
  }
  .pt-20-xxl {
    padding-top: 2rem !important;
  }
  .mb-20-xxl {
    margin-bottom: 2rem !important;
  }
  .pb-20-xxl {
    padding-bottom: 2rem !important;
  }
  .ml-20-xxl {
    margin-left: 2rem !important;
  }
  .pl-20-xxl {
    padding-left: 2rem !important;
  }
  .mr-20-xxl {
    margin-right: 2rem !important;
  }
  .pr-20-xxl {
    padding-right: 2rem !important;
  }
  .mx-20-xxl {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .px-20-xxl {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .my-20-xxl {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .py-20-xxl {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .mt-25-xxl {
    margin-top: 2.5rem !important;
  }
  .pt-25-xxl {
    padding-top: 2.5rem !important;
  }
  .mb-25-xxl {
    margin-bottom: 2.5rem !important;
  }
  .pb-25-xxl {
    padding-bottom: 2.5rem !important;
  }
  .ml-25-xxl {
    margin-left: 2.5rem !important;
  }
  .pl-25-xxl {
    padding-left: 2.5rem !important;
  }
  .mr-25-xxl {
    margin-right: 2.5rem !important;
  }
  .pr-25-xxl {
    padding-right: 2.5rem !important;
  }
  .mx-25-xxl {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
  }
  .px-25-xxl {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
  }
  .my-25-xxl {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
  }
  .py-25-xxl {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  .mt-30-xxl {
    margin-top: 3rem !important;
  }
  .pt-30-xxl {
    padding-top: 3rem !important;
  }
  .mb-30-xxl {
    margin-bottom: 3rem !important;
  }
  .pb-30-xxl {
    padding-bottom: 3rem !important;
  }
  .ml-30-xxl {
    margin-left: 3rem !important;
  }
  .pl-30-xxl {
    padding-left: 3rem !important;
  }
  .mr-30-xxl {
    margin-right: 3rem !important;
  }
  .pr-30-xxl {
    padding-right: 3rem !important;
  }
  .mx-30-xxl {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .px-30-xxl {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .my-30-xxl {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .py-30-xxl {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .mt-35-xxl {
    margin-top: 3.5rem !important;
  }
  .pt-35-xxl {
    padding-top: 3.5rem !important;
  }
  .mb-35-xxl {
    margin-bottom: 3.5rem !important;
  }
  .pb-35-xxl {
    padding-bottom: 3.5rem !important;
  }
  .ml-35-xxl {
    margin-left: 3.5rem !important;
  }
  .pl-35-xxl {
    padding-left: 3.5rem !important;
  }
  .mr-35-xxl {
    margin-right: 3.5rem !important;
  }
  .pr-35-xxl {
    padding-right: 3.5rem !important;
  }
  .mx-35-xxl {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
  }
  .px-35-xxl {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
  .my-35-xxl {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
  }
  .py-35-xxl {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }
  .mt-40-xxl {
    margin-top: 4rem !important;
  }
  .pt-40-xxl {
    padding-top: 4rem !important;
  }
  .mb-40-xxl {
    margin-bottom: 4rem !important;
  }
  .pb-40-xxl {
    padding-bottom: 4rem !important;
  }
  .ml-40-xxl {
    margin-left: 4rem !important;
  }
  .pl-40-xxl {
    padding-left: 4rem !important;
  }
  .mr-40-xxl {
    margin-right: 4rem !important;
  }
  .pr-40-xxl {
    padding-right: 4rem !important;
  }
  .mx-40-xxl {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .px-40-xxl {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .my-40-xxl {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .py-40-xxl {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .mt-45-xxl {
    margin-top: 4.5rem !important;
  }
  .pt-45-xxl {
    padding-top: 4.5rem !important;
  }
  .mb-45-xxl {
    margin-bottom: 4.5rem !important;
  }
  .pb-45-xxl {
    padding-bottom: 4.5rem !important;
  }
  .ml-45-xxl {
    margin-left: 4.5rem !important;
  }
  .pl-45-xxl {
    padding-left: 4.5rem !important;
  }
  .mr-45-xxl {
    margin-right: 4.5rem !important;
  }
  .pr-45-xxl {
    padding-right: 4.5rem !important;
  }
  .mx-45-xxl {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
  }
  .px-45-xxl {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }
  .my-45-xxl {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
  .py-45-xxl {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .mt-50-xxl {
    margin-top: 5rem !important;
  }
  .pt-50-xxl {
    padding-top: 5rem !important;
  }
  .mb-50-xxl {
    margin-bottom: 5rem !important;
  }
  .pb-50-xxl {
    padding-bottom: 5rem !important;
  }
  .ml-50-xxl {
    margin-left: 5rem !important;
  }
  .pl-50-xxl {
    padding-left: 5rem !important;
  }
  .mr-50-xxl {
    margin-right: 5rem !important;
  }
  .pr-50-xxl {
    padding-right: 5rem !important;
  }
  .mx-50-xxl {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
  }
  .px-50-xxl {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
  .my-50-xxl {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
  }
  .py-50-xxl {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
  .mt-60-xxl {
    margin-top: 6rem !important;
  }
  .pt-60-xxl {
    padding-top: 6rem !important;
  }
  .mb-60-xxl {
    margin-bottom: 6rem !important;
  }
  .pb-60-xxl {
    padding-bottom: 6rem !important;
  }
  .ml-60-xxl {
    margin-left: 6rem !important;
  }
  .pl-60-xxl {
    padding-left: 6rem !important;
  }
  .mr-60-xxl {
    margin-right: 6rem !important;
  }
  .pr-60-xxl {
    padding-right: 6rem !important;
  }
  .mx-60-xxl {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
  }
  .px-60-xxl {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
  }
  .my-60-xxl {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
  }
  .py-60-xxl {
    padding-top: 6rem !important;
    padding-bottom: 6rem !important;
  }
  .mt-70-xxl {
    margin-top: 7rem !important;
  }
  .pt-70-xxl {
    padding-top: 7rem !important;
  }
  .mb-70-xxl {
    margin-bottom: 7rem !important;
  }
  .pb-70-xxl {
    padding-bottom: 7rem !important;
  }
  .ml-70-xxl {
    margin-left: 7rem !important;
  }
  .pl-70-xxl {
    padding-left: 7rem !important;
  }
  .mr-70-xxl {
    margin-right: 7rem !important;
  }
  .pr-70-xxl {
    padding-right: 7rem !important;
  }
  .mx-70-xxl {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
  }
  .px-70-xxl {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
  }
  .my-70-xxl {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
  }
  .py-70-xxl {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
  }
  .mt-80-xxl {
    margin-top: 8rem !important;
  }
  .pt-80-xxl {
    padding-top: 8rem !important;
  }
  .mb-80-xxl {
    margin-bottom: 8rem !important;
  }
  .pb-80-xxl {
    padding-bottom: 8rem !important;
  }
  .ml-80-xxl {
    margin-left: 8rem !important;
  }
  .pl-80-xxl {
    padding-left: 8rem !important;
  }
  .mr-80-xxl {
    margin-right: 8rem !important;
  }
  .pr-80-xxl {
    padding-right: 8rem !important;
  }
  .mx-80-xxl {
    margin-left: 8rem !important;
    margin-right: 8rem !important;
  }
  .px-80-xxl {
    padding-left: 8rem !important;
    padding-right: 8rem !important;
  }
  .my-80-xxl {
    margin-top: 8rem !important;
    margin-bottom: 8rem !important;
  }
  .py-80-xxl {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
  }
  .mt-90-xxl {
    margin-top: 9rem !important;
  }
  .pt-90-xxl {
    padding-top: 9rem !important;
  }
  .mb-90-xxl {
    margin-bottom: 9rem !important;
  }
  .pb-90-xxl {
    padding-bottom: 9rem !important;
  }
  .ml-90-xxl {
    margin-left: 9rem !important;
  }
  .pl-90-xxl {
    padding-left: 9rem !important;
  }
  .mr-90-xxl {
    margin-right: 9rem !important;
  }
  .pr-90-xxl {
    padding-right: 9rem !important;
  }
  .mx-90-xxl {
    margin-left: 9rem !important;
    margin-right: 9rem !important;
  }
  .px-90-xxl {
    padding-left: 9rem !important;
    padding-right: 9rem !important;
  }
  .my-90-xxl {
    margin-top: 9rem !important;
    margin-bottom: 9rem !important;
  }
  .py-90-xxl {
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
  }
  .mt-100-xxl {
    margin-top: 10rem !important;
  }
  .pt-100-xxl {
    padding-top: 10rem !important;
  }
  .mb-100-xxl {
    margin-bottom: 10rem !important;
  }
  .pb-100-xxl {
    padding-bottom: 10rem !important;
  }
  .ml-100-xxl {
    margin-left: 10rem !important;
  }
  .pl-100-xxl {
    padding-left: 10rem !important;
  }
  .mr-100-xxl {
    margin-right: 10rem !important;
  }
  .pr-100-xxl {
    padding-right: 10rem !important;
  }
  .mx-100-xxl {
    margin-left: 10rem !important;
    margin-right: 10rem !important;
  }
  .px-100-xxl {
    padding-left: 10rem !important;
    padding-right: 10rem !important;
  }
  .my-100-xxl {
    margin-top: 10rem !important;
    margin-bottom: 10rem !important;
  }
  .py-100-xxl {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}
@media (max-width: 1199px) {
  .mt-0-xl {
    margin-top: 0rem !important;
  }
  .pt-0-xl {
    padding-top: 0rem !important;
  }
  .mb-0-xl {
    margin-bottom: 0rem !important;
  }
  .pb-0-xl {
    padding-bottom: 0rem !important;
  }
  .ml-0-xl {
    margin-left: 0rem !important;
  }
  .pl-0-xl {
    padding-left: 0rem !important;
  }
  .mr-0-xl {
    margin-right: 0rem !important;
  }
  .pr-0-xl {
    padding-right: 0rem !important;
  }
  .mx-0-xl {
    margin-left: 0rem !important;
    margin-right: 0rem !important;
  }
  .px-0-xl {
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
  .my-0-xl {
    margin-top: 0rem !important;
    margin-bottom: 0rem !important;
  }
  .py-0-xl {
    padding-top: 0rem !important;
    padding-bottom: 0rem !important;
  }
  .mt-5-xl {
    margin-top: 0.5rem !important;
  }
  .pt-5-xl {
    padding-top: 0.5rem !important;
  }
  .mb-5-xl {
    margin-bottom: 0.5rem !important;
  }
  .pb-5-xl {
    padding-bottom: 0.5rem !important;
  }
  .ml-5-xl {
    margin-left: 0.5rem !important;
  }
  .pl-5-xl {
    padding-left: 0.5rem !important;
  }
  .mr-5-xl {
    margin-right: 0.5rem !important;
  }
  .pr-5-xl {
    padding-right: 0.5rem !important;
  }
  .mx-5-xl {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .px-5-xl {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .my-5-xl {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .py-5-xl {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .mt-10-xl {
    margin-top: 1rem !important;
  }
  .pt-10-xl {
    padding-top: 1rem !important;
  }
  .mb-10-xl {
    margin-bottom: 1rem !important;
  }
  .pb-10-xl {
    padding-bottom: 1rem !important;
  }
  .ml-10-xl {
    margin-left: 1rem !important;
  }
  .pl-10-xl {
    padding-left: 1rem !important;
  }
  .mr-10-xl {
    margin-right: 1rem !important;
  }
  .pr-10-xl {
    padding-right: 1rem !important;
  }
  .mx-10-xl {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .px-10-xl {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .my-10-xl {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .py-10-xl {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .mt-15-xl {
    margin-top: 1.5rem !important;
  }
  .pt-15-xl {
    padding-top: 1.5rem !important;
  }
  .mb-15-xl {
    margin-bottom: 1.5rem !important;
  }
  .pb-15-xl {
    padding-bottom: 1.5rem !important;
  }
  .ml-15-xl {
    margin-left: 1.5rem !important;
  }
  .pl-15-xl {
    padding-left: 1.5rem !important;
  }
  .mr-15-xl {
    margin-right: 1.5rem !important;
  }
  .pr-15-xl {
    padding-right: 1.5rem !important;
  }
  .mx-15-xl {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .px-15-xl {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .my-15-xl {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .py-15-xl {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .mt-20-xl {
    margin-top: 2rem !important;
  }
  .pt-20-xl {
    padding-top: 2rem !important;
  }
  .mb-20-xl {
    margin-bottom: 2rem !important;
  }
  .pb-20-xl {
    padding-bottom: 2rem !important;
  }
  .ml-20-xl {
    margin-left: 2rem !important;
  }
  .pl-20-xl {
    padding-left: 2rem !important;
  }
  .mr-20-xl {
    margin-right: 2rem !important;
  }
  .pr-20-xl {
    padding-right: 2rem !important;
  }
  .mx-20-xl {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .px-20-xl {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .my-20-xl {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .py-20-xl {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .mt-25-xl {
    margin-top: 2.5rem !important;
  }
  .pt-25-xl {
    padding-top: 2.5rem !important;
  }
  .mb-25-xl {
    margin-bottom: 2.5rem !important;
  }
  .pb-25-xl {
    padding-bottom: 2.5rem !important;
  }
  .ml-25-xl {
    margin-left: 2.5rem !important;
  }
  .pl-25-xl {
    padding-left: 2.5rem !important;
  }
  .mr-25-xl {
    margin-right: 2.5rem !important;
  }
  .pr-25-xl {
    padding-right: 2.5rem !important;
  }
  .mx-25-xl {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
  }
  .px-25-xl {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
  }
  .my-25-xl {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
  }
  .py-25-xl {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  .mt-30-xl {
    margin-top: 3rem !important;
  }
  .pt-30-xl {
    padding-top: 3rem !important;
  }
  .mb-30-xl {
    margin-bottom: 3rem !important;
  }
  .pb-30-xl {
    padding-bottom: 3rem !important;
  }
  .ml-30-xl {
    margin-left: 3rem !important;
  }
  .pl-30-xl {
    padding-left: 3rem !important;
  }
  .mr-30-xl {
    margin-right: 3rem !important;
  }
  .pr-30-xl {
    padding-right: 3rem !important;
  }
  .mx-30-xl {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .px-30-xl {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .my-30-xl {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .py-30-xl {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .mt-35-xl {
    margin-top: 3.5rem !important;
  }
  .pt-35-xl {
    padding-top: 3.5rem !important;
  }
  .mb-35-xl {
    margin-bottom: 3.5rem !important;
  }
  .pb-35-xl {
    padding-bottom: 3.5rem !important;
  }
  .ml-35-xl {
    margin-left: 3.5rem !important;
  }
  .pl-35-xl {
    padding-left: 3.5rem !important;
  }
  .mr-35-xl {
    margin-right: 3.5rem !important;
  }
  .pr-35-xl {
    padding-right: 3.5rem !important;
  }
  .mx-35-xl {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
  }
  .px-35-xl {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
  .my-35-xl {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
  }
  .py-35-xl {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }
  .mt-40-xl {
    margin-top: 4rem !important;
  }
  .pt-40-xl {
    padding-top: 4rem !important;
  }
  .mb-40-xl {
    margin-bottom: 4rem !important;
  }
  .pb-40-xl {
    padding-bottom: 4rem !important;
  }
  .ml-40-xl {
    margin-left: 4rem !important;
  }
  .pl-40-xl {
    padding-left: 4rem !important;
  }
  .mr-40-xl {
    margin-right: 4rem !important;
  }
  .pr-40-xl {
    padding-right: 4rem !important;
  }
  .mx-40-xl {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .px-40-xl {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .my-40-xl {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .py-40-xl {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .mt-45-xl {
    margin-top: 4.5rem !important;
  }
  .pt-45-xl {
    padding-top: 4.5rem !important;
  }
  .mb-45-xl {
    margin-bottom: 4.5rem !important;
  }
  .pb-45-xl {
    padding-bottom: 4.5rem !important;
  }
  .ml-45-xl {
    margin-left: 4.5rem !important;
  }
  .pl-45-xl {
    padding-left: 4.5rem !important;
  }
  .mr-45-xl {
    margin-right: 4.5rem !important;
  }
  .pr-45-xl {
    padding-right: 4.5rem !important;
  }
  .mx-45-xl {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
  }
  .px-45-xl {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }
  .my-45-xl {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
  .py-45-xl {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .mt-50-xl {
    margin-top: 5rem !important;
  }
  .pt-50-xl {
    padding-top: 5rem !important;
  }
  .mb-50-xl {
    margin-bottom: 5rem !important;
  }
  .pb-50-xl {
    padding-bottom: 5rem !important;
  }
  .ml-50-xl {
    margin-left: 5rem !important;
  }
  .pl-50-xl {
    padding-left: 5rem !important;
  }
  .mr-50-xl {
    margin-right: 5rem !important;
  }
  .pr-50-xl {
    padding-right: 5rem !important;
  }
  .mx-50-xl {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
  }
  .px-50-xl {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
  .my-50-xl {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
  }
  .py-50-xl {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
  .mt-60-xl {
    margin-top: 6rem !important;
  }
  .pt-60-xl {
    padding-top: 6rem !important;
  }
  .mb-60-xl {
    margin-bottom: 6rem !important;
  }
  .pb-60-xl {
    padding-bottom: 6rem !important;
  }
  .ml-60-xl {
    margin-left: 6rem !important;
  }
  .pl-60-xl {
    padding-left: 6rem !important;
  }
  .mr-60-xl {
    margin-right: 6rem !important;
  }
  .pr-60-xl {
    padding-right: 6rem !important;
  }
  .mx-60-xl {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
  }
  .px-60-xl {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
  }
  .my-60-xl {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
  }
  .py-60-xl {
    padding-top: 6rem !important;
    padding-bottom: 6rem !important;
  }
  .mt-70-xl {
    margin-top: 7rem !important;
  }
  .pt-70-xl {
    padding-top: 7rem !important;
  }
  .mb-70-xl {
    margin-bottom: 7rem !important;
  }
  .pb-70-xl {
    padding-bottom: 7rem !important;
  }
  .ml-70-xl {
    margin-left: 7rem !important;
  }
  .pl-70-xl {
    padding-left: 7rem !important;
  }
  .mr-70-xl {
    margin-right: 7rem !important;
  }
  .pr-70-xl {
    padding-right: 7rem !important;
  }
  .mx-70-xl {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
  }
  .px-70-xl {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
  }
  .my-70-xl {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
  }
  .py-70-xl {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
  }
  .mt-80-xl {
    margin-top: 8rem !important;
  }
  .pt-80-xl {
    padding-top: 8rem !important;
  }
  .mb-80-xl {
    margin-bottom: 8rem !important;
  }
  .pb-80-xl {
    padding-bottom: 8rem !important;
  }
  .ml-80-xl {
    margin-left: 8rem !important;
  }
  .pl-80-xl {
    padding-left: 8rem !important;
  }
  .mr-80-xl {
    margin-right: 8rem !important;
  }
  .pr-80-xl {
    padding-right: 8rem !important;
  }
  .mx-80-xl {
    margin-left: 8rem !important;
    margin-right: 8rem !important;
  }
  .px-80-xl {
    padding-left: 8rem !important;
    padding-right: 8rem !important;
  }
  .my-80-xl {
    margin-top: 8rem !important;
    margin-bottom: 8rem !important;
  }
  .py-80-xl {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
  }
  .mt-90-xl {
    margin-top: 9rem !important;
  }
  .pt-90-xl {
    padding-top: 9rem !important;
  }
  .mb-90-xl {
    margin-bottom: 9rem !important;
  }
  .pb-90-xl {
    padding-bottom: 9rem !important;
  }
  .ml-90-xl {
    margin-left: 9rem !important;
  }
  .pl-90-xl {
    padding-left: 9rem !important;
  }
  .mr-90-xl {
    margin-right: 9rem !important;
  }
  .pr-90-xl {
    padding-right: 9rem !important;
  }
  .mx-90-xl {
    margin-left: 9rem !important;
    margin-right: 9rem !important;
  }
  .px-90-xl {
    padding-left: 9rem !important;
    padding-right: 9rem !important;
  }
  .my-90-xl {
    margin-top: 9rem !important;
    margin-bottom: 9rem !important;
  }
  .py-90-xl {
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
  }
  .mt-100-xl {
    margin-top: 10rem !important;
  }
  .pt-100-xl {
    padding-top: 10rem !important;
  }
  .mb-100-xl {
    margin-bottom: 10rem !important;
  }
  .pb-100-xl {
    padding-bottom: 10rem !important;
  }
  .ml-100-xl {
    margin-left: 10rem !important;
  }
  .pl-100-xl {
    padding-left: 10rem !important;
  }
  .mr-100-xl {
    margin-right: 10rem !important;
  }
  .pr-100-xl {
    padding-right: 10rem !important;
  }
  .mx-100-xl {
    margin-left: 10rem !important;
    margin-right: 10rem !important;
  }
  .px-100-xl {
    padding-left: 10rem !important;
    padding-right: 10rem !important;
  }
  .my-100-xl {
    margin-top: 10rem !important;
    margin-bottom: 10rem !important;
  }
  .py-100-xl {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}
@media (max-width: 991px) {
  .mt-0-lg {
    margin-top: 0rem !important;
  }
  .pt-0-lg {
    padding-top: 0rem !important;
  }
  .mb-0-lg {
    margin-bottom: 0rem !important;
  }
  .pb-0-lg {
    padding-bottom: 0rem !important;
  }
  .ml-0-lg {
    margin-left: 0rem !important;
  }
  .pl-0-lg {
    padding-left: 0rem !important;
  }
  .mr-0-lg {
    margin-right: 0rem !important;
  }
  .pr-0-lg {
    padding-right: 0rem !important;
  }
  .mx-0-lg {
    margin-left: 0rem !important;
    margin-right: 0rem !important;
  }
  .px-0-lg {
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
  .my-0-lg {
    margin-top: 0rem !important;
    margin-bottom: 0rem !important;
  }
  .py-0-lg {
    padding-top: 0rem !important;
    padding-bottom: 0rem !important;
  }
  .mt-5-lg {
    margin-top: 0.5rem !important;
  }
  .pt-5-lg {
    padding-top: 0.5rem !important;
  }
  .mb-5-lg {
    margin-bottom: 0.5rem !important;
  }
  .pb-5-lg {
    padding-bottom: 0.5rem !important;
  }
  .ml-5-lg {
    margin-left: 0.5rem !important;
  }
  .pl-5-lg {
    padding-left: 0.5rem !important;
  }
  .mr-5-lg {
    margin-right: 0.5rem !important;
  }
  .pr-5-lg {
    padding-right: 0.5rem !important;
  }
  .mx-5-lg {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .px-5-lg {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .my-5-lg {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .py-5-lg {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .mt-10-lg {
    margin-top: 1rem !important;
  }
  .pt-10-lg {
    padding-top: 1rem !important;
  }
  .mb-10-lg {
    margin-bottom: 1rem !important;
  }
  .pb-10-lg {
    padding-bottom: 1rem !important;
  }
  .ml-10-lg {
    margin-left: 1rem !important;
  }
  .pl-10-lg {
    padding-left: 1rem !important;
  }
  .mr-10-lg {
    margin-right: 1rem !important;
  }
  .pr-10-lg {
    padding-right: 1rem !important;
  }
  .mx-10-lg {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .px-10-lg {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .my-10-lg {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .py-10-lg {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .mt-15-lg {
    margin-top: 1.5rem !important;
  }
  .pt-15-lg {
    padding-top: 1.5rem !important;
  }
  .mb-15-lg {
    margin-bottom: 1.5rem !important;
  }
  .pb-15-lg {
    padding-bottom: 1.5rem !important;
  }
  .ml-15-lg {
    margin-left: 1.5rem !important;
  }
  .pl-15-lg {
    padding-left: 1.5rem !important;
  }
  .mr-15-lg {
    margin-right: 1.5rem !important;
  }
  .pr-15-lg {
    padding-right: 1.5rem !important;
  }
  .mx-15-lg {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .px-15-lg {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .my-15-lg {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .py-15-lg {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .mt-20-lg {
    margin-top: 2rem !important;
  }
  .pt-20-lg {
    padding-top: 2rem !important;
  }
  .mb-20-lg {
    margin-bottom: 2rem !important;
  }
  .pb-20-lg {
    padding-bottom: 2rem !important;
  }
  .ml-20-lg {
    margin-left: 2rem !important;
  }
  .pl-20-lg {
    padding-left: 2rem !important;
  }
  .mr-20-lg {
    margin-right: 2rem !important;
  }
  .pr-20-lg {
    padding-right: 2rem !important;
  }
  .mx-20-lg {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .px-20-lg {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .my-20-lg {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .py-20-lg {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .mt-25-lg {
    margin-top: 2.5rem !important;
  }
  .pt-25-lg {
    padding-top: 2.5rem !important;
  }
  .mb-25-lg {
    margin-bottom: 2.5rem !important;
  }
  .pb-25-lg {
    padding-bottom: 2.5rem !important;
  }
  .ml-25-lg {
    margin-left: 2.5rem !important;
  }
  .pl-25-lg {
    padding-left: 2.5rem !important;
  }
  .mr-25-lg {
    margin-right: 2.5rem !important;
  }
  .pr-25-lg {
    padding-right: 2.5rem !important;
  }
  .mx-25-lg {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
  }
  .px-25-lg {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
  }
  .my-25-lg {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
  }
  .py-25-lg {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  .mt-30-lg {
    margin-top: 3rem !important;
  }
  .pt-30-lg {
    padding-top: 3rem !important;
  }
  .mb-30-lg {
    margin-bottom: 3rem !important;
  }
  .pb-30-lg {
    padding-bottom: 3rem !important;
  }
  .ml-30-lg {
    margin-left: 3rem !important;
  }
  .pl-30-lg {
    padding-left: 3rem !important;
  }
  .mr-30-lg {
    margin-right: 3rem !important;
  }
  .pr-30-lg {
    padding-right: 3rem !important;
  }
  .mx-30-lg {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .px-30-lg {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .my-30-lg {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .py-30-lg {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .mt-35-lg {
    margin-top: 3.5rem !important;
  }
  .pt-35-lg {
    padding-top: 3.5rem !important;
  }
  .mb-35-lg {
    margin-bottom: 3.5rem !important;
  }
  .pb-35-lg {
    padding-bottom: 3.5rem !important;
  }
  .ml-35-lg {
    margin-left: 3.5rem !important;
  }
  .pl-35-lg {
    padding-left: 3.5rem !important;
  }
  .mr-35-lg {
    margin-right: 3.5rem !important;
  }
  .pr-35-lg {
    padding-right: 3.5rem !important;
  }
  .mx-35-lg {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
  }
  .px-35-lg {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
  .my-35-lg {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
  }
  .py-35-lg {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }
  .mt-40-lg {
    margin-top: 4rem !important;
  }
  .pt-40-lg {
    padding-top: 4rem !important;
  }
  .mb-40-lg {
    margin-bottom: 4rem !important;
  }
  .pb-40-lg {
    padding-bottom: 4rem !important;
  }
  .ml-40-lg {
    margin-left: 4rem !important;
  }
  .pl-40-lg {
    padding-left: 4rem !important;
  }
  .mr-40-lg {
    margin-right: 4rem !important;
  }
  .pr-40-lg {
    padding-right: 4rem !important;
  }
  .mx-40-lg {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .px-40-lg {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .my-40-lg {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .py-40-lg {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .mt-45-lg {
    margin-top: 4.5rem !important;
  }
  .pt-45-lg {
    padding-top: 4.5rem !important;
  }
  .mb-45-lg {
    margin-bottom: 4.5rem !important;
  }
  .pb-45-lg {
    padding-bottom: 4.5rem !important;
  }
  .ml-45-lg {
    margin-left: 4.5rem !important;
  }
  .pl-45-lg {
    padding-left: 4.5rem !important;
  }
  .mr-45-lg {
    margin-right: 4.5rem !important;
  }
  .pr-45-lg {
    padding-right: 4.5rem !important;
  }
  .mx-45-lg {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
  }
  .px-45-lg {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }
  .my-45-lg {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
  .py-45-lg {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .mt-50-lg {
    margin-top: 5rem !important;
  }
  .pt-50-lg {
    padding-top: 5rem !important;
  }
  .mb-50-lg {
    margin-bottom: 5rem !important;
  }
  .pb-50-lg {
    padding-bottom: 5rem !important;
  }
  .ml-50-lg {
    margin-left: 5rem !important;
  }
  .pl-50-lg {
    padding-left: 5rem !important;
  }
  .mr-50-lg {
    margin-right: 5rem !important;
  }
  .pr-50-lg {
    padding-right: 5rem !important;
  }
  .mx-50-lg {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
  }
  .px-50-lg {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
  .my-50-lg {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
  }
  .py-50-lg {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
  .mt-60-lg {
    margin-top: 6rem !important;
  }
  .pt-60-lg {
    padding-top: 6rem !important;
  }
  .mb-60-lg {
    margin-bottom: 6rem !important;
  }
  .pb-60-lg {
    padding-bottom: 6rem !important;
  }
  .ml-60-lg {
    margin-left: 6rem !important;
  }
  .pl-60-lg {
    padding-left: 6rem !important;
  }
  .mr-60-lg {
    margin-right: 6rem !important;
  }
  .pr-60-lg {
    padding-right: 6rem !important;
  }
  .mx-60-lg {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
  }
  .px-60-lg {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
  }
  .my-60-lg {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
  }
  .py-60-lg {
    padding-top: 6rem !important;
    padding-bottom: 6rem !important;
  }
  .mt-70-lg {
    margin-top: 7rem !important;
  }
  .pt-70-lg {
    padding-top: 7rem !important;
  }
  .mb-70-lg {
    margin-bottom: 7rem !important;
  }
  .pb-70-lg {
    padding-bottom: 7rem !important;
  }
  .ml-70-lg {
    margin-left: 7rem !important;
  }
  .pl-70-lg {
    padding-left: 7rem !important;
  }
  .mr-70-lg {
    margin-right: 7rem !important;
  }
  .pr-70-lg {
    padding-right: 7rem !important;
  }
  .mx-70-lg {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
  }
  .px-70-lg {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
  }
  .my-70-lg {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
  }
  .py-70-lg {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
  }
  .mt-80-lg {
    margin-top: 8rem !important;
  }
  .pt-80-lg {
    padding-top: 8rem !important;
  }
  .mb-80-lg {
    margin-bottom: 8rem !important;
  }
  .pb-80-lg {
    padding-bottom: 8rem !important;
  }
  .ml-80-lg {
    margin-left: 8rem !important;
  }
  .pl-80-lg {
    padding-left: 8rem !important;
  }
  .mr-80-lg {
    margin-right: 8rem !important;
  }
  .pr-80-lg {
    padding-right: 8rem !important;
  }
  .mx-80-lg {
    margin-left: 8rem !important;
    margin-right: 8rem !important;
  }
  .px-80-lg {
    padding-left: 8rem !important;
    padding-right: 8rem !important;
  }
  .my-80-lg {
    margin-top: 8rem !important;
    margin-bottom: 8rem !important;
  }
  .py-80-lg {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
  }
  .mt-90-lg {
    margin-top: 9rem !important;
  }
  .pt-90-lg {
    padding-top: 9rem !important;
  }
  .mb-90-lg {
    margin-bottom: 9rem !important;
  }
  .pb-90-lg {
    padding-bottom: 9rem !important;
  }
  .ml-90-lg {
    margin-left: 9rem !important;
  }
  .pl-90-lg {
    padding-left: 9rem !important;
  }
  .mr-90-lg {
    margin-right: 9rem !important;
  }
  .pr-90-lg {
    padding-right: 9rem !important;
  }
  .mx-90-lg {
    margin-left: 9rem !important;
    margin-right: 9rem !important;
  }
  .px-90-lg {
    padding-left: 9rem !important;
    padding-right: 9rem !important;
  }
  .my-90-lg {
    margin-top: 9rem !important;
    margin-bottom: 9rem !important;
  }
  .py-90-lg {
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
  }
  .mt-100-lg {
    margin-top: 10rem !important;
  }
  .pt-100-lg {
    padding-top: 10rem !important;
  }
  .mb-100-lg {
    margin-bottom: 10rem !important;
  }
  .pb-100-lg {
    padding-bottom: 10rem !important;
  }
  .ml-100-lg {
    margin-left: 10rem !important;
  }
  .pl-100-lg {
    padding-left: 10rem !important;
  }
  .mr-100-lg {
    margin-right: 10rem !important;
  }
  .pr-100-lg {
    padding-right: 10rem !important;
  }
  .mx-100-lg {
    margin-left: 10rem !important;
    margin-right: 10rem !important;
  }
  .px-100-lg {
    padding-left: 10rem !important;
    padding-right: 10rem !important;
  }
  .my-100-lg {
    margin-top: 10rem !important;
    margin-bottom: 10rem !important;
  }
  .py-100-lg {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}
@media (max-width: 767px) {
  .mt-0-md {
    margin-top: 0rem !important;
  }
  .pt-0-md {
    padding-top: 0rem !important;
  }
  .mb-0-md {
    margin-bottom: 0rem !important;
  }
  .pb-0-md {
    padding-bottom: 0rem !important;
  }
  .ml-0-md {
    margin-left: 0rem !important;
  }
  .pl-0-md {
    padding-left: 0rem !important;
  }
  .mr-0-md {
    margin-right: 0rem !important;
  }
  .pr-0-md {
    padding-right: 0rem !important;
  }
  .mx-0-md {
    margin-left: 0rem !important;
    margin-right: 0rem !important;
  }
  .px-0-md {
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
  .my-0-md {
    margin-top: 0rem !important;
    margin-bottom: 0rem !important;
  }
  .py-0-md {
    padding-top: 0rem !important;
    padding-bottom: 0rem !important;
  }
  .mt-5-md {
    margin-top: 0.5rem !important;
  }
  .pt-5-md {
    padding-top: 0.5rem !important;
  }
  .mb-5-md {
    margin-bottom: 0.5rem !important;
  }
  .pb-5-md {
    padding-bottom: 0.5rem !important;
  }
  .ml-5-md {
    margin-left: 0.5rem !important;
  }
  .pl-5-md {
    padding-left: 0.5rem !important;
  }
  .mr-5-md {
    margin-right: 0.5rem !important;
  }
  .pr-5-md {
    padding-right: 0.5rem !important;
  }
  .mx-5-md {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .px-5-md {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .my-5-md {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .py-5-md {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .mt-10-md {
    margin-top: 1rem !important;
  }
  .pt-10-md {
    padding-top: 1rem !important;
  }
  .mb-10-md {
    margin-bottom: 1rem !important;
  }
  .pb-10-md {
    padding-bottom: 1rem !important;
  }
  .ml-10-md {
    margin-left: 1rem !important;
  }
  .pl-10-md {
    padding-left: 1rem !important;
  }
  .mr-10-md {
    margin-right: 1rem !important;
  }
  .pr-10-md {
    padding-right: 1rem !important;
  }
  .mx-10-md {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .px-10-md {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .my-10-md {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .py-10-md {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .mt-15-md {
    margin-top: 1.5rem !important;
  }
  .pt-15-md {
    padding-top: 1.5rem !important;
  }
  .mb-15-md {
    margin-bottom: 1.5rem !important;
  }
  .pb-15-md {
    padding-bottom: 1.5rem !important;
  }
  .ml-15-md {
    margin-left: 1.5rem !important;
  }
  .pl-15-md {
    padding-left: 1.5rem !important;
  }
  .mr-15-md {
    margin-right: 1.5rem !important;
  }
  .pr-15-md {
    padding-right: 1.5rem !important;
  }
  .mx-15-md {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .px-15-md {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .my-15-md {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .py-15-md {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .mt-20-md {
    margin-top: 2rem !important;
  }
  .pt-20-md {
    padding-top: 2rem !important;
  }
  .mb-20-md {
    margin-bottom: 2rem !important;
  }
  .pb-20-md {
    padding-bottom: 2rem !important;
  }
  .ml-20-md {
    margin-left: 2rem !important;
  }
  .pl-20-md {
    padding-left: 2rem !important;
  }
  .mr-20-md {
    margin-right: 2rem !important;
  }
  .pr-20-md {
    padding-right: 2rem !important;
  }
  .mx-20-md {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .px-20-md {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .my-20-md {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .py-20-md {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .mt-25-md {
    margin-top: 2.5rem !important;
  }
  .pt-25-md {
    padding-top: 2.5rem !important;
  }
  .mb-25-md {
    margin-bottom: 2.5rem !important;
  }
  .pb-25-md {
    padding-bottom: 2.5rem !important;
  }
  .ml-25-md {
    margin-left: 2.5rem !important;
  }
  .pl-25-md {
    padding-left: 2.5rem !important;
  }
  .mr-25-md {
    margin-right: 2.5rem !important;
  }
  .pr-25-md {
    padding-right: 2.5rem !important;
  }
  .mx-25-md {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
  }
  .px-25-md {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
  }
  .my-25-md {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
  }
  .py-25-md {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  .mt-30-md {
    margin-top: 3rem !important;
  }
  .pt-30-md {
    padding-top: 3rem !important;
  }
  .mb-30-md {
    margin-bottom: 3rem !important;
  }
  .pb-30-md {
    padding-bottom: 3rem !important;
  }
  .ml-30-md {
    margin-left: 3rem !important;
  }
  .pl-30-md {
    padding-left: 3rem !important;
  }
  .mr-30-md {
    margin-right: 3rem !important;
  }
  .pr-30-md {
    padding-right: 3rem !important;
  }
  .mx-30-md {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .px-30-md {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .my-30-md {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .py-30-md {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .mt-35-md {
    margin-top: 3.5rem !important;
  }
  .pt-35-md {
    padding-top: 3.5rem !important;
  }
  .mb-35-md {
    margin-bottom: 3.5rem !important;
  }
  .pb-35-md {
    padding-bottom: 3.5rem !important;
  }
  .ml-35-md {
    margin-left: 3.5rem !important;
  }
  .pl-35-md {
    padding-left: 3.5rem !important;
  }
  .mr-35-md {
    margin-right: 3.5rem !important;
  }
  .pr-35-md {
    padding-right: 3.5rem !important;
  }
  .mx-35-md {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
  }
  .px-35-md {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
  .my-35-md {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
  }
  .py-35-md {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }
  .mt-40-md {
    margin-top: 4rem !important;
  }
  .pt-40-md {
    padding-top: 4rem !important;
  }
  .mb-40-md {
    margin-bottom: 4rem !important;
  }
  .pb-40-md {
    padding-bottom: 4rem !important;
  }
  .ml-40-md {
    margin-left: 4rem !important;
  }
  .pl-40-md {
    padding-left: 4rem !important;
  }
  .mr-40-md {
    margin-right: 4rem !important;
  }
  .pr-40-md {
    padding-right: 4rem !important;
  }
  .mx-40-md {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .px-40-md {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .my-40-md {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .py-40-md {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .mt-45-md {
    margin-top: 4.5rem !important;
  }
  .pt-45-md {
    padding-top: 4.5rem !important;
  }
  .mb-45-md {
    margin-bottom: 4.5rem !important;
  }
  .pb-45-md {
    padding-bottom: 4.5rem !important;
  }
  .ml-45-md {
    margin-left: 4.5rem !important;
  }
  .pl-45-md {
    padding-left: 4.5rem !important;
  }
  .mr-45-md {
    margin-right: 4.5rem !important;
  }
  .pr-45-md {
    padding-right: 4.5rem !important;
  }
  .mx-45-md {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
  }
  .px-45-md {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }
  .my-45-md {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
  .py-45-md {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .mt-50-md {
    margin-top: 5rem !important;
  }
  .pt-50-md {
    padding-top: 5rem !important;
  }
  .mb-50-md {
    margin-bottom: 5rem !important;
  }
  .pb-50-md {
    padding-bottom: 5rem !important;
  }
  .ml-50-md {
    margin-left: 5rem !important;
  }
  .pl-50-md {
    padding-left: 5rem !important;
  }
  .mr-50-md {
    margin-right: 5rem !important;
  }
  .pr-50-md {
    padding-right: 5rem !important;
  }
  .mx-50-md {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
  }
  .px-50-md {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
  .my-50-md {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
  }
  .py-50-md {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
  .mt-60-md {
    margin-top: 6rem !important;
  }
  .pt-60-md {
    padding-top: 6rem !important;
  }
  .mb-60-md {
    margin-bottom: 6rem !important;
  }
  .pb-60-md {
    padding-bottom: 6rem !important;
  }
  .ml-60-md {
    margin-left: 6rem !important;
  }
  .pl-60-md {
    padding-left: 6rem !important;
  }
  .mr-60-md {
    margin-right: 6rem !important;
  }
  .pr-60-md {
    padding-right: 6rem !important;
  }
  .mx-60-md {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
  }
  .px-60-md {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
  }
  .my-60-md {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
  }
  .py-60-md {
    padding-top: 6rem !important;
    padding-bottom: 6rem !important;
  }
  .mt-70-md {
    margin-top: 7rem !important;
  }
  .pt-70-md {
    padding-top: 7rem !important;
  }
  .mb-70-md {
    margin-bottom: 7rem !important;
  }
  .pb-70-md {
    padding-bottom: 7rem !important;
  }
  .ml-70-md {
    margin-left: 7rem !important;
  }
  .pl-70-md {
    padding-left: 7rem !important;
  }
  .mr-70-md {
    margin-right: 7rem !important;
  }
  .pr-70-md {
    padding-right: 7rem !important;
  }
  .mx-70-md {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
  }
  .px-70-md {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
  }
  .my-70-md {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
  }
  .py-70-md {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
  }
  .mt-80-md {
    margin-top: 8rem !important;
  }
  .pt-80-md {
    padding-top: 8rem !important;
  }
  .mb-80-md {
    margin-bottom: 8rem !important;
  }
  .pb-80-md {
    padding-bottom: 8rem !important;
  }
  .ml-80-md {
    margin-left: 8rem !important;
  }
  .pl-80-md {
    padding-left: 8rem !important;
  }
  .mr-80-md {
    margin-right: 8rem !important;
  }
  .pr-80-md {
    padding-right: 8rem !important;
  }
  .mx-80-md {
    margin-left: 8rem !important;
    margin-right: 8rem !important;
  }
  .px-80-md {
    padding-left: 8rem !important;
    padding-right: 8rem !important;
  }
  .my-80-md {
    margin-top: 8rem !important;
    margin-bottom: 8rem !important;
  }
  .py-80-md {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
  }
  .mt-90-md {
    margin-top: 9rem !important;
  }
  .pt-90-md {
    padding-top: 9rem !important;
  }
  .mb-90-md {
    margin-bottom: 9rem !important;
  }
  .pb-90-md {
    padding-bottom: 9rem !important;
  }
  .ml-90-md {
    margin-left: 9rem !important;
  }
  .pl-90-md {
    padding-left: 9rem !important;
  }
  .mr-90-md {
    margin-right: 9rem !important;
  }
  .pr-90-md {
    padding-right: 9rem !important;
  }
  .mx-90-md {
    margin-left: 9rem !important;
    margin-right: 9rem !important;
  }
  .px-90-md {
    padding-left: 9rem !important;
    padding-right: 9rem !important;
  }
  .my-90-md {
    margin-top: 9rem !important;
    margin-bottom: 9rem !important;
  }
  .py-90-md {
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
  }
  .mt-100-md {
    margin-top: 10rem !important;
  }
  .pt-100-md {
    padding-top: 10rem !important;
  }
  .mb-100-md {
    margin-bottom: 10rem !important;
  }
  .pb-100-md {
    padding-bottom: 10rem !important;
  }
  .ml-100-md {
    margin-left: 10rem !important;
  }
  .pl-100-md {
    padding-left: 10rem !important;
  }
  .mr-100-md {
    margin-right: 10rem !important;
  }
  .pr-100-md {
    padding-right: 10rem !important;
  }
  .mx-100-md {
    margin-left: 10rem !important;
    margin-right: 10rem !important;
  }
  .px-100-md {
    padding-left: 10rem !important;
    padding-right: 10rem !important;
  }
  .my-100-md {
    margin-top: 10rem !important;
    margin-bottom: 10rem !important;
  }
  .py-100-md {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}
@media (max-width: 575px) {
  .mt-0-sm {
    margin-top: 0rem !important;
  }
  .pt-0-sm {
    padding-top: 0rem !important;
  }
  .mb-0-sm {
    margin-bottom: 0rem !important;
  }
  .pb-0-sm {
    padding-bottom: 0rem !important;
  }
  .ml-0-sm {
    margin-left: 0rem !important;
  }
  .pl-0-sm {
    padding-left: 0rem !important;
  }
  .mr-0-sm {
    margin-right: 0rem !important;
  }
  .pr-0-sm {
    padding-right: 0rem !important;
  }
  .mx-0-sm {
    margin-left: 0rem !important;
    margin-right: 0rem !important;
  }
  .px-0-sm {
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
  .my-0-sm {
    margin-top: 0rem !important;
    margin-bottom: 0rem !important;
  }
  .py-0-sm {
    padding-top: 0rem !important;
    padding-bottom: 0rem !important;
  }
  .mt-5-sm {
    margin-top: 0.5rem !important;
  }
  .pt-5-sm {
    padding-top: 0.5rem !important;
  }
  .mb-5-sm {
    margin-bottom: 0.5rem !important;
  }
  .pb-5-sm {
    padding-bottom: 0.5rem !important;
  }
  .ml-5-sm {
    margin-left: 0.5rem !important;
  }
  .pl-5-sm {
    padding-left: 0.5rem !important;
  }
  .mr-5-sm {
    margin-right: 0.5rem !important;
  }
  .pr-5-sm {
    padding-right: 0.5rem !important;
  }
  .mx-5-sm {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .px-5-sm {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .my-5-sm {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .py-5-sm {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .mt-10-sm {
    margin-top: 1rem !important;
  }
  .pt-10-sm {
    padding-top: 1rem !important;
  }
  .mb-10-sm {
    margin-bottom: 1rem !important;
  }
  .pb-10-sm {
    padding-bottom: 1rem !important;
  }
  .ml-10-sm {
    margin-left: 1rem !important;
  }
  .pl-10-sm {
    padding-left: 1rem !important;
  }
  .mr-10-sm {
    margin-right: 1rem !important;
  }
  .pr-10-sm {
    padding-right: 1rem !important;
  }
  .mx-10-sm {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .px-10-sm {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .my-10-sm {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .py-10-sm {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .mt-15-sm {
    margin-top: 1.5rem !important;
  }
  .pt-15-sm {
    padding-top: 1.5rem !important;
  }
  .mb-15-sm {
    margin-bottom: 1.5rem !important;
  }
  .pb-15-sm {
    padding-bottom: 1.5rem !important;
  }
  .ml-15-sm {
    margin-left: 1.5rem !important;
  }
  .pl-15-sm {
    padding-left: 1.5rem !important;
  }
  .mr-15-sm {
    margin-right: 1.5rem !important;
  }
  .pr-15-sm {
    padding-right: 1.5rem !important;
  }
  .mx-15-sm {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .px-15-sm {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .my-15-sm {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .py-15-sm {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .mt-20-sm {
    margin-top: 2rem !important;
  }
  .pt-20-sm {
    padding-top: 2rem !important;
  }
  .mb-20-sm {
    margin-bottom: 2rem !important;
  }
  .pb-20-sm {
    padding-bottom: 2rem !important;
  }
  .ml-20-sm {
    margin-left: 2rem !important;
  }
  .pl-20-sm {
    padding-left: 2rem !important;
  }
  .mr-20-sm {
    margin-right: 2rem !important;
  }
  .pr-20-sm {
    padding-right: 2rem !important;
  }
  .mx-20-sm {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .px-20-sm {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .my-20-sm {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .py-20-sm {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .mt-25-sm {
    margin-top: 2.5rem !important;
  }
  .pt-25-sm {
    padding-top: 2.5rem !important;
  }
  .mb-25-sm {
    margin-bottom: 2.5rem !important;
  }
  .pb-25-sm {
    padding-bottom: 2.5rem !important;
  }
  .ml-25-sm {
    margin-left: 2.5rem !important;
  }
  .pl-25-sm {
    padding-left: 2.5rem !important;
  }
  .mr-25-sm {
    margin-right: 2.5rem !important;
  }
  .pr-25-sm {
    padding-right: 2.5rem !important;
  }
  .mx-25-sm {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
  }
  .px-25-sm {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
  }
  .my-25-sm {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
  }
  .py-25-sm {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  .mt-30-sm {
    margin-top: 3rem !important;
  }
  .pt-30-sm {
    padding-top: 3rem !important;
  }
  .mb-30-sm {
    margin-bottom: 3rem !important;
  }
  .pb-30-sm {
    padding-bottom: 3rem !important;
  }
  .ml-30-sm {
    margin-left: 3rem !important;
  }
  .pl-30-sm {
    padding-left: 3rem !important;
  }
  .mr-30-sm {
    margin-right: 3rem !important;
  }
  .pr-30-sm {
    padding-right: 3rem !important;
  }
  .mx-30-sm {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .px-30-sm {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .my-30-sm {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .py-30-sm {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .mt-35-sm {
    margin-top: 3.5rem !important;
  }
  .pt-35-sm {
    padding-top: 3.5rem !important;
  }
  .mb-35-sm {
    margin-bottom: 3.5rem !important;
  }
  .pb-35-sm {
    padding-bottom: 3.5rem !important;
  }
  .ml-35-sm {
    margin-left: 3.5rem !important;
  }
  .pl-35-sm {
    padding-left: 3.5rem !important;
  }
  .mr-35-sm {
    margin-right: 3.5rem !important;
  }
  .pr-35-sm {
    padding-right: 3.5rem !important;
  }
  .mx-35-sm {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
  }
  .px-35-sm {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
  }
  .my-35-sm {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
  }
  .py-35-sm {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }
  .mt-40-sm {
    margin-top: 4rem !important;
  }
  .pt-40-sm {
    padding-top: 4rem !important;
  }
  .mb-40-sm {
    margin-bottom: 4rem !important;
  }
  .pb-40-sm {
    padding-bottom: 4rem !important;
  }
  .ml-40-sm {
    margin-left: 4rem !important;
  }
  .pl-40-sm {
    padding-left: 4rem !important;
  }
  .mr-40-sm {
    margin-right: 4rem !important;
  }
  .pr-40-sm {
    padding-right: 4rem !important;
  }
  .mx-40-sm {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .px-40-sm {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .my-40-sm {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .py-40-sm {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .mt-45-sm {
    margin-top: 4.5rem !important;
  }
  .pt-45-sm {
    padding-top: 4.5rem !important;
  }
  .mb-45-sm {
    margin-bottom: 4.5rem !important;
  }
  .pb-45-sm {
    padding-bottom: 4.5rem !important;
  }
  .ml-45-sm {
    margin-left: 4.5rem !important;
  }
  .pl-45-sm {
    padding-left: 4.5rem !important;
  }
  .mr-45-sm {
    margin-right: 4.5rem !important;
  }
  .pr-45-sm {
    padding-right: 4.5rem !important;
  }
  .mx-45-sm {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
  }
  .px-45-sm {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
  }
  .my-45-sm {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
  .py-45-sm {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .mt-50-sm {
    margin-top: 5rem !important;
  }
  .pt-50-sm {
    padding-top: 5rem !important;
  }
  .mb-50-sm {
    margin-bottom: 5rem !important;
  }
  .pb-50-sm {
    padding-bottom: 5rem !important;
  }
  .ml-50-sm {
    margin-left: 5rem !important;
  }
  .pl-50-sm {
    padding-left: 5rem !important;
  }
  .mr-50-sm {
    margin-right: 5rem !important;
  }
  .pr-50-sm {
    padding-right: 5rem !important;
  }
  .mx-50-sm {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
  }
  .px-50-sm {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
  }
  .my-50-sm {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
  }
  .py-50-sm {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
  .mt-60-sm {
    margin-top: 6rem !important;
  }
  .pt-60-sm {
    padding-top: 6rem !important;
  }
  .mb-60-sm {
    margin-bottom: 6rem !important;
  }
  .pb-60-sm {
    padding-bottom: 6rem !important;
  }
  .ml-60-sm {
    margin-left: 6rem !important;
  }
  .pl-60-sm {
    padding-left: 6rem !important;
  }
  .mr-60-sm {
    margin-right: 6rem !important;
  }
  .pr-60-sm {
    padding-right: 6rem !important;
  }
  .mx-60-sm {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
  }
  .px-60-sm {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
  }
  .my-60-sm {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
  }
  .py-60-sm {
    padding-top: 6rem !important;
    padding-bottom: 6rem !important;
  }
  .mt-70-sm {
    margin-top: 7rem !important;
  }
  .pt-70-sm {
    padding-top: 7rem !important;
  }
  .mb-70-sm {
    margin-bottom: 7rem !important;
  }
  .pb-70-sm {
    padding-bottom: 7rem !important;
  }
  .ml-70-sm {
    margin-left: 7rem !important;
  }
  .pl-70-sm {
    padding-left: 7rem !important;
  }
  .mr-70-sm {
    margin-right: 7rem !important;
  }
  .pr-70-sm {
    padding-right: 7rem !important;
  }
  .mx-70-sm {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
  }
  .px-70-sm {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
  }
  .my-70-sm {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
  }
  .py-70-sm {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
  }
  .mt-80-sm {
    margin-top: 8rem !important;
  }
  .pt-80-sm {
    padding-top: 8rem !important;
  }
  .mb-80-sm {
    margin-bottom: 8rem !important;
  }
  .pb-80-sm {
    padding-bottom: 8rem !important;
  }
  .ml-80-sm {
    margin-left: 8rem !important;
  }
  .pl-80-sm {
    padding-left: 8rem !important;
  }
  .mr-80-sm {
    margin-right: 8rem !important;
  }
  .pr-80-sm {
    padding-right: 8rem !important;
  }
  .mx-80-sm {
    margin-left: 8rem !important;
    margin-right: 8rem !important;
  }
  .px-80-sm {
    padding-left: 8rem !important;
    padding-right: 8rem !important;
  }
  .my-80-sm {
    margin-top: 8rem !important;
    margin-bottom: 8rem !important;
  }
  .py-80-sm {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
  }
  .mt-90-sm {
    margin-top: 9rem !important;
  }
  .pt-90-sm {
    padding-top: 9rem !important;
  }
  .mb-90-sm {
    margin-bottom: 9rem !important;
  }
  .pb-90-sm {
    padding-bottom: 9rem !important;
  }
  .ml-90-sm {
    margin-left: 9rem !important;
  }
  .pl-90-sm {
    padding-left: 9rem !important;
  }
  .mr-90-sm {
    margin-right: 9rem !important;
  }
  .pr-90-sm {
    padding-right: 9rem !important;
  }
  .mx-90-sm {
    margin-left: 9rem !important;
    margin-right: 9rem !important;
  }
  .px-90-sm {
    padding-left: 9rem !important;
    padding-right: 9rem !important;
  }
  .my-90-sm {
    margin-top: 9rem !important;
    margin-bottom: 9rem !important;
  }
  .py-90-sm {
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
  }
  .mt-100-sm {
    margin-top: 10rem !important;
  }
  .pt-100-sm {
    padding-top: 10rem !important;
  }
  .mb-100-sm {
    margin-bottom: 10rem !important;
  }
  .pb-100-sm {
    padding-bottom: 10rem !important;
  }
  .ml-100-sm {
    margin-left: 10rem !important;
  }
  .pl-100-sm {
    padding-left: 10rem !important;
  }
  .mr-100-sm {
    margin-right: 10rem !important;
  }
  .pr-100-sm {
    padding-right: 10rem !important;
  }
  .mx-100-sm {
    margin-left: 10rem !important;
    margin-right: 10rem !important;
  }
  .px-100-sm {
    padding-left: 10rem !important;
    padding-right: 10rem !important;
  }
  .my-100-sm {
    margin-top: 10rem !important;
    margin-bottom: 10rem !important;
  }
  .py-100-sm {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}
.mx-auto, .footer-etc__inner, .page-header__inner {
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 1600px) {
  .mx-auto-xxxl {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 1399px) {
  .mx-auto-xxl {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 1199px) {
  .mx-auto-xl {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 991px) {
  .mx-auto-lg {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 767px) {
  .mx-auto-md {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 575px) {
  .mx-auto-sm {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
.gap-0 {
  gap: 0rem;
}

.gap-5 {
  gap: 0.5rem;
}

.gap-10 {
  gap: 1rem;
}

.gap-15 {
  gap: 1.5rem;
}

.gap-20 {
  gap: 2rem;
}

.gap-25 {
  gap: 2.5rem;
}

.gap-30 {
  gap: 3rem;
}

.gap-35 {
  gap: 3.5rem;
}

.gap-40 {
  gap: 4rem;
}

.gap-45 {
  gap: 4.5rem;
}

.gap-50 {
  gap: 5rem;
}

.gap-60 {
  gap: 6rem;
}

.gap-70 {
  gap: 7rem;
}

.gap-80 {
  gap: 8rem;
}

.gap-90 {
  gap: 9rem;
}

.gap-100 {
  gap: 10rem;
}

@media (max-width: 1600px) {
  .gap-0-xxxl {
    gap: 0rem !important;
  }
  .gap-5-xxxl {
    gap: 0.5rem !important;
  }
  .gap-10-xxxl {
    gap: 1rem !important;
  }
  .gap-15-xxxl {
    gap: 1.5rem !important;
  }
  .gap-20-xxxl {
    gap: 2rem !important;
  }
  .gap-25-xxxl {
    gap: 2.5rem !important;
  }
  .gap-30-xxxl {
    gap: 3rem !important;
  }
  .gap-35-xxxl {
    gap: 3.5rem !important;
  }
  .gap-40-xxxl {
    gap: 4rem !important;
  }
  .gap-45-xxxl {
    gap: 4.5rem !important;
  }
  .gap-50-xxxl {
    gap: 5rem !important;
  }
  .gap-60-xxxl {
    gap: 6rem !important;
  }
  .gap-70-xxxl {
    gap: 7rem !important;
  }
  .gap-80-xxxl {
    gap: 8rem !important;
  }
  .gap-90-xxxl {
    gap: 9rem !important;
  }
  .gap-100-xxxl {
    gap: 10rem !important;
  }
}
@media (max-width: 1399px) {
  .gap-0-xxl {
    gap: 0rem !important;
  }
  .gap-5-xxl {
    gap: 0.5rem !important;
  }
  .gap-10-xxl {
    gap: 1rem !important;
  }
  .gap-15-xxl {
    gap: 1.5rem !important;
  }
  .gap-20-xxl {
    gap: 2rem !important;
  }
  .gap-25-xxl {
    gap: 2.5rem !important;
  }
  .gap-30-xxl {
    gap: 3rem !important;
  }
  .gap-35-xxl {
    gap: 3.5rem !important;
  }
  .gap-40-xxl {
    gap: 4rem !important;
  }
  .gap-45-xxl {
    gap: 4.5rem !important;
  }
  .gap-50-xxl {
    gap: 5rem !important;
  }
  .gap-60-xxl {
    gap: 6rem !important;
  }
  .gap-70-xxl {
    gap: 7rem !important;
  }
  .gap-80-xxl {
    gap: 8rem !important;
  }
  .gap-90-xxl {
    gap: 9rem !important;
  }
  .gap-100-xxl {
    gap: 10rem !important;
  }
}
@media (max-width: 1199px) {
  .gap-0-xl {
    gap: 0rem !important;
  }
  .gap-5-xl {
    gap: 0.5rem !important;
  }
  .gap-10-xl {
    gap: 1rem !important;
  }
  .gap-15-xl {
    gap: 1.5rem !important;
  }
  .gap-20-xl {
    gap: 2rem !important;
  }
  .gap-25-xl {
    gap: 2.5rem !important;
  }
  .gap-30-xl {
    gap: 3rem !important;
  }
  .gap-35-xl {
    gap: 3.5rem !important;
  }
  .gap-40-xl {
    gap: 4rem !important;
  }
  .gap-45-xl {
    gap: 4.5rem !important;
  }
  .gap-50-xl {
    gap: 5rem !important;
  }
  .gap-60-xl {
    gap: 6rem !important;
  }
  .gap-70-xl {
    gap: 7rem !important;
  }
  .gap-80-xl {
    gap: 8rem !important;
  }
  .gap-90-xl {
    gap: 9rem !important;
  }
  .gap-100-xl {
    gap: 10rem !important;
  }
}
@media (max-width: 991px) {
  .gap-0-lg {
    gap: 0rem !important;
  }
  .gap-5-lg {
    gap: 0.5rem !important;
  }
  .gap-10-lg {
    gap: 1rem !important;
  }
  .gap-15-lg {
    gap: 1.5rem !important;
  }
  .gap-20-lg {
    gap: 2rem !important;
  }
  .gap-25-lg {
    gap: 2.5rem !important;
  }
  .gap-30-lg {
    gap: 3rem !important;
  }
  .gap-35-lg {
    gap: 3.5rem !important;
  }
  .gap-40-lg {
    gap: 4rem !important;
  }
  .gap-45-lg {
    gap: 4.5rem !important;
  }
  .gap-50-lg {
    gap: 5rem !important;
  }
  .gap-60-lg {
    gap: 6rem !important;
  }
  .gap-70-lg {
    gap: 7rem !important;
  }
  .gap-80-lg {
    gap: 8rem !important;
  }
  .gap-90-lg {
    gap: 9rem !important;
  }
  .gap-100-lg {
    gap: 10rem !important;
  }
}
@media (max-width: 767px) {
  .gap-0-md {
    gap: 0rem !important;
  }
  .gap-5-md {
    gap: 0.5rem !important;
  }
  .gap-10-md {
    gap: 1rem !important;
  }
  .gap-15-md {
    gap: 1.5rem !important;
  }
  .gap-20-md {
    gap: 2rem !important;
  }
  .gap-25-md {
    gap: 2.5rem !important;
  }
  .gap-30-md {
    gap: 3rem !important;
  }
  .gap-35-md {
    gap: 3.5rem !important;
  }
  .gap-40-md {
    gap: 4rem !important;
  }
  .gap-45-md {
    gap: 4.5rem !important;
  }
  .gap-50-md {
    gap: 5rem !important;
  }
  .gap-60-md {
    gap: 6rem !important;
  }
  .gap-70-md {
    gap: 7rem !important;
  }
  .gap-80-md {
    gap: 8rem !important;
  }
  .gap-90-md {
    gap: 9rem !important;
  }
  .gap-100-md {
    gap: 10rem !important;
  }
}
@media (max-width: 575px) {
  .gap-0-sm {
    gap: 0rem !important;
  }
  .gap-5-sm {
    gap: 0.5rem !important;
  }
  .gap-10-sm {
    gap: 1rem !important;
  }
  .gap-15-sm {
    gap: 1.5rem !important;
  }
  .gap-20-sm {
    gap: 2rem !important;
  }
  .gap-25-sm {
    gap: 2.5rem !important;
  }
  .gap-30-sm {
    gap: 3rem !important;
  }
  .gap-35-sm {
    gap: 3.5rem !important;
  }
  .gap-40-sm {
    gap: 4rem !important;
  }
  .gap-45-sm {
    gap: 4.5rem !important;
  }
  .gap-50-sm {
    gap: 5rem !important;
  }
  .gap-60-sm {
    gap: 6rem !important;
  }
  .gap-70-sm {
    gap: 7rem !important;
  }
  .gap-80-sm {
    gap: 8rem !important;
  }
  .gap-90-sm {
    gap: 9rem !important;
  }
  .gap-100-sm {
    gap: 10rem !important;
  }
}
/* スクロールで「ふわっと」表示されるアニメーション */
.fade-in {
  opacity: 0;
  transition: all 0.8s ease-out;
}

.fade-in.active {
  opacity: 1;
}

/* 背景5本線 */
.has-vertical-lines, .p-top-course, .p-top-points {
  position: relative;
  background: linear-gradient(#EDEDED, #EDEDED) 16.66% 0/1px 100% no-repeat, linear-gradient(#EDEDED, #EDEDED) 33.33% 0/1px 100% no-repeat, linear-gradient(#EDEDED, #EDEDED) 50% 0/1px 100% no-repeat, linear-gradient(#EDEDED, #EDEDED) 66.66% 0/1px 100% no-repeat, linear-gradient(#EDEDED, #EDEDED) 83.33% 0/1px 100% no-repeat;
}
@media (max-width: 1199px) {
  .has-vertical-lines, .p-top-course, .p-top-points {
    background: linear-gradient(#EDEDED, #EDEDED) 25% 0/1px 100% no-repeat, linear-gradient(#EDEDED, #EDEDED) 50% 0/1px 100% no-repeat, linear-gradient(#EDEDED, #EDEDED) 75% 0/1px 100% no-repeat;
  }
}

body.course,
body.schedule {
  background: #F9F9F9;
}

/****************************************

	container

*****************************************/
.container-sm {
  max-width: 800px;
  margin: 0 auto;
}
@media (max-width: 991px) {
  .container-sm {
    padding: 0 5rem;
  }
}
@media (max-width: 767px) {
  .container-sm {
    padding: 0 2rem;
  }
}

.container-md {
  max-width: 1000px;
  margin: 0 auto;
}
@media (max-width: 1399px) {
  .container-md {
    padding: 0 5rem;
  }
}
@media (max-width: 767px) {
  .container-md {
    padding: 0 2rem;
  }
}

.container-lg {
  max-width: 1200px;
  margin: 0 auto;
}
@media (max-width: 1599px) {
  .container-lg {
    padding: 0 5rem;
  }
}
@media (max-width: 767px) {
  .container-lg {
    padding: 0 2rem;
  }
}

.container-xl {
  max-width: 1400px;
  margin: 0 auto;
}
@media (max-width: 1799px) {
  .container-xl {
    padding: 0 5rem;
  }
}
@media (max-width: 767px) {
  .container-xl {
    padding: 0 2rem;
  }
}

/****************************************

	area-wrap

*****************************************/
.area-wrap-padding-01 {
  padding: 12rem 0;
}

.area-wrap-padding-02 {
  padding: 10rem 0;
}

@media (max-width: 1199px) {
  .area-wrap-padding-01,
  .area-wrap-padding-02 {
    padding: 6rem 0;
  }
}

.area-wrap-margin-01 {
  margin: 12rem 0;
}

.area-wrap-margin-02 {
  margin: 10rem 0;
}

@media (max-width: 1199px) {
  .area-wrap-margin-01,
  .area-wrap-margin-02 {
    margin: 6rem 0;
  }
}

/****************************************

	c-btn

*****************************************/
.c-btn {
  position: relative;
  display: inline-block;
  padding: 1.4rem 1.6rem;
  font-size: 1.4rem;
  line-height: 1.6;
  text-align: center;
  transition: all 0.3s ease;
}
.c-btn::after {
  content: "";
  position: absolute;
  right: 1.5rem;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 0.8rem;
  height: 0.8rem;
  transition: transform 0.3s ease;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
}
.c-btn:hover::after {
  transform: translateX(4px) rotate(-45deg);
}

.c-btn--sub {
  background: #BDA703;
  color: #fff;
}

.c-btn--dark {
  background: #000;
  color: #fff;
}

.c-btn--md {
  width: 300px;
  padding: 1.6rem 1.6rem;
}
@media (max-width: 575px) {
  .c-btn--md {
    width: 250px;
  }
}

.c-btn--sm {
  width: 230px;
  padding: 1.2rem 1.4rem;
  font-size: 1.4rem;
}

.c-btn--lg {
  display: block;
  width: 100%;
  padding: 3rem 1.4rem;
}

/****************************************

	c-heading

*****************************************/
.c-heading-set {
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}
.c-heading-set__en {
  font-size: 1.8rem;
  color: #BDA703;
}
@media (max-width: 991px) {
  .c-heading-set__en {
    font-size: 1.2rem;
  }
}
.c-heading-set__en:after {
  content: "";
  display: block;
  margin: 0.4rem auto 0.6rem;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #BDA703;
}
.c-heading-set__jp {
  font-size: 3.6rem;
  line-height: 1.4;
}
@media (max-width: 1399px) {
  .c-heading-set__jp {
    font-size: 3rem;
  }
}
@media (max-width: 767px) {
  .c-heading-set__jp {
    font-size: clamp(2.4rem, 2vw, 3rem);
  }
}
.c-heading-set__text {
  margin-top: 1rem;
}
.c-heading-set--white .c-heading-set__en:after {
  background-color: #fff;
}

.c-heading-dark {
  display: flex;
  align-items: center;
  padding: 2rem 3.5rem;
  background: #242424;
  color: #fff;
}
@media (max-width: 1199px) {
  .c-heading-dark {
    padding: 1.5rem 2rem;
  }
}
.c-heading-dark__num {
  flex-shrink: 0;
  font-size: 3.2rem;
  line-height: 1;
}
@media (max-width: 1199px) {
  .c-heading-dark__num {
    font-size: clamp(2.4rem, 2.8vw, 3rem);
  }
}
.c-heading-dark__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  margin-right: 1.5rem;
  width: 50px;
  height: 50px;
  overflow: hidden;
  border-radius: 50%;
}
@media (max-width: 1199px) {
  .c-heading-dark__icon {
    width: 3.3rem;
    height: 3.3rem;
  }
}
.c-heading-dark__icon img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-heading-dark__text {
  display: flex;
  align-items: center;
  font-size: 2.6rem;
  line-height: 1.5;
}
@media (max-width: 1199px) {
  .c-heading-dark__text {
    font-size: clamp(1.9rem, 2.3vw, 2.6rem);
  }
}
.c-heading-dark__text::before {
  content: "";
  display: block;
  width: 1px;
  height: 23px;
  margin: 0 2rem 0 2.3rem;
  background: rgba(255, 255, 255, 0.4);
}

.c-heading-simple {
  font-size: 2.6rem;
  line-height: 1.5;
}
@media (max-width: 1199px) {
  .c-heading-simple {
    font-size: clamp(2rem, 2.3vw, 2.6rem);
  }
}
.c-heading-simple::after {
  content: "";
  display: block;
  width: 70px;
  height: 1px;
  background-color: #000;
  margin-top: 2rem;
}

.c-heading-overlay {
  position: relative;
  text-align: center;
}
.c-heading-overlay__en {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -60%);
  font-size: clamp(10rem, 10vw, 12.8rem);
  color: rgba(0, 0, 0, 0.04);
  line-height: 0.5;
  white-space: nowrap;
  pointer-events: none;
}
@media (max-width: 991px) {
  .c-heading-overlay__en {
    font-size: 10rem;
  }
}
@media (max-width: 767px) {
  .c-heading-overlay__en {
    font-size: 8rem;
  }
}
.c-heading-overlay__jp {
  position: relative;
  font-size: 3.6rem;
  z-index: 1;
}
@media (max-width: 1399px) {
  .c-heading-overlay__jp {
    font-size: 3rem;
  }
}
@media (max-width: 767px) {
  .c-heading-overlay__jp {
    font-size: clamp(2.4rem, 2vw, 3rem);
  }
}
.c-heading-overlay::after {
  content: "";
  display: block;
  width: 2rem;
  height: 1px;
  background: #000;
  margin: 1.2rem auto 0;
  transform: rotate(-45deg);
}

.c-heading-text-set__main {
  margin-bottom: 0.5rem;
  font-size: clamp(2.2rem, 3vw, 3.6rem);
}

.c-heading-line {
  font-size: clamp(2.2rem, 2.6vw, 3.2rem);
  text-align: center;
}
.c-heading-line::after {
  content: "";
  display: block;
  width: clamp(50px, 8vw, 130px);
  height: 1px;
  background: #000;
  margin: 2rem auto 0;
}

/****************************************

	c-table

*****************************************/
.c-table-basic {
  width: 100%;
  margin: 3rem 0;
}
.c-table-basic th,
.c-table-basic td {
  border-top: none;
  border-right: none;
  border-left: none;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .c-table-basic tr:first-child td {
    padding-top: 0.5rem;
    border-top: none;
  }
}
.c-table-basic th {
  position: relative;
  vertical-align: top;
  width: 31rem;
  padding: 3rem;
  font-weight: 600;
  text-align: left;
  border-bottom: 1px solid #242424;
  vertical-align: middle;
}
.c-table-basic td {
  width: calc(100% - 31rem);
  padding: 3rem;
  border-bottom: 1px solid #E0E0E0;
}
.c-table-basic td p + p {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .c-table-basic th,
  .c-table-basic td {
    display: block;
    width: 100%;
  }
  .c-table-basic th {
    padding: 1.5rem 0 0;
    border-bottom: none;
  }
  .c-table-basic td {
    padding: 0.5rem 0 1.5rem;
  }
}

.c-career-table {
  width: 100%;
  margin: 6rem 0;
}
@media (max-width: 1399px) {
  .c-career-table {
    margin: 3rem 0;
  }
}
.c-career-table th,
.c-career-table td {
  border-top: none;
  border-right: none;
  border-left: none;
  border-bottom: 1px solid #E0E0E0;
  line-height: 1.5;
  vertical-align: middle;
}
@media (max-width: 767px) {
  .c-career-table tr:first-child td {
    padding-top: 0.5rem;
    border-top: none;
  }
}
.c-career-table th {
  width: 9rem;
  padding: 2rem 2rem 2rem 0;
  font-weight: 600;
  text-align: left;
}
.c-career-table td {
  width: calc(100% - 9rem);
  padding: 1.5rem 0;
}
.c-career-table td p + p {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .c-career-table th,
  .c-career-table td {
    display: block;
    width: 100%;
  }
  .c-career-table th {
    padding: 1.5rem 0 0;
    border-bottom: none;
  }
  .c-career-table td {
    padding: 0.5rem 0 1.5rem;
  }
}

h2 + .c-career-table,
h3 + .c-career-table,
h4 + .c-career-table,
h5 + .c-career-table,
h6 + .c-career-table {
  margin: 0 0 6rem;
}

.c-table-schedule {
  width: 100%;
}
.c-table-schedule th,
.c-table-schedule td {
  width: 50%;
  padding: 2rem;
  border: 1px solid #E0E0E0;
  line-height: 1.5;
  vertical-align: middle;
}
@media (max-width: 767px) {
  .c-table-schedule th,
  .c-table-schedule td {
    width: 100%;
    display: block;
    padding: 1.5rem;
  }
}
.c-table-schedule th {
  background: #003366;
  color: #fff;
  text-align: left;
}
.c-table-schedule td {
  background: #fff;
  line-height: 2;
}

/****************************************

	c-course(以下で使用)

	front-page.php
	page-course.php
	page-schedule.php

*****************************************/
.c-course {
  background: #fff;
  padding: 5rem;
}
@media (max-width: 767px) {
  .c-course {
    padding: 3rem 2rem;
  }
}
.c-course__heading {
  font-size: 2.4rem;
  line-height: 1.5;
  position: relative;
  margin: 0 0 4rem;
  padding-bottom: 2.2rem;
  line-height: 1.5;
}
@media (max-width: 1399px) {
  .c-course__heading {
    font-size: 1.9rem;
    padding-bottom: 2rem;
  }
}
@media (max-width: 767px) {
  .c-course__heading {
    margin: 0 0 3rem;
  }
}
@media (max-width: 575px) {
  .c-course__heading {
    font-size: 1.8rem;
  }
}
.c-course__heading::before, .c-course__heading::after {
  content: "";
  position: absolute;
  left: 0;
  background: #242424;
}
.c-course__heading::before {
  bottom: 0;
  width: 100%;
  height: 1px;
}
.c-course__heading::after {
  bottom: -1px;
  width: 5%;
  height: 3px;
}
.c-course__inner {
  display: flex;
  gap: clamp(3rem, 4vw, 6rem);
}
@media (max-width: 767px) {
  .c-course__inner {
    flex-direction: column;
    align-items: stretch;
  }
}
.c-course__media {
  flex: 0 0 280px;
}
@media (max-width: 1199px) {
  .c-course__media {
    flex: 0 0 30%;
  }
}
@media (max-width: 767px) {
  .c-course__media {
    flex-basis: auto;
    width: 100%;
    margin-inline: auto;
  }
}
.c-course__media img {
  display: block;
  width: 100%;
  height: auto;
}
.c-course__text p + p {
  margin-top: 3rem;
}

/****************************************

	c-flow(以下で使用)

	front-page.php
	page-course-template.php

*****************************************/
.c-flow {
  counter-reset: flow;
  display: grid;
  gap: 4.5rem;
}
.c-flow__box {
  display: grid;
  grid-template-columns: 40rem 1fr;
  align-items: stretch;
  position: relative;
  box-shadow: 0 0 22px rgba(0, 0, 0, 0.1);
  counter-increment: flow;
}
@media (max-width: 991px) {
  .c-flow__box {
    grid-template-columns: 40% 1fr;
  }
}
@media (max-width: 767px) {
  .c-flow__box {
    grid-template-columns: 1fr;
  }
}
.c-flow__box:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -3rem;
  margin-inline: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 13px 19.5px 0 19.5px;
  border-color: #003366 transparent transparent transparent;
}
.c-flow__heading {
  position: relative;
  display: grid;
  align-items: center;
  padding: 2rem 3rem 2rem 10rem;
  background: #003366;
  font-size: 1.8rem;
  color: #fff;
}
@media (max-width: 991px) {
  .c-flow__heading {
    font-size: 1.6rem;
    padding: 1.5rem 3rem 1.5rem 10rem;
  }
}
@media (max-width: 575px) {
  .c-flow__heading {
    padding: 1.5rem 3rem 1.5rem 8rem;
  }
}
.c-flow__heading::before {
  content: counter(flow, decimal-leading-zero);
  position: absolute;
  left: 2.5rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 3.2rem;
  color: rgba(255, 255, 255, 0.3);
}
@media (max-width: 575px) {
  .c-flow__heading::before {
    font-size: 2.5rem;
  }
}
.c-flow__heading::after {
  content: "";
  position: absolute;
  left: 8rem;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 1px;
  background: rgba(255, 255, 255, 0.3);
}
@media (max-width: 575px) {
  .c-flow__heading::after {
    left: 6.5rem;
  }
}
.c-flow__text {
  padding: 2rem 3rem;
  background: #fff;
}
.c-flow__text a {
  color: #BDA703;
  text-decoration: underline;
}

/****************************************

	.c-achievements(以下で使用)

	front-page.php
	archive-achievements.php

*****************************************/
.c-achievements {
  display: grid;
  gap: 2rem;
}
.c-achievements__body {
  display: flex;
  align-items: center;
  gap: 1.5rem 2rem;
}
.c-achievements__thumbnail {
  flex-shrink: 0;
  width: 100px;
  height: 100px;
  overflow: hidden;
  border-radius: 50%;
}
.c-achievements__thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-achievements__label {
  display: inline-block;
  padding: 0.2rem 1rem 0.5rem;
  border: 1px solid #000;
  font-size: 1.2rem;
  line-height: 1.2;
}
.c-achievements__heading {
  font-size: clamp(2rem, 2.2vw, 2.4rem);
  line-height: 1.5;
  margin: 0.5rem 0;
}
.c-achievements__position {
  font-size: 1.4rem;
  color: #666;
}
.c-achievements table {
  width: 100%;
}
.c-achievements table th {
  width: 150px;
  background: #003366;
  color: #fff;
}
.c-achievements table td {
  background: #fff;
}
.c-achievements table th,
.c-achievements table td {
  padding: 1.5rem 1rem;
  border: 1px solid #E0E0E0;
  font-size: 1.4rem;
}
@media (max-width: 375px) {
  .c-achievements table th,
  .c-achievements table td {
    display: block;
    width: 100%;
  }
}
.c-achievements .c-heading-dark {
  margin-top: clamp(3rem, 2.5vw, 5rem);
}
@media (max-width: 767px) {
  .c-achievements .c-heading-dark {
    margin-top: 0;
  }
}
.c-achievements .c-heading-dark__text::before {
  content: none;
}
.c-achievements {
  /* archive-achievements.php で使用 */
}
.c-achievements__item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem 3rem;
  padding-block: 4rem;
}
@media (max-width: 991px) {
  .c-achievements__item {
    grid-template-columns: 1fr;
  }
}
.c-achievements__item:not(:last-child) {
  border-bottom: 1px solid #E0E0E0;
}
.c-achievements {
  /* end archive-achievements.php で使用 */
}

/****************************************

	.c-profile(以下で使用)

	front-page.php
	page-about.php
	profile-block.php

*****************************************/
.c-profile {
  display: grid;
  grid-template-columns: 36rem 1fr;
  gap: clamp(4rem, 5vw, 6rem);
}
@media (max-width: 1199px) {
  .c-profile {
    grid-template-columns: 30rem 1fr;
  }
}
@media (max-width: 767px) {
  .c-profile {
    grid-template-columns: 1fr;
    gap: 3rem;
    max-width: 550px;
    margin-inline: auto;
  }
}
@media (max-width: 767px) {
  .c-profile__media {
    max-width: 50%;
    margin-inline: auto;
  }
}
.c-profile__media img {
  display: block;
  width: 100%;
  height: auto;
}
.c-profile__info {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.c-profile__company {
  margin-bottom: 1.2rem;
  font-size: 1.4rem;
}
.c-profile__name {
  margin-bottom: 0.8rem;
  font-size: clamp(2.2rem, 3vw, 3.4rem);
  line-height: 1.2;
}
.c-profile__name-en {
  margin-bottom: 3rem;
  font-size: clamp(0.9rem, 1vw, 1.2rem);
  color: #BDA703;
  letter-spacing: 0.4em;
}
.c-profile__body p {
  line-height: 2;
}
.c-profile__body p + p {
  margin-top: 3rem;
}

/****************************************

	.c-cta-banner(以下で使用)

	front-page.php
	page-about.php
	page-schedule.php

*****************************************/
.c-cta-banner {
  display: grid;
  gap: 1.5rem;
}
.c-cta-banner__inner {
  position: relative;
  overflow: hidden;
}
.c-cta-banner__link {
  display: block;
  padding: 4rem;
  color: #fff;
}
@media (max-width: 991px) {
  .c-cta-banner__link {
    padding: clamp(2rem, 3vw, 4rem) clamp(2.5rem, 3vw, 4rem);
  }
}
.c-cta-banner__info {
  position: relative;
  z-index: 1;
  max-width: 59rem;
  padding-right: 5rem;
}
@media (max-width: 1399px) {
  .c-cta-banner__info {
    max-width: 65%;
  }
}
@media (max-width: 767px) {
  .c-cta-banner__info {
    max-width: none;
    width: 100%;
    padding-right: 0;
  }
}
.c-cta-banner__point {
  display: inline-block;
  margin-bottom: 1rem;
  padding: 0.1rem 2rem;
  background: #fff;
  border-radius: 2rem;
  font-size: clamp(1.2rem, 1.5vw, 1.6rem);
  color: #000;
}
@media (max-width: 767px) {
  .c-cta-banner__point {
    padding: 0 2rem 0.3rem;
  }
}
.c-cta-banner__heading {
  margin-bottom: 1rem;
  font-size: clamp(1.8rem, 2vw, 2.4rem);
  line-height: 1.3;
}
.c-cta-banner__text {
  margin-bottom: clamp(1rem, 1.5vw, 2rem);
  font-size: clamp(1.2rem, 1.3vw, 1.4rem);
}
.c-cta-banner__btn {
  display: grid;
  grid-template-columns: 1fr 2rem;
  align-items: center;
  max-width: 260px;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid #fff;
  font-size: clamp(1.2rem, 1.3vw, 1.4rem);
}
.c-cta-banner__btn::after {
  content: "";
  display: block;
  width: 1.7rem;
  height: 1.3rem;
  background: url(../images/common/ic_blank.svg) center center no-repeat;
  background-size: cover;
}
.c-cta-banner__media {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(38%, 42rem);
  height: 100%;
}
@media (max-width: 767px) {
  .c-cta-banner__media {
    display: none;
  }
}
.c-cta-banner__media::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 8rem;
  z-index: 1;
  pointer-events: none;
}
.c-cta-banner__media img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

/****************************************

	c-category-nav(以下で使用)

	archive-achievements.php
	archive-voice.php

*****************************************/
.c-category-nav ul {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1rem, 1.3vw, 1.3rem);
}
.c-category-nav li.is-active a {
  background: #003366;
  border: 1px solid #003366;
  color: #fff;
}
.c-category-nav a {
  display: block;
  padding: 1.5rem 3rem;
  padding-block: clamp(0.8rem, 1.3vw, 1.5rem);
  padding-inline: clamp(2rem, 2.5vw, 3rem);
  border: 1px solid #E0E0E0;
}
@media (max-width: 767px) {
  .c-category-nav a {
    font-size: clamp(1.2rem, 1.3vw, 1.4rem);
  }
}
.c-category-nav a:hover {
  background: #003366;
  border: 1px solid #003366;
  color: #fff;
}

/****************************************

	c-note-box(以下で使用)

	page-schedule.php

*****************************************/
.c-note-box {
  padding-block: clamp(2.5rem, 3.5vw, 7rem);
  padding-inline: clamp(2rem, 6vw, 10rem);
  background: #fff;
}
.c-note-box__heading {
  margin-bottom: clamp(1rem, 1.5vw, 2.5rem);
  padding-bottom: clamp(1rem, 1.5vw, 2.5rem);
  border-bottom: 1px solid #E0E0E0;
  font-size: clamp(1.6rem, 2vw, 2.4rem);
  line-height: 1.5;
}
/****************************************

	c-note-box(以下で使用)

	page-course-template.php

*****************************************/
.c-feature-grid {
  max-width: 1100px;
}
.c-feature-grid__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
@media (max-width: 991px) {
  .c-feature-grid__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575px) {
  .c-feature-grid__list {
    grid-template-columns: 1fr;
  }
}
.c-feature-grid__item {
  background: #fff;
  padding: 4rem 3rem;
}
.c-feature-grid__img {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-inline: auto;
  margin-bottom: 1.8rem;
  text-align: center;
  width: clamp(100px, 10vw, 150px);
}
.c-feature-grid__img img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 100px;
}
.c-feature-grid__title {
  font-size: clamp(1.8rem, 1.9vw, 2rem);
  margin-bottom: 1rem;
  text-align: center;
  line-height: 1.5;
}
.c-feature-grid__title::after {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background: #000;
  margin: 2rem auto;
}
.c-feature-grid__text {
  font-size: clamp(1.4rem, 1.45vw, 1.5rem);
  line-height: 1.8;
}

.c-check-list {
  padding-block: clamp(1rem, 2vw, 3rem);
  padding-inline: clamp(2rem, 5vw, 8rem);
  background: #fff;
}
.c-check-list__item {
  position: relative;
  padding-block: clamp(1.2rem, 1.5vw, 2rem);
  padding-left: 3.2rem;
  border-bottom: 1px solid #E0E0E0;
  line-height: 1.6;
}
.c-check-list__item::before {
  content: "";
  position: absolute;
  left: 0.4rem;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1rem;
  height: 1.8rem;
  border-right: 2px solid #BDA703;
  border-bottom: 2px solid #BDA703;
  transform: rotate(45deg);
}
.c-check-list__item:last-child {
  border-bottom: none;
}

.c-list-bordered {
  padding-block: clamp(1rem, 2vw, 3rem);
  padding-inline: clamp(2rem, 5vw, 8rem);
  background: #fff;
}
.c-list-bordered__item {
  position: relative;
  padding: 2rem 0 2rem 2rem;
  border-bottom: 1px solid #E0E0E0;
  line-height: 1.8;
}
.c-list-bordered__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3rem;
  width: 6px;
  height: 6px;
  background: currentColor;
  border-radius: 50%;
}
.c-list-bordered__item:last-child {
  border-bottom: none;
}

.c-text-supplement {
  max-width: 800px;
  margin-inline: auto;
}

/****************************************

	c-list

*****************************************/
.c-list01 li, .post-sec .wp-block-list li, .c-note-box .post-sec li {
  position: relative;
  padding-left: 1.5rem;
  line-height: 1.7;
}
.c-list01 li:not(:last-child), .post-sec .wp-block-list li:not(:last-child), .c-note-box .post-sec li:not(:last-child) {
  margin-bottom: 0.8rem;
}
.c-list01 li::before, .post-sec .wp-block-list li::before, .c-note-box .post-sec li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1.1rem;
  width: 6px;
  height: 6px;
  background: currentColor;
  border-radius: 50%;
}

/****************************************

	mod-toggle

*****************************************/
.mod-toggle {
  margin-bottom: 1.8rem;
}
@media (max-width: 575px) {
  .mod-toggle {
    margin-bottom: 1rem;
  }
}
.mod-toggle dt {
  font-size: clamp(1.4rem, 1.6vw, 1.8rem);
  line-height: 1.5;
  color: #fff;
  padding: 2.5rem 6rem;
  background: #242424;
  position: relative;
}
@media (max-width: 991px) {
  .mod-toggle dt {
    padding: 2rem 4rem 2rem 5rem;
  }
}
.mod-toggle dt::before {
  content: "Q";
  position: absolute;
  top: 23%;
  left: 2rem;
  font-size: clamp(2rem, 2.2vw, 2.4rem);
  color: #BDA703;
}
@media (max-width: 991px) {
  .mod-toggle dt::before {
    left: 1.5rem;
    width: 3rem;
    height: 3rem;
  }
}
.mod-toggle dt:after {
  content: "";
  position: absolute;
  right: 2.5rem;
  top: 38%;
  width: 0.9rem;
  height: 0.9rem;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
  transition: 0.5s;
}
@media (max-width: 991px) {
  .mod-toggle dt:after {
    right: 1.5rem;
  }
}
.mod-toggle dt.open:after {
  top: 43%;
  transform: rotate(225deg);
  transition: 0.5s;
}
.mod-toggle dd {
  display: none;
  padding: 2rem 0;
}

/****************************************

	form

*****************************************/
.wpcf7-form button,
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=url],
.wpcf7-form input[type=tel],
.wpcf7-form input[type=password],
.wpcf7-form textarea {
  padding: 2.4rem 2rem;
  box-sizing: border-box;
  background-color: #F6F6F6;
  border: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  font-size: 1.6rem;
  font-weight: normal;
}
@media (max-width: 767px) {
  .wpcf7-form button,
  .wpcf7-form input[type=text],
  .wpcf7-form input[type=email],
  .wpcf7-form input[type=url],
  .wpcf7-form input[type=tel],
  .wpcf7-form input[type=password],
  .wpcf7-form textarea {
    padding: 1.8rem 2rem;
  }
}
.wpcf7-form input::-moz-placeholder, .wpcf7-form textarea::-moz-placeholder {
  color: #BBBBBB;
  font-size: 1.5rem;
}
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder {
  color: #BBBBBB;
  font-size: 1.5rem;
}
.wpcf7-form .input-s {
  width: 100px;
}
.wpcf7-form .input-m {
  width: 240px;
}
.wpcf7-form .input-l {
  width: 100%;
}
.wpcf7-form p {
  margin: 0 !important;
}
.wpcf7-form textarea {
  width: 100%;
}
.wpcf7-form select {
  font-size: 1.6rem;
  line-height: 1em;
  padding-right: 25px;
  border: 1px solid #E0E0E0;
  padding: 1.5rem;
  width: 100%;
  background: white;
  border-radius: 5px;
  /* iphoneにpaddingが効かないので追加 */
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  /* 右側に矢印を追加 */
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24"><path d="M7 10l5 5 5-5z" fill="black"/></svg>');
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 20px;
}
.wpcf7-form input[type=checkbox] {
  border: 1px solid #999999;
  padding: 12px 8px;
  width: 20px;
  height: 20px;
}
.wpcf7-form input[type=radio] {
  position: relative;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  box-sizing: border-box;
  width: 24px;
  height: 24px;
  content: "";
  background-color: #FFFFFF;
  border: 1px solid #999999;
  border-radius: 24px;
  vertical-align: middle;
  cursor: pointer;
  margin: 0 5px 4px 0;
  padding: 10px 10px 10px 0;
}
.wpcf7-form button,
.wpcf7-form input[type=submit],
.wpcf7-form input[type=button],
.wpcf7-form input[type=reset] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: #BDA703;
  color: #fff;
  border: none;
  display: block;
  font-size: 1.6rem;
  font-weight: 500;
  padding: 2.4rem 1rem;
  width: 300px;
}
@media (max-width: 575px) {
  .wpcf7-form button,
  .wpcf7-form input[type=submit],
  .wpcf7-form input[type=button],
  .wpcf7-form input[type=reset] {
    width: auto;
  }
}
.wpcf7-form button:hover,
.wpcf7-form input[type=submit]:hover,
.wpcf7-form input[type=button]:hover,
.wpcf7-form input[type=reset]:hover {
  opacity: 0.9;
}
.wpcf7-form .error {
  color: #ff0000;
}
@media (max-width: 575px) {
  .wpcf7-form textarea {
    width: 100%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
  }
  .wpcf7-form input[type=text],
  .wpcf7-form input[type=email],
  .wpcf7-form input[type=url],
  .wpcf7-form input[type=tel] {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    width: 100%;
  }
  .wpcf7-form button,
  .wpcf7-form input[type=submit],
  .wpcf7-form input[type=button],
  .wpcf7-form input[type=reset] {
    width: 100%;
  }
}
.wpcf7-form table {
  width: 100%;
}
.wpcf7-form table th,
.wpcf7-form table td {
  padding: 2.4rem 0;
  border-top: none;
  border-right: none;
  border-left: none;
  border-bottom: 1px solid #E0E0E0;
}
.wpcf7-form table th {
  width: 28rem;
  vertical-align: middle;
  text-align: left;
}
.wpcf7-form table td {
  width: calc(100% - 28rem);
}
.wpcf7-form table td p + p {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .wpcf7-form table th,
  .wpcf7-form table td {
    width: 100%;
    display: block;
  }
  .wpcf7-form table th {
    padding: 1.5rem 0 0;
    border-bottom: none;
  }
  .wpcf7-form table td {
    padding: 1.5rem 0;
  }
}

.hissu,
.nini {
  font-size: 1.2rem;
  line-height: 1.5;
  margin-right: 1rem;
  padding: 0.2rem 0.8rem;
}

.hissu {
  color: #BDA703;
}

.wpcf7-list-item {
  margin-left: 0;
  margin-right: 2.5rem;
}

.wpcf7-spinner {
  position: absolute;
  opacity: 0;
  bottom: 0;
  left: 0;
}

.wpcf7-submit:disabled {
  background-color: #999 !important;
}

/****************************************

pagination

*****************************************/
ul.page-numbers {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 4rem;
  gap: 9px 9px;
}
@media (max-width: 575px) {
  ul.page-numbers {
    justify-content: start;
    margin-top: 2rem;
  }
}
ul.page-numbers li {
  width: 41px;
  height: 41px;
}
@media (max-width: 767px) {
  ul.page-numbers li {
    width: 35px;
    height: 35px;
  }
}
ul.page-numbers li .page-numbers {
  background: #242424;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 41px;
  height: 41px;
  font-size: 1.5rem;
  color: #fff;
}
@media (max-width: 767px) {
  ul.page-numbers li .page-numbers {
    width: 35px;
    height: 35px;
    font-size: 1.2rem;
  }
}
ul.page-numbers li .page-numbers.current {
  background: #BDA703;
  color: #fff;
}
ul.page-numbers li a {
  color: #fff;
}
ul.page-numbers .prev,
ul.page-numbers .next {
  position: relative;
}
ul.page-numbers .prev::before,
ul.page-numbers .next::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  width: 7px;
  height: 7px;
}
ul.page-numbers .prev:before {
  transform: rotate(135deg);
}
ul.page-numbers .next:before {
  transform: rotate(-45deg);
}

/****************************************

	youtube / googlemap

*****************************************/
.video-wrapper,
.gmap {
  line-height: 0;
}
.video-wrapper iframe,
.gmap iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: 100%;
}

/****************************************

	print

*****************************************/
@media print {
  header,
  footer,
  #pup {
    display: none !important;
  }
}
/****************************************

	アンカーリンク ズレ対策

*****************************************/
[id] {
  scroll-margin-top: 100px;
}
@media (max-width: 575px) {
  [id] {
    scroll-margin-top: 60px;
  }
}

/****************************************

	header

*****************************************/
.clone-nav {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  transition: 0.3s;
  transform: translateY(-200%);
  background: #fff;
}

.is-show {
  transform: translateY(0);
}

/* .header に記述すると動作しない */
header {
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #E0E0E0;
  padding: 0 3rem;
}
@media (max-width: 1399px) {
  header {
    position: fixed;
    z-index: 100;
    padding: 1.8rem 1.5rem;
  }
}
@media (max-width: 575px) {
  header {
    display: flex;
    align-items: center;
    padding: 1rem 1.5rem;
  }
}

/* end　↑.header に記述すると動作しない */
.header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header__left {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.header__main-title {
  font-size: 2.1rem;
}
@media (max-width: 1600px) {
  .header__main-title {
    font-size: 1.8rem;
  }
}
@media (max-width: 575px) {
  .header__main-title {
    font-size: 1.5rem;
  }
}
.header__sub-title {
  font-size: 0.9rem;
  color: #8B8B8B;
  letter-spacing: 2px;
}
@media (max-width: 1600px) {
  .header__sub-title {
    font-size: 0.73rem;
  }
}
@media (max-width: 575px) {
  .header__sub-title {
    font-size: 0.57rem;
  }
}
.header__right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 3rem;
}
@media (max-width: 1600px) {
  .header__right {
    gap: 3rem;
  }
}

/* PC/スマホ共通 */
@media (max-width: 1399px) {
  .header-btn {
    margin-top: 2rem;
  }
}
@media (max-width: 1399px) {
  .header-btn li {
    width: 80%;
  }
}
.header-btn li a {
  display: block;
  width: 150px;
  padding: 0.8rem 1rem;
  background: #003366;
  font-size: 1.4rem;
  color: #fff;
  text-align: center;
}
@media (max-width: 1399px) {
  .header-btn li a {
    width: 100%;
    padding: 1rem;
    background: #BDA703;
  }
}

/* end PC/スマホ共通 */
.nav-pc__gnav {
  display: flex;
  justify-content: center;
  align-items: center;
  -moz-column-gap: 3.5rem;
       column-gap: 3.5rem;
  width: auto;
  font-size: 1.5rem;
}
@media (max-width: 1600px) {
  .nav-pc__gnav {
    -moz-column-gap: 2.3rem;
         column-gap: 2.3rem;
  }
}
.nav-pc__gnav > li {
  display: flex;
  align-items: center;
  background: transparent;
  text-decoration: none;
  border-left: none;
}
.nav-pc__gnav > li a {
  display: block;
  padding: 4rem 0;
  border-left: none;
  background: transparent;
  text-decoration: none;
}
@media (max-width: 1199px) {
  .nav-pc__gnav > li a {
    font-size: 1.4rem;
  }
}
.nav-pc__gnav > li {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  text-align: center;
}
.nav-pc__gnav > li > a {
  position: relative;
  display: flex;
  align-items: center;
  height: 10rem;
  line-height: 1.5;
}
@media (max-width: 991px) {
  .nav-pc__gnav > li > a {
    padding: 0 2rem;
    height: 8rem;
  }
}
.nav-pc__gnav .menu-item-has-children {
  position: relative;
}
.nav-pc__gnav .menu-item-has-children a {
  padding-right: 1.8rem;
}
.nav-pc__gnav .menu-item-has-children::after {
  content: "";
  position: absolute;
  right: 0;
  top: 46%;
  width: 0.7rem;
  height: 0.7rem;
  border-right: 1px solid #242424;
  border-bottom: 1px solid #242424;
  transform: rotate(45deg);
}
.nav-pc__gnav .menu-item-has-children .sub-menu {
  min-width: 300px;
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 101px;
  left: 0;
  z-index: 3;
  text-align: left;
  transition: 0.5s ease-out;
  -o-transition: 0.5s ease-out;
  -moz-transition: 0.5s ease-out;
  -webkit-transition: 0.5s ease-out;
}
@media (max-width: 991px) {
  .nav-pc__gnav .menu-item-has-children .sub-menu {
    visibility: visible;
    opacity: 1;
    position: static;
  }
}
.nav-pc__gnav .menu-item-has-children .sub-menu li {
  padding-right: 0;
  width: 100%;
}
.nav-pc__gnav .menu-item-has-children .sub-menu li a {
  width: 100%;
  color: #fff;
  text-align: left;
  background: #242424;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  padding: 1.5rem 2rem;
  font-size: 1.5rem;
}
.nav-pc__gnav .menu-item-has-children .sub-menu li a:hover {
  opacity: 0.95;
}
.nav-pc__gnav .menu-item-has-children:hover > .sub-menu {
  visibility: visible;
  opacity: 1 !important;
}
.nav-pc__gnav .sub-menu .menu-item-has-children {
  position: relative;
}
.nav-pc__gnav .sub-menu .menu-item-has-children::after {
  right: 1.5rem;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
}
.nav-pc__gnav .sub-menu .menu-item-has-children {
  /* 3階層目はデフォルト非表示 */
}
.nav-pc__gnav .sub-menu .menu-item-has-children > .sub-menu {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 100%;
}
.nav-pc__gnav .sub-menu .menu-item-has-children > .sub-menu li a {
  background: #242424;
}
.nav-pc__gnav .sub-menu .menu-item-has-children {
  /* 2階層目（3階層を持つ項目）にhoverした時だけ表示 */
}
.nav-pc__gnav .sub-menu .menu-item-has-children:hover > .sub-menu {
  visibility: visible;
  opacity: 1;
}

@media (max-width: 1399px) {
  .header-clone {
    display: none;
  }
  .clone-nav {
    display: none;
  }
}
/****************************************

	header-sns

*****************************************/
.header-sns {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.header-sns li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.4rem;
  height: 3.4rem;
}
.header-sns li a img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
}

.header__right .header-sns::before {
  content: "";
  display: block;
  width: 1px;
  height: 22px;
  background: #E0E0E0;
  margin-right: 1rem;
}

/****************************************

hamburger

*****************************************/
.nav-sp {
  display: none;
}

@media (max-width: 1399px) {
  .nav-sp {
    margin: 0;
    padding-top: 1rem;
    transition: all 0.6s;
    overflow-y: auto;
    width: 300px;
    height: 100vh;
    z-index: 200;
    top: 0;
    left: -320px;
    background-color: #003366;
    position: fixed;
    display: block;
  }
  .nav-sp__sns {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem 1.5rem;
    margin: 2rem 0.5rem 1.5rem;
  }
  .nav-sp__inner a {
    display: block;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: #fff;
    font-weight: bold;
    padding: 1.5rem 2rem;
    font-size: 1.6rem;
  }
  .nav-sp__inner li {
    position: relative;
  }
  .nav-sp__inner li a {
    position: relative;
    font-size: 1.3rem;
  }
  .nav-sp__inner li i {
    display: none;
  }
  .nav-sp__inner .menu-item-has-children > i {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    height: 49px;
    width: 70px;
    z-index: 1000;
    cursor: pointer;
    display: table;
  }
  .nav-sp__inner .menu-item-has-children > .fa::before {
    content: "";
    position: absolute;
    right: 1rem;
    top: 0;
    bottom: 0;
    margin: auto;
    text-align: right;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    width: 7px;
    height: 7px;
    transform: rotate(45deg);
  }
  .nav-sp__inner .menu-item-has-children > .menu-item-has-children a i {
    display: none;
  }
  .nav-sp .sub-menu {
    display: none;
  }
  .nav-sp .sub-menu a {
    background-color: rgba(0, 0, 0, 0.1);
  }
  .nav-sp .sub-menu .menu-item-has-children > .sub-menu a {
    background-color: rgba(0, 0, 0, 0.15);
  }
  .nav_btn {
    width: 40px;
    height: 44px;
    z-index: 300;
    top: 0;
    bottom: 0;
    right: 1.5rem;
    margin: auto;
    cursor: pointer;
    position: absolute;
  }
  .hamburger_line {
    transition: all 0.6s;
    width: 34px;
    height: 1px;
    left: 5px;
    background-color: #333;
    position: absolute;
  }
  .hamburger_line1 {
    top: 10px;
  }
  .hamburger_line2 {
    top: 21px;
  }
  .hamburger_line3 {
    top: 32px;
  }
  .nav_bg {
    opacity: 0;
    transition: all 0.6s;
    width: 100vw;
    height: 100vh;
    z-index: 100;
    top: 0;
    left: 0;
    visibility: hidden;
    background-color: #333;
    cursor: pointer;
    position: fixed;
  }
  /* 表示された時用のCSS */
  .nav_open header .nav-sp {
    left: 0;
  }
  .nav_open .nav_bg {
    opacity: 0.8;
    visibility: visible;
  }
  .nav_open .hamburger_line {
    background-color: #fff;
  }
  .nav_open .hamburger_line1 {
    transform: rotate(45deg);
    top: 20px;
  }
  .nav_open .hamburger_line2 {
    width: 0;
    left: 50%;
  }
  .nav_open .hamburger_line3 {
    transform: rotate(-45deg);
    top: 20px;
  }
}
/****************************************

	footer

*****************************************/
.footer-etc {
  position: relative;
  margin-bottom: -21rem;
  padding-top: clamp(5rem, 10vw, 15rem);
  padding-bottom: clamp(3rem, 4vw, 9rem);
}
@media (max-width: 1600px) {
  .footer-etc {
    margin-bottom: 0;
  }
}
.footer-etc::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 210px;
}
@media (max-width: 991px) {
  .footer-etc::after {
    height: 100%;
  }
}
.about .footer-etc::before, .page-template-page-course-template .footer-etc::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -2;
  width: 100%;
  height: 100%;
  background: #F9F9F9;
}
.footer-etc {
  /* ===== item 共通 ===== */
}
.footer-etc__item {
  position: relative;
  width: 50%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media (max-width: 767px) {
  .footer-etc__item {
    width: 100%;
    border-bottom: 1px solid #444444;
  }
}
.footer-etc__item::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.85);
}
.footer-etc__item:nth-of-type(odd) {
  border-right: 1px solid #444444;
}
@media (max-width: 767px) {
  .footer-etc__item:nth-of-type(odd) {
    border-right: none;
  }
}
.footer-etc__item a {
  position: relative;
  z-index: 1;
  display: block;
  padding: 5rem;
  color: #fff;
}
@media (max-width: 991px) {
  .footer-etc__item a {
    padding: 3rem;
  }
}
@media (max-width: 575px) {
  .footer-etc__item a {
    padding: 2.8rem 2.5rem;
  }
}
.footer-etc__item a:hover::after {
  transform: translateX(0.5rem);
}
.footer-etc__heading {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  margin-bottom: 1rem;
  line-height: 1.5;
}
.footer-etc__heading::before {
  content: "";
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.footer-etc__heading-en {
  font-size: clamp(1.2rem, 1.5vw, 1.8rem);
  color: #BDA703;
}
.footer-etc__heading-jp {
  display: flex;
  align-items: center;
  gap: clamp(2rem, 2vw, 3rem);
  margin-bottom: clamp(0.5rem, 1vw, 1.4rem);
  font-size: clamp(1.9rem, 2.2vw, 2.4rem);
  line-height: 1.5;
}
.footer-etc__heading-jp::after {
  content: "";
  display: inline-block;
  width: 2rem;
  height: 2rem;
  background: url(../images/common/ic-arrow-white.svg) center/contain no-repeat;
}
@media (max-width: 991px) {
  .footer-etc__heading-jp::after {
    right: 1.5rem;
    width: 1.5rem;
    height: 1.5rem;
  }
}
.footer-etc__detail {
  font-size: clamp(1.2rem, 1.5vw, 1.4rem);
}
@media (max-width: 991px) {
  .footer-etc__detail br {
    display: none;
  }
}

.footer {
  padding-top: 12rem;
  background: #2B2B2B;
  color: #fff;
}
@media (max-width: 1600px) {
  .footer {
    padding-top: 0;
  }
}
.footer a {
  color: #fff;
}
.footer__inner {
  display: flex;
  align-items: flex-start;
  max-width: 1200px;
  margin: 0 auto;
  padding: 9rem 0;
}
@media (max-width: 1399px) {
  .footer__inner {
    padding: clamp(5vw, 5vw, 9rem) 5vw;
  }
}
@media (max-width: 991px) {
  .footer__inner {
    flex-wrap: wrap;
    gap: 5vw;
    padding: 5vw;
  }
}
.footer__overview {
  display: grid;
  place-content: center;
  gap: 0.3rem;
  margin-top: 1rem;
  margin-right: clamp(9rem, 8vw, 11rem);
  flex-shrink: 0;
}
@media (max-width: 1399px) {
  .footer__overview {
    display: none;
  }
}
.footer__main-title {
  font-size: clamp(1.6rem, 1.8vw, 2.1rem);
}
.footer__sub-title {
  font-size: 0.9rem;
  line-height: 1.5;
  letter-spacing: 2px;
}
.footer__nav {
  display: flex;
  gap: 0 clamp(2rem, 5vw, 8rem);
}
@media (max-width: 1399px) {
  .footer__nav {
    width: 100%;
  }
}
@media (max-width: 991px) {
  .footer__nav {
    order: 1;
  }
}
.footer__nav a {
  display: block;
  line-height: 1.5;
}
.footer__nav-group {
  min-width: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (max-width: 1399px) {
  .footer__nav-group {
    width: 33.3333333333%;
  }
}
@media (max-width: 991px) {
  .footer__nav-group {
    width: 100%;
  }
}
.footer__nav-group:last-of-type li:last-child {
  border-bottom: none;
}
@media (max-width: 767px) {
  .footer__nav-group > li {
    border-bottom: 1px solid #444444;
    padding: 0.2rem 0;
  }
}
.footer__nav-group > li > a {
  padding: 1rem 0;
}
@media (max-width: 767px) {
  .footer__nav-group > li > a {
    font-size: 1.4rem;
  }
}
.footer__nav-group > li > .sub-menu {
  margin-bottom: 1.5rem;
}
.footer__nav-group > li > .sub-menu a {
  position: relative;
  padding: 0.8rem 0 0.8rem 2.3rem;
  font-size: 1.5rem;
}
@media (max-width: 767px) {
  .footer__nav-group > li > .sub-menu a {
    padding: 0.7rem 0 0.7rem 2rem;
    font-size: 1.3rem;
  }
}
.footer__nav-group > li > .sub-menu a::before {
  content: "";
  position: absolute;
  top: 1.9rem;
  left: 0;
  background: #575757;
  width: 15px;
  height: 1px;
}
@media (max-width: 991px) {
  .footer__nav-group > li > .sub-menu a::before {
    top: 1.9rem;
  }
}
.footer__nav-group > li > .sub-menu .sub-menu a {
  font-size: 1.4rem;
  padding: 0.4rem 0 0.4rem 2.3rem;
}
@media (max-width: 767px) {
  .footer__nav-group > li > .sub-menu .sub-menu a {
    padding: 0.4rem 0 0.4rem 2rem;
    font-size: 1.2rem;
  }
}
.footer__nav-group > li > .sub-menu .sub-menu a::before {
  content: none;
}
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}
@media (max-width: 1399px) {
  .footer__bottom {
    padding: 2.4rem 5vw;
  }
}
@media (max-width: 991px) {
  .footer__bottom {
    flex-direction: column;
    gap: 4rem;
  }
}
@media (max-width: 767px) {
  .footer__bottom {
    align-items: flex-start;
    padding: 4vw 5vw;
  }
}
.footer__sub-nav {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  list-style: none;
}
.footer__sub-nav li {
  position: relative;
  margin-right: 2.4rem;
  padding-left: 1.5rem;
}
.footer__sub-nav li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  color: rgba(255, 255, 255, 0.5);
  width: 5px;
  height: 5px;
  transform: rotate(-45deg);
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
.footer__sub-nav li:last-child {
  margin-right: 0;
  padding-right: 0;
}
.footer__sub-nav a {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
}
.footer__sub-nav a:hover {
  opacity: 0.7;
}
.footer__copy {
  margin: 0;
  font-size: clamp(0.9rem, 1vw, 1.2rem);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.85);
}
@media (max-width: 991px) {
  .footer__copy {
    text-align: center;
  }
}

#pup {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 51px;
  height: 51px;
  text-decoration: none;
  position: fixed;
  right: 25px;
  bottom: 1.8rem;
  background: #242424;
  text-align: center;
  line-height: 45px;
  z-index: 1;
  cursor: pointer;
}
@media (max-width: 575px) {
  #pup {
    right: 1rem;
    bottom: 1rem;
  }
}
#pup::before {
  content: "";
  position: absolute;
  top: 45%;
  border-top: 2px solid #fff;
  border-left: 2px solid #fff;
  width: 9px;
  height: 9px;
  transform: rotate(45deg);
}

/****************************************

page-header

*****************************************/
.page-header {
  position: relative;
  z-index: 0;
  margin-bottom: 4rem;
  padding: 8rem 0 16rem;
  background: #003366;
}
@media (max-width: 1399px) {
  .page-header {
    margin-bottom: clamp(4rem, 6vw, 8rem);
    padding: 6rem 0 5rem;
  }
}
@media (max-width: 575px) {
  .page-header {
    padding: 10vw 0;
  }
}
.page-header::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: calc(100% - (100% - 1400px) / 2);
  height: 70px;
  background: #fff;
}
@media (max-width: 1399px) {
  .page-header::after {
    width: 80%;
    content: none;
  }
}
.course .page-header::after, .schedule .page-header::after {
  background: #F9F9F9;
}
.page-header__inner {
  position: relative;
  z-index: 2;
  padding-bottom: 2.5rem;
}
.page-header__inner::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: clamp(50px, 7vw, 100px);
  height: 1px;
  background: rgba(255, 255, 255, 0.5);
}
.page-header__en {
  margin-bottom: 0.5rem;
  font-size: 1.8rem;
  color: #BDA703;
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 1399px) {
  .page-header__en {
    font-size: clamp(1.2rem, 1.4vw, 1.6rem);
  }
}
.page-header__jp {
  font-size: 4rem;
  line-height: 1.3;
  color: #fff;
}
@media (max-width: 1399px) {
  .page-header__jp {
    font-size: clamp(2.6rem, 3.1vw, 3.5rem);
  }
}
@media (max-width: 575px) {
  .page-header__jp {
    margin-bottom: 1vw;
  }
}

/****************************************

	breadcrumb

*****************************************/
#breadcrumb {
  padding: 1.8rem 0;
  background: #003366;
  font-size: 1.2rem;
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
@media (max-width: 1399px) {
  #breadcrumb {
    margin: 83px auto 0;
    padding: 1.2rem 0;
    font-size: 1rem;
  }
}
@media (max-width: 1199px) {
  #breadcrumb {
    margin: 7vw auto 0;
  }
}
@media (max-width: 1100px) {
  #breadcrumb {
    margin: 82px auto 0;
  }
}
@media (max-width: 991px) {
  #breadcrumb {
    margin: 81px auto 0;
  }
}
@media (max-width: 575px) {
  #breadcrumb {
    margin: 58px auto 0;
    padding: 0.8rem 0;
    font-size: 1rem;
  }
}
#breadcrumb a {
  color: #fff;
}
#breadcrumb i {
  margin: 0 8px;
}
#breadcrumb span {
  margin-right: 0.5rem;
}
#breadcrumb span:nth-child(n+2) {
  margin-left: 0.5rem;
}

.page-template-page-course-template #breadcrumb,
.single-post #breadcrumb {
  background: #fff;
  border-bottom: 1px solid #E0E0E0;
  color: #242424;
}
.page-template-page-course-template #breadcrumb a,
.single-post #breadcrumb a {
  color: #242424;
}

/****************************************

post-sec

*****************************************/
.post-sec h2,
.post-sec h3,
.post-sec h4,
.post-sec h5,
.post-sec h6 {
  margin: 4rem 0 2.5rem;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .post-sec h2,
  .post-sec h3,
  .post-sec h4,
  .post-sec h5,
  .post-sec h6 {
    margin: 3rem 0 2rem;
  }
}
.post-sec > p,
.post-sec > ul,
.post-sec > ol,
.post-sec > .wp-block-columns {
  margin: 3rem 0;
}
.post-sec > h2:first-child,
.post-sec > h3:first-child,
.post-sec > p:first-child,
.post-sec > ol:first-child,
.post-sec > ul:first-child,
.post-sec > .wp-block-columns:first-child,
.post-sec > .video-wrapper:first-child {
  margin-top: 0;
}
.post-sec > h2:last-child,
.post-sec > h3:last-child,
.post-sec > p:last-child,
.post-sec > ol:last-child,
.post-sec > ul:last-child,
.post-sec > .wp-block-columns:last-child,
.post-sec > .video-wrapper:last-child {
  margin-bottom: 0 !important;
}
.post-sec h2 {
  font-size: 2.4rem;
  position: relative;
  padding-bottom: 2.2rem;
}
@media (max-width: 1399px) {
  .post-sec h2 {
    font-size: 1.9rem;
    padding-bottom: 2rem;
  }
}
.post-sec h2::before, .post-sec h2::after {
  content: "";
  position: absolute;
  left: 0;
  background: #242424;
}
.post-sec h2::before {
  bottom: 0;
  width: 100%;
  height: 1px;
}
.post-sec h2::after {
  bottom: -1px;
  width: 5%;
  height: 3px;
}
.post-sec h3 {
  font-size: 2.1rem;
  padding: 1.9rem 3rem;
  background: #F9F9F9;
}
@media (max-width: 1399px) {
  .post-sec h3 {
    font-size: 1.8rem;
  }
}
.post-sec h4 {
  padding: 0 0 0 2rem;
  border-left: 2px solid #242424;
  font-size: 2.1rem;
}
@media (max-width: 1399px) {
  .post-sec h4 {
    font-size: 1.8rem;
  }
}
.post-sec h5 {
  position: relative;
  font-size: 1.9rem;
  padding-left: 2rem;
}
@media (max-width: 1399px) {
  .post-sec h5 {
    font-size: 1.7rem;
  }
}
.post-sec h5::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1.4rem;
  width: 10px;
  height: 1px;
  background: #242424;
}
.post-sec h6 {
  font-size: 1.8rem;
}
@media (max-width: 1399px) {
  .post-sec h6 {
    font-size: 1.5rem;
  }
}
.post-sec p {
  line-height: 2;
}
.post-sec ol li {
  padding: 0.3rem 0;
}
.post-sec ol li:last-child {
  padding-bottom: 0;
}
.post-sec a {
  color: #BDA703;
  text-decoration: none;
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-position: right bottom;
  background-size: 100% 1px;
  transition: background-size 0.4s ease;
}
.post-sec a:hover {
  background-size: 0% 1px;
}
.post-sec .wp-block-separator {
  border-top: 1px solid #E0E0E0;
  border-right: none;
  border-bottom: none;
  border-left: none;
}
.post-sec {
  /* ブロック系の大枠だけ */
}
.post-sec > .wp-block-group,
.post-sec > .wp-block-columns,
.post-sec > .wp-block-image,
.post-sec > .wp-block-table,
.post-sec > .wp-block-separator,
.post-sec > .video-wrapper {
  margin: 5rem 0;
}
@media (max-width: 1399px) {
  .post-sec > .wp-block-group,
  .post-sec > .wp-block-columns,
  .post-sec > .wp-block-image,
  .post-sec > .wp-block-table,
  .post-sec > .wp-block-separator,
  .post-sec > .video-wrapper {
    margin: 3rem 0;
  }
}
.post-sec > .wp-block-flexible-table-block-table {
  margin: 3rem 0;
}
.post-sec {
  /* 最初・最後は詰める */
}
.post-sec > :first-child {
  margin-top: 0 !important;
}
.post-sec > :last-child {
  margin-bottom: 0 !important;
}
.post-sec > .wp-block-columns p + p {
  margin-top: 2rem;
}
.post-sec .wp-element-caption {
  line-height: 1.5;
}
.post-sec .wp-block-button__link {
  color: #fff !important;
}
.post-sec .wp-block-buttons a {
  text-decoration: none !important;
  background-image: none;
  transition: 0.3s linear;
}
.post-sec .wp-block-image.aligncenter {
  margin-left: auto;
  margin-right: auto;
}
.post-sec .video-wrapper {
  margin: 3rem 0;
}
.post-sec blockquote {
  background-color: #fafbfc;
  border: 1px solid #ddd;
  margin: 1em 0;
  padding: 10px 1.2em;
  position: relative;
}
.post-sec blockquote::before,
.post-sec blockquote::after {
  color: #c8c8c8;
  font-family: serif;
  position: absolute;
  font-size: 300%;
}
.post-sec blockquote::before {
  content: "“";
  line-height: 1.1;
  left: 10px;
  top: 0;
}
.post-sec blockquote::after {
  content: "”";
  line-height: 0;
  right: 10px;
  bottom: 0px;
}
.post-sec blockquote cite {
  font-size: 0.7em;
}

/****************************************

	single

*****************************************/
.single-head {
  margin: 8rem 0 10rem;
  border-bottom: 1px solid #E0E0E0;
}
@media (max-width: 1199px) {
  .single-head {
    margin-top: clamp(5rem, 7vw, 8rem);
    margin-bottom: clamp(4rem, 6vw, 8rem);
  }
}
.single-head .container-md {
  position: relative;
  padding-bottom: clamp(4rem, 5vw, 7rem);
}
.single-head .container-md::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 85px;
  height: 3px;
  background: #242424;
}
@media (max-width: 1399px) {
  .single-head .container-md::after {
    left: 5rem;
  }
}
@media (max-width: 767px) {
  .single-head .container-md::after {
    left: 2rem;
  }
}
.single-head h1 {
  font-size: 3.6rem;
  line-height: 1.4;
}
@media (max-width: 1399px) {
  .single-head h1 {
    font-size: 2.6rem;
  }
}
@media (max-width: 767px) {
  .single-head h1 {
    font-size: 2.4rem;
  }
}
@media (max-width: 575px) {
  .single-head h1 {
    font-size: 2.2rem;
  }
}
.single-head__date {
  font-size: 1.4rem;
  color: #A1A1A1;
}
@media (max-width: 575px) {
  .single-head__date {
    font-size: 1.2rem;
  }
}
.single-head__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
}

/****************************************

	category / taxonomy

*****************************************/
.cat-header {
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  display: flex;
  align-items: center;
  border-bottom: 1px solid #242424;
  font-size: 2.6rem;
  line-height: 1.5;
}
@media (max-width: 991px) {
  .cat-header {
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    font-size: 2rem;
  }
}
@media (max-width: 575px) {
  .cat-header {
    font-size: 1.8rem;
  }
}

/****************************************

	archive.php

*****************************************/
.post-date {
  font-size: 1.4rem;
  color: #999;
  text-align: right;
}
@media (max-width: 575px) {
  .post-date {
    font-size: 1.2rem;
  }
}

.post-cat {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}
@media (max-width: 575px) {
  .post-cat {
    gap: 3px;
  }
}
.post-cat li {
  padding: 0.2rem 1.5rem 0.3rem 1.5rem;
  background: var(--cat-color, #003366);
  font-size: clamp(1rem, 1vw, 1.4rem);
  color: #fff;
  line-height: 1.5;
}
@media (max-width: 575px) {
  .post-cat li {
    padding: 0.2rem 0.7rem;
  }
}
.post-cat li a {
  display: block;
  color: #fff;
}

.post-header {
  font-size: clamp(1.4rem, 0.671rem + 1.52vw, 2rem);
  line-height: 1.5;
  margin: 0.8rem 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.post-header__wrap {
  margin-bottom: 1.3rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid #242424;
}

.c-archive a {
  position: relative;
  display: block;
  padding: 3rem;
  border-bottom: 1px solid #E0E0E0;
  background: #fff;
}
@media (max-width: 767px) {
  .c-archive a {
    padding: 1.5rem 3.5rem 1.5rem 1.5rem;
  }
}
.c-archive a::after {
  content: "";
  position: absolute;
  right: clamp(1.5rem, 1.5vw, 2rem);
  top: 0;
  bottom: 0;
  margin: auto;
  width: 0.7rem;
  height: 0.7rem;
  border-right: 1px solid #242424;
  border-bottom: 1px solid #242424;
  transform: rotate(-45deg);
}
.c-archive__date {
  font-size: 1.4rem;
  color: #666666;
}
@media (max-width: 767px) {
  .c-archive__date {
    font-size: 1.2rem;
  }
}
.c-archive__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  margin-bottom: 0.5rem;
}

/****************************************

	front-page.php

*****************************************/
.p-top-hero {
  position: relative;
  overflow: hidden;
}
.p-top-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 35rem;
  background: #003366;
  z-index: 0;
}
@media (max-width: 1399px) {
  .p-top-hero::after {
    height: 25rem;
  }
}
@media (max-width: 575px) {
  .p-top-hero::after {
    height: 15rem;
  }
}
.p-top-hero__top {
  position: relative;
  z-index: 2;
  padding-top: 10rem;
}
@media (max-width: 1399px) {
  .p-top-hero__top {
    padding-top: 18rem;
  }
}
@media (max-width: 991px) {
  .p-top-hero__top {
    padding-top: 16vw;
  }
}
@media (max-width: 767px) {
  .p-top-hero__top {
    padding-top: 13rem;
  }
}
@media (max-width: 575px) {
  .p-top-hero__top {
    padding-top: 11rem;
  }
}
.p-top-hero__inner {
  display: flex;
  gap: 4rem;
  max-width: 1600px;
  margin: 0 auto;
  padding: 0 7rem;
}
@media (max-width: 1199px) {
  .p-top-hero__inner {
    gap: 0;
    align-items: flex-end;
  }
}
@media (max-width: 991px) {
  .p-top-hero__inner {
    padding: 0 5vw 4rem;
  }
}
.p-top-hero__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../images/top/bg_hero.svg) right 20% center no-repeat;
  z-index: 0;
  pointer-events: none;
}
@media (max-width: 991px) {
  .p-top-hero__inner::before {
    background-position: center bottom -3rem;
  }
}
.p-top-hero__lead, .p-top-hero__circle {
  position: relative;
  z-index: 2;
}
@media (max-width: 767px) {
  .p-top-hero__lead {
    width: 100%;
  }
}
.p-top-hero__catch {
  display: inline-flex;
  flex-wrap: wrap;
  margin-bottom: 2rem;
  line-height: 1;
}
@media (max-width: 767px) {
  .p-top-hero__catch {
    margin-bottom: 2vw;
  }
}
.p-top-hero__catch-main, .p-top-hero__catch-sub {
  display: inline-block;
  padding: 0.8rem 1.1rem 1rem;
  font-size: 3rem;
}
@media (max-width: 767px) {
  .p-top-hero__catch-main, .p-top-hero__catch-sub {
    padding: 1vw 1.4vw 1.2vw;
    font-size: 4.5vw;
  }
}
.p-top-hero__catch-main {
  background: #003366;
  color: #fff;
}
.p-top-hero__catch-sub {
  background: transparent;
  border: 1px solid #003366;
  color: #003366;
}
.p-top-hero__title {
  margin-bottom: 1.1rem;
  font-size: 4.8rem;
  line-height: 1.35;
  letter-spacing: 0.02em;
  font-weight: 600;
}
@media (max-width: 767px) {
  .p-top-hero__title {
    margin-bottom: 2.5vw;
    font-size: 7.5vw;
  }
}
.p-top-hero__text {
  margin-bottom: 2.5rem;
  font-size: clamp(1.8rem, 1.4vw, 2.2rem);
  line-height: 2;
}
@media (max-width: 767px) {
  .p-top-hero__text {
    margin-bottom: 2.8rem;
    font-size: 1.6rem;
    line-height: 1.8;
  }
}
@media (max-width: 575px) {
  .p-top-hero__text {
    font-size: 3vw;
  }
}
.p-top-hero__cta {
  max-width: 53rem;
}
@media (max-width: 1199px) {
  .p-top-hero__cta {
    max-width: none;
    display: inline-block;
  }
}
.p-top-hero__cta-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.6rem;
  padding: 2rem 2.4rem;
  background: #BDA703;
  border-radius: 4px;
  color: #fff;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.p-top-hero__cta-btn:hover {
  opacity: 0.85;
}
@media (max-width: 767px) {
  .p-top-hero__cta-btn {
    padding: 1.6rem 1.8rem;
    gap: 1.2rem;
  }
}
.p-top-hero__cta-icon {
  flex-shrink: 0;
  width: 2.8rem;
}
@media (max-width: 575px) {
  .p-top-hero__cta-icon {
    width: 1.8rem;
  }
}
.p-top-hero__cta-icon img {
  display: block;
  width: 100%;
  height: auto;
}
.p-top-hero__cta-text {
  position: relative;
  display: block;
  padding-right: 2.4rem;
  font-size: clamp(1.3rem, 1.3vw, 2rem);
  line-height: 1.5;
}
.p-top-hero__cta-text::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}
.p-top-hero__circle {
  display: grid;
  place-content: center;
  flex-shrink: 0;
  width: 20rem;
  height: 20rem;
  padding: 2rem;
  background: #000;
  border-radius: 50%;
  color: #fff;
  text-align: center;
}
@media (max-width: 1199px) {
  .p-top-hero__circle {
    position: absolute;
    right: 8vw;
    bottom: -12rem;
  }
}
@media (max-width: 991px) {
  .p-top-hero__circle {
    right: 6vw;
  }
}
@media (max-width: 767px) {
  .p-top-hero__circle {
    right: 1rem;
    bottom: -35rem;
  }
}
@media (max-width: 575px) {
  .p-top-hero__circle {
    bottom: -55vw;
    width: 15rem;
    height: 15rem;
  }
}
.p-top-hero__circle-head {
  margin-bottom: 0.8rem;
  font-size: 2.1rem;
  line-height: 1.4;
}
@media (max-width: 767px) {
  .p-top-hero__circle-head {
    font-size: 1.6rem;
  }
}
@media (max-width: 575px) {
  .p-top-hero__circle-head {
    font-size: 1.4rem;
  }
}
.p-top-hero__circle-date {
  margin-bottom: 1.3rem;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(255, 255, 255, 0.4);
  font-size: 1.2rem;
  line-height: 1.4;
}
@media (max-width: 575px) {
  .p-top-hero__circle-date {
    font-size: 1rem;
  }
}
.p-top-hero__circle-number {
  line-height: 1;
}
.p-top-hero__circle-number span {
  font-size: clamp(4rem, 3.2vw, 4.8rem);
}
@media (max-width: 575px) {
  .p-top-hero__circle-number span {
    font-size: 3rem;
  }
}
.p-top-hero__circle-number small {
  font-size: 2.1rem;
}
@media (max-width: 575px) {
  .p-top-hero__circle-number small {
    font-size: 1.6rem;
  }
}
.p-top-hero__media {
  position: relative;
  margin-top: -4rem;
  padding: 0 0 8rem;
}
@media (max-width: 991px) {
  .p-top-hero__media {
    margin-top: 0;
    padding: 0 0 8rem;
  }
}
@media (max-width: 767px) {
  .p-top-hero__media {
    padding: 0 0 6rem;
  }
}
.p-top-hero__image {
  position: relative;
  z-index: 1;
  width: calc(100% - 13rem);
  margin-left: 0;
}
@media (max-width: 1399px) {
  .p-top-hero__image {
    width: calc(100% - 5rem);
  }
}
@media (max-width: 767px) {
  .p-top-hero__image {
    width: 100%;
  }
}
.p-top-hero__image img {
  display: block;
  height: 29vw;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  aspect-ratio: 149/52;
  -o-object-position: right top;
     object-position: right top;
}
@media (max-width: 1600px) {
  .p-top-hero__image img {
    height: 530px;
  }
}
@media (max-width: 1399px) {
  .p-top-hero__image img {
    height: 400px;
  }
}
@media (max-width: 767px) {
  .p-top-hero__image img {
    height: 50vw;
  }
}
.p-top-hero__scroll {
  position: absolute;
  top: 10%;
  right: 8rem;
  width: 38px;
  height: 180px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
}
@media (max-width: 1399px) {
  .p-top-hero__scroll {
    right: 0.7rem;
  }
}
@media (max-width: 767px) {
  .p-top-hero__scroll {
    display: none;
  }
}
.p-top-hero__scroll::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 80%;
}
.p-top-hero__scroll-text {
  display: inline-block;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  padding: 10px 10px 100px;
  color: #000;
  font-size: 1rem;
  line-height: 1.8;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-decoration: none;
  writing-mode: vertical-lr;
  transition: 0.2s;
  overflow: hidden;
  margin: auto;
}
.p-top-hero__scroll-text::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 80px;
  background: #E0E0E0;
}
.p-top-hero__scroll-text::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 80px;
  background: #000;
}
.p-top-hero #type01 .p-top-hero__scroll-text::after {
  animation: sdl01 3s cubic-bezier(1, 0, 0, 1) infinite;
}

@keyframes sdl01 {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.p-top-news {
  padding-bottom: 8rem;
  background: #003366;
  margin-top: -1px;
}
@media (max-width: 991px) {
  .p-top-news {
    padding-bottom: 6rem;
  }
}
.p-top-news__inner {
  display: grid;
  grid-template-columns: 30rem 1fr;
  gap: 2rem 5rem;
  align-items: start;
}
@media (max-width: 1399px) {
  .p-top-news__inner {
    grid-template-columns: 20rem 1fr;
    padding: 0 clamp(2rem, 3vw, 5rem);
  }
}
@media (max-width: 991px) {
  .p-top-news__inner {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 575px) {
  .p-top-news__inner {
    padding: 0;
  }
}
.p-top-news__intro {
  display: grid;
  align-content: start;
  padding-top: 2rem;
}
@media (max-width: 991px) {
  .p-top-news__intro {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media (max-width: 1399px) {
  .p-top-news__intro .c-btn {
    width: auto;
    padding-left: 2rem;
    padding-right: 6rem;
  }
}
.p-top-news__heading-en {
  font-size: 8rem;
  text-transform: none;
  color: #fff;
  line-height: 1;
}
@media (max-width: 1399px) {
  .p-top-news__heading-en {
    font-size: 6rem;
  }
}
@media (max-width: 767px) {
  .p-top-news__heading-en {
    font-size: 4rem;
  }
}
.p-top-news__heading-jp {
  font-size: 2rem;
  color: #fff;
}
@media (max-width: 1399px) {
  .p-top-news__heading-jp {
    font-size: 1rem;
  }
}
.p-top-news .c-archive {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.p-top-news .c-archive a {
  border-bottom: none;
}

.p-top-intro {
  display: grid;
  gap: 10rem;
  padding: 12rem 0;
}
@media (max-width: 1199px) {
  .p-top-intro {
    padding: 6rem 0;
    gap: 6rem;
  }
}
@media (max-width: 767px) {
  .p-top-intro {
    padding: 0 0 6rem;
  }
}

@media (max-width: 767px) {
  .p-top-schedule .container-lg {
    padding-left: 0;
    padding-right: 0;
  }
}
.p-top-schedule__inner {
  position: relative;
  padding: 7rem 2rem 8rem;
  background: url(../images/top/schedule_bg.jpg) center center no-repeat;
  background-size: cover;
  color: #fff;
  text-align: center;
}
@media (max-width: 1199px) {
  .p-top-schedule__inner {
    padding: 6rem 2rem;
  }
}
@media (max-width: 767px) {
  .p-top-schedule__inner {
    padding: 4rem 2rem;
  }
}
.p-top-schedule__inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  display: block;
  width: 1px;
  height: 30px;
  background-color: #fff;
  margin-inline: auto;
}
@media (max-width: 767px) {
  .p-top-schedule__inner::before {
    height: 15px;
  }
}
.p-top-schedule__button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.6rem;
  max-width: 40rem;
  margin-inline: auto;
  padding: 1.6rem 2.4rem;
  background: #BDA703;
  border-radius: 4px;
  color: #fff;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
@media (max-width: 767px) {
  .p-top-schedule__button {
    padding: 1.6rem 1.8rem;
    gap: 1.2rem;
  }
}
.p-top-schedule__button::before, .p-top-schedule__button::after {
  content: "";
}
.p-top-schedule__button::before {
  width: 2.8rem;
  height: 2.8rem;
  background: url(../images/top/ic_calendar.svg) center center no-repeat;
  background-size: contain;
}
.p-top-schedule__button::after {
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg);
}
.p-top-schedule__button:hover {
  opacity: 0.85;
}
.p-top-schedule__cta-text {
  position: relative;
  display: block;
  padding-right: 2.4rem;
  font-size: clamp(1.8rem, 1.3vw, 2rem);
  line-height: 1.5;
}
.p-top-schedule__cta-text::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}
@media (max-width: 767px) {
  .p-top-schedule__cta-text {
    font-size: 1.6rem;
  }
}

.p-top-message__inner {
  display: flex;
  gap: clamp(3rem, 4vw, 6rem);
}
@media (max-width: 767px) {
  .p-top-message__inner {
    flex-direction: column;
    align-items: stretch;
  }
}
.p-top-message .c-heading-set {
  margin-bottom: clamp(2.5rem, 4vw, 6rem);
}
.p-top-message__media {
  flex: 0 0 280px;
}
@media (max-width: 767px) {
  .p-top-message__media {
    flex-basis: auto;
    width: 280px;
    margin-inline: auto;
  }
}
.p-top-message__media img {
  display: block;
  width: 100%;
  height: auto;
}
.p-top-message__body {
  flex: 1;
  min-width: 0;
}
.p-top-message__text p + p {
  margin-top: 3rem;
}

.p-top-learning-wrap {
  background: #F9F9F9;
}

.p-top-points {
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.p-top-points::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  width: 160%;
  height: 420px;
  background: #000;
  border-bottom-left-radius: 50% 160px;
  border-bottom-right-radius: 50% 160px;
}
.p-top-points::after {
  content: "";
  position: absolute;
  margin-inline: auto;
  top: 0;
  left: 0;
  right: 0;
  width: 203px;
  height: 34px;
  background: url(../images/common/bg_lines_white.svg) center top no-repeat;
  background-size: contain;
}
@media (max-width: 991px) {
  .p-top-points::after {
    top: 0;
    width: 140px;
  }
}
.p-top-points__bg {
  position: relative;
  z-index: 1;
}
.p-top-points__inner {
  display: flex;
  gap: 3.5rem 2.5rem;
}
@media (max-width: 991px) {
  .p-top-points__inner {
    flex-direction: column;
    max-width: 650px;
    margin-inline: auto;
  }
}
.p-top-points__box {
  position: relative;
  background: #fff;
  border: 1px solid #000;
  padding: 5rem 5rem 3rem;
}
@media (max-width: 1199px) {
  .p-top-points__box {
    padding: clamp(3rem, 1.16rem + 5.12vw, 5rem) 3rem 3rem;
  }
}
.p-top-points__num {
  position: absolute;
  top: -2.5rem;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(6rem, 3.24rem + 7.68vw, 9rem);
  height: clamp(3rem, 1.16rem + 5.12vw, 5rem);
  border-radius: 50%;
  margin: auto;
  padding-top: 0.5rem;
  background: #BDA703;
  font-size: clamp(1.8rem, 1.248rem + 1.54vw, 2.4rem);
  color: #fff;
}
@media (max-width: 575px) {
  .p-top-points__num {
    top: -4vw;
  }
}
.p-top-points__heading {
  margin-bottom: 2rem;
  padding-bottom: 2.3rem;
  border-bottom: 1px solid #000;
  text-align: center;
}
.p-top-points__heading span {
  display: block;
  line-height: 1.3;
}
.p-top-points__heading span:nth-of-type(1) {
  margin-bottom: 0.8rem;
  font-size: 2.2rem;
}
@media (max-width: 1199px) {
  .p-top-points__heading span:nth-of-type(1) {
    font-size: clamp(1.4rem, 1.032rem + 1.02vw, 1.8rem);
  }
}
.p-top-points__heading span:nth-of-type(2) {
  font-size: 2.6rem;
}
@media (max-width: 1199px) {
  .p-top-points__heading span:nth-of-type(2) {
    font-size: clamp(1.8rem, 1.248rem + 1.54vw, 2.4rem);
  }
}

.p-top-course {
  padding: 0 0 15rem;
}
@media (max-width: 991px) {
  .p-top-course {
    padding: 0 0 5rem;
  }
}
.p-top-course__inner {
  display: grid;
  gap: clamp(2rem, 3vw, 4rem);
}
.p-top-course .c-course + .c-heading-dark {
  margin-top: 2rem;
}
.p-top-course .c-heading-simple {
  margin-top: 2rem;
}
.p-top-course__attention {
  padding-block: clamp(2.5rem, 3vw, 3.5rem);
  padding-inline: clamp(3rem, 3.5vw, 5rem);
  background: #F3F3F3;
}
.p-top-course__attention dt {
  border-bottom: 1px solid #242424;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
}
.p-top-course__attention dd {
  font-size: clamp(1.2rem, 1.3vw, 1.4rem);
}
.p-top-course__attention dd + dd {
  margin-top: 1rem;
}

.p-top-flow {
  position: relative;
  padding: 5rem 0 0;
}
.p-top-flow::before, .p-top-flow::after {
  content: "";
  position: absolute;
  margin-inline: auto;
}
.p-top-flow::before {
  top: -40px;
  left: 0;
  right: 0;
  width: 1200px;
  height: 40px;
  background: #fff;
}
@media (max-width: 991px) {
  .p-top-flow::before {
    content: none;
  }
}
.p-top-flow::after {
  top: -40px;
  left: 0;
  right: 0;
  width: 203px;
  height: 34px;
  background: url(../images/common/bg_lines.svg) center top no-repeat;
  background-size: contain;
}
@media (max-width: 991px) {
  .p-top-flow::after {
    top: 0;
    width: 140px;
  }
}
.p-top-flow__inner {
  position: relative;
  z-index: -1;
  padding-bottom: clamp(150px, 25vw, 275px);
}
@media (max-width: 1399px) {
  .p-top-flow__inner {
    padding-bottom: 150px;
  }
}
@media (max-width: 767px) {
  .p-top-flow__inner {
    padding-bottom: 20px;
  }
}
.p-top-flow__inner::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
  background: url(../images/top/bg_flow.jpg) center bottom no-repeat;
  background-size: cover;
  width: 100%;
  height: 275px;
}
@media (max-width: 1399px) {
  .p-top-flow__inner::after {
    height: 150px;
  }
}
.p-top-flow .c-flow {
  margin-bottom: clamp(6rem, 8vw, 12rem);
}

.p-top-voice {
  position: relative;
  padding: 14rem 0 10rem;
}
@media (max-width: 991px) {
  .p-top-voice {
    padding: 10rem 0 6rem;
  }
}
@media (max-width: 575px) {
  .p-top-voice {
    padding: 8rem 0 6rem;
  }
}
.p-top-voice::before {
  content: "";
  position: absolute;
  margin-inline: auto;
  top: 0;
  left: 0;
  right: 0;
  width: 203px;
  height: 34px;
  background: url(../images/common/bg_lines.svg) center top no-repeat;
  background-size: contain;
}
@media (max-width: 991px) {
  .p-top-voice::before {
    width: 140px;
  }
}
.p-top-voice .swiper {
  position: relative;
}
@media (max-width: 575px) {
  .p-top-voice .swiper {
    padding-bottom: 4rem;
  }
}
.p-top-voice .swiper-wrap {
  position: relative;
}
@media (max-width: 1399px) {
  .p-top-voice .swiper-wrap {
    width: 90%;
    margin-inline: auto;
  }
}
@media (max-width: 767px) {
  .p-top-voice .swiper-wrap {
    width: 80%;
  }
}
@media (max-width: 575px) {
  .p-top-voice .swiper-wrap {
    width: 100%;
  }
}
.p-top-voice__pagination {
  display: none;
}
@media (max-width: 575px) {
  .p-top-voice__pagination {
    display: block;
    text-align: center;
  }
}
.p-top-voice .swiper-button-prev:after,
.p-top-voice .swiper-button-next:after {
  display: none;
}
.p-top-voice .swiper-button-prev,
.p-top-voice .swiper-button-next {
  width: 41px;
  height: 41px;
  top: 48%;
}
@media (max-width: 575px) {
  .p-top-voice .swiper-button-prev,
  .p-top-voice .swiper-button-next {
    display: none;
  }
}
.p-top-voice .swiper-button-prev {
  background: url(../images/common/ic-arrow-main.svg) center center no-repeat;
  left: -8rem;
  transform: scale(-1, 1);
  background-size: cover;
}
@media (max-width: 991px) {
  .p-top-voice .swiper-button-prev {
    left: -6.5rem;
  }
}
.p-top-voice .swiper-button-next {
  background: url(../images/common/ic-arrow-main.svg) center center no-repeat;
  right: -8rem;
  background-size: cover;
}
@media (max-width: 991px) {
  .p-top-voice .swiper-button-next {
    right: -6.5rem;
  }
}
.p-top-voice__img {
  width: 146px;
  margin: 0 auto 1rem;
}
@media (max-width: 767px) {
  .p-top-voice__img {
    width: 60%;
  }
}
.p-top-voice__img img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 100px;
}
.p-top-voice__text {
  margin-bottom: 1.5rem;
  line-height: 1.5;
}

.p-top-achievements {
  position: relative;
  padding: 10rem 0;
}
@media (max-width: 991px) {
  .p-top-achievements {
    padding: 5rem 0;
  }
}
.p-top-achievements::before {
  content: "";
  position: absolute;
  margin-inline: auto;
  top: 0;
  left: 0;
  right: 0;
  width: 203px;
  height: 34px;
  background: url(../images/common/bg_lines.svg) center top no-repeat;
  background-size: contain;
}
@media (max-width: 991px) {
  .p-top-achievements::before {
    width: 140px;
  }
}
.p-top-achievements .swiper {
  position: relative;
}
@media (max-width: 575px) {
  .p-top-achievements .swiper {
    padding-bottom: 4rem;
  }
}
.p-top-achievements .swiper-wrap {
  position: relative;
}
@media (max-width: 1399px) {
  .p-top-achievements .swiper-wrap {
    width: 90%;
    margin-inline: auto;
  }
}
@media (max-width: 767px) {
  .p-top-achievements .swiper-wrap {
    width: 80%;
  }
}
@media (max-width: 575px) {
  .p-top-achievements .swiper-wrap {
    width: 100%;
  }
}
.p-top-achievements__pagination {
  display: none;
}
@media (max-width: 575px) {
  .p-top-achievements__pagination {
    display: block;
    text-align: center;
  }
}
.p-top-achievements .swiper-button-prev:after,
.p-top-achievements .swiper-button-next:after {
  display: none;
}
.p-top-achievements .swiper-button-prev,
.p-top-achievements .swiper-button-next {
  width: 41px;
  height: 41px;
  top: 48%;
}
@media (max-width: 575px) {
  .p-top-achievements .swiper-button-prev,
  .p-top-achievements .swiper-button-next {
    display: none;
  }
}
.p-top-achievements .swiper-button-prev {
  background: url(../images/common/ic-arrow-main.svg) center center no-repeat;
  left: -8rem;
  transform: scale(-1, 1);
  background-size: cover;
}
@media (max-width: 991px) {
  .p-top-achievements .swiper-button-prev {
    left: -6.5rem;
  }
}
.p-top-achievements .swiper-button-next {
  background: url(../images/common/ic-arrow-main.svg) center center no-repeat;
  right: -8rem;
  background-size: cover;
}
@media (max-width: 991px) {
  .p-top-achievements .swiper-button-next {
    right: -6.5rem;
  }
}

.p-top-profile {
  padding: 10rem 0 0;
}
@media (max-width: 991px) {
  .p-top-profile {
    padding: 5rem 0 0;
  }
}
.p-top-profile .c-profile {
  margin-bottom: clamp(5rem, 8vw, 10rem);
}

/****************************************

	page-about.php

*****************************************/
.p-about-message {
  position: relative;
  padding: 10rem 0 0;
}
@media (max-width: 1199px) {
  .p-about-message {
    padding: 6rem 0 0;
  }
}
.p-about-message::before {
  content: "";
  position: absolute;
  margin-inline: auto;
  top: 0;
  left: 0;
  right: 0;
  width: 203px;
  height: 34px;
  background: url(../images/common/bg_lines.svg) center top no-repeat;
  background-size: contain;
}
@media (max-width: 991px) {
  .p-about-message::before {
    top: 0;
    width: 140px;
  }
}
.p-about-message__heading {
  background: url(../images/about/bg_message_heading.jpg) center center no-repeat;
  padding-block: clamp(5rem, 7vw, 8rem);
  padding-inline: 2rem;
  text-align: center;
  font-size: clamp(2rem, 2.5vw, 2.9rem);
  color: #fff;
}
@media (max-width: 767px) {
  .p-about-message__heading {
    width: calc(100% + 4rem);
    overflow: visible;
    margin: 0 -2rem;
  }
}
.p-about-message__text {
  max-width: 800px;
  margin: 5rem auto 0;
}

/****************************************

	page-course.php

*****************************************/
.p-course__inner {
  display: grid;
  gap: clamp(2rem, 3vw, 4rem);
}
.p-course .c-course + .c-heading-dark {
  margin-top: 2rem;
}
.p-course .c-heading-simple {
  margin-top: 2rem;
}

/****************************************

	page-schedule.php

*****************************************/
.p-schedule__inner {
  display: grid;
  gap: clamp(2rem, 3vw, 4rem);
}
.p-schedule .c-course {
  padding-block: 5rem;
  padding-inline: clamp(2rem, 6vw, 10rem);
}
.p-schedule .c-course + .c-heading-dark {
  margin-top: 2rem;
}
.p-schedule .c-heading-simple {
  margin-top: 2rem;
}
.p-schedule .c-table-schedule {
  margin: 3rem 0;
}

/****************************************

	archive-voice.php
	single-voice.php

*****************************************/
.p-voice-cat {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.p-voice-cat li {
  display: inline-block;
  padding: 0.3rem 1.2rem 0.4rem;
  border: 1px solid #E0E0E0;
  background: #F9F9F9;
  font-size: clamp(1rem, 1.2vw, 1.4rem);
  line-height: 1.5;
}

/****************************************

	archive-voice.php

*****************************************/
.p-archive-voice {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6rem;
}
@media (max-width: 991px) {
  .p-archive-voice {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 767px) {
  .p-archive-voice {
    gap: 5rem 2rem;
  }
}
.p-archive-voice__media {
  margin-bottom: 1.7rem;
}
.p-archive-voice__media img {
  width: 100%;
  aspect-ratio: 360/203;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-archive-voice__heading {
  margin: 1rem 0;
  font-size: clamp(1.4rem, 1.6vw, 1.8rem);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.p-archive-voice__name {
  font-size: clamp(1.2rem, 1.3vw, 1.4rem);
}

/****************************************

	single-voice.php

*****************************************/
.p-single-voice {
  display: flex;
  gap: 3rem clamp(3rem, 4.5vw, 6rem);
}
@media (max-width: 767px) {
  .p-single-voice {
    flex-direction: column;
  }
}
.p-single-voice__media {
  flex-shrink: 0;
  width: 360px;
}
@media (max-width: 991px) {
  .p-single-voice__media {
    width: 30%;
  }
}
@media (max-width: 767px) {
  .p-single-voice__media {
    order: 2;
    width: 100%;
  }
}
.p-single-voice__media img {
  width: 100%;
  aspect-ratio: 360/203;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-single-voice__text {
  order: 1;
}
.p-single-voice.is-noimage {
  grid-template-columns: 1fr;
}
.p-single-voice.is-noimage .p-single-voice__media {
  display: none;
}
.p-single-voice__heading {
  margin: 1.5rem 0 2rem;
  font-size: clamp(2.4rem, 2.9vw, 3.6rem);
  line-height: 1.3;
}

/****************************************

	page-course-template.php

*****************************************/
.p-course-intro__header {
  margin-top: clamp(4rem, 7vw, 9rem);
  margin-bottom: clamp(3rem, 3.5vw, 4rem);
}
.p-course-intro__header::after {
  content: "";
  display: block;
  width: clamp(80px, 10vw, 125px);
  height: 1px;
  background: #000;
  margin-top: 3rem;
}
.p-course-intro__header-sub {
  margin-bottom: 1.5rem;
  font-size: clamp(1.3rem, 1.6vw, 1.9rem);
}
.p-course-intro__header-main {
  font-size: clamp(2.6rem, 3vw, 4rem);
  line-height: 1.3;
}
.p-course-intro__overview {
  margin-bottom: clamp(3rem, 3.5vw, 4rem);
}
@media (max-width: 767px) {
  .p-course-intro__overview br {
    display: none;
  }
}

.p-course-eyecatch {
  position: relative;
  z-index: 0;
  padding-bottom: clamp(5rem, 7.5vw, 10rem);
}
.p-course-eyecatch::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  margin: auto;
  width: 100%;
  height: clamp(100px, 20vw, 300px);
  background: #003366;
}
.p-course-eyecatch img {
  width: 100%;
  aspect-ratio: 1400/356;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 767px) {
  .p-course-eyecatch img {
    aspect-ratio: 3/1.5;
  }
}

.p-course-container {
  padding: clamp(5rem, 7.5vw, 10rem) 0 0;
  background: #F9F9F9;
}
.p-course-container .c-heading-line {
  margin: clamp(5rem, 7.5vw, 10rem) auto clamp(3rem, 4vw, 5rem);
}
.p-course-container .container-md > :first-child.c-heading-line {
  margin-top: 0;
}
.p-course-container .c-feature-grid,
.p-course-container .c-check-list,
.p-course-container .c-text-supplement {
  margin: clamp(3rem, 4vw, 5rem) auto;
}
.p-course-container .c-list-bordered {
  margin: clamp(2rem, 3vw, 4rem) auto clamp(3rem, 4vw, 5rem);
}

.c-table-course {
  width: 100%;
}
.c-table-course th,
.c-table-course td {
  padding: 2rem;
  border: 1px solid #E0E0E0;
  line-height: 1.5;
  vertical-align: middle;
}
@media (max-width: 767px) {
  .c-table-course th,
  .c-table-course td {
    padding: 1.5rem;
  }
}
.c-table-course th {
  width: 28%;
  background: #003366;
  color: #fff;
  text-align: left;
}
@media (max-width: 767px) {
  .c-table-course th {
    width: 100%;
    display: block;
  }
}
@media (max-width: 767px) {
  .c-table-course th br {
    display: none;
  }
}
.c-table-course td {
  background: #fff;
  line-height: 2;
}
@media (max-width: 767px) {
  .c-table-course td {
    width: 100%;
    display: block;
  }
}/*# sourceMappingURL=style.css.map */