/*!**************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[3]!./scss/top.scss ***!
  \**************************************************************************************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500&family=Shippori+Mincho+B1:wght@400;500&family=Open+Sans:wght@600&display=swap);
/*!******************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[3]!./scss/top.scss (1) ***!
  \******************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* -------------------------------------------------------------------
  default colors
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  default web-font
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  default spacing
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  hover anitionの適用（～xまで）
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  default font-size
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  breakpoints
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  各種rem計算（font以外）
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  flex時のgapを差し引いた横幅計算
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  アスペクト比固定
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  vw変換
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  MediaQuery
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  border
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  background
------------------------------------------------------------------- */
.background__base {
  background-color: #EBF3F9;
}
.background__white {
  background-color: white;
}
.background__main {
  background-color: #DE863F;
}

@media (min-width: 768px) {
  body:not(.block-editor-page) .--sp {
    display: none !important;
  }
}
@media (max-width: 767.9px) {
  body:not(.block-editor-page) .--tb {
    display: none !important;
  }
}
@media (max-width: 1023.9px) {
  body:not(.block-editor-page) .--pc {
    display: none !important;
  }
}
@media (min-width: 1024px) {
  body:not(.block-editor-page) .--show-sp-nav {
    display: none !important;
  }
}
@media (max-width: 1023.9px) {
  body:not(.block-editor-page) .--show-pc-nav {
    display: none !important;
  }
}

/* -------------------------------------------------------------------
  margin / padding
------------------------------------------------------------------- */
.mt-high, .footer {
  margin-top: clamp(50px, 9.765625vw, 100px);
}
.mt-middle {
  margin-top: clamp(30px, 5.2083333333vw, 50px);
}
.mt-low {
  margin-top: clamp(30px, 3.90625vw, 30px);
}
.mt-0 {
  margin-top: 0rem !important;
}

.mr-high {
  margin-right: clamp(50px, 9.765625vw, 100px);
}
.mr-middle {
  margin-right: clamp(30px, 5.2083333333vw, 50px);
}
.mr-low {
  margin-right: clamp(30px, 3.90625vw, 30px);
}
.mr-0 {
  margin-right: 0rem !important;
}

.mb-high {
  margin-bottom: clamp(50px, 9.765625vw, 100px);
}
.mb-middle {
  margin-bottom: clamp(30px, 5.2083333333vw, 50px);
}
.mb-low {
  margin-bottom: clamp(30px, 3.90625vw, 30px);
}
.mb-0 {
  margin-bottom: 0rem !important;
}

.ml-high {
  margin-left: clamp(50px, 9.765625vw, 100px);
}
.ml-middle {
  margin-left: clamp(30px, 5.2083333333vw, 50px);
}
.ml-low {
  margin-left: clamp(30px, 3.90625vw, 30px);
}
.ml-0 {
  margin-left: 0rem !important;
}

.mx-high {
  margin-inline: clamp(50px, 9.765625vw, 100px);
}
.mx-middle {
  margin-inline: clamp(30px, 5.2083333333vw, 50px);
}
.mx-low {
  margin-inline: clamp(30px, 3.90625vw, 30px);
}
.mx-0 {
  margin-inline: 0rem !important;
}

.my-high {
  margin-block: clamp(50px, 9.765625vw, 100px);
}
.my-middle {
  margin-block: clamp(30px, 5.2083333333vw, 50px);
}
.my-low {
  margin-block: clamp(30px, 3.90625vw, 30px);
}
.my-0 {
  margin-block: 0rem !important;
}

.ma-high {
  margin: clamp(50px, 9.765625vw, 100px);
}
.ma-middle {
  margin: clamp(30px, 5.2083333333vw, 50px);
}
.ma-low {
  margin: clamp(30px, 3.90625vw, 30px);
}
.ma-0 {
  margin: 0rem !important;
}

.pt-high {
  padding-top: clamp(50px, 9.765625vw, 100px);
}
.pt-middle {
  padding-top: clamp(30px, 5.2083333333vw, 50px);
}
.pt-low {
  padding-top: clamp(30px, 3.90625vw, 30px);
}
.pt-0 {
  padding-top: 0rem !important;
}

.pr-high {
  padding-right: clamp(50px, 9.765625vw, 100px);
}
.pr-middle {
  padding-right: clamp(30px, 5.2083333333vw, 50px);
}
.pr-low {
  padding-right: clamp(30px, 3.90625vw, 30px);
}
.pr-0 {
  padding-right: 0rem !important;
}

.pb-high {
  padding-bottom: clamp(50px, 9.765625vw, 100px);
}
.pb-middle {
  padding-bottom: clamp(30px, 5.2083333333vw, 50px);
}
.pb-low {
  padding-bottom: clamp(30px, 3.90625vw, 30px);
}
.pb-0 {
  padding-bottom: 0rem !important;
}

.pl-high {
  padding-left: clamp(50px, 9.765625vw, 100px);
}
.pl-middle {
  padding-left: clamp(30px, 5.2083333333vw, 50px);
}
.pl-low {
  padding-left: clamp(30px, 3.90625vw, 30px);
}
.pl-0 {
  padding-left: 0rem !important;
}

.px-high {
  padding-inline: clamp(50px, 9.765625vw, 100px);
}
.px-middle {
  padding-inline: clamp(30px, 5.2083333333vw, 50px);
}
.px-low {
  padding-inline: clamp(30px, 3.90625vw, 30px);
}
.px-0 {
  padding-inline: 0rem !important;
}

.py-high, .section {
  padding-block: clamp(50px, 9.765625vw, 100px);
}
.py-middle {
  padding-block: clamp(30px, 5.2083333333vw, 50px);
}
.py-low {
  padding-block: clamp(30px, 3.90625vw, 30px);
}
.py-0 {
  padding-block: 0rem !important;
}

.pa-high {
  padding: clamp(50px, 9.765625vw, 100px);
}
.pa-middle {
  padding: clamp(30px, 5.2083333333vw, 50px);
}
.pa-low {
  padding: clamp(30px, 3.90625vw, 30px);
}
.pa-0 {
  padding: 0rem !important;
}

@media (max-width: 599.9px) {
  .--sp-pd-x-0 {
    padding-inline: 0 !important;
  }
}

.header__nav-ul,
.footer__nav-ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.header__nav-ul a,
.footer__nav-ul a {
  text-decoration: none;
  font-size: 13px;
  line-height: 1.5;
}
.header__nav-ul > li > a,
.footer__nav-ul > li > a {
  font-weight: 700;
}
.header__nav-ul .sub-menu,
.footer__nav-ul .sub-menu {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.header__nav-ul .sub-menu li,
.footer__nav-ul .sub-menu li {
  padding-left: 10px;
}
.header__nav-ul .sub-menu a,
.footer__nav-ul .sub-menu a {
  color: rgba(18, 30, 46, 0.5);
}
@media (max-width: 1023.9px) {
  .header__nav-ul > .menu-item,
  .footer__nav-ul > .menu-item {
    border-bottom: 1px solid #D8D5D1;
  }
  .header__nav-ul > .menu-item > a,
  .footer__nav-ul > .menu-item > a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-block: 7.5px;
  }
  .header__nav-ul > .menu-item > a::after,
  .footer__nav-ul > .menu-item > a::after {
    flex-shrink: 0;
    display: grid;
  }
  .header__nav-ul > .menu-item.menu-item-has-children > a::after,
  .footer__nav-ul > .menu-item.menu-item-has-children > a::after {
    content: "＋";
    place-items: center;
    width: 16px;
    height: 16px;
    background-color: #DE863F;
    border-radius: 50%;
    color: white;
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
  }
  .header__nav-ul > .menu-item.menu-item-has-children > a.--accordion-on::after,
  .footer__nav-ul > .menu-item.menu-item-has-children > a.--accordion-on::after {
    content: "ー";
  }
  .header__nav-ul > .menu-item:not(.menu-item-has-children) > a::after,
  .footer__nav-ul > .menu-item:not(.menu-item-has-children) > a::after {
    content: "";
    width: 10px;
    height: 6px;
    background-image: url(../assets/icon/arrow-r-main.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
  }
  .header__nav-ul a,
  .footer__nav-ul a {
    display: block;
    padding-block: 5px;
  }
  .header__nav-ul .sub-menu,
  .footer__nav-ul .sub-menu {
    display: none;
  }
  .header__nav-ul .nav-item-child,
  .footer__nav-ul .nav-item-child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 7px;
    padding-left: 1.3em;
    border-top: 1px solid #D8D5D1;
  }
  .header__nav-ul .nav-item-child__text,
  .footer__nav-ul .nav-item-child__text {
    font-size: 13px;
    color: #121E2E;
    line-height: 1.5;
  }
  .header__nav-ul .nav-item-child::after,
  .footer__nav-ul .nav-item-child::after {
    flex-shrink: 0;
    content: "";
    display: block;
    width: 10px;
    height: 6px;
    background: url(../assets/icon/arrow-r-main.svg) center center no-repeat;
    background-size: contain;
  }
  .header__nav-ul .nav-img-item__img,
  .footer__nav-ul .nav-img-item__img {
    display: none;
  }
}

.header {
  position: relative;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  max-height: 100dvh;
  background-color: white;
}
.--header-scroll-standby .header {
  transform: translateY(0);
}
.--header-scroll-ready .header {
  transform: translateY(-100%);
  transition: transform 0.3s linear;
}
.--header-scroll-on .header {
  position: fixed;
  transform: translateY(0%);
  transition: transform 0.3s linear;
}
.--header-scroll-out .header {
  transform: translateY(-100%);
}
.header__title {
  margin: 0;
  padding-block: 10px;
  padding-left: clamp(15px, 2.9296875vw, 30px);
}
.header__title a {
  line-height: 1;
}
.header__logo {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: logo;
  height: 40px;
}
.header__inner {
  display: grid;
  grid-template: "logo btn" auto "nav nav" 1fr/auto 1fr;
  background-color: white;
}
.header__nav-btn {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: btn;
  align-self: center;
  justify-self: flex-end;
}
.header__nav-ul > li > a {
  font-size: clamp(14px, 1.8229166667vw, 16px);
}
.header__nav-wrap {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: nav;
  padding: 30px 10px;
}
.header__nav-btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  background-color: white;
  border: 0;
  cursor: pointer;
}
.--nav-on .header__nav-btn {
  background-color: #DE863F;
}
.header__nav-btn__burger {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.header__nav-btn__burger span {
  position: relative;
  display: block;
  width: clamp(20px, 3.2552083333vw, 30px);
  height: 2px;
  background-color: #DE863F;
  transition: transform 0.3s linear;
}
.--nav-on .header__nav-btn__burger span {
  background-color: white;
}
.--nav-on .header__nav-btn__burger span:first-child {
  top: 3px;
  transform: rotate(45deg);
}
.--nav-on .header__nav-btn__burger span:last-child {
  top: -3px;
  transform: rotate(-45deg);
}
.--nav-on .header__nav-btn__burger span:nth-child(2) {
  display: none;
}
.header__cta-title {
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
.header__cta-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.header__cta-link {
  display: grid;
  place-items: center;
  padding: 8px;
  background-color: #DD6717;
  text-align: center;
  color: white;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-decoration: none;
}
.header__cta-link + .header__cta-link {
  border-left: 1px solid white;
}
.header .common-cta__wrap {
  margin-top: 30px;
  padding-inline: 0;
}
@media (min-width: 1024px) {
  .header {
    box-shadow: 0 4px 4px rgba(18, 30, 46, 0.05);
  }
  .--header-scroll-ready .header .header__nav-wrap {
    display: none;
  }
  .--header-scroll-ready .header .header__logo {
    height: 44px;
  }
  .--header-scroll-ready .header .header__title {
    padding-block: 5px;
  }
  .header__inner {
    grid-template: "logo cta" auto "nav nav" auto/auto 1fr;
  }
  .header__title {
    display: grid;
    place-items: center;
    margin-bottom: 0;
  }
  .header__logo {
    height: 54px;
  }
  .header__cta {
    grid-area: cta;
    justify-self: flex-end;
    display: flex;
    align-items: center;
    transition: all 0.3s linear;
  }
  .header__cta-list {
    grid-template-columns: repeat(4, 1fr);
    height: 100%;
  }
  .header__nav-wrap {
    position: relative;
    padding: 0 clamp(15px, 2.2786458333vw, 20px);
  }
  .header__nav-ul {
    display: flex;
    justify-content: center;
    -moz-column-gap: clamp(20px, 4.2317708333vw, 45px);
         column-gap: clamp(20px, 4.2317708333vw, 45px);
  }
  .header__nav-ul > .menu-item {
    padding-block: clamp(15px, 2.2786458333vw, 20px);
  }
  .header__nav-ul > .menu-item-has-children > .menu-item__parent {
    display: flex;
    -moz-column-gap: 10px;
         column-gap: 10px;
    cursor: pointer;
  }
  .header__nav-ul > .menu-item-has-children > .menu-item__parent::after {
    flex-shrink: 0;
    content: "▼";
    display: grid;
    place-items: center;
    transform: scaleY(0.7);
    font-size: 8px;
    line-height: 1;
  }
  .header__nav-ul > .menu-item-has-children .sub-menu {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 10;
    transform: translateY(100%) scaleY(0);
    transform-origin: top center;
    display: block !important;
    width: 100%;
    opacity: 0;
    transition: transform 0.3s linear, opacity 0.3s 0.1s linear;
  }
  .header__nav-ul > .menu-item-has-children:hover .sub-menu {
    transform: translateY(100%) scaleY(1);
    opacity: 1;
  }
  .header__nav-ul .header__nav-sub-menu {
    padding-block: 30px 50px;
    padding-inline: 20px;
    background-color: rgba(222, 134, 63, 0.8);
  }
  .header__nav-ul .header__nav-sub-menu__inner {
    width: 1080px;
    max-width: 100%;
    margin-inline: auto;
    list-style-type: none;
  }
  .header__nav-ul .header__nav-sub-menu__inner.--has-img-item {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
  }
  .header__nav-ul .header__nav-sub-menu__inner.--has-text-item {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px 20px;
    padding: 20px 20px 30px;
    background-color: white;
  }
  .header__nav-ul .header__nav-sub-menu__label {
    display: flex;
    align-items: center;
    gap: 5px;
    grid-column: span 4;
    margin-bottom: 0;
  }
  .header__nav-ul .header__nav-sub-menu__label .nav-item-child__text {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
    color: #121E2E;
  }
  .header__nav-ul .header__nav-sub-menu__label::before {
    flex-shrink: 0;
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #DE863F;
  }
  .header__nav-ul .header__nav-sub-menu__label:not(:first-child) {
    margin-top: 5px;
  }
  .header__nav-ul .header__nav-sub-menu .header__nav-item__child.menu-item {
    padding-left: 0;
  }
  .header__nav-img-item {
    position: relative;
    display: flex;
    align-items: center;
    -moz-column-gap: 15px;
         column-gap: 15px;
    background-color: white;
  }
  .header__nav-img-item__img {
    flex-shrink: 0;
    width: 117px;
  }
  .header__nav-img-item__text {
    color: #121E2E;
  }
  .header__nav-img-item::after {
    content: "";
    position: absolute;
    right: 15px;
    bottom: 10px;
    display: block;
    width: 15px;
    height: 9px;
    background: url(../assets/icon/arrow-r-b.svg) center center no-repeat;
    background-size: contain;
  }
  .header__nav-text-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-bottom: 13px;
    border-bottom: 1px solid #D8D5D1;
  }
  .header__nav-text-item__text {
    font-size: 14px;
    color: #121E2E;
    line-height: 1.5;
  }
  .header__nav-text-item::after {
    flex-shrink: 0;
    content: "";
    display: block;
    width: 15px;
    height: 9px;
    background: url(../assets/icon/arrow-r-main.svg) center center no-repeat;
    background-size: contain;
  }
  .header__nav-btn {
    display: none;
  }
  .header .common-cta__wrap {
    display: none;
  }
  .header__tel {
    display: grid;
    padding-inline: clamp(10px, 1.6276041667vw, 15px) clamp(15px, 2.9296875vw, 30px);
    padding-bottom: 7px;
  }
  .header__tel-tel {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-size: clamp(22px, 2.9947916667vw, 24px);
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-decoration: none;
  }
  .header__tel-tel::before {
    content: "";
    flex-shrink: 0;
    transform: translateY(10%);
    display: block;
    width: clamp(18px, 2.734375vw, 24px);
    height: clamp(18px, 2.734375vw, 24px);
    background-image: url(../assets/icon/phone.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
  }
  .header__tel-notice {
    transform: translateX(19%);
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    text-align: center;
    font-size: clamp(8px, 1.171875vw, 10px);
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
  }
  .header__tel-notice .--small {
    font-size: 8px;
  }
  .header__logo {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .header__nav-wrap {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
}
@media (min-width: 1024px){
  .header__cta {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
}
@media (max-width: 1023.9px) {
  .header__inner {
    box-shadow: 0 4px 4px rgba(18, 30, 46, 0.05);
  }
  .header__title {
    display: grid;
  }
  .header__tel {
    display: none;
  }
  .header__nav-wrap {
    position: absolute;
    top: 60px;
    z-index: -1;
    transform: translateY(-100%);
    overflow-y: auto;
    width: 100%;
    height: calc(100dvh - 60px);
    background-color: white;
    transition: transform 0.5s linear;
  }
  .--nav-on .header__nav-wrap {
    transform: translateY(0%);
  }
  .header__nav-ul {
    padding-inline: 5px;
  }
  .header .sub-menu {
    display: none;
  }
  .header__cta {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 50;
    transform: translateY(100%);
    transition: transform 0.3s linear;
    width: 100%;
  }
  .--header-scroll-on .header__cta {
    transform: translateY(0%);
  }
  .--header-scroll-out .header__cta {
    transform: translateY(100%);
  }
  .header__cta-inner {
    padding: 9px 10px 18px;
    border-top: 1px solid #121E2E;
    background-color: #F9F8F4;
  }
  .header__cta-title {
    text-align: center;
  }
  .header__cta-list {
    grid-template-columns: 21.7% repeat(3, 21%) 1fr;
    margin-top: 9px;
    border-radius: 5em;
    box-shadow: 0 3px 0 #c05a15;
  }
  .header__cta-link {
    padding-block: 11px;
  }
  .header__cta-link:first-child {
    padding-left: 15px;
    border-radius: 5em 0 0 5em;
  }
  .header__cta-link:last-child {
    padding-right: 10px;
    border-radius: 0 5em 5em 0;
  }
  .header__cta-link.--tel svg path {
    fill: white;
  }
}

/* -------------------------------------------------------------------
  layout
------------------------------------------------------------------- */
.inner {
  width: 1110px;
  max-width: 100%;
  margin-inline: auto;
  padding-inline: 15px;
}
.inner.--pd-0 {
  width: 1080px;
  padding-inline: 0;
}
.inner.--sub {
  width: 1230px;
}
.inner.--sub.--pd-0 {
  width: 1200px;
}
.inner.--wide {
  width: 1270px;
}
.inner.--wide.--pd-0 {
  width: 1240px;
}
.inner.--max {
  width: 1370px;
}
.inner.--max.--pd-0 {
  width: 1340px;
}

.title-label {
  display: flex;
  flex-direction: column;
  row-gap: clamp(2px, 0.390625vw, 4px);
}
.title-label__text {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: clamp(15px, 2.2786458333vw, 20px);
  background-color: #DE863F;
  color: white;
  font-size: clamp(20px, 3.2552083333vw, 30px);
  letter-spacing: 0.05em;
  line-height: 1.5;
}
.title-label.--sub .title-label__text {
  background-color: #4E71A6;
}
.--has-float-title .title-label {
  position: relative;
  margin-top: calc(-1 * clamp(37px, 6.1197916667vw, 57px));
  margin-left: calc(-1 * clamp(15px, 2.2786458333vw, 20px));
  transform: translateY(calc(-1 * clamp(15px, 2.734375vw, 27px))) translateX(calc(-1 * clamp(15px, 2.2786458333vw, 20px)));
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

.title__h2 {
  margin-bottom: clamp(20px, 3.2552083333vw, 30px);
  padding: clamp(10px, 1.953125vw, 20px) clamp(10px, 1.6276041667vw, 15px);
  border-left: clamp(10px, 1.6276041667vw, 15px) solid #DE863F;
  background-color: rgba(205, 181, 143, 0.15);
  font-size: clamp(18px, 2.6041666667vw, 22px);
  font-weight: 700;
  line-height: 1.2;
}
.title__h3 {
  position: relative;
  margin-bottom: 20px;
  padding-bottom: clamp(10px, 1.953125vw, 20px);
  border-bottom: clamp(3px, 0.5208333333vw, 5px) solid rgba(205, 181, 143, 0.15);
  font-size: clamp(16px, 2.2135416667vw, 18px);
  font-weight: 700;
  line-height: 1.2;
}
.title__h3::after {
  content: "";
  position: absolute;
  bottom: calc(-1 * clamp(3px, 0.5208333333vw, 5px));
  left: 0;
  display: block;
  width: clamp(50px, 9.765625vw, 100px);
  height: clamp(3px, 0.5208333333vw, 5px);
  background-color: #DE863F;
}
.title__sub {
  color: #DE863F;
}
.title__mini {
  color: #DE863F;
}
.title__text {
  font-family: "Shippori Mincho B1", serif;
}

/* -------------------------------------------------------------------
  btn
------------------------------------------------------------------- */
.btn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  -moz-column-gap: 0.5em;
       column-gap: 0.5em;
  max-width: 100%;
  padding-block: clamp(8px, 1.5625vw, 16px);
  padding-inline: 20px 15px;
  background-color: #DE863F;
  border: 1px solid #DE863F;
  border-radius: 100em;
  color: white;
  font-size: clamp(14px, 1.953125vw, 16px);
  line-height: 1.2;
  text-decoration: none;
}
.btn:not(.--no-shadow) {
  margin-bottom: 3px;
  box-shadow: 0 3px 0 0 #c47536;
}
.btn:not(.--no-shadow).--accent {
  box-shadow: 0 3px 0 0 #c05a15;
}
.btn:not(.--no-shadow).--sub {
  box-shadow: 0 3px 0 0 #3a557d;
}
.btn.--accent {
  background-color: #DD6717;
  border-color: #DD6717;
}
.btn.--sub {
  background-color: #4E71A6;
  border-color: #4E71A6;
}
.btn:not(.--no-arrow)::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 15px;
  height: 9px;
  background-image: url(../assets/icon/arrow-r-w.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.btn.--solid {
  background-color: white;
  color: #DE863F;
}
.btn.--solid.--accent {
  color: #DD6717;
}
.btn.--solid.--sub {
  color: #4E71A6;
}
.btn.--solid:not(.--no-arrow)::after {
  background-image: url(../assets/icon/arrow-r-main.svg);
}
.btn.--solid:not(.--no-arrow).--sub:after {
  background-image: url(../assets/icon/arrow-r-sub.svg);
}
.btn.--mini {
  min-width: 130px;
  padding-block: 5px;
  font-size: 14px;
}
.btn.--mini:not(.--no-arrow)::after {
  width: 10px;
  height: 6px;
}
.btn.--mini.--tel::after {
  width: 15px;
  height: 15px;
  background-image: url(../assets/icon/tel-w.svg);
}
.btn.--mini.--map::after {
  width: 15px;
  height: 15px;
  background-image: url(../assets/icon/mappin-main.svg);
}
.btn.--fix-width {
  width: 300px;
}
.btn.--cta {
  justify-content: center;
  padding-block: clamp(14px, 1.953125vw, 16px);
  padding-inline: 15px;
  font-size: clamp(16px, 2.2135416667vw, 18px);
}
.btn.--center {
  margin-inline: auto;
}

.footer {
  padding-bottom: clamp(30px, 5.2083333333vw, 50px);
}
.footer__top {
  max-width: 1200px;
  margin: clamp(50px, 9.765625vw, 100px) auto 0;
  padding-top: clamp(20px, 3.2552083333vw, 30px);
  border-top: 2px solid #D8D5D1;
}
.footer__logo {
  display: none;
}
.footer__nav-list {
  display: grid;
  -moz-column-gap: 20px;
       column-gap: 20px;
  width: 100%;
}
.footer__nav-img-item__img {
  display: none;
}
.footer__bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: clamp(20px, 4.5572916667vw, 50px);
}
.footer__bottom-link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 50px;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.footer__bottom-link-item a {
  text-decoration: none;
  font-size: 11px;
}
.footer__privacy {
  display: flex;
  align-items: center;
  -moz-column-gap: 5px;
       column-gap: 5px;
  max-width: 100%;
  width: 368px;
}
.footer__privacy-img {
  flex-shrink: 0;
}
.footer__privacy-text {
  font-size: 11px;
  line-height: 1.5;
}
.footer__copy {
  display: block;
  margin-top: 30px;
  text-align: center;
  color: rgba(18, 30, 46, 0.5);
  font-size: 11px;
  line-height: 1.5;
}
.footer__subTitle {
  position: relative;
  padding-left: clamp(16px, 2.6692708333vw, 25px);
  font-size: clamp(16px, 2.34375vw, 20px);
}
.footer__subTitle::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  width: clamp(10px, 1.6276041667vw, 15px);
  height: clamp(10px, 1.6276041667vw, 15px);
  margin: auto;
  background-color: #DE863F;
  border-radius: 50%;
}
.footer__classrooms {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0 20px;
  padding-left: 0;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .footer__classrooms {
    grid-template-columns: repeat(2, 1fr);
  }
}
.footer__classrooms li a {
  position: relative;
  display: flex;
  align-items: center;
  height: clamp(38px, 5.5989583333vw, 48px);
  padding-right: 40px;
  font-size: clamp(12px, 1.6927083333vw, 14px);
  font-weight: 500;
  border-bottom: 1px solid #D8D5D1;
  text-decoration: none;
}
.footer__classrooms li a::before {
  position: absolute;
  content: "→";
  right: 0;
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  margin: auto;
  font-size: clamp(18px, 2.734375vw, 24px);
  color: #DE863F;
}
.footer__button {
  display: flex;
  justify-content: right;
  margin-top: clamp(15px, 2.2786458333vw, 20px);
}
.footer__button .btn {
  width: 130px;
}
@media (min-width: 1024px) {
  .footer .menu-footer-nav-1-container,
  .footer .menu-footer-nav-2-container,
  .footer .menu-footer-nav-3-container {
    width: 200px;
  }
  .footer .menu-footer-nav-4-container {
    width: 130px;
  }
  .footer__bottom {
    justify-content: space-between;
  }
  .footer__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    -moz-column-gap: clamp(50px, 9.765625vw, 100px);
         column-gap: clamp(50px, 9.765625vw, 100px);
  }
  .footer__logo {
    display: block;
    width: 164px;
    height: auto;
  }
  .footer__nav-list {
    grid-template-columns: repeat(auto-fit, minmax(150px, -webkit-max-content));
    grid-template-columns: repeat(auto-fit, minmax(150px, max-content));
    justify-content: flex-end;
  }
  .footer .menu-footer-nav-1-container,
  .footer .menu-footer-nav-2-container,
  .footer .menu-footer-nav-3-container {
    width: 150px;
  }
  .footer .menu-footer-nav-4-container {
    width: 100px;
  }
  .footer .sub-menu {
    display: block !important;
  }
  .footer__nav-img-item {
    padding-left: 1em;
  }
  .footer__nav-img-item__img {
    display: none;
  }
  .footer__nav-sub-menu__label {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  .footer .--has-text-item {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding-left: 1em;
  }
}
@media (max-width: 1023.9px) {
  .footer__inner {
    padding-inline: 25px;
  }
}

.breadcrumbs {
  display: flex;
  gap: clamp(19px, 2.6692708333vw, 22px);
  margin-top: clamp(5px, 1.3020833333vw, 15px);
}
.breadcrumbs__inner {
  width: 1230px;
  max-width: 100%;
  margin-inline: auto;
  padding-inline: 15px;
  color: rgba(18, 30, 46, 0.5);
  font-size: clamp(9px, 1.3671875vw, 12px);
  letter-spacing: 0.05em;
  line-height: normal;
}
.breadcrumbs__inner a {
  color: #DE863F;
  text-decoration: none;
}

/* -------------------------------------------------------------------
  btn
------------------------------------------------------------------- */
.label {
  display: inline-block;
  padding: 2.5px 10px;
  background-color: #DE863F;
  border: 1px solid #DE863F;
  border-radius: 5px;
  color: white;
  font-size: 13px;
  line-height: 1.5;
  text-decoration: none;
}
@media (min-width: 768px) {
  .label {
    padding-block: 1px;
    font-size: 15px;
  }
}
.label.--off {
  background-color: white;
  border-color: #D8D5D1;
  color: rgba(18, 30, 46, 0.5);
}
.label.--solid {
  background-color: white;
  border-color: #DE863F;
  color: #DE863F;
}
.label.--gray {
  background-color: rgba(216, 213, 209, 0.5);
  border: 0;
  color: #121E2E;
}
.label.--small {
  font-size: clamp(12px, 1.6927083333vw, 14px);
}

.label-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.label-list:not(:first-child) {
  margin-top: clamp(10px, 1.6276041667vw, 15px);
}
.label-list.--thin {
  gap: 5px;
}

.box__inner {
  padding: 30px clamp(20px, 3.2552083333vw, 30px);
  border-radius: 1px;
  border: 1px solid #DE863F;
  background-color: white;
}
.box.--sub .box__inner {
  border-color: #395683;
}
.box.--has-float-title {
  margin-top: clamp(15px, 2.734375vw, 27px);
}
.box.--has-float-title .box__inner {
  position: relative;
  padding-top: clamp(37px, 6.1197916667vw, 57px);
}

/* -------------------------------------------------------------------
  img-banner
------------------------------------------------------------------- */
.img-banner {
  position: relative;
  display: grid;
  align-items: center;
  aspect-ratio: 187/105;
  width: 100%;
  max-width: 540px;
  height: 100%;
  padding-inline: clamp(15px, 2.9296875vw, 30px);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  text-decoration: none;
}
@media (min-width: 1024px) {
  .img-banner {
    aspect-ratio: 540/211;
  }
}
.img-banner::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(18, 30, 46, 0.7);
}
.img-banner__img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.img-banner__img-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.img-banner__text {
  z-index: 1;
  color: white;
  font-size: clamp(16px, 2.0833333333vw, 18px);
  line-height: 1.2;
}
.img-banner__text .--small {
  font-size: 0.8125em;
}
.img-banner__text::before {
  content: "";
  position: absolute;
  display: block;
  top: 5px;
  left: 5px;
  width: 50%;
  height: 50%;
  border-top-left-radius: 5px;
  border-top: 1px solid white;
  border-left: 1px solid white;
}
.img-banner__text::after {
  content: "";
  position: absolute;
  display: block;
  right: clamp(15px, 1.953125vw, 30px);
  bottom: clamp(15px, 1.953125vw, 20px);
  width: 20px;
  height: 12px;
  background-image: url(../assets/icon/arrow-r-w.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.--large .img-banner__text::after {
  bottom: clamp(15px, 1.953125vw, 30px);
}
.img-banner.--white::after {
  background-color: rgba(255, 255, 255, 0.6);
}
.img-banner.--white .img-banner__text {
  color: #121E2E;
}
.img-banner.--white .img-banner__text::before {
  border-color: #121E2E;
}
.img-banner.--white .img-banner__text::after {
  background-image: url(../assets/icon/arrow-r-b.svg);
}

.info-contents p {
  margin-bottom: clamp(30px, 5.2083333333vw, 50px);
  font-size: clamp(13px, 1.953125vw, 17px);
  line-height: 1.7;
}
.info-contents img {
  display: block;
  width: 100%;
  max-width: 720px;
  max-height: clamp(434px, 90.7552083333vw, 960px);
  margin: 0 auto clamp(30px, 5.2083333333vw, 50px);
  -o-object-fit: cover;
     object-fit: cover;
}
.info-contents h2 {
  max-width: 100% !important;
  margin: auto !important;
}
.info-contents h3 {
  max-width: 100% !important;
  margin: auto !important;
}

.info-category {
  margin-left: 10px;
  padding: 2px 10px;
  font-size: 13px;
  color: #DE863F;
  border: 1px solid #DE863F;
  border-radius: 5px;
}

.info-buttons {
  display: flex;
  justify-content: center;
  gap: 50px;
}
.info-buttons__prev {
  position: relative;
  font-size: clamp(14px, 1.953125vw, 16px);
  text-decoration: none;
  color: #DE863F;
}
.info-buttons__prev::before {
  position: absolute;
  content: "←";
  left: -24px;
  top: 0;
  bottom: 0;
  width: 16px;
  height: 16px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}
.info-buttons__next {
  position: relative;
  font-size: clamp(14px, 1.953125vw, 16px);
  text-decoration: none;
  color: #DE863F !important;
}
.info-buttons__next::before {
  position: absolute;
  content: "→";
  right: -24px;
  top: 0;
  bottom: 0;
  width: 16px;
  height: 16px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.info-link {
  text-align: center;
  margin-top: 30px;
}
.info-link a {
  color: #888;
  font-size: clamp(14px, 1.953125vw, 16px);
  text-decoration: none;
}

/* -------------------------------------------------------------------
  content-news
------------------------------------------------------------------- */
.content-news {
  position: relative;
  display: flex;
  flex-direction: column;
  row-gap: 5px;
  padding-block: clamp(10px, 1.6276041667vw, 15px);
}
.content-news::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 1px;
  background: repeating-linear-gradient(to right, #D8D5D1 0, #D8D5D1 1px, transparent 1px, transparent 3px);
  bottom: 0;
}
.content-news:first-child::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 1px;
  background: repeating-linear-gradient(to right, #D8D5D1 0, #D8D5D1 1px, transparent 1px, transparent 3px);
  top: 0;
}
.content-news__meta {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.content-news__time {
  flex-shrink: 0;
  color: rgba(18, 30, 46, 0.5);
  font-family: "Open Sans", sans-serif;
  font-size: clamp(11px, 1.5625vw, 13px);
  line-height: 1.5;
}
.content-news__categories {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.content-news__category {
  font-size: clamp(10px, 1.4973958333vw, 13px);
  padding-block: 1px;
}
.content-news__title {
  font-size: clamp(13px, 1.7578125vw, 14px);
  line-height: 1.5;
  text-decoration: none;
}

/* -------------------------------------------------------------------
  content-result
------------------------------------------------------------------- */
.content-result {
  position: relative;
  display: grid;
  align-items: flex-end;
  width: 100%;
  margin-inline: auto;
  padding-block: clamp(11px, 2.2135416667vw, 23px) 11px;
}
.content-result::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 1px;
  background: repeating-linear-gradient(to right, #D8D5D1 0, #D8D5D1 1px, transparent 1px, transparent 3px);
  bottom: 0;
}
.content-result__label {
  position: relative;
  left: clamp(5px, 0.8463541667vw, 8px);
  display: block;
  width: calc(100% - clamp(5px, 0.8463541667vw, 8px) * 2);
  max-width: clamp(160px, 25vw, 224px);
  margin-top: 8px;
  margin-bottom: clamp(1px, 0.4557291667vw, 6px);
  padding-block: 3px;
  text-align: center;
  color: #DD1717;
  font-size: clamp(10px, 1.5625vw, 14px);
  line-height: 1.2;
}
.content-result__label::before, .content-result__label::after {
  content: "";
  position: absolute;
  top: 0;
  width: clamp(28px, 4.9479166667vw, 48px);
  height: 80%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.content-result__label::before {
  left: -2px;
  background-image: url("../assets/results/left.png");
}
.content-result__label::after {
  right: -2px;
  background-image: url("../assets/results/right.png");
}
.content-result__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.content-result__title {
  font-weight: 700;
  line-height: 1.5;
}
.content-result__result {
  flex-shrink: 0;
  font-size: clamp(24px, 3.3854166667vw, 28px);
  font-weight: 700;
  line-height: 1;
}
.content-result__result::after {
  content: attr(after);
  margin-left: clamp(6px, 0.8463541667vw, 7px);
  font-size: clamp(13px, 1.8229166667vw, 15px);
}
.content-result.--emphasis {
  padding-block: 0;
}
.content-result.--emphasis::after {
  display: none;
}
.content-result.--emphasis .content-result__label {
  margin-bottom: 0;
}
.content-result.--emphasis .content-result__title {
  font-family: "Shippori Mincho B1", serif;
}
.content-result.--emphasis .content-result__name {
  display: block;
  font-size: clamp(18px, 3.125vw, 30px);
  line-height: 1.4;
}
.content-result.--emphasis .content-result__grade {
  display: block;
  font-size: clamp(9px, 1.5625vw, 15px);
  line-height: 1.2;
}
.content-result.--emphasis .content-result__result {
  color: #DD6717;
  font-size: clamp(24px, 4.1666666667vw, 40px);
  font-family: "Open Sans", sans-serif;
  line-height: 1.2;
}
.content-result.--emphasis .content-result__result::after {
  margin-left: 0;
  color: #121E2E;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(9px, 1.7578125vw, 18px);
}
.content-result.--emphasis.--sub .content-result__result {
  color: #4E71A6;
}
.content-result.--emphasis.--sub .content-result__result::after {
  color: #121E2E;
}

.title-h1 {
  position: relative;
  z-index: 1;
  margin: 0;
  padding: clamp(40px, 5.859375vw, 50px) clamp(15px, 8.7890625vw, 120px);
  font-size: clamp(20px, 3.3854166667vw, 32px) !important;
  line-height: 1;
  background-color: #EEE;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #FFF calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #FFF calc(100% - 1px));
  background-size: 16px 16px;
  background-repeat: repeat;
  background-position: center center;
  overflow: hidden;
}
.title-h1::before {
  position: absolute;
  content: "";
  z-index: -1;
  left: -30px;
  top: calc(-1 * clamp(30px, 5.859375vw, 60px));
  width: clamp(125px, 19.8567708333vw, 180px);
  height: clamp(125px, 19.8567708333vw, 180px);
  background-color: #DE863F;
  border-radius: 50%;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  box-sizing: border-box;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
       user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__arrow {
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  height: 2em;
  justify-content: center;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2em;
  z-index: 1;
}

.splide__arrow svg {
  fill: #000;
  height: 1.2em;
  width: 1.2em;
}

.splide__arrow:hover:not(:disabled) {
  opacity: 0.9;
}

.splide__arrow:disabled {
  opacity: 0.3;
}

.splide__arrow:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__arrow--prev {
  left: 1em;
}

.splide__arrow--prev svg {
  transform: scaleX(-1);
}

.splide__arrow--next {
  right: 1em;
}

.splide.is-focus-in .splide__arrow:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__pagination {
  bottom: 0.5em;
  left: 0;
  padding: 0 1em;
  position: absolute;
  right: 0;
  z-index: 1;
}

.splide__pagination__page {
  background: #ccc;
  border: 0;
  border-radius: 50%;
  display: inline-block;
  height: 8px;
  margin: 3px;
  opacity: 0.7;
  padding: 0;
  position: relative;
  transition: transform 0.2s linear;
  width: 8px;
}

.splide__pagination__page.is-active {
  background: #fff;
  transform: scale(1.4);
  z-index: 1;
}

.splide__pagination__page:hover {
  cursor: pointer;
  opacity: 0.9;
}

.splide__pagination__page:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__pagination__page:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__progress__bar {
  background: #ccc;
  height: 3px;
}

.splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.splide__slide:focus {
  outline: 0;
}

@supports (outline-offset: -3px) {
  .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }
  .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.splide__toggle {
  cursor: pointer;
}

.splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}

.splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}

.splide__arrows--rtl .splide__arrow--prev {
  left: auto;
  right: 1em;
}

.splide__arrows--rtl .splide__arrow--prev svg {
  transform: scaleX(1);
}

.splide__arrows--rtl .splide__arrow--next {
  left: 1em;
  right: auto;
}

.splide__arrows--rtl .splide__arrow--next svg {
  transform: scaleX(-1);
}

.splide__arrows--ttb .splide__arrow {
  left: 50%;
  transform: translate(-50%);
}

.splide__arrows--ttb .splide__arrow--prev {
  top: 1em;
}

.splide__arrows--ttb .splide__arrow--prev svg {
  transform: rotate(-90deg);
}

.splide__arrows--ttb .splide__arrow--next {
  bottom: 1em;
  top: auto;
}

.splide__arrows--ttb .splide__arrow--next svg {
  transform: rotate(90deg);
}

.splide__pagination--ttb {
  bottom: 0;
  display: flex;
  flex-direction: column;
  left: auto;
  padding: 1em 0;
  right: 0.5em;
  top: 0;
}

.splide__slide {
  max-width: 100%;
  border: 0 !important;
}
.splide__pagination {
  position: relative;
  margin-top: clamp(15px, 2.2786458333vw, 20px);
  -moz-column-gap: 10px;
       column-gap: 10px;
  bottom: 0;
}
.splide__pagination__page {
  background-color: #EBEBEA;
  width: 10px;
  height: 10px;
  opacity: 1;
  margin: 0;
}
.splide__pagination__page.is-active {
  transform: scale(1);
  background-color: #DE863F;
}
.splide__pagination > li {
  line-height: 0;
}
.splide__arrow {
  position: absolute;
  top: 50%;
  width: clamp(30px, 3.90625vw, 45px);
  height: clamp(30px, 3.90625vw, 45px);
  background-color: white;
  border: 1px solid #DE863F;
  opacity: 1;
}
.splide__arrow svg {
  display: none;
}
.splide__arrow::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 15px;
  height: 9px;
  background-image: url(../assets/icon/arrow-r-main.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.splide__arrow--prev {
  transform: translateY(-50%) translateX(-60%);
}
@media screen and (min-width: 1300px) {
  .splide__arrow--prev {
    left: 0;
    transform: translateY(-50%) translateX(-50%);
  }
}
.splide__arrow--prev::after {
  transform: rotate(180deg);
}
.splide__arrow--next {
  transform: translateY(-50%) translateX(60%);
}
@media screen and (min-width: 1300px) {
  .splide__arrow--next {
    right: 0;
    transform: translateY(-50%) translateX(50%);
  }
}

/* -------------------------------------------------------------------
  btn
------------------------------------------------------------------- */
.lp-fv {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 1000px;
  color: #263D60;
  margin-bottom: 72px;
  font-family: "Noto Sans JP", sans-serif;
  background-image: url(../assets/lp/summer/bg.svg), url(../assets/lp/summer/bg-2.png);
  background-repeat: no-repeat;
  background-size: 1920px 540px, 1920px 1000px;
  background-position: left bottom 240px, left bottom;
}
@media screen and (min-width: 1920px) {
  .lp-fv {
    background-size: 1920px 540px, cover;
    background-position: left bottom 240px, center;
  }
}
@media screen and (min-width: 768px) and (max-width: 1320px) {
  .lp-fv {
    background-position: left bottom 240px, left top;
  }
}
@media screen and (min-width: 767px) and (max-width: 1079px) {
  .lp-fv {
    height: 1120px;
  }
}
@media screen and (max-width: 767px) {
  .lp-fv {
    height: calc(clamp(480px, 96.3541666667vw, 1000px) + 280px);
    background-image: linear-gradient(to bottom, #B1E8F6, #3EA7D7);
    background-size: cover;
    background-position: center;
  }
}
.lp-fv__main {
  position: relative;
  max-width: 1500px;
  margin: auto;
  height: 760px;
  overflow: hidden;
}
@media screen and (min-width: 767px) and (max-width: 1079px) {
  .lp-fv__main {
    height: 840px;
  }
}
@media screen and (max-width: 767px) {
  .lp-fv__main {
    height: clamp(480px, 96.3541666667vw, 1000px);
    background-image: url(../assets/lp/summer/bg-sp.svg);
    background-repeat: no-repeat;
    background-size: auto 300px;
    background-position: left bottom;
  }
}
.lp-fv__main::before {
  position: absolute;
  content: "";
  z-index: -2;
  right: calc(-1 * clamp(50px, 9.765625vw, 100px));
  bottom: calc(-1 * clamp(50px, 9.765625vw, 100px));
  width: clamp(360px, 65.1041666667vw, 640px);
  height: clamp(360px, 65.1041666667vw, 640px);
  background-image: url(../assets/lp/summer/fv-image-3.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-fv__main::before {
    z-index: 1;
  }
}
.lp-fv__main--image-01 {
  position: absolute;
  right: 0;
  top: 0;
  display: block;
  width: auto;
  height: clamp(60px, 13.28125vw, 144px);
}
@media screen and (min-width: 1320px) and (max-width: 1499px) {
  .lp-fv__main--image-01 {
    right: calc(100vw - 1480px);
  }
}
@media screen and (max-width: 767px) {
  .lp-fv__main--image-01 {
    position: relative;
    margin: auto;
  }
}
.lp-fv__main--image-02 {
  position: absolute;
  left: 0;
  top: 72px;
  display: block;
  width: auto;
  height: clamp(100px, 23.1770833333vw, 256px);
}
@media screen and (max-width: 1320px) {
  .lp-fv__main--image-02 {
    top: 132px;
    height: 192px;
  }
}
@media screen and (max-width: 767px) {
  .lp-fv__main--image-02 {
    position: relative;
    top: 0;
    width: 100%;
    height: auto;
    margin: 8px auto 0;
  }
}
.lp-fv__main--text {
  position: absolute;
  left: 80px;
  bottom: 70px;
  transform-origin: left bottom;
  transform: rotate(-4deg);
}
@media screen and (max-width: 767px) {
  .lp-fv__main--text {
    display: flex;
    flex-direction: row-reverse;
    gap: clamp(10px, 1.6276041667vw, 15px);
    left: 0;
    bottom: 20px;
    transform: rotate(0deg);
  }
}
.lp-fv__main--text span {
  display: block;
  color: #FFF;
  font-size: clamp(30px, 6.640625vw, 72px);
  font-weight: 900;
  line-height: 1.25;
  filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.25));
}
@media screen and (max-width: 767px) {
  .lp-fv__main--text span {
    display: inline-flex;
    align-items: center;
    justify-content: start;
    line-height: 1;
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-size: 36px;
    letter-spacing: -0.1em;
  }
}
.lp-fv__main--text span strong {
  padding-left: 0.75em;
  font-size: 2.25em;
}
@media screen and (max-width: 767px) {
  .lp-fv__main--text span strong {
    font-size: 48px;
    letter-spacing: 0;
  }
}
.lp-fv__main--text span .pointer {
  display: inline;
}
@media screen and (max-width: 767px) {
  .lp-fv__main--text span .pointer {
    letter-spacing: -0.5em;
  }
}
.lp-fv__main--badge {
  position: absolute;
  left: 720px;
  right: 0;
  bottom: 60px;
  display: inline-block;
  width: clamp(140px, 30.9895833333vw, 336px);
  margin: auto;
  padding: clamp(2px, 0.6510416667vw, 8px) 0;
  color: white;
  font-size: clamp(14px, 3.2552083333vw, 36px);
  line-height: 1;
  background-color: #006CAA;
  border-radius: 50px;
  text-align: center;
}
@media screen and (max-width: 1119px) {
  .lp-fv__main--badge {
    right: 200px;
    left: auto;
    bottom: 40px;
    margin: 0;
  }
}
@media screen and (max-width: 767px) {
  .lp-fv__main--badge {
    z-index: 2;
    right: 20px;
    bottom: 20px;
  }
}
.lp-fv__cta {
  position: relative;
  z-index: 1;
  width: calc(100% - 64px);
  max-width: 900px;
  margin: -20px auto 0;
  padding: clamp(20px, 3.90625vw, 40px) 0;
  background-color: #FFF;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .lp-fv__cta {
    margin-top: 40px;
  }
}
.lp-fv__cta--wrapper {
  position: relative;
  z-index: -2;
  height: 280px;
}
.lp-fv__cta--wrapper::before {
  position: absolute;
  content: "";
  z-index: -1;
  width: 100%;
  height: calc(100% - 35px);
  background: linear-gradient(to bottom, #A8DBEF, #B9E5F5);
  filter: blur(24px);
}
.lp-fv__cta--wrapper::after {
  position: absolute;
  content: "";
  z-index: -1;
  left: 0;
  bottom: -55px;
  width: 100%;
  height: 110px;
  background: linear-gradient(to bottom, #BFE8F7, #FFF);
}
.lp-fv__cta__inner {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 80px;
  align-items: center;
  max-width: 760px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .lp-fv__cta__inner {
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
  }
}
.lp-fv__cta__inner--buttons {
  display: grid;
  gap: 15px;
  width: 280px;
}
@media screen and (max-width: 767px) {
  .lp-fv__cta__inner--buttons {
    margin: auto;
  }
}
.lp-fv__cta__inner--buttons__item {
  display: block;
  text-align: center;
  padding: 12px 0;
  font-size: 24px;
  line-height: 1.25;
  color: #FFF;
  border-radius: 36px;
  text-decoration: none;
}
.lp-fv__cta__inner--buttons__item small {
  font-size: 14px;
}
.lp-fv__cta__inner--buttons__item.--request {
  background: linear-gradient(to right, #026DAB, #42ABE8);
  border: 2px solid #006CAA;
  color: #FFF;
}
.lp-fv__cta__inner--buttons__item.--entry {
  background: #FFE427;
  border: 2px solid #EBCE09;
  color: #024A73;
}
.lp-fv__cta__inner--tel {
  position: relative;
  padding-left: 40px;
}
@media screen and (max-width: 767px) {
  .lp-fv__cta__inner--tel {
    margin: auto;
  }
}
.lp-fv__cta__inner--tel::before {
  position: absolute;
  content: "";
  left: 0;
  top: 8px;
  width: clamp(24px, 3.6458333333vw, 32px);
  height: clamp(24px, 3.6458333333vw, 32px);
  background-image: url(../assets/lp/summer/tel.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-fv__cta__inner--tel::before {
    top: 0;
  }
}
.lp-fv__cta__inner--tel--number {
  font-size: clamp(24px, 4.6875vw, 48px);
  line-height: 1;
  color: #006CAA;
  font-weight: 700;
  font-family: "Open Sans", sans-serif;
}
.lp-fv__cta__inner--tel--note {
  margin-top: 8px;
  font-size: clamp(10px, 1.5625vw, 14px);
  line-height: 1.2;
  color: #006CAA;
}

.lp-summer {
  position: relative;
  z-index: 2;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 767px) {
  .lp-summer {
    margin-top: 96px;
  }
}
.lp-summer__title {
  width: clamp(300px, 50.78125vw, 480px);
  margin: auto;
  font-size: clamp(20px, 3.3854166667vw, 32px);
  font-weight: 700;
}
.lp-summer__title span.--bigger {
  font-size: clamp(30px, 4.5572916667vw, 40px);
}
.lp-summer__title span.--blue {
  color: #006CAA;
}
.lp-summer__title span.--marker {
  background-color: #FFE427;
}
.lp-summer__text {
  margin-top: clamp(10px, 2.6041666667vw, 30px);
  font-size: clamp(14px, 2.2135416667vw, 20px);
  text-align: center;
}
.lp-summer__presents {
  position: relative;
  padding-top: 420px;
}
@media screen and (max-width: 767px) {
  .lp-summer__presents {
    padding-top: 120px;
  }
}
.lp-summer__presents--title {
  position: absolute;
  left: 0;
  right: 0;
  top: 380px;
  width: 464px;
  height: 78px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .lp-summer__presents--title {
    top: 80px;
    width: 355px;
    height: 78px;
  }
}
.lp-summer__presents::before {
  position: absolute;
  content: "";
  z-index: -1;
  left: 0;
  top: -160px;
  width: 100%;
  height: 850px;
  background-image: url(../assets/lp/summer/present-bg.png);
  background-repeat: no-repeat;
  background-size: 1920px 850px;
  background-position: left calc(50vw - 960px) center;
}
@media screen and (max-width: 767px) {
  .lp-summer__presents::before {
    top: -80px;
    height: 57vw;
    background-size: 128vw 57vw;
    background-position: left -14vw center;
  }
}
.lp-summer__presents--blocks {
  display: flex;
  gap: 60px;
  align-items: stretch;
  justify-content: center;
  max-width: 1080px;
  margin: auto;
  padding: clamp(25px, 6.8359375vw, 80px) 0;
  background-color: #CCE2EE;
}
@media screen and (max-width: 767px) {
  .lp-summer__presents--blocks {
    display: grid;
    gap: 20px;
    padding-top: 60px;
  }
}
.lp-summer__presents--blocks__item {
  width: 100%;
  max-width: 400px;
}
.lp-summer__presents--blocks__item--title {
  display: block;
  width: 60px;
  height: 30px;
  margin: auto;
}
.lp-summer__presents--blocks__item--box {
  padding: 20px 70px;
  background-color: #FFF;
  border-radius: 5px;
  box-sizing: border-box;
  border: 2px solid #006CAA;
}
@media screen and (max-width: 767px) {
  .lp-summer__presents--blocks__item--box {
    padding: 20px 25px;
  }
}
.lp-summer__presents--blocks__item--box--title {
  margin-bottom: 16px;
  font-size: 18px;
  text-align: center;
  text-decoration: underline;
}
.lp-summer__presents--blocks__item--box--text {
  font-weight: 700;
}
.lp-summer__presents--blocks__item--box--text.--size-01 {
  margin-bottom: 0;
  font-size: clamp(24px, 3.3854166667vw, 28px);
  line-height: 1.2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .lp-summer__presents--blocks__item--box--text.--size-01 {
    text-align: left;
  }
}
.lp-summer__presents--blocks__item--box--text.--size-02 {
  font-size: clamp(40px, 5.5989583333vw, 46px);
  line-height: 1.2;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .lp-summer__presents--blocks__item--box--text.--size-02 {
    margin-top: 24px;
  }
}
.lp-summer__presents--blocks__item--box--text.--size-03 {
  margin-bottom: 0;
  font-size: 12px;
}
.lp-summer__presents--blocks__item--box--text.--size-03 strong {
  font-size: 18px;
}
.lp-summer__presents--blocks__item--box--text.--size-04 {
  margin-bottom: 8px;
  text-align: right;
  font-size: 16px;
  line-height: 1;
}
.lp-summer__presents--blocks__item--box--text.--size-04 strong {
  font-size: 32px;
  line-height: 1;
}
.lp-summer__presents--blocks__item--box--text.--marker span {
  display: inline-block;
  background-color: #FFE427;
}
.lp-summer__presents--blocks__item--box--note {
  margin-top: 16px;
  font-size: 10px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .lp-summer__presents--blocks__item--box--note.--mt-long {
    margin-top: 30px;
  }
}
@media screen and (max-width: 767px) {
  .lp-summer__presents--blocks__item .--sp-flex {
    display: flex;
    align-items: flex-end;
    gap: 12px;
  }
}

.lp-innerLinks {
  max-width: 960px;
  margin: clamp(32px, 4.6875vw, 40px) auto clamp(40px, 7.8125vw, 80px);
  font-family: "Noto Sans JP", sans-serif;
}
.lp-innerLinks__title {
  margin-bottom: 6px;
  font-size: clamp(14px, 2.2135416667vw, 20px);
  font-weight: 700;
  text-align: center;
}
.lp-innerLinks__description {
  margin-bottom: clamp(16px, 2.34375vw, 20px);
  font-size: clamp(10px, 1.6927083333vw, 16px);
  font-weight: 400;
  text-align: center;
}
.lp-innerLinks__buttons {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
@media screen and (max-width: 767px) {
  .lp-innerLinks__buttons {
    width: 334px;
    gap: 5px;
    margin: auto;
  }
}
.lp-innerLinks__buttons__item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 108px;
  padding-bottom: 20px;
  font-size: 28px;
  font-weight: 900;
  color: #FFF;
  border-radius: 54px;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .lp-innerLinks__buttons__item {
    padding-bottom: 8px;
    font-size: 20px;
    border-radius: 50%;
  }
}
.lp-innerLinks__buttons__item.--grade-1 {
  background-color: #63A4DC;
}
.lp-innerLinks__buttons__item.--grade-2 {
  background-color: #DD6717;
}
.lp-innerLinks__buttons__item.--grade-3 {
  background-color: #7BAA7C;
}
.lp-innerLinks__buttons__item::before {
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: 20px;
  width: 28px;
  height: 18px;
  margin: auto;
  background-color: #FFF;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
          clip-path: polygon(0 0, 50% 100%, 100% 0);
}
@media screen and (max-width: 767px) {
  .lp-innerLinks__buttons__item::before {
    bottom: 18px;
    width: 22px;
    height: 12px;
  }
}
.lp-innerLinks__buttons__item::after {
  position: absolute;
  content: "";
  left: 6px;
  top: 6px;
  width: calc(100% - 12px);
  height: calc(100% - 12px);
  border: 1px solid #FFF;
  border-radius: 52px;
}

.lp-results {
  width: 100%;
  height: 960px;
  padding-top: 100px;
  background-image: url(../assets/lp/summer/results-bg.jpg);
  background-repeat: no-repeat;
  background-size: 1920px 960px;
  background-position: left calc(50vw - 960px) center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .lp-results {
    height: auto;
    padding-bottom: 30px;
    background-size: cover;
    background-position: center;
  }
}
.lp-results__contents {
  position: relative;
  width: calc(100% - 30px);
  max-width: 1080px;
  margin: auto;
  padding: 100px 0 80px;
  background-color: #FFF;
}
@media screen and (max-width: 767px) {
  .lp-results__contents {
    padding: 140px 0 40px;
  }
}
.lp-results__contents--head {
  position: absolute;
  left: -118px;
  top: -40px;
}
@media screen and (max-width: 1319px) {
  .lp-results__contents--head {
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .lp-results__contents--head {
    left: -8px;
    top: -35px;
  }
}
.lp-results__contents--head--sub {
  color: #FFF;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 10px;
}
.lp-results__contents--head--main {
  font-size: 36px;
  color: #FFF;
}
@media screen and (max-width: 1319px) {
  .lp-results__contents--head--main {
    left: -16px;
    font-size: 28px;
  }
}
@media screen and (max-width: 767px) {
  .lp-results__contents--head--main {
    display: grid;
    gap: 8px;
    font-size: clamp(24px, 3.90625vw, 36px);
  }
}
.lp-results__contents--head--main span {
  display: inline-block;
  padding: 4px 0 8px;
  background-color: #006CAA;
  line-height: 1;
}
.lp-results__contents--head--main span:nth-child(1) {
  padding-left: 8px;
}
@media screen and (max-width: 767px) {
  .lp-results__contents--head--main span:nth-child(1) {
    padding-right: 8px;
  }
}
.lp-results__contents--head--main span:nth-child(2) {
  padding-right: 8px;
}
@media screen and (max-width: 767px) {
  .lp-results__contents--head--main span:nth-child(2) {
    padding-left: 8px;
  }
}
.lp-results__contents--head--main span strong {
  font-size: 64px;
}
@media screen and (max-width: 1319px) {
  .lp-results__contents--head--main span strong {
    font-size: 48px;
  }
}
@media screen and (max-width: 767px) {
  .lp-results__contents--head--main span strong {
    font-size: clamp(42px, 6.9010416667vw, 64px);
  }
}
.lp-results__contents__item {
  width: 400px;
}
@media screen and (max-width: 767px) {
  .lp-results__contents__item {
    width: calc(100% - 50px);
    margin: auto;
  }
  .lp-results__contents__item:not(:last-child) {
    margin-bottom: 30px;
  }
}
.lp-results__contents__item--wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
}
@media screen and (max-width: 767px) {
  .lp-results__contents__item--wrapper {
    display: block;
  }
}
.lp-results__contents__item--head {
  height: 176px;
  padding-left: 10px;
  padding-top: 10px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-results__contents__item--head span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  padding: 6px 4px;
  background-color: #FFF;
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: 0.15em;
  box-sizing: border-box;
  border: 1px solid #263D60;
}
.lp-results__contents__item--head.--head-1 {
  background-image: url(../assets/lp/summer/results-head-1.jpg);
}
@media screen and (max-width: 767px) {
  .lp-results__contents__item--head.--head-1 {
    position: relative;
    left: 50px;
  }
  .lp-results__contents__item--head.--head-1 span {
    position: absolute;
    left: -20px;
    top: 10px;
  }
}
.lp-results__contents__item--head.--head-2 {
  background-image: url(../assets/lp/summer/results-head-2.jpg);
}
@media screen and (max-width: 767px) {
  .lp-results__contents__item--head.--head-2 {
    position: relative;
    right: 50px;
  }
  .lp-results__contents__item--head.--head-2 span {
    position: absolute;
    right: -20px;
    top: 10px;
  }
}
.lp-results__contents__item--data {
  margin-bottom: 30px;
  background-color: #EFF5F7;
}
.lp-results__contents__item--data__block {
  padding: 8px 24px;
  border-bottom: 1px solid #263D60;
}
.lp-results__contents__item--data__block--note {
  line-height: 1;
}
.lp-results__contents__item--data__block--note span {
  display: inline-block;
  font-size: 10px;
  line-height: 12px;
  padding: 0 6px;
  background-color: #FFF;
  border-radius: 10px;
}
.lp-results__contents__item--data__block--main {
  display: flex;
  align-items: flex-end;
  margin-top: 5px;
}
.lp-results__contents__item--data__block--main span.--school-name {
  font-size: 36px;
  line-height: 1;
}
.lp-results__contents__item--data__block--main span.--school-unit {
  margin-left: 5px;
}
.lp-results__contents__item--data__block--main span.--school-unit span {
  display: block;
  line-height: 18px;
}
.lp-results__contents__item--data__block--main span.--person-number {
  margin-left: auto;
  font-size: 30px;
  line-height: 1;
}
.lp-results__contents__item--data__block--main span.--person-unit {
  margin-left: 8px;
  font-size: 14px;
  line-height: 1;
}
.lp-results__contents__item--footer {
  display: flex;
  align-items: center;
}
.lp-results__contents__item--footer--caption {
  line-height: 1.2;
}
.lp-results__contents__item--footer--link {
  position: relative;
  display: flex;
  align-items: center;
  width: 155px;
  height: 50px;
  margin-left: auto;
  padding-left: 20px;
  color: #FFF;
  line-height: 1.2;
  background-color: #DE863F;
  border-radius: 28px;
  text-decoration: none;
  filter: drop-shadow(0 3px 0 #C47638);
}
.lp-results__contents__item--footer--link::before {
  position: absolute;
  content: "→";
  right: 12px;
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: right;
  width: 24px;
  height: 24px;
  margin: auto;
  color: white;
  font-size: 15px;
}

.lp-points {
  font-family: "Noto Sans JP", sans-serif;
  color: #263D60;
}
.lp-points__head {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 333px;
  margin-bottom: 20px;
  background-image: url(../assets/lp/summer/points-bg.svg);
  background-repeat: no-repeat;
  background-size: 1920px 333px;
  background-position: left calc(50vw - 960px) center;
}
@media screen and (max-width: 767px) {
  .lp-points__head {
    height: 182px;
    padding-bottom: 20px;
    background-image: url(../assets/lp/summer/points-bg-sp.svg);
    background-image: contain;
    background-position: center bottom;
  }
}
.lp-points__head-text {
  color: #FFF;
  text-align: center;
}
.lp-points__head-text span {
  display: block;
  line-height: 1.2;
}
.lp-points__head-text span.--line-1 {
  font-size: 26px;
}
@media screen and (max-width: 767px) {
  .lp-points__head-text span.--line-1 {
    font-size: clamp(16px, 2.734375vw, 26px);
  }
}
.lp-points__head-text span.--line-1 strong {
  font-size: 34px;
}
@media screen and (max-width: 767px) {
  .lp-points__head-text span.--line-1 strong {
    font-size: clamp(24px, 3.7760416667vw, 34px);
  }
}
.lp-points__head-text span.--line-2 {
  font-size: 42px;
}
@media screen and (max-width: 767px) {
  .lp-points__head-text span.--line-2 {
    font-size: clamp(32px, 4.8177083333vw, 42px);
  }
}
.lp-points__head-text span.--line-2 strong {
  font-size: 58px;
}
@media screen and (max-width: 767px) {
  .lp-points__head-text span.--line-2 strong {
    font-size: clamp(48px, 6.9010416667vw, 58px);
  }
}
.lp-points__head-text span.--line-3 {
  font-size: 34px;
}
@media screen and (max-width: 767px) {
  .lp-points__head-text span.--line-3 {
    font-size: clamp(24px, 3.7760416667vw, 34px);
  }
}
.lp-points__contents {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: calc(100% - 80px);
  max-width: 1320px;
  margin: 0 auto clamp(30px, 7.1614583333vw, 80px);
}
@media screen and (max-width: 1199px) {
  .lp-points__contents {
    grid-template-columns: repeat(2, 1fr);
    max-width: 840px;
  }
}
@media screen and (max-width: 767px) {
  .lp-points__contents {
    grid-template-columns: repeat(1, 1fr);
  }
}
.lp-points__contents__item {
  position: relative;
}
@media screen and (max-width: 767px) {
  .lp-points__contents__item {
    padding-top: 50px;
  }
}
@media screen and (max-width: 767px) {
  .lp-points__contents__item:nth-child(2)::before, .lp-points__contents__item:nth-child(4)::before {
    position: absolute;
    content: "";
    z-index: -1;
    left: -40px;
    top: 0;
    width: calc(100% + 80px);
    height: 100%;
    background-color: #F7F5ED;
  }
}
@media screen and (max-width: 767px) {
  .lp-points__contents__item:nth-child(4) {
    padding-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .lp-points__contents__item .--bg01 {
    position: absolute;
    content: "";
    z-index: 2;
    left: -40px;
    top: 0;
    width: calc(100% + 80px);
    height: 40px;
    background-color: #FFF;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
  }
  .lp-points__contents__item .--bg02 {
    position: absolute;
    content: "";
    z-index: 2;
    left: -40px;
    bottom: -40px;
    width: calc(100% + 80px);
    height: 40px;
    background-color: #F7F5ED;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
  }
}
.lp-points__contents__item--head {
  position: relative;
  margin-bottom: 10px;
  padding: 30px 30px 0;
}
@media screen and (max-width: 767px) {
  .lp-points__contents__item--head {
    max-width: 420px;
    margin: 0 auto 10px;
  }
}
.lp-points__contents__item--head-img {
  width: 100%;
  height: auto;
}
.lp-points__contents__item--head-text {
  position: absolute;
  z-index: -1;
  right: 0;
  top: -20px;
  font-size: 120px;
  line-height: 1;
  color: #263D60;
  font-weight: 700;
  opacity: 0.3;
}
.lp-points__contents__item--concept {
  font-size: 18px;
  font-weight: 900;
}
.lp-points__contents__item--detail {
  font-size: 14px;
}

.lp-feature {
  font-family: "Noto Sans JP", sans-serif;
  margin-bottom: clamp(48px, 8.984375vw, 90px);
  color: #263D60;
}
.lp-feature__title {
  text-align: center;
  margin-bottom: clamp(12px, 3.3854166667vw, 40px);
}
.lp-feature__title--sub {
  display: block;
  width: 360px;
  margin: 0 auto 10px;
  padding: 6px 12px;
  font-size: 26px;
  line-height: 33px;
  text-align: center;
  color: #FFF;
  background-color: #263D60;
  border-radius: 30px;
}
.lp-feature__title--sub strong {
  font-size: 30px;
}
.lp-feature__title--main {
  position: relative;
  display: block;
  width: clamp(120px, 26.5625vw, 288px);
  margin: auto;
  font-size: clamp(48px, 10.9375vw, 120px);
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: clamp(4.8px, 1.09375vw, 12px);
  color: #FFE427;
  text-align: center;
  border-bottom: 2px solid #263D60;
  -webkit-text-fill-color: #FFE427;
  -webkit-text-stroke: 3px #263D60;
  paint-order: stroke;
}
.lp-feature__title--main::before {
  position: absolute;
  content: "";
  right: calc(-1 * clamp(36px, 6.25vw, 60px));
  bottom: 0;
  width: clamp(36px, 6.25vw, 60px);
  height: clamp(36px, 6.25vw, 60px);
  background-image: url(../assets/lp/summer/pencil.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-feature__blocks {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 40px;
  width: calc(100% - 30px);
  max-width: 1220px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks {
    gap: 0;
  }
}
.lp-feature__blocks__item {
  position: relative;
  padding: 48px clamp(15px, 5.4036458333vw, 68px) clamp(15px, 3.5807291667vw, 40px);
  border-radius: 30px;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item {
    background: none !important;
    box-sizing: border-box;
    border: 3px solid #263D60;
    border-radius: 0;
  }
  .lp-feature__blocks__item:nth-child(1)::before {
    position: absolute;
    content: "";
    left: -18px;
    top: -18px;
    width: 15px;
    height: 15px;
    border-right: 3px solid #263D60;
    border-bottom: 3px solid #263D60;
  }
  .lp-feature__blocks__item:nth-child(1)::after {
    position: absolute;
    content: "";
    right: -18px;
    top: -18px;
    width: 15px;
    height: 15px;
    border-left: 3px solid #263D60;
    border-bottom: 3px solid #263D60;
  }
  .lp-feature__blocks__item:nth-child(2) {
    border-top: none;
  }
  .lp-feature__blocks__item:nth-child(2)::before {
    position: absolute;
    content: "";
    left: -18px;
    top: -3px;
    width: 15px;
    height: 100%;
    border-top: 3px solid #263D60;
    border-bottom: 3px solid #263D60;
  }
  .lp-feature__blocks__item:nth-child(2)::after {
    position: absolute;
    content: "";
    right: -18px;
    top: -3px;
    width: 15px;
    height: 100%;
    border-top: 3px solid #263D60;
    border-bottom: 3px solid #263D60;
  }
  .lp-feature__blocks__item:nth-child(3) {
    border-top: none;
  }
  .lp-feature__blocks__item:nth-child(3)::before {
    position: absolute;
    content: "";
    left: -18px;
    bottom: -18px;
    width: 15px;
    height: 15px;
    border-right: 3px solid #263D60;
    border-top: 3px solid #263D60;
  }
  .lp-feature__blocks__item:nth-child(3)::after {
    position: absolute;
    content: "";
    right: -18px;
    bottom: -18px;
    width: 15px;
    height: 15px;
    border-left: 3px solid #263D60;
    border-top: 3px solid #263D60;
  }
}
.lp-feature__blocks__item.--grade-1 {
  background-color: #EFF6FB;
}
.lp-feature__blocks__item.--grade-1 .--title span:nth-child(1) {
  background-color: #63A4DC;
}
.lp-feature__blocks__item.--grade-1 .--title span:nth-child(2) {
  color: #63A4DC;
}
.lp-feature__blocks__item.--grade-1 .--message {
  color: #63A4DC;
}
.lp-feature__blocks__item.--grade-1 .--image {
  position: absolute;
  right: clamp(15px, 5.4036458333vw, 68px);
  top: 0;
  width: clamp(200px, 32.421875vw, 298px);
  height: clamp(156px, 21.2890625vw, 171px);
  background-image: url(../assets/lp/summer/feature-image-1.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item.--grade-1 .--image {
    right: 0;
    background-size: auto 100%;
    background-position: left top;
  }
}
.lp-feature__blocks__item.--grade-2 {
  background-color: #FCF0E8;
}
.lp-feature__blocks__item.--grade-2 .--title {
  justify-content: right;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item.--grade-2 .--title {
    display: block;
    width: clamp(126px, 17.96875vw, 150px);
    margin-left: auto;
    text-align: left !important;
  }
}
.lp-feature__blocks__item.--grade-2 .--title span:nth-child(1) {
  background-color: #DD6717;
}
.lp-feature__blocks__item.--grade-2 .--title span:nth-child(2) {
  color: #DD6717;
}
.lp-feature__blocks__item.--grade-2 .--message {
  color: #DD6717;
}
.lp-feature__blocks__item.--grade-2 .--image {
  position: absolute;
  left: clamp(15px, 5.4036458333vw, 68px);
  top: 0;
  width: clamp(180px, 31.1197916667vw, 298px);
  height: clamp(138px, 20.1171875vw, 171px);
  background-image: url(../assets/lp/summer/feature-image-2.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item.--grade-2 .--image {
    left: 0;
    background-size: auto 100%;
    background-position: right top;
  }
}
.lp-feature__blocks__item.--grade-3 {
  background-color: #F2F6F2;
}
.lp-feature__blocks__item.--grade-3 .--title span:nth-child(1) {
  background-color: #7BAA7C;
}
.lp-feature__blocks__item.--grade-3 .--title span:nth-child(2) {
  color: #7BAA7C;
}
.lp-feature__blocks__item.--grade-3 .--message {
  color: #7BAA7C;
}
.lp-feature__blocks__item.--grade-3 .--image {
  position: absolute;
  right: clamp(15px, 5.4036458333vw, 68px);
  top: 0;
  width: clamp(200px, 32.421875vw, 298px);
  height: clamp(156px, 21.2890625vw, 171px);
  background-image: url(../assets/lp/summer/feature-image-3.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item.--grade-3 .--image {
    right: 0;
    background-size: auto 100%;
    background-position: left top;
  }
}
.lp-feature__blocks__item-title {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  margin-bottom: clamp(60px, 9.1145833333vw, 80px);
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item-title {
    display: inline-block;
  }
}
.lp-feature__blocks__item-title span:nth-child(1) {
  padding: 2px 10px;
  font-size: clamp(36px, 5.3385416667vw, 46px);
  line-height: 1.2;
  color: #FFF;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item-title span:nth-child(1) {
    display: block;
  }
}
.lp-feature__blocks__item-title span:nth-child(2) {
  font-size: clamp(22px, 3.515625vw, 32px);
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item-title span:nth-child(2) {
    display: block;
    text-align: right;
  }
}
.lp-feature__blocks__item-subTitle {
  margin-bottom: 10px;
  font-size: clamp(16px, 2.34375vw, 20px);
  font-weight: 700;
}
.lp-feature__blocks__item-text {
  margin-bottom: 40px;
  font-size: clamp(14px, 1.953125vw, 16px);
  line-height: 1.3;
}
.lp-feature__blocks__item-message {
  margin-bottom: 40px;
  font-size: clamp(16px, 2.34375vw, 20px);
  font-weight: 700;
}
.lp-feature__blocks__item-classification {
  margin-bottom: 14px;
}
.lp-feature__blocks__item-classification span {
  padding: 0 8px 4px;
  font-size: 16px;
  border-bottom: 5px solid #263D60;
}
.lp-feature__blocks__item-classification span strong {
  font-size: 1.25em;
}
.lp-feature__blocks__item--detail {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px 60px;
  max-width: 860px;
  margin: 40px auto;
}
@media screen and (max-width: 1079px) {
  .lp-feature__blocks__item--detail {
    gap: 30px;
  }
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item--detail {
    grid-template-columns: repeat(1, 1fr);
    transition: all 0.8s;
  }
  .lp-feature__blocks__item--detail.open {
    display: grid;
  }
}
.lp-feature__blocks__item--detail:last-child {
  margin-bottom: 0;
}
.lp-feature__blocks__item--detail.--flex-center {
  display: flex;
  justify-content: center;
}
.lp-feature__blocks__item--detail.--flex-center .lp-feature__blocks__item--detail__item {
  width: calc(50% - 30px);
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item--detail.--flex-center .lp-feature__blocks__item--detail__item {
    width: 100%;
  }
}
.lp-feature__blocks__item--detail__item {
  overflow: hidden;
  position: relative;
}
.lp-feature__blocks__item--detail__item--head {
  position: relative;
  height: 70px;
  padding: 2px 0 8px;
  background-color: #FFF;
  box-sizing: border-box;
  border-top: 6px solid;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}
.lp-feature__blocks__item--detail__item--head.--grade-1 {
  border-color: #63A4DC;
  color: #63A4DC;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item--detail__item--head.--grade-1 {
    background-color: #EFF6FB;
  }
}
.lp-feature__blocks__item--detail__item--head.--grade-1 .--name {
  background-color: #63A4DC;
}
.lp-feature__blocks__item--detail__item--head.--grade-2 {
  border-color: #DD6717;
  color: #DD6717;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item--detail__item--head.--grade-2 {
    background-color: #FCF0E8;
  }
}
.lp-feature__blocks__item--detail__item--head.--grade-2 .--name {
  background-color: #DD6717;
}
.lp-feature__blocks__item--detail__item--head.--grade-3 {
  border-color: #DD9817;
  color: #DD9817;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item--detail__item--head.--grade-3 {
    background-color: rgba(221, 152, 23, 0.1);
  }
}
.lp-feature__blocks__item--detail__item--head.--grade-3 .--name {
  background-color: #DD9817;
}
.lp-feature__blocks__item--detail__item--head.--grade-4 {
  border-color: #7BAA7C;
  color: #7BAA7C;
}
@media screen and (max-width: 767px) {
  .lp-feature__blocks__item--detail__item--head.--grade-4 {
    background-color: rgba(123, 170, 124, 0.1);
  }
}
.lp-feature__blocks__item--detail__item--head.--grade-4 .--name {
  background-color: #7BAA7C;
}
.lp-feature__blocks__item--detail__item--head::before {
  position: absolute;
  content: "";
  top: 24px;
  right: clamp(8px, 2.0833333333vw, 24px);
  width: 9px;
  height: 9px;
  border-left: 2px solid #000;
  border-bottom: 2px solid #000;
  transform: rotate(-45deg);
  transition: all 0.8s;
}
.lp-feature__blocks__item--detail__item--head.active::before {
  transform: rotate(-225deg);
}
.lp-feature__blocks__item--detail__item--head--info {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-bottom: 2px;
}
.lp-feature__blocks__item--detail__item--head--text {
  font-size: clamp(10px, 1.4322916667vw, 12px);
  font-weight: 700;
}
.lp-feature__blocks__item--detail__item--head--tags {
  display: flex;
  gap: 4px;
}
.lp-feature__blocks__item--detail__item--head--tags span {
  font-size: 10px;
  line-height: 1;
  font-weight: 700;
  padding: 2px 4px;
  border: 1px solid;
  border-radius: 10px;
}
.lp-feature__blocks__item--detail__item--head--name {
  width: clamp(240px, 32.5520833333vw, 260px);
  margin: auto;
  font-size: 18px;
  color: #FFF;
  font-weight: 700;
  text-align: center;
}
.lp-feature__blocks__item--detail__item--content {
  height: 0;
  padding: 0 14px;
  background-color: #FFF;
  transition: all 0.8s;
  overflow: hidden;
  filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.25));
}
.lp-feature__blocks__item--detail__item--content.open {
  padding: 20px 14px;
}
.lp-feature__blocks__item--detail__item--content-text {
  letter-spacing: 0.5px;
}
.lp-feature__blocks__item--detail__item--content-description {
  padding: 4px;
  border-bottom: 3px solid;
  line-height: 1.3;
}
.lp-feature__blocks__item--detail__item--content-description strong {
  display: inline-block;
  margin-right: 12px;
}
.lp-feature__blocks__item--detail__item--content-description.--grade-2 {
  background-color: #FCF0E8;
  border-color: #DD6717;
}
.lp-feature__blocks__item--detail__item--content-description.--grade-3 {
  background-color: #FCF5E8;
  border-color: #E9BE6E;
}
.lp-feature__blocks__item--detail__item--content-description.--grade-4 {
  background-color: #F2F6F2;
  border-color: #7BAA7C;
}
.lp-feature__blocks__item--detail__item--content-list {
  display: flex;
  align-items: start;
  font-weight: 500;
}
.lp-feature__blocks__item--detail__item--content-list dt {
  padding: 0 4px;
  background-color: #D9D9D9;
  flex-shrink: 0;
}
.lp-feature__blocks__item--detail__item--content-list dd {
  margin-left: 10px;
}
.lp-feature__blocks__item--detail__item--content-list dd small {
  font-size: 0.75em;
}
.lp-feature__blocks__item--detail__item--content-list.--flex-wrap {
  flex-wrap: wrap;
  gap: 10px;
}
.lp-feature__blocks__item--detail__item--content-list.--flex-wrap dd {
  width: 100%;
  margin-left: 0;
  font-size: 14px;
}
.lp-feature__blocks__item--detail__item--content-list.--border-bottom {
  margin-bottom: 0;
  padding-bottom: 20px;
  border-bottom: 1px dashed #000;
}

.lp-exam {
  position: relative;
  color: #263D60;
  font-family: "Noto Sans JP", sans-serif;
  padding: clamp(30px, 7.1614583333vw, 80px) 0;
  overflow: hidden;
}
.lp-exam::before {
  position: absolute;
  content: "";
  z-index: -1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #F7F5ED calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #F7F5ED calc(100% - 1px));
  background-size: 16px 16px;
  background-repeat: repeat;
  background-position: center;
}
.lp-exam__inner {
  position: relative;
  width: 375px;
  margin: 0 auto;
}
@media screen and (max-width: 400px) {
  .lp-exam__inner {
    width: 100%;
  }
}
.lp-exam__inner::before {
  position: absolute;
  content: "";
  z-index: -1;
  left: -280px;
  bottom: 50px;
  width: 240px;
  height: 240px;
  background-image: url(../assets/lp/summer/exam-image-1.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-exam__inner::before {
    width: 160px;
    height: 160px;
    left: calc(-1 * clamp(40px, 20.8333333333vw, 280px));
    bottom: clamp(20px, 4.5572916667vw, 50px);
  }
}
.lp-exam__inner::after {
  position: absolute;
  content: "";
  z-index: -1;
  right: -280px;
  bottom: 150px;
  width: 240px;
  height: 240px;
  background-image: url(../assets/lp/summer/exam-image-2.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-exam__inner::after {
    width: 130px;
    height: 130px;
    right: calc(-1 * clamp(40px, 20.8333333333vw, 280px));
    bottom: clamp(72px, 14.453125vw, 150px);
  }
}
.lp-exam__inner--message {
  width: 100%;
  height: auto;
  margin-bottom: 15px;
}
.lp-exam__inner--detail {
  text-align: center;
}
.lp-exam__inner--detail.--size01 {
  font-size: 14px;
}
@media screen and (max-width: 400px) {
  .lp-exam__inner--detail.--size01 {
    font-size: 12px;
  }
}
.lp-exam__inner--detail.--size01 strong {
  font-size: 18px;
}
@media screen and (max-width: 400px) {
  .lp-exam__inner--detail.--size01 strong {
    font-size: 16px;
  }
}
.lp-exam__inner--detail.--size02 {
  margin-bottom: 0;
  font-size: 40px;
  font-weight: 700;
}
.lp-exam__inner--detail.--size02 span {
  position: relative;
}
.lp-exam__inner--detail.--size02 span::before {
  position: absolute;
  z-index: -1;
  content: "";
  left: -15px;
  top: -5px;
  width: 70px;
  height: 70px;
  background-image: url(../assets/lp/summer/emphasis.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-exam__inner--detail.--size03 {
  margin-bottom: 5px;
  font-size: 18px;
}
.lp-exam__inner--link {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 300px;
  height: 93px;
  margin: auto;
  background-color: #DE863F;
  border: 1px solid white;
  border-radius: 50px;
  text-decoration: none;
  filter: drop-shadow(0 7px 0 #D97111);
}
@media screen and (max-width: 767px) {
  .lp-exam__inner--link {
    margin-top: 32px;
  }
}
.lp-exam__inner--link span {
  display: block;
  font-size: 14px;
  line-height: 32px;
  color: #FFF;
}
.lp-exam__inner--link span strong {
  font-size: 24px;
  line-height: 32px;
}

.lp-lectures {
  font-family: "Noto Sans JP", sans-serif;
  color: #263D60;
  padding: 80px 0;
  background-color: #F7F5ED;
}
.lp-lectures__title {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 20px;
}
.lp-lectures__title--sub {
  font-size: clamp(18px, 3.125vw, 30px);
  line-height: 1;
}
.lp-lectures__title--main {
  font-size: clamp(40px, 6.7057291667vw, 63px);
  line-height: 1;
}
.lp-lectures__message {
  margin-bottom: 40px;
  font-size: clamp(16px, 2.2135416667vw, 18px);
  text-align: center;
}
.lp-lectures__inner {
  width: calc(100% - 30px);
  max-width: 1080px;
  margin: auto;
}
.lp-lectures__inner--title {
  position: relative;
  font-size: clamp(16px, 2.34375vw, 20px);
  color: #FFF;
  padding: clamp(5px, 1.3020833333vw, 15px) 0;
  text-align: center;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .lp-lectures__inner--title {
    margin-bottom: 8px;
  }
}
.lp-lectures__inner--title.--grade-1 {
  background-color: #63A4DC;
}
.lp-lectures__inner--title.--grade-2 {
  background-color: #DD6717;
}
.lp-lectures__inner--title.--grade-3 {
  background-color: #DD9817;
}
.lp-lectures__inner--title.--grade-4 {
  background-color: #7BAA7C;
}
@media screen and (max-width: 767px) {
  .lp-lectures__inner--title::before {
    position: absolute;
    content: "";
    right: 10px;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 24px;
    height: 18px;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
    background-color: #FFF;
    transform-origin: center;
    transition: all 0.8s;
  }
  .lp-lectures__inner--title.open::before {
    transform: rotate(-180deg);
  }
}
.lp-lectures__inner--blocks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px 60px;
  max-width: 860px;
  margin: 40px auto;
}
@media screen and (max-width: 767px) {
  .lp-lectures__inner--blocks {
    display: none;
    grid-template-columns: repeat(1, 1fr);
    gap: 30px;
    transition: all 0.8s;
  }
  .lp-lectures__inner--blocks.open {
    display: grid;
  }
}
.lp-lectures__inner--blocks:last-child {
  margin-bottom: 0;
}
.lp-lectures__inner--blocks.--flex-center {
  display: flex;
  justify-content: center;
}
.lp-lectures__inner--blocks.--flex-center .lp-lectures__inner--blocks__item {
  width: calc(50% - 30px);
}
@media screen and (max-width: 767px) {
  .lp-lectures__inner--blocks.--flex-center {
    display: none;
  }
  .lp-lectures__inner--blocks.--flex-center.open {
    display: flex;
  }
  .lp-lectures__inner--blocks.--flex-center .lp-lectures__inner--blocks__item {
    width: 100%;
  }
}
.lp-lectures__inner--blocks__item {
  overflow: hidden;
  position: relative;
}
.lp-lectures__inner--blocks__item--head {
  position: relative;
  height: 70px;
  padding: 2px 0 8px;
  background-color: #FFF;
  box-sizing: border-box;
  border-top: 6px solid;
  filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.25));
}
.lp-lectures__inner--blocks__item--head.--grade-1 {
  border-color: #63A4DC;
  color: #63A4DC;
}
.lp-lectures__inner--blocks__item--head.--grade-1 .--name {
  background-color: #63A4DC;
}
.lp-lectures__inner--blocks__item--head.--grade-2 {
  border-color: #DD6717;
  color: #DD6717;
}
.lp-lectures__inner--blocks__item--head.--grade-2 .--name {
  background-color: #DD6717;
}
.lp-lectures__inner--blocks__item--head.--grade-3 {
  border-color: #DD9817;
  color: #DD9817;
}
.lp-lectures__inner--blocks__item--head.--grade-3 .--name {
  background-color: #DD9817;
}
.lp-lectures__inner--blocks__item--head.--grade-4 {
  border-color: #7BAA7C;
  color: #7BAA7C;
}
.lp-lectures__inner--blocks__item--head.--grade-4 .--name {
  background-color: #7BAA7C;
}
.lp-lectures__inner--blocks__item--head::before {
  position: absolute;
  content: "";
  top: 24px;
  right: 24px;
  width: 9px;
  height: 9px;
  border-left: 2px solid #000;
  border-bottom: 2px solid #000;
  transform: rotate(-45deg);
  transition: all 0.8s;
}
.lp-lectures__inner--blocks__item--head.active::before {
  transform: rotate(-225deg);
}
.lp-lectures__inner--blocks__item--head--info {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-bottom: 2px;
}
.lp-lectures__inner--blocks__item--head--text {
  font-size: 12px;
  font-weight: 700;
}
.lp-lectures__inner--blocks__item--head--tags {
  display: flex;
  gap: 4px;
}
.lp-lectures__inner--blocks__item--head--tags span {
  font-size: 10px;
  line-height: 1;
  font-weight: 700;
  padding: 2px 4px;
  border: 1px solid;
  border-radius: 10px;
}
.lp-lectures__inner--blocks__item--head--name {
  width: 260px;
  margin: auto;
  font-size: 18px;
  color: #FFF;
  font-weight: 700;
  text-align: center;
}
.lp-lectures__inner--blocks__item--content {
  height: 0;
  padding: 0 14px;
  background-color: #FFF;
  transition: all 0.8s;
  overflow: hidden;
  filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.25));
}
.lp-lectures__inner--blocks__item--content.open {
  padding: 20px 14px;
}
.lp-lectures__inner--blocks__item--content-text {
  letter-spacing: 0.5px;
}
.lp-lectures__inner--blocks__item--content-description {
  padding: 4px;
  border-bottom: 3px solid;
  line-height: 1.3;
}
.lp-lectures__inner--blocks__item--content-description strong {
  display: inline-block;
  margin-right: 12px;
}
.lp-lectures__inner--blocks__item--content-description.--grade-2 {
  background-color: #FCF0E8;
  border-color: #DD6717;
}
.lp-lectures__inner--blocks__item--content-description.--grade-3 {
  background-color: #FCF5E8;
  border-color: #E9BE6E;
}
.lp-lectures__inner--blocks__item--content-description.--grade-4 {
  background-color: #F2F6F2;
  border-color: #7BAA7C;
}
.lp-lectures__inner--blocks__item--content-list {
  display: flex;
  align-items: start;
  font-weight: 500;
}
.lp-lectures__inner--blocks__item--content-list dt {
  padding: 0 4px;
  background-color: #D9D9D9;
  flex-shrink: 0;
}
.lp-lectures__inner--blocks__item--content-list dd {
  margin-left: 10px;
}
.lp-lectures__inner--blocks__item--content-list dd small {
  font-size: 0.75em;
}
.lp-lectures__inner--blocks__item--content-list.--flex-wrap {
  flex-wrap: wrap;
  gap: 10px;
}
.lp-lectures__inner--blocks__item--content-list.--flex-wrap dd {
  width: 100%;
  margin-left: 0;
  font-size: 14px;
}
.lp-lectures__inner--blocks__item--content-list.--border-bottom {
  margin-bottom: 0;
  padding-bottom: 20px;
  border-bottom: 1px dashed #000;
}

.lp-voice {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  color: #263D60;
  margin-bottom: clamp(20px, 6.5104166667vw, 80px);
  padding: clamp(60px, 9.1145833333vw, 80px) 0;
}
.lp-voice::before {
  position: absolute;
  content: "";
  z-index: -1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #F7F5ED calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #F7F5ED calc(100% - 1px));
  background-size: 16px 16px;
  background-repeat: repeat;
  background-position: center;
}
.lp-voice__title {
  font-size: 53px;
  text-align: center;
  margin-bottom: 40px;
}
.lp-voice__title strong {
  font-size: 63px;
}
.lp-voice__contents {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 80px;
  max-width: 1080px;
  margin: auto;
}
@media screen and (max-width: 1199px) {
  .lp-voice__contents {
    gap: 30px;
  }
}
@media screen and (max-width: 839px) {
  .lp-voice__contents {
    grid-template-columns: repeat(1, 1fr);
    gap: 8px;
    max-width: 480px;
  }
}
@media screen and (max-width: 839px) {
  .lp-voice__contents__item {
    padding: 0 10px;
  }
}
.lp-voice__contents__item--head {
  display: grid;
  grid-template-columns: 104px 1fr;
  gap: 30px;
  align-items: flex-end;
  margin-bottom: 10px;
}
@media screen and (max-width: 839px) {
  .lp-voice__contents__item--head.--reverse {
    grid-template-columns: 1fr 104px;
  }
}
@media screen and (max-width: 839px) {
  .lp-voice__contents__item--head .--order-sp-1 {
    order: 1;
  }
}
@media screen and (max-width: 839px) {
  .lp-voice__contents__item--head .--order-sp-2 {
    order: 2;
  }
}
.lp-voice__contents__item--head--face {
  width: 100%;
  height: auto;
}
.lp-voice__contents__item--head--info {
  padding-bottom: 14px;
}
.lp-voice__contents__item--head--info--title {
  font-weight: 700;
  margin-bottom: 8px;
}
.lp-voice__contents__item--head--info--tags {
  display: flex;
  gap: 8px;
}
.lp-voice__contents__item--head--info--tags span {
  display: inline-block;
  font-size: 10px;
  line-height: 1;
  padding: 2px 6px;
  background-color: #FDDB9A;
  border-radius: 10px;
}

.lp-faq {
  font-family: "Noto Sans JP", sans-serif;
  padding: 30px 0;
  color: #263D60;
  background-color: #CCE2EE;
}
.lp-faq__inner {
  width: calc(100% - 30px);
  max-width: 1080px;
  margin: auto;
  padding: 30px clamp(10px, 3.90625vw, 50px);
  background-color: #FFF;
  border-radius: 30px;
}
.lp-faq__inner-title {
  margin-bottom: 30px;
  font-size: 40px;
  line-height: 1;
  text-align: center;
}
.lp-faq__inner--blocks {
  display: grid;
  gap: 40px;
}
.lp-faq__inner--blocks__item--question {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 4px;
  margin-bottom: 6px;
}
.lp-faq__inner--blocks__item--question span {
  font-family: "Noto Sans", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 25px;
  font-size: 18px;
  font-weight: 700;
  background-color: #FDDB9A;
  border-radius: 50%;
}
.lp-faq__inner--blocks__item--question p {
  padding-top: 2px;
  line-height: 21px;
}
.lp-faq__inner--blocks__item--answer {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 4px;
}
.lp-faq__inner--blocks__item--answer span {
  font-family: "Noto Sans", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 25px;
  font-size: 18px;
  font-weight: 700;
  color: #DD6717;
  background-color: #FDDB9A;
  border-radius: 50%;
}
.lp-faq__inner--blocks__item--answer p {
  padding-top: 2px;
  line-height: 21px;
}

.lp-flow {
  color: #263D60;
  padding: clamp(40px, 7.8125vw, 80px) 0;
  margin-bottom: clamp(35px, 7.4869791667vw, 80px);
  font-family: "Noto Sans JP", sans-serif;
}
.lp-flow__title {
  margin-bottom: 40px;
  font-size: 40px;
  line-height: 1;
  text-align: center;
}
.lp-flow__blocks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
  max-width: 912px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .lp-flow__blocks {
    grid-template-columns: repeat(1, 1fr);
    gap: 30px;
    padding-left: 15px;
  }
}
.lp-flow__blocks__item {
  position: relative;
  padding-left: 70px;
  padding-top: 27px;
}
.lp-flow__blocks__item:nth-child(1)::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  width: 78px;
  height: 82px;
  margin: auto;
  background-image: url(../assets/lp/summer/flow-image-1.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-flow__blocks__item:nth-child(2)::after {
  position: absolute;
  content: "";
  left: 8px;
  top: 96px;
  width: 49px;
  height: 69px;
  background-image: url(../assets/lp/summer/flow-image-2.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-flow__blocks__item:nth-child(3)::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  width: 66px;
  height: 83.4px;
  margin: auto;
  background-image: url(../assets/lp/summer/flow-image-3.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-flow__blocks__item:nth-child(4)::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  width: 78px;
  height: 82px;
  margin: auto;
  background-image: url(../assets/lp/summer/flow-image-4.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-flow__blocks__item::before {
    position: absolute;
    content: "";
    left: 28px;
    top: 0;
    width: 2px;
    height: calc(100% + 30px);
    background-color: #DE863F;
  }
}
@media screen and (max-width: 767px) {
  .lp-flow__blocks__item:last-child::before {
    height: 100%;
  }
}
.lp-flow__blocks__item--title {
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  padding-right: 20px;
  box-sizing: border-box;
  border: 1px solid #DE863F;
  border-radius: 30px;
  background-color: #FFF;
}
.lp-flow__blocks__item--title--step {
  width: 60px;
  height: 60px;
  margin-right: 10px;
  padding-top: 14px;
  border-radius: 50%;
  background-color: #DE863F;
  color: #FFF;
}
.lp-flow__blocks__item--title--step span {
  display: block;
  text-align: center;
}
.lp-flow__blocks__item--title--step span:nth-child(1) {
  font-size: 14px;
  line-height: 1;
}
.lp-flow__blocks__item--title--step span:nth-child(2) {
  font-size: 20px;
  line-height: 1;
}
.lp-flow__blocks__item--title--main {
  font-size: 18px;
  color: #DE863F;
  font-weight: 700;
}
.lp-flow__blocks__item-img {
  width: 100%;
  height: auto;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .lp-flow__blocks__item-img {
    max-height: 200px;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.lp-flow__blocks__item-text {
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .lp-flow__blocks__item-text {
    padding-right: 16px;
  }
}

.lp-common__cta {
  position: relative;
  z-index: 1;
  width: calc(100% - 64px);
  max-width: 900px;
  margin: 0 auto clamp(30px, 7.1614583333vw, 80px);
  padding: clamp(20px, 3.90625vw, 40px) 0;
  background-color: #FFF;
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .lp-common__cta {
    background-color: #FFFAE7;
  }
}
@media screen and (max-width: 767px) {
  .lp-common__cta {
    margin-top: 40px;
  }
}
.lp-common__cta--wrapper {
  position: relative;
  z-index: -2;
  height: 280px;
}
.lp-common__cta--wrapper::before {
  position: absolute;
  content: "";
  z-index: -1;
  width: 100%;
  height: calc(100% - 35px);
  background: linear-gradient(to bottom, #A8DBEF, #B9E5F5);
  filter: blur(24px);
}
.lp-common__cta--wrapper::after {
  position: absolute;
  content: "";
  z-index: -1;
  left: 0;
  bottom: -55px;
  width: 100%;
  height: 110px;
  background: linear-gradient(to bottom, #BFE8F7, #FFF);
}
.lp-common__cta__inner {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 80px;
  align-items: center;
  max-width: 760px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .lp-common__cta__inner {
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
  }
}
.lp-common__cta__inner--buttons {
  display: grid;
  gap: 15px;
  width: 280px;
}
@media screen and (max-width: 767px) {
  .lp-common__cta__inner--buttons {
    margin: auto;
  }
}
.lp-common__cta__inner--buttons__item {
  display: block;
  text-align: center;
  padding: 12px 0;
  font-size: 24px;
  line-height: 1.25;
  color: #FFF;
  border-radius: 36px;
  text-decoration: none;
}
.lp-common__cta__inner--buttons__item small {
  font-size: 14px;
}
.lp-common__cta__inner--buttons__item.--request {
  background: linear-gradient(to right, #026DAB, #42ABE8);
  border: 2px solid #006CAA;
  color: #FFF;
}
.lp-common__cta__inner--buttons__item.--entry {
  background: #FFE427;
  border: 2px solid #EBCE09;
  color: #024A73;
}
.lp-common__cta__inner--tel {
  position: relative;
  padding-left: 40px;
}
@media screen and (max-width: 767px) {
  .lp-common__cta__inner--tel {
    margin: auto;
  }
}
.lp-common__cta__inner--tel::before {
  position: absolute;
  content: "";
  left: 0;
  top: 8px;
  width: clamp(24px, 3.6458333333vw, 32px);
  height: clamp(24px, 3.6458333333vw, 32px);
  background-image: url(../assets/lp/summer/tel.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .lp-common__cta__inner--tel::before {
    top: 0;
  }
}
.lp-common__cta__inner--tel--number {
  font-size: clamp(24px, 4.6875vw, 48px);
  line-height: 1;
  color: #006CAA;
  font-weight: 700;
  font-family: "Open Sans", sans-serif;
}
.lp-common__cta__inner--tel--note {
  margin-top: 8px;
  font-size: clamp(10px, 1.5625vw, 14px);
  line-height: 1.2;
  color: #006CAA;
}

.lp-week {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #7DBFE5;
  background-image: url(../assets/lp/week/week-thin-wave.png);
  background-repeat: space repeat;
  background-size: 1760px 13px;
}
.lp-week__title {
  padding-bottom: 16px;
}
.lp-week__title img {
  display: block;
  width: 100%;
  max-width: 450px;
  margin: auto;
}
.lp-week__head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 880px;
  padding-right: 480px;
  background-image: url(../assets/lp/week/week-bg.png);
  background-repeat: no-repeat;
  background-size: 1920px auto;
  background-position: left calc(50vw - 960px) bottom;
}
@media screen and (max-width: 1199px) {
  .lp-week__head {
    justify-content: left;
  }
}
@media screen and (max-width: 767px) {
  .lp-week__head {
    align-items: flex-start;
    height: 72vw;
    padding-right: 0;
    background-image: url(../assets/lp/week/week-bg-sp.png);
    background-size: cover;
    background-position: center;
  }
}
.lp-week__head::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: clamp(21px, 4.1015625vw, 42px);
  background-image: url(../assets/lp/week/week-bg-wave.png);
  background-repeat: repeat-x;
  background-size: clamp(960px, 187.5vw, 1920px) clamp(21px, 4.1015625vw, 42px);
  background-position: left calc(50vw - 960px) bottom;
}
.lp-week__head--contents img:nth-child(1) {
  display: block;
  width: 814px;
  height: auto;
}
@media screen and (max-width: 1199px) {
  .lp-week__head--contents img:nth-child(1) {
    max-width: 80vw;
  }
}
.lp-week__head--contents img:nth-child(2) {
  display: block;
  width: 674px;
  height: auto;
  margin: auto;
}
@media screen and (max-width: 1199px) {
  .lp-week__head--contents img:nth-child(2) {
    max-width: 72vw;
  }
}
.lp-week__main {
  width: calc(100% - 30px);
  margin: auto;
  padding: clamp(30px, 7.1614583333vw, 80px) 0;
}
.lp-week__main-title {
  margin-bottom: clamp(20px, 3.2552083333vw, 30px);
  font-size: clamp(26px, 4.0364583333vw, 36px);
  text-align: center;
  color: #FFF;
}
.lp-week__main-title strong {
  color: #FFEA82;
}
.lp-week__main-text {
  font-size: 18px;
  text-align: center;
  color: #FFF;
}

.lp-events {
  font-family: "Noto Sans JP", sans-serif;
  padding: clamp(20px, 6.5104166667vw, 80px) 0 clamp(40px, 10.4166666667vw, 120px);
  background-image: url(../assets/lp/week/events-bg.png);
  background-repeat: no-repeat;
  background-size: 1920px auto;
  background-position: left calc(50vw - 960px) bottom;
}
@media screen and (max-width: 767px) {
  .lp-events {
    width: 120vw;
    transform-origin: center;
    transform: rotate(-5deg) translateX(-5vw);
    background-image: none;
  }
}
@media screen and (min-width: 1200px) {
  .lp-events {
    position: relative;
  }
  .lp-events::before {
    position: absolute;
    content: "";
    left: 0;
    right: 1320px;
    bottom: -20px;
    width: 200px;
    height: 183px;
    margin: auto;
    background-image: url(../assets/lp/week/events-pc-1.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
  }
  .lp-events::after {
    position: absolute;
    content: "";
    left: 1260px;
    right: 0;
    bottom: -20px;
    width: 200px;
    height: 211px;
    margin: auto;
    background-image: url(../assets/lp/week/events-pc-2.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
  }
}
.lp-events-wrapper {
  overflow: hidden;
}
.lp-events-title {
  font-size: clamp(20px, 3.2552083333vw, 30px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .lp-events-title {
    text-align: left;
    padding-left: 12vw;
  }
}
.lp-events-text {
  margin-bottom: clamp(20px, 3.90625vw, 40px);
  font-size: clamp(10px, 1.8229166667vw, 18px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .lp-events-text {
    text-align: left;
    padding-left: 12vw;
  }
}
.lp-events__buttons {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  width: calc(100% - 30px);
  max-width: 1040px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .lp-events__buttons {
    grid-template-columns: repeat(1, 1fr);
    width: 100%;
  }
}
.lp-events__buttons__item.--grade-1 a {
  background-color: #7DBFE5;
  filter: drop-shadow(0 4px 0 #0F6A91);
}
.lp-events__buttons__item.--grade-2 a {
  background-color: #F37D7D;
  filter: drop-shadow(0 4px 0 #EC4747);
}
.lp-events__buttons__item.--grade-3 a {
  background-color: #FFA433;
  filter: drop-shadow(0 4px 0 #C56B00);
}
.lp-events__buttons__item.--grade-4 a {
  background-color: #86BCAA;
  filter: drop-shadow(0 4px 0 #248061);
}
@media screen and (max-width: 767px) {
  .lp-events__buttons__item {
    position: relative;
    padding-bottom: clamp(30px, 5.2083333333vw, 50px);
    background-image: url(../assets/lp/week/events-bg.png);
    background-repeat: no-repeat;
    background-size: 140vw auto;
    background-position: left -20vw bottom;
  }
  .lp-events__buttons__item::before {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
  }
  .lp-events__buttons__item:nth-child(1) {
    padding-left: 10vw;
  }
  .lp-events__buttons__item:nth-child(1)::before {
    position: absolute;
    content: "";
    right: 10vw;
    bottom: clamp(20px, 3.90625vw, 40px);
    width: 60px;
    height: 76px;
    background-image: url(../assets/lp/week/events-picture-1.png);
  }
  .lp-events__buttons__item:nth-child(2) {
    display: flex;
    justify-content: right;
    padding-right: 15vw;
  }
  .lp-events__buttons__item:nth-child(2)::before {
    position: absolute;
    content: "";
    left: 6vw;
    bottom: clamp(20px, 3.90625vw, 40px);
    width: 80px;
    height: 48px;
    background-image: url(../assets/lp/week/events-picture-2.png);
  }
  .lp-events__buttons__item:nth-child(3) {
    padding-left: 4vw;
  }
  .lp-events__buttons__item:nth-child(3)::before {
    position: absolute;
    content: "";
    right: 15vw;
    bottom: clamp(20px, 3.90625vw, 40px);
    width: 67px;
    height: 105px;
    background-image: url(../assets/lp/week/events-picture-3.png);
  }
  .lp-events__buttons__item:nth-child(4) {
    display: flex;
    justify-content: right;
    padding-right: 18vw;
  }
  .lp-events__buttons__item:nth-child(4)::before {
    position: absolute;
    content: "";
    left: 6vw;
    bottom: clamp(20px, 3.90625vw, 40px);
    width: 80px;
    height: 80px;
    background-image: url(../assets/lp/week/events-picture-4.png);
  }
}
.lp-events__buttons__item-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: clamp(280px, 50.78125vw, 500px);
  max-width: 100%;
  height: clamp(60px, 9.1145833333vw, 80px);
  text-decoration: none;
  border-radius: 50px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .lp-events__buttons__item-link {
    justify-content: left;
    padding-left: 12px;
  }
}
.lp-events__buttons__item-link::after {
  position: absolute;
  content: "";
  z-index: 1;
  right: 20px;
  top: 0;
  bottom: 0;
  width: 20px;
  height: 20px;
  margin: auto;
  background-image: url(../assets/lp/week/arrow.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.lp-events__buttons__item-link span:nth-child(1) {
  font-size: clamp(20px, 3.125vw, 28px);
  color: white;
  line-height: 1.1;
  text-align: center;
}
.lp-events__buttons__item-link span:nth-child(2) {
  display: inline-block;
  padding: 5px 10px;
  font-size: clamp(10px, 1.6927083333vw, 16px);
  line-height: 1;
  font-weight: 700;
  background-color: white;
  border-radius: 50px;
}
@media screen and (max-width: 767px) {
  .lp-events__buttons__item-link span:nth-child(2) {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    padding: 0;
    border-radius: 50%;
  }
}

.lp-programs {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  padding: clamp(40px, 7.8125vw, 80px) 0;
  background-image: url(../assets/lp/week/program-bg.png);
  background-repeat: repeat-y;
  background-size: 1920px auto;
  background-position: left calc(50vw - 960px) top;
}
@media screen and (max-width: 767px) {
  .lp-programs::before {
    position: absolute;
    content: "";
    z-index: -1;
    left: 0;
    top: 0;
    width: 120px;
    height: 100%;
    background-image: url(../assets/lp/week/program-bg-sp-1.png);
    background-repeat: repeat-y;
    background-size: 100% auto;
    background-position: left top;
  }
  .lp-programs::after {
    position: absolute;
    content: "";
    z-index: -1;
    right: 0;
    top: 0;
    width: 120px;
    height: 100%;
    background-image: url(../assets/lp/week/program-bg-sp-2.png);
    background-repeat: repeat-y;
    background-size: 100% auto;
    background-position: right top;
  }
}
.lp-programs__blocks {
  display: grid;
  gap: clamp(40px, 7.8125vw, 80px);
  width: calc(100% - 30px);
  max-width: 1080px;
  margin: auto;
}
.lp-programs__blocks__item {
  width: 100%;
  margin: auto;
  padding: clamp(15px, 3.5807291667vw, 40px) clamp(20px, 5.859375vw, 70px) clamp(20px, 3.90625vw, 40px);
  background-color: #FFF4C9;
}
.lp-programs__blocks__item .lp-cta__main-link {
  position: relative;
}
.lp-programs__blocks__item .lp-cta__main-link::before {
  position: absolute;
  content: "";
  right: 20px;
  top: 0;
  bottom: 0;
  width: 10px;
  height: 10px;
  margin: auto;
  border-right: 2px solid #FFF;
  border-bottom: 2px solid #FFF;
  transform-origin: center;
  transform: rotate(-45deg);
}
.lp-programs__blocks__item.--grade-1 .--catchcopy {
  background-color: #7DBFE5;
}
.lp-programs__blocks__item.--grade-1 .--catchcopy::before {
  background-color: #7DBFE5;
}
.lp-programs__blocks__item.--grade-1 h4 span {
  background-color: #7DBFE5;
}
.lp-programs__blocks__item.--grade-1 li::before {
  background-color: #BEDFF2;
}
.lp-programs__blocks__item.--grade-1 .lp-cta__main-link {
  background-color: #7DBFE5;
  filter: drop-shadow(0 4px 1px #0F6A91);
}
.lp-programs__blocks__item.--grade-2 .--catchcopy {
  background-color: #F37D7D;
}
.lp-programs__blocks__item.--grade-2 .--catchcopy::before {
  background-color: #F37D7D;
}
.lp-programs__blocks__item.--grade-2 h4 span {
  background-color: #F37D7D;
}
.lp-programs__blocks__item.--grade-2 li::before {
  background-color: #F9BEBE;
}
.lp-programs__blocks__item.--grade-2 .lp-cta__main-link {
  background-color: #F37D7D;
  filter: drop-shadow(0 4px 1px #EC4747);
}
.lp-programs__blocks__item.--grade-3 .--catchcopy {
  background-color: #FFA233;
}
.lp-programs__blocks__item.--grade-3 .--catchcopy::before {
  background-color: #FFA233;
}
.lp-programs__blocks__item.--grade-3 h4 span {
  background-color: #FFA233;
}
.lp-programs__blocks__item.--grade-3 li::before {
  background-color: #FFD199;
}
.lp-programs__blocks__item.--grade-3 .lp-cta__main-link {
  background-color: #FFA233;
  filter: drop-shadow(0 4px 1px #C56C01);
}
.lp-programs__blocks__item.--grade-4 .--catchcopy {
  background-color: #86BCAA;
}
.lp-programs__blocks__item.--grade-4 .--catchcopy::before {
  background-color: #86BCAA;
}
.lp-programs__blocks__item.--grade-4 h4 span {
  background-color: #86BCAA;
}
.lp-programs__blocks__item.--grade-4 li::before {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: #FFF;
  background-color: #C3DDD5;
}
.lp-programs__blocks__item.--grade-4 li:nth-child(1)::before {
  content: "1" !important;
}
.lp-programs__blocks__item.--grade-4 li:nth-child(2)::before {
  content: "2" !important;
}
.lp-programs__blocks__item.--grade-4 li:nth-child(3)::before {
  content: "3" !important;
}
.lp-programs__blocks__item.--grade-4 .lp-cta__main-link {
  background-color: #86BCAA;
  filter: drop-shadow(0 4px 1px #258163);
}
.lp-programs__blocks__item--button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 295px;
  height: 35px;
  margin: 0 auto 40px;
  color: #FFF;
  font-weight: 700;
  background-color: #7DBFE5;
  border-radius: 10px;
  filter: drop-shadow(0 4px 1px #0F6A91);
  text-decoration: none;
}
.lp-programs__blocks__item--button::before {
  position: absolute;
  content: "";
  right: 10px;
  top: 12px;
  width: 18px;
  height: 12px;
  background-color: #FFF;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
          clip-path: polygon(0 0, 50% 100%, 100% 0);
  transform-origin: center;
  transition: all 0.8s;
}
.lp-programs__blocks__item--button.open::before {
  transform: rotate(-180deg);
}
.lp-programs__blocks__item--allCourses {
  display: none;
}
.lp-programs__blocks__item--allCourses.open {
  display: grid;
}
@media screen and (max-width: 767px) {
  .lp-programs__blocks__item--allCourses .lp-feature__blocks__item--detail__item--head {
    color: #FFF !important;
    padding: 8px 0;
    background-color: #7DBFE5;
    border-radius: 40px;
    border-top: none;
    filter: drop-shadow(0 4px 1px #0F6A91);
    box-shadow: none !important;
  }
  .lp-programs__blocks__item--allCourses .lp-feature__blocks__item--detail__item--head::before {
    width: 20px;
    height: 15px;
    background-color: #FFF;
    border: none;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
    transform: rotate(0deg) !important;
  }
  .lp-programs__blocks__item--allCourses .lp-feature__blocks__item--detail__item--head.open::before {
    transform: rotate(-180deg) !important;
  }
  .lp-programs__blocks__item--allCourses .lp-feature__blocks__item--detail__item--head .--name {
    background-color: #7DBFE5 !important;
  }
  .lp-programs__blocks__item--allCourses .lp-feature__blocks__item--detail__item--content {
    margin-top: 4px;
  }
}
.lp-programs__blocks__item--catchcopy {
  position: relative;
  width: 225px;
  margin: 0 auto 12px;
  padding: 8px 0;
  font-size: 16px;
  line-height: 1.2;
  text-align: center;
  color: #FFF;
  font-weight: 900;
  border-radius: 16px;
}
.lp-programs__blocks__item--catchcopy::before {
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: -7px;
  width: 12px;
  height: 10px;
  margin: auto;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
          clip-path: polygon(0 0, 50% 100%, 100% 0);
  background-color: #7DBFE5;
}
.lp-programs__blocks__item--caption {
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  line-height: 1;
}
.lp-programs__blocks__item--caption strong {
  font-size: 16px;
}
.lp-programs__blocks__item--title {
  margin-bottom: 30px;
  font-size: 36px;
  text-align: center;
  line-height: 1;
}
.lp-programs__blocks__item--image {
  display: block;
  width: 100%;
  max-width: 720px;
  margin: 0 auto 40px;
}
.lp-programs__blocks__item--subText {
  width: 100%;
  max-width: 720px;
  margin: 0 auto clamp(20px, 3.90625vw, 40px);
  font-size: clamp(13px, 1.8229166667vw, 15px);
}
.lp-programs__blocks__item--description {
  margin-bottom: 20px;
  padding: 40px calc(50% - 360px) 0;
  font-weight: 700;
  border-top: 1px dashed #263D60;
}
.lp-programs__blocks__item--recommendation {
  max-width: 720px;
  margin: 0 auto 40px;
  padding: clamp(15px, 2.2786458333vw, 20px) clamp(15px, 4.2317708333vw, 50px);
  background-color: #FFF;
  border-radius: 10px;
}
.lp-programs__blocks__item--recommendation-text {
  margin-bottom: 30px;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
.lp-programs__blocks__item--recommendation-list {
  list-style: none;
  margin-bottom: 0;
  padding-left: 0;
}
.lp-programs__blocks__item--recommendation-list li {
  position: relative;
  padding-left: 28px;
  line-height: 1.5;
}
.lp-programs__blocks__item--recommendation-list li:not(:last-child) {
  margin-bottom: 30px;
}
.lp-programs__blocks__item--recommendation-list li::before {
  position: absolute;
  content: "";
  left: 0;
  top: 4px;
  width: 16px;
  height: 16px;
  background-color: #7DBFE5;
  border-radius: 50%;
}
.lp-programs__blocks__item--subTitle {
  max-width: 720px;
  margin: auto;
}
.lp-programs__blocks__item--subTitle span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 30px;
  color: #FFF;
  background-color: #7DBFE5;
  border-radius: 10px 10px 0 0;
}
.lp-programs__blocks__item--detail {
  font-family: "Zen Kaku Gothic New", sans-serif;
  max-width: 720px;
  margin: 0 auto 40px;
}
.lp-programs__blocks__item--detail dt {
  padding: 6px 0;
  font-size: 14px;
  text-align: center;
  background-color: #EBEBEA;
}
.lp-programs__blocks__item--detail dd {
  margin: 0;
  padding: 10px 20px;
  font-size: 14px;
  background-color: #FFF;
}

.lp-academicExam__lead {
  padding: 10px 0;
  background-color: #263D60;
  color: white;
  font-size: clamp(18px, 3.7760416667vw, 40px);
  text-align: center;
  font-weight: 900;
}
.lp-academicExam__main {
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 800px;
  padding: 0 clamp(16px, 3.6458333333vw, 40px) clamp(16px, 4.1666666667vw, 48px);
  background-image: url(../assets/lp/exam/bg.jpg);
  background-repeat: no-repeat;
  background-size: 1920px 800px;
  background-position: left calc(50vw - 960px) center;
}
@media screen and (min-width: 1440px) {
  .lp-academicExam__main {
    padding-left: calc(50vw - 720px);
    padding-right: calc(50vw - 720px);
  }
}
@media screen and (max-width: 767px) {
  .lp-academicExam__main {
    height: clamp(300px, 71.6145833333vw, 800px);
    background-size: cover;
    background-position: center;
  }
}
.lp-academicExam__main--title {
  width: calc(100% - 2rem);
  max-width: 1280px;
  margin: auto;
  /*
  &--sub {
    display: block;
    width: auto;
    height: mx.autoClamp(30, 120);
    margin-bottom: mx.autoClamp(10, 15);
  }
  &--main {
    display: block;
    width: auto;
    height: mx.autoClamp(160, 480);
  }
    */
}
.lp-academicExam__main--badge {
  margin-left: auto;
  width: clamp(60px, 18.8802083333vw, 230px);
  height: clamp(60px, 18.8802083333vw, 230px);
}
@media screen and (max-width: 767px) {
  .lp-academicExam__main--badge {
    margin-left: 12px;
  }
}

.common-cta {
  padding: clamp(5px, 0.9765625vw, 10px);
  background-color: #F9F8F4;
  border: 1px solid #121E2E;
}
.common-cta__wrap {
  width: 1100px;
  padding-inline: 10px;
}
.block-contents .common-cta__wrap {
  max-width: 100%;
  margin-top: clamp(50px, 9.1145833333vw, 90px);
  padding-inline: 0;
}
.common-cta__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-block: clamp(30px, 4.5572916667vw, 40px);
  padding-inline: clamp(15px, 2.2786458333vw, 20px);
  border: 1px solid #121E2E;
}
@media (max-width: 767.9px) {
  .common-cta__inner {
    flex-direction: column;
  }
}
.--has-tel .common-cta__inner {
  gap: 20px clamp(15px, 1.953125vw, 20px);
}
.common-cta__main {
  width: 630px;
  max-width: 100%;
}
.--has-tel .common-cta__main {
  width: 615px;
}
.common-cta__main-title {
  margin-bottom: 0;
  text-align: center;
  font-size: clamp(14px, 2.0833333333vw, 18px);
  font-weight: 700;
  line-height: 1.2;
}
.common-cta__btn-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(15px, 1.953125vw, 30px) clamp(15px, 2.2786458333vw, 20px);
  margin-top: 15px;
}
.--has-tel .common-cta__btn-list {
  -moz-column-gap: 15px;
       column-gap: 15px;
}
.common-cta__btn-list .btn {
  width: 100%;
}
.common-cta__sub {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (min-width: 768px) {
  .common-cta__sub {
    transform: translateY(19%);
  }
}
.common-cta__sub.--is-tel-only {
  transform: translateY(0);
}
.common-cta__sub-title {
  margin-bottom: 0;
  font-size: clamp(12px, 1.7578125vw, 15px);
  font-weight: 700;
  line-height: 1.2;
}
.common-cta__tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-size: clamp(37px, 5.5338541667vw, 48px);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.3;
  text-decoration: none;
}
.common-cta__tel::before {
  content: "";
  flex-shrink: 0;
  transform: translateY(13%);
  display: block;
  width: clamp(30px, 4.5572916667vw, 40px);
  height: clamp(30px, 4.5572916667vw, 40px);
  background-image: url(../assets/icon/phone.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.common-cta__tel-notice {
  transform: translateX(8%);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  text-align: center;
  font-size: clamp(12px, 1.7578125vw, 15px);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.common-cta__tel-notice .--small {
  font-size: clamp(10px, 1.4973958333vw, 13px);
}

@media (max-width: 599.9px) {
  .common-course__inner {
    margin-inline: -15px;
  }
}
.common-course__item-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 15px;
}
@media (min-width: 768px) {
  .common-course__item-list {
    grid-template-columns: repeat(4, 1fr);
    -moz-column-gap: clamp(10px, 1.953125vw, 20px);
         column-gap: clamp(10px, 1.953125vw, 20px);
  }
}
.common-course__item {
  text-decoration: none;
}
.common-course__item-figure {
  position: relative;
  aspect-ratio: 187/105;
  width: 100%;
}
.common-course__item-figure::before {
  content: "";
  position: absolute;
  display: block;
  top: 5px;
  left: 5px;
  width: 50%;
  height: 50%;
  border-top-left-radius: 5px;
  border-top: 1px solid #121E2E;
  border-left: 1px solid #121E2E;
}
.common-course__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.common-course__item-bottom {
  display: flex;
  justify-content: space-between;
}
.common-course__item-title {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  padding: clamp(5px, 0.9765625vw, 10px) 15px;
  line-height: 1.2;
}
@media (max-width: 599.9px) {
  .common-course__item-title {
    flex-direction: column;
  }
}
.common-course__item-title__text {
  font-size: clamp(18px, 2.4739583333vw, 20px);
}
.common-course__item-title__notice {
  font-size: clamp(13px, 1.7578125vw, 14px);
}
.common-course__item-link {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 44px;
}
.--green .common-course__item-link {
  background-color: #ADCC85;
}
.--blue .common-course__item-link {
  background-color: #8DB1DB;
}
.--dark-blue .common-course__item-link {
  background-color: #4E71A6;
}
.common-course__banner-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  max-width: 960px;
  margin-top: clamp(15px, 2.9296875vw, 30px);
  margin-inline: auto;
}
@media (min-width: 768px) {
  .common-course__banner-list {
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-radius: 5px;
    overflow: hidden;
  }
}
.common-course .img-banner__text {
  font-size: 16px;
}
.common-course .img-banner__text .--small {
  font-size: 13px;
}
.common-course .img-banner__text::after {
  right: 15px;
  bottom: 10px;
}

.lp-cta {
  padding: clamp(5px, 0.9765625vw, 10px);
  background-color: #F9F8F4;
  border: 1px solid #121E2E;
}
@media screen and (max-width: 767px) {
  .lp-cta {
    padding: 0;
    background: none;
    border: none;
  }
}
.lp-cta__wrap {
  max-width: 920px;
  padding-inline: 10px;
}
@media screen and (max-width: 767px) {
  .lp-cta__wrap {
    padding-inline: 0;
  }
}
.block-contents .lp-cta__wrap {
  max-width: 100%;
  margin-top: clamp(50px, 9.1145833333vw, 90px);
  padding-inline: 0;
}
.lp-cta__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-block: clamp(30px, 4.5572916667vw, 40px);
  padding-inline: clamp(15px, 2.2786458333vw, 20px);
  border: 1px solid #121E2E;
}
@media screen and (max-width: 767px) {
  .lp-cta__inner {
    padding-block: 0;
    border: none;
  }
}
@media (max-width: 767.9px) {
  .lp-cta__inner {
    flex-direction: column;
  }
}
.lp-cta__inner.--not-flex {
  display: block;
}
.--has-tel .lp-cta__inner {
  gap: 20px clamp(15px, 1.953125vw, 20px);
}
@media screen and (max-width: 767px) {
  .--has-tel .lp-cta__inner {
    gap: 0;
  }
}
.lp-cta__inner.--no-border-top {
  border-top: none !important;
}
.lp-cta__inner.--no-border-bottom {
  border-bottom: none !important;
}
.lp-cta__main {
  width: 100%;
  max-width: 400px;
}
.lp-cta__main.--long {
  width: calc(100% - 2rem);
  max-width: 800px;
  margin: 20px auto 0;
  padding-top: 20px;
  border-top: 1px solid #121E2E;
}
.lp-cta__main-link {
  display: flex;
  width: 295px;
  height: 64px;
  margin: 10px auto 0;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: #FFF;
  background-color: #7DBFE5;
  border-radius: 33.5px;
  text-decoration: none;
}
.lp-cta__main-link--columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
  margin-top: 8px;
}
@media screen and (max-width: 991px) {
  .lp-cta__main-link--columns {
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
}
.lp-cta__main-link.--small {
  width: 100%;
  max-width: 300px;
  font-size: 1.2em;
  justify-content: left;
  padding-left: 16px;
}
.lp-cta__main-link.--small span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 45px;
  height: 45px;
  margin-right: 16px;
  font-size: 18px;
  color: #F37D7D;
  background-color: #FFF;
  border-radius: 50%;
}
.lp-cta__main-title {
  margin-bottom: 0;
  text-align: center;
  font-size: clamp(14px, 2.0833333333vw, 18px);
  font-weight: 700;
  line-height: 1.2;
}
.lp-cta__btn-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(15px, 1.953125vw, 30px) clamp(15px, 2.2786458333vw, 20px);
  margin-top: 15px;
}
.--has-tel .lp-cta__btn-list {
  -moz-column-gap: 15px;
       column-gap: 15px;
}
.lp-cta__sub {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .lp-cta__sub {
    display: none;
  }
}
@media (min-width: 768px) {
  .lp-cta__sub {
    transform: translateY(2%);
  }
}
.lp-cta__sub-title {
  margin-bottom: 0;
  font-size: clamp(12px, 1.7578125vw, 15px);
  font-weight: 700;
  line-height: 1.2;
}
.lp-cta__tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-size: clamp(37px, 5.5338541667vw, 48px);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.3;
  text-decoration: none;
}
.lp-cta__tel::before {
  content: "";
  flex-shrink: 0;
  transform: translateY(13%);
  display: block;
  width: clamp(30px, 4.5572916667vw, 40px);
  height: clamp(30px, 4.5572916667vw, 40px);
  background-image: url(../assets/icon/phone.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.lp-cta__tel-notice {
  transform: translateX(8%);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  text-align: center;
  font-size: clamp(12px, 1.7578125vw, 15px);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.lp-cta__tel-notice .--small {
  font-size: clamp(10px, 1.4973958333vw, 13px);
}

.sitemap {
  display: flex;
  max-width: 720px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .sitemap {
    display: block;
  }
}
.sitemap__main {
  width: calc(100% - 200px);
}
@media screen and (max-width: 767px) {
  .sitemap__main {
    width: 100%;
  }
}
.sitemap__sub {
  width: 200px;
}
@media screen and (max-width: 767px) {
  .sitemap__sub {
    width: 100%;
  }
}
.sitemap__block ul {
  padding-left: 0;
  list-style: none;
}
.sitemap__block ul li {
  margin-bottom: clamp(10px, 2.6041666667vw, 30px);
}
.sitemap__block ul li a, .sitemap__block ul li span {
  font-size: clamp(16px, 2.2135416667vw, 18px);
  font-weight: 700;
  text-decoration: none;
}
.sitemap__block ul li ul {
  display: grid;
  gap: 4px;
  padding-left: 10px;
}
.sitemap__block ul li ul li {
  margin-top: 4px;
  margin-bottom: 0;
}
.sitemap__block ul li ul li a {
  font-size: clamp(13px, 1.8880208333vw, 16px);
  color: rgba(18, 30, 46, 0.5);
}

/* -------------------------------------------------------------------
  base
------------------------------------------------------------------- */
html,
body {
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
}

body {
  position: relative;
  font-size: clamp(14px, 1.953125vw, 16px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.7;
  color: #121E2E;
}
body.--on {
  overflow: hidden;
}

a {
  color: #121E2E;
  text-decoration: underline;
}

p {
  margin-top: 0;
}
p:last-child {
  margin-bottom: 0;
}

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

figure {
  margin: 0;
}

b, strong {
  font-weight: 700;
}

* {
  box-sizing: border-box;
}

h2, h3, h4, h5 {
  margin: 0;
}

button {
  cursor: pointer;
}

.fw-b {
  font-weight: 700;
}
.fw-m {
  font-weight: 500;
}
.fw-l {
  font-weight: 400;
}

.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}

.scroll-top {
  position: absolute;
  right: 15px;
  top: -15px;
  z-index: 500;
  display: grid;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  padding: 10px;
  border-radius: 50%;
  background-color: white;
  box-shadow: 0 5px 5px rgba(180, 80, 52, 0.15);
  text-align: center;
  font-size: 0.8rem;
  text-decoration: none;
  line-height: 1;
  transition: all linear 0.3s;
  transform: scale(0) translateY(-100%);
}
.--header-scroll-on .scroll-top {
  transform: scale(1) translateY(-100%);
}

.title-h2 {
  position: relative;
  width: calc(100% - 30px);
  max-width: 1200px;
  margin: clamp(35px, 6.5104166667vw, 65px) auto 30px;
  padding-left: clamp(20px, 3.5807291667vw, 35px);
  font-size: clamp(22px, 3.6458333333vw, 34px);
}
.title-h2::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  width: clamp(15px, 2.2786458333vw, 20px);
  height: clamp(15px, 2.2786458333vw, 20px);
  margin: auto;
  background-color: #DE863F;
  border-radius: 50%;
}
.title-h2.--small {
  font-size: clamp(16px, 3.2552083333vw, 34px);
}

.category-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  width: calc(100% - 30px);
  max-width: 1200px;
  margin: auto;
}
.category-list__item {
  padding: 4px 10px;
  font-size: 14px;
  color: #FFF;
  border-radius: 5px;
  background-color: #DE863F;
}
.category-list__item.--bg-color-1 {
  background-color: #ADCC85;
}
.category-list__item.--bg-color-2 {
  background-color: #8DB1DB;
}
.category-list__item.--bg-color-3 {
  background-color: #4E71A6;
}

.--is-target-blank::after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-left: 3px;
  background-image: url(../assets/icon/blank.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center bottom;
}

@media screen and (min-width: 600px) {
  .scroll-top:hover {
    background-color: white;
  }
  .scroll-top:hover::before {
    border-color: #DE863F;
  }
}
/* -------------------------------------------------------------------
  1024px以上
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  768px以上
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  767以下
------------------------------------------------------------------- */
.common-result {
  position: relative;
  overflow-x: hidden;
  padding-block: clamp(26px, 3.6458333333vw, 30px) clamp(21px, 3.3203125vw, 30px);
  background-color: #F9F8F4;
}
.common-result.--high_school {
  padding-top: clamp(10px, 2.6041666667vw, 30px);
}
@media (min-width: 768px) {
  .common-result {
    background-color: transparent;
  }
  .common-result.--junior_high_school {
    background-image: linear-gradient(to right, #F7DFCF 50%, transparent 50%);
  }
  .common-result.--high_school {
    background-image: linear-gradient(to left, #A7B8D3 50%, transparent 50%);
  }
}
.common-result__inner {
  position: relative;
  z-index: 1;
}
.common-result__box {
  position: relative;
  padding-block: clamp(10px, 1.953125vw, 20px) clamp(30px, 5.2083333333vw, 50px);
  padding-inline: 15px;
  background-color: white;
  box-shadow: 2px 4px 10px rgba(18, 30, 46, 0.1);
  border-radius: 1px;
}
@media (max-width: 767.9px) {
  .common-result__box::before {
    content: "";
    position: absolute;
    top: -10px;
    z-index: -1;
    display: block;
    width: 100px;
    height: 100px;
    border-radius: 1px;
  }
  .--junior_high_school .common-result__box::before {
    left: -10px;
    background-color: #DD6717;
  }
  .--high_school .common-result__box::before {
    right: -10px;
    background-color: #4E71A6;
  }
}
.common-result__header {
  text-align: center;
  font-family: "Shippori Mincho B1", serif;
  line-height: 1.2;
}
.common-result__year {
  font-size: clamp(14px, 2.0833333333vw, 18px);
}
.common-result__title {
  font-size: clamp(20px, 3.2552083333vw, 30px);
  font-weight: 500;
}
.--junior_high_school .common-result__title .--emphasis {
  color: #DD6717;
}
.--high_school .common-result__title .--emphasis {
  color: #4E71A6;
}
.common-result__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: center;
  gap: 15px clamp(10px, 3.90625vw, 50px);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  width: 847px;
  max-width: 100%;
  margin-inline: auto;
  margin-top: clamp(15px, 2.9296875vw, 30px);
}
@media (min-width: 1024px) {
  .common-result__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 599.9px) {
  .common-result__list {
    -moz-column-gap: 7px;
         column-gap: 7px;
  }
}
.common-result__btn-wrap {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  -moz-column-gap: clamp(10px, 3.90625vw, 50px);
       column-gap: clamp(10px, 3.90625vw, 50px);
  margin-top: clamp(15px, 2.9296875vw, 30px);
}
@media (max-width: 599.9px) {
  .common-result__btn-wrap {
    -moz-column-gap: 7px;
         column-gap: 7px;
  }
}
.common-result__img {
  position: absolute;
  bottom: calc(-1 * clamp(21px, 3.3203125vw, 30px));
  width: clamp(306px, 59.765625vw, 612px);
}
.--junior_high_school .common-result__img {
  left: 0;
  transform: translateX(clamp(-50%, -16vw, -37%));
}
.--high_school .common-result__img {
  right: 0;
  transform: translateX(clamp(37%, 16vw, 50%));
}
.common-result .content-result {
  max-width: 250px;
}
.common-result .btn {
  width: 300px;
  max-width: 100%;
}

.common-news-list.--thin {
  width: 720px;
  max-width: 100%;
  margin-inline: auto;
}
.common-news-list__labels {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
@media (min-width: 600px) {
  .common-news-list__labels {
    justify-content: center;
  }
}
.common-news-list__list {
  margin-top: clamp(20px, 3.2552083333vw, 30px);
}
.common-news-list__section:not(.is-active) {
  display: none;
}

body {
  background-image: repeating-linear-gradient(to right, transparent 0, transparent 15.8px, #FBFAF7 15.8px, #FBFAF7 17.3px), repeating-linear-gradient(to bottom, transparent 0, transparent 13.8px, #FBFAF7 13.8px, #FBFAF7 15.3px);
  background-size: 17.3px 15.8px;
  background-repeat: repeat;
}

.home-fv {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  height: clamp(310px, 70.703125vw, 776px);
  padding-bottom: clamp(15px, 2.9296875vw, 30px);
  background-image: url(../assets/home/fv-sp.jpg);
  background-size: auto 100%;
  background-position: center center;
  background-repeat: no-repeat;
}
@media (min-width: 768px) {
  .home-fv {
    background-image: url(../assets/home/fv-pc.jpg);
  }
}
.home-fv__banner-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px 20px;
}
.home-fv .img-banner {
  width: clamp(227px, 29.5572916667vw, 350px);
  aspect-ratio: 540/211;
  box-shadow: 0 5px 5px rgba(18, 30, 46, 0.15);
}

.common-thumb-slider__visual {
  margin-bottom: clamp(15px, 4.2317708333vw, 50px);
}
@media screen and (max-width: 599px) {
  .common-thumb-slider__list {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
}

.home-thumb-slider__cta .common-cta__wrap {
  padding-inline: 0;
}

.home-fv-news {
  background-color: #F9F8F4;
}
.home-fv-news__inner {
  display: flex;
  max-width: 850px;
  margin-inline: auto;
}
.home-fv-news__title {
  flex-shrink: 0;
  align-self: center;
  display: inline-block;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  font-family: "Open Sans", sans-serif;
  font-size: clamp(13px, 1.8229166667vw, 15px);
  text-transform: uppercase;
  line-height: 1.5;
  transform: rotate(90deg);
}
.home-fv-news .content-news {
  padding: clamp(15px, 2.2786458333vw, 20px) 15px;
  border-left: 1px solid #A8ADB4;
}
.home-fv-news .content-news::after {
  display: none;
}

.home-thumb-slider {
  padding-block: clamp(30px, 5.2083333333vw, 50px);
}
.home-thumb-slider__cta {
  margin-top: clamp(30px, 5.2083333333vw, 50px);
}

.home-rate {
  padding-top: clamp(254px, 35.2213541667vw, 287px);
  height: clamp(460px, 67.96875vw, 584px);
  background-size: auto 100%;
  background-position: center center;
  background-repeat: no-repeat;
}
@media screen and (min-width: 1921px) {
  .home-rate {
    background-size: 100% auto;
  }
}
.home-rate__circle {
  position: relative;
  display: grid;
  place-items: center;
  width: clamp(180px, 27.9947916667vw, 250px);
  height: clamp(180px, 27.9947916667vw, 250px);
  margin-left: clamp(15px, 2.9296875vw, 30px);
  border-radius: 50%;
  background-color: #F9F8F4;
}
@media (min-width: 768px) {
  .home-rate__circle {
    margin-left: clamp(60px, 12.6953125vw, 135px);
  }
}
.home-rate__circle-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #F9F8F4;
}
.home-rate__circle-svg .--progress {
  transform: rotate(-90deg);
  transform-origin: 50% 50%;
  stroke: #DE863F;
}
.home-rate__circle-svg .--progress.--animated {
  animation: fillup 1.2s ease-out forwards;
}
.home-rate__text {
  position: relative;
  display: grid;
  place-items: center;
  width: clamp(109px, 16.8619791667vw, 150px);
  height: clamp(109px, 16.8619791667vw, 150px);
  border-radius: 50%;
  background-color: white;
}
.home-rate__label {
  display: block;
  text-align: center;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(12px, 1.8229166667vw, 16px);
  line-height: 1.2;
}
.home-rate__rate {
  text-align: center;
  color: #DD6717;
  font-family: "Open Sans", sans-serif;
  font-size: clamp(40px, 5.859375vw, 50px);
  font-weight: 700;
  line-height: 1.1;
}
.home-rate__rate::after {
  content: attr(after);
  font-size: clamp(14px, 2.2135416667vw, 20px);
}
.home-rate__object {
  position: absolute;
}
.home-rate__object.--l {
  bottom: clamp(14px, 3.515625vw, 40px);
  left: calc(-1 * clamp(8px, 2.0833333333vw, 24px));
  width: clamp(30px, 4.6875vw, 42px);
}
@media (min-width: 768px) {
  .home-rate__object.--l {
    bottom: clamp(40px, 7.9427083333vw, 82px);
  }
}
.home-rate__object.--r {
  top: clamp(30px, 4.6875vw, 42px);
  right: calc(-1 * clamp(16px, 3.125vw, 32px));
  width: clamp(52px, 8.1380208333vw, 73px);
}

.home-gallery__item {
  width: clamp(121px, 24.0885416667vw, 249px);
  height: clamp(80px, 16.2109375vw, 169px);
}
.home-gallery__img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.home-header {
  display: flex;
  align-items: center;
  -moz-column-gap: clamp(25px, 4.8828125vw, 50px);
       column-gap: clamp(25px, 4.8828125vw, 50px);
  margin-bottom: clamp(20px, 3.2552083333vw, 30px);
}
.home-header__title {
  flex-shrink: 0;
  display: grid;
  row-gap: 15px;
  font-weight: 500;
  line-height: 1.2;
  writing-mode: vertical-rl;
}
.home-header__title::after {
  content: attr(en);
  transform: rotate(180deg);
  display: block;
  border-left: 1px solid #121E2E;
  text-align: right;
  font-family: "Open Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}
.home-header__title-text {
  padding-inline: 10px 5px;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(32px, 4.5572916667vw, 38px);
  letter-spacing: 0.2em;
}
.home-header__title-text::first-letter {
  color: #DE863F;
}
.home-header__description {
  font-size: clamp(13px, 1.8229166667vw, 15px);
  line-height: 1.7;
  letter-spacing: 0.05em;
}

.home-classroom {
  padding-block: 50px;
  background-color: #D8D5D1;
}
.home-classroom__box {
  padding: clamp(30px, 5.2083333333vw, 50px) clamp(15px, 3.5807291667vw, 40px);
  background-color: white;
}
.home-classroom__contents {
  max-width: 958px;
  margin-inline: auto;
}
.home-classroom__area-list {
  display: grid;
  gap: clamp(20px, 3.2552083333vw, 30px);
}
@media (min-width: 768px) {
  .home-classroom__area-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
.home-classroom__area-title {
  padding-bottom: clamp(5px, 1.3020833333vw, 15px);
  border-bottom: 1px solid #121E2E;
  font-size: clamp(16px, 2.2135416667vw, 18px);
  line-height: 1.2;
}
.home-classroom__classroom-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 10px;
  margin-top: 15px;
}
.home-classroom .label {
  font-size: clamp(13px, 1.8229166667vw, 15px);
}
.home-classroom .btn {
  margin: 15px 0 0 auto;
  width: 130px;
}

.home-copy {
  position: relative;
  height: clamp(460px, 59.8958333333vw, 584px);
  padding-block: clamp(30px, 8.1380208333vw, 95px);
  padding-right: 15px;
  background: url(../assets/home/copy-sp.jpg) center center no-repeat;
  background-size: auto 100%;
}
.home-copy::before {
  content: "";
  position: absolute;
  top: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to right, #EEEDEC 50%, #FDFEF8 50%);
}
@media (min-width: 768px) {
  .home-copy {
    background-image: url(../assets/home/copy-pc.jpg);
  }
}
@media (min-width: 1366px) {
  .home-copy {
    padding-right: 0;
  }
}
.home-copy__copy {
  display: flex;
  flex-direction: row-reverse;
  gap: clamp(10px, 1.6276041667vw, 15px);
  font-family: "Shippori Mincho B1", serif;
  line-height: 1;
}
.home-copy__copy-text {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: clamp(6px, 1.1067708333vw, 11px) 8px clamp(8px, 1.1067708333vw, 9px);
  background-color: #DE863F;
  color: white;
  font-size: clamp(18px, 2.9947916667vw, 28px);
  writing-mode: vertical-rl;
  letter-spacing: 0.15em;
}

.home-voice {
  padding-top: clamp(20px, 4.5572916667vw, 50px);
}
@media (min-width: 768px) {
  .home-voice {
    padding-bottom: clamp(20px, 4.5572916667vw, 50px);
  }
}
.home-voice__inner {
  position: relative;
}
@media (min-width: 768px) {
  .home-voice__inner {
    display: flex;
    -moz-column-gap: clamp(30px, 7.5520833333vw, 86px);
         column-gap: clamp(30px, 7.5520833333vw, 86px);
  }
  .home-voice__inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    z-index: -1;
    transform: translateY(-36%) translateX(-150%);
    display: block;
    width: clamp(331px, 64.6484375vw, 662px);
    height: clamp(331px, 64.6484375vw, 662px);
    background-color: #FCF3EC;
    border-radius: 50%;
  }
}
.home-voice__title {
  flex-shrink: 0;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(32px, 4.5572916667vw, 38px);
  font-weight: 400;
  color: #DE863F;
  line-height: 1;
}
@media (min-width: 768px) {
  .home-voice__title {
    writing-mode: vertical-rl;
    letter-spacing: 0.05em;
  }
}
.home-voice__voice-list {
  padding-inline: 5px;
}
@media (min-width: 600px) {
  .home-voice__voice-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    -moz-column-gap: clamp(10px, 2.6041666667vw, 30px);
         column-gap: clamp(10px, 2.6041666667vw, 30px);
    margin-top: 50px;
    padding-inline: 0;
  }
}
.home-voice__voice {
  display: flex;
}
@media (max-width: 599.9px) {
  .home-voice__voice {
    align-items: flex-end;
  }
  .home-voice__voice:nth-child(2n) {
    flex-direction: row-reverse;
    transform: translateX(5px);
  }
}
.home-voice__voice-label {
  flex-shrink: 0;
  position: relative;
  z-index: 2;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: 5px;
  background-color: white;
  border: 1px solid #121E2E;
  border-radius: 1px;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(11px, 1.5625vw, 13px);
  line-height: 1;
  writing-mode: vertical-rl;
  letter-spacing: 0.05em;
}
@media (max-width: 599.9px) {
  .home-voice__voice-label {
    transform: translateX(10px);
  }
  .home-voice__voice:nth-child(2n) .home-voice__voice-label {
    transform: translateX(-10px);
  }
}
.home-voice__voice-contents {
  position: relative;
  left: -1px;
}
@media (min-width: 600px) {
  .home-voice__voice-contents {
    padding: 10px clamp(5px, 1.3020833333vw, 15px) 5px;
    background-color: white;
    border: 1px solid #121E2E;
  }
}
@media (max-width: 599.9px) {
  .home-voice__voice-contents {
    display: flex;
    align-items: flex-end;
    gap: 5px;
  }
  .home-voice__voice:nth-child(2n) .home-voice__voice-contents {
    flex-direction: row-reverse;
  }
}
.home-voice__voice-img {
  flex-shrink: 0;
  display: block;
  height: clamp(147px, 22.5911458333vw, 200px);
  margin-inline: auto;
}
.home-voice__voice-description {
  padding: 5px 0 5px 10px;
  border-left: 1px solid #121E2E;
  font-size: clamp(13px, 1.8229166667vw, 15px);
  letter-spacing: 0.05em;
}
@media (min-width: 600px) {
  .home-voice__voice-description {
    padding: 15px 6px;
    border-top: 1px solid #121E2E;
    border-left: 0;
  }
}
@media (max-width: 599.9px) {
  .home-voice__voice-description {
    display: flex;
    align-items: center;
    min-height: 100px;
  }
  .home-voice__voice:nth-child(2n) .home-voice__voice-description {
    padding: 5px 10px 5px 0;
    border-right: 1px solid #121E2E;
    border-left: 0;
  }
}

.home-event__inner {
  position: relative;
  padding-top: clamp(20px, 4.5572916667vw, 50px);
}
@media (min-width: 600px) {
  .home-event__box {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    height: 66%;
    padding: clamp(10px, 1.6276041667vw, 15px);
    background-color: #F9F8F4;
  }
  .home-event__box-circles {
    display: flex;
    justify-content: space-between;
  }
  .home-event__box-circles::before, .home-event__box-circles::after {
    content: "";
    display: block;
    width: clamp(10px, 1.6276041667vw, 15px);
    height: clamp(10px, 1.6276041667vw, 15px);
    border-radius: 50%;
    background-color: #D8D5D1;
  }
}
.home-event__contents {
  position: relative;
  max-width: calc(1080px + clamp(20px, 3.2552083333vw, 30px) * 2);
  margin-inline: auto;
}
@media (min-width: 600px) {
  .home-event__contents {
    padding-inline: clamp(20px, 3.2552083333vw, 30px);
  }
}
.home-event__list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  justify-content: center;
  gap: 15px;
}
@media (min-width: 480px) {
  .home-event__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 768px) {
  .home-event__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 599.9px) {
  .home-event__list {
    padding-inline: 10px;
  }
}
.home-event__banner {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  justify-self: center;
}

@media (min-width: 768px) {
  .home-banners {
    padding-block: clamp(20px, 4.5572916667vw, 50px);
    background-color: #D8D5D1;
  }
}
.home-banners__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px) {
  .home-banners__list {
    gap: 10px;
  }
}
@media (max-width: 599.9px) {
  .home-banners__list {
    margin-inline: -15px;
  }
}

.home-news {
  padding-top: 50px;
}
@media (min-width: 600px) {
  .home-news {
    padding-bottom: 50px;
    background-color: #F9F8F4;
  }
}
@media (min-width: 600px) {
  .home-news__box {
    padding: clamp(20px, 4.5572916667vw, 50px);
    background-color: white;
    border: 1px solid #121E2E;
  }
}
.home-news__contents {
  max-width: 1080px;
  margin-inline: auto;
}
@media (min-width: 1024px) {
  .home-news__contents {
    display: flex;
    -moz-column-gap: clamp(20px, 4.5572916667vw, 50px);
         column-gap: clamp(20px, 4.5572916667vw, 50px);
    align-items: flex-start;
  }
}
@media (min-width: 1024px) {
  .home-news__news {
    flex-shrink: 0;
    width: 540px;
  }
}
.home-news .common-news-list__labels {
  justify-content: flex-start;
}
.home-news .btn {
  width: 130px;
  margin-top: 20px;
  margin-left: auto;
}

.home-school__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 5px;
       column-gap: 5px;
}
@media (min-width: 600px) {
  .home-school__list {
    grid-template-columns: repeat(3, 1fr);
  }
}

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