@charset "UTF-8";
:root {
  --base-width: 1180px;
  --base-font-size: 16px;
  --base-color: #6b849c;
  --base-light-color: #e4eaf0;
  --key-color: #f6e211;
  --gray-color: #3e3a39;
  --all: #595757;
  --high: #64c8eb;
  --juniorhigh: #96cd7d;
  --kindergarten: #d28686;
  --nursery: #d8a85a;
  --gnenral: #6b849c;
}

@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 100;
  src: local("Roboto Thin"), local("Roboto-Thin"), url("./fonts/Roboto-Thin.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url("./fonts/Roboto-Light.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 400;
  src: local("Roboto Regular"), local("Roboto-Regular"), url("./fonts/Roboto-Regular.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 700;
  src: local("Roboto Bold"), local("Roboto-Bold"), url("./fonts/Roboto-Bold.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 900;
  src: local("Roboto Black"), local("Roboto-Black"), url("./fonts/Roboto-Black.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKJPlocal";
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans CJK JP"), local("NotoSansCJKjp-Regular"), local("Noto Sans JP"), local("NotoSansJP-Regular");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKJPsub";
  font-style: normal;
  font-weight: 400;
  src: url("./fonts/NotoSansJP-Regular-lws.woff2") format("woff2"), url("./fonts/NotoSansJP-Regular-lws.woff") format("woff"), url("./fonts/NotoSansJP-Regular-lws.otf") format("opentype");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKJPlocal";
  font-style: normal;
  font-weight: 500;
  src: local("Noto Sans CJK JP"), local("NotoSansCJKjp-Medium"), local("Noto Sans JP"), local("NotoSansJP-Medium");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKJPsub";
  font-style: normal;
  font-weight: 500;
  src: url("./fonts/NotoSansJP-Medium-lws.woff2") format("woff2"), url("./fonts/NotoSansJP-Medium-lws.woff") format("woff"), url("./fonts/NotoSansJP-Medium-lws.otf") format("opentype");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKJPlocal";
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans CJK JP"), local("NotoSansCJKjp-Bold"), local("Noto Sans JP"), local("NotoSansJP-Bold");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKJPsub";
  font-style: normal;
  font-weight: 700;
  src: url("./fonts/NotoSansJP-Bold-lws.woff2") format("woff2"), url("./fonts/NotoSansJP-Bold-lws.woff") format("woff"), url("./fonts/NotoSansJP-Bold-lws.otf") format("opentype");
  font-display: swap;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}

ul,
ol {
  padding: 0;
}

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

body {
  scroll-behavior: smooth;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

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

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

img {
  vertical-align: top;
}

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

button:focus {
  outline: 0;
}

input[type=text],
input[type=password],
textarea,
select {
  outline: none;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
ul:not([class]) {
  margin-bottom: 20px;
}
ul:not([class]) li {
  font-size: 16px;
  font-size: 1.6rem;
}

ol:not([class]) {
  margin-bottom: 20px;
}
ol:not([class]) li {
  font-size: 16px;
  font-size: 1.6rem;
}

h1:not[class], h2:not[class], h3:not[class], h4:not[class], h5:not[class] {
  padding-bottom: 0;
}

.fSSS {
  font-size: 10px !important;
  font-size: 1rem !important;
}

.fSS {
  font-size: 12px !important;
  font-size: 1.2rem !important;
}

.fS {
  font-size: 14px !important;
  font-size: 1.4rem !important;
}

.fM {
  font-size: 16px !important;
  font-size: 1.6rem !important;
}

.fL {
  font-size: 18px !important;
  font-size: 1.8rem !important;
}

.fLL {
  font-size: 20px !important;
  font-size: 2rem !important;
}

.fLLL {
  font-size: 22px !important;
  font-size: 2.2rem !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.mt55 {
  margin-top: 5.5rem !important;
}

.mr55 {
  margin-right: 5.5rem !important;
}

.mb55 {
  margin-bottom: 5.5rem !important;
}

.ml55 {
  margin-left: 5.5rem !important;
}

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

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

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

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

.mt65 {
  margin-top: 6.5rem !important;
}

.mr65 {
  margin-right: 6.5rem !important;
}

.mb65 {
  margin-bottom: 6.5rem !important;
}

.ml65 {
  margin-left: 6.5rem !important;
}

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

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

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

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

.mt75 {
  margin-top: 7.5rem !important;
}

.mr75 {
  margin-right: 7.5rem !important;
}

.mb75 {
  margin-bottom: 7.5rem !important;
}

.ml75 {
  margin-left: 7.5rem !important;
}

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

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

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

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

.mt85 {
  margin-top: 8.5rem !important;
}

.mr85 {
  margin-right: 8.5rem !important;
}

.mb85 {
  margin-bottom: 8.5rem !important;
}

.ml85 {
  margin-left: 8.5rem !important;
}

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

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

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

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

.mt95 {
  margin-top: 9.5rem !important;
}

.mr95 {
  margin-right: 9.5rem !important;
}

.mb95 {
  margin-bottom: 9.5rem !important;
}

.ml95 {
  margin-left: 9.5rem !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.pt55 {
  padding-top: 5.5rem !important;
}

.pr55 {
  padding-right: 5.5rem !important;
}

.pb55 {
  padding-bottom: 5.5rem !important;
}

.pl55 {
  padding-left: 5.5rem !important;
}

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

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

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

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

.pt65 {
  padding-top: 6.5rem !important;
}

.pr65 {
  padding-right: 6.5rem !important;
}

.pb65 {
  padding-bottom: 6.5rem !important;
}

.pl65 {
  padding-left: 6.5rem !important;
}

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

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

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

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

.pt75 {
  padding-top: 7.5rem !important;
}

.pr75 {
  padding-right: 7.5rem !important;
}

.pb75 {
  padding-bottom: 7.5rem !important;
}

.pl75 {
  padding-left: 7.5rem !important;
}

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

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

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

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

.pt85 {
  padding-top: 8.5rem !important;
}

.pr85 {
  padding-right: 8.5rem !important;
}

.pb85 {
  padding-bottom: 8.5rem !important;
}

.pl85 {
  padding-left: 8.5rem !important;
}

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

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

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

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

.pt95 {
  padding-top: 9.5rem !important;
}

.pr95 {
  padding-right: 9.5rem !important;
}

.pb95 {
  padding-bottom: 9.5rem !important;
}

.pl95 {
  padding-left: 9.5rem !important;
}

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

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

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

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

.w5 {
  width: 5% !important;
}

.w10 {
  width: 10% !important;
}

.w15 {
  width: 15% !important;
}

.w20 {
  width: 20% !important;
}

.w25 {
  width: 25% !important;
}

.w30 {
  width: 30% !important;
}

.w35 {
  width: 35% !important;
}

.w40 {
  width: 40% !important;
}

.w45 {
  width: 45% !important;
}

.w50 {
  width: 50% !important;
}

.w55 {
  width: 55% !important;
}

.w60 {
  width: 60% !important;
}

.w65 {
  width: 65% !important;
}

.w70 {
  width: 70% !important;
}

.w75 {
  width: 75% !important;
}

.w80 {
  width: 80% !important;
}

.w85 {
  width: 85% !important;
}

.w90 {
  width: 90% !important;
}

.w95 {
  width: 95% !important;
}

.w100 {
  width: 100% !important;
}

@media screen and (max-width: 767px) {
  .md-mt0 {
    margin-top: 0px !important;
  }
  .md-pt50 {
    padding-top: 50px !important;
  }
  .md-mt15 {
    margin-top: 15px !important;
  }
  .md-mt20 {
    margin-top: 20px !important;
  }
  .md-mt30 {
    margin-top: 30px !important;
  }
  .md-mt40 {
    margin-top: 40px !important;
  }
  .md-mt50 {
    margin-top: 50px !important;
  }
  .md-mb0 {
    margin-bottom: 0px !important;
  }
  .md-mb15 {
    margin-bottom: 15px !important;
  }
  .md-pt0 {
    padding-top: 0px !important;
  }
  .md-pb0 {
    padding-bottom: 0px !important;
  }
  .md-pb15 {
    padding-bottom: 15px !important;
  }
  .md-pb30 {
    padding-bottom: 30px !important;
  }
  .md-pr0 {
    padding-right: 0px !important;
  }
  .md-pl0 {
    padding-left: 0px !important;
  }
}
@media screen and (max-width: 480px) {
  .sp-pl20 {
    padding-left: 20px !important;
  }
  .sp-mr0 {
    margin-right: 0 !important;
  }
  .sp-ml0 {
    margin-left: 0 !important;
  }
  .sp-mb10 {
    margin-bottom: 10px !important;
  }
}
.robot-r {
  font-family: Roboto;
  font-weight: 400;
}

.robot-l {
  font-family: Roboto;
  font-weight: 300;
}

.robot-t {
  font-family: Roboto;
  font-weight: 100;
}

.mincho {
  font-family: "Yu Mincho", YuMincho, serif;
}

.marugo {
  font-family: "ヒラギノ丸ゴ Std w6";
}

.ffs-palt {
  font-feature-settings: "palt" 1;
}

.text-10 {
  font-size: 10px !important;
  font-size: 1rem !important;
}

.text-12 {
  font-size: 12px !important;
  font-size: 1.2rem !important;
}

.text-13 {
  font-size: 13px !important;
  font-size: 1.3rem !important;
}

.text-14 {
  font-size: 14px !important;
  font-size: 1.4rem !important;
}

.text-15 {
  font-size: 15px !important;
  font-size: 1.5rem !important;
}

.text-16 {
  font-size: 16px !important;
  font-size: 1.6rem !important;
}

.text-17 {
  font-size: 17px !important;
  font-size: 1.7rem !important;
}

.text-18 {
  font-size: 18px !important;
  font-size: 1.8rem !important;
}

.text-19 {
  font-size: 19px !important;
  font-size: 1.9rem !important;
}

.text-20 {
  font-size: 20px !important;
  font-size: 2rem !important;
}

.text-21 {
  font-size: 21px !important;
  font-size: 2.1rem !important;
}

.text-22 {
  font-size: 22px !important;
  font-size: 2.2rem !important;
}

.text-23 {
  font-size: 23px !important;
  font-size: 2.3rem !important;
}

.text-24 {
  font-size: 24px !important;
  font-size: 2.4rem !important;
}

.text-25 {
  font-size: 25px !important;
  font-size: 2.5rem !important;
}

.text-shadow {
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.9), 0 0 4px rgba(0, 0, 0, 0.5);
}

.text-center {
  text-align: center !important;
}

.text-justify {
  text-align: justify !important;
}

.text-right {
  text-align: right !important;
}

.text-left {
  text-align: left !important;
}

@media screen and (max-width: 767px) {
  .md-text-center {
    text-align: center !important;
  }
  .md-text-right {
    text-align: right !important;
  }
  .md-text-left {
    text-align: left !important;
  }
}
@media screen and (max-width: 480px) {
  .sp-text-12 {
    font-size: 12px !important;
    font-size: 1.2rem !important;
  }
  .sp-text-14 {
    font-size: 14px !important;
    font-size: 1.4rem !important;
  }
  .sp-text-16 {
    font-size: 16px !important;
    font-size: 1.6rem !important;
  }
  .sp-text-20 {
    font-size: 20px !important;
    font-size: 2rem !important;
  }
  .sp-text-center {
    text-align: center !important;
  }
  .sp-text-right {
    text-align: right !important;
  }
  .sp-text-left {
    text-align: left !important;
  }
}
.underline {
  text-decoration: underline;
}

.no-underline {
  text-decoration: none;
}

.normal {
  font-weight: normal !important;
}

.bold {
  font-weight: bold !important;
}

.italic {
  font-style: italic;
}

.indent {
  text-indent: 1em;
}

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

.ls {
  letter-spacing: 0.1em !important;
}

.noindent {
  letter-spacing: 0 !important;
  text-indent: 0 !important;
}

.lh1 {
  line-height: 1;
}

.lh12 {
  line-height: 1.2;
}

.lh14 {
  line-height: 1.4;
}

.lh16 {
  line-height: 1.6;
}

.lh18 {
  line-height: 1.8;
}

.nowrap {
  white-space: nowrap;
}

.vertical-rl {
  writing-mode: vertical-rl;
}

.text-crop::before {
  content: "";
  display: block;
  height: 0;
  width: 0;
  margin-top: calc((1 - 1.2) * 0.5em);
}

.hidetxt {
  -moz-user-select: none;
  -ms-user-select: none;
  -khtml-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

.static {
  position: static;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.floL {
  float: left;
}

.floR {
  float: right;
}

.imgL {
  float: left;
  margin-right: 50px;
  margin-bottom: 35px;
  width: fit-content;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .imgL {
    float: none;
    margin: 0 auto 20px auto;
  }
}

.imgR {
  float: right;
  margin-left: 50px;
  margin-bottom: 35px;
  width: fit-content;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .imgR {
    float: none;
    margin: 0 auto 20px auto;
  }
}

.clear {
  clear: both;
}

.clear-left {
  clear: left;
}

.clear-right {
  clear: right;
}

.clearfix:after {
  content: "";
  clear: both;
  display: table;
}

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

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

.v-bottom {
  vertical-align: bottom;
}

.margin-auto {
  margin: auto;
}

.mt-auto {
  margin-top: auto;
}

.mr-auto {
  margin-right: auto;
}

.ml-auto {
  margin-left: auto;
}

.mb-auto {
  margin-bottom: auto;
}

.block {
  display: block;
}

.inline {
  display: inline;
}

.overhidden {
  overflow: hidden;
}

.inline-block {
  display: inline-block;
}

.visible {
  visibility: visible;
}

.invisible {
  visibility: hidden;
}

.hidden {
  display: none !important;
}

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

@media screen and (max-width: 767px) {
  .hidden-tablet {
    display: none !important;
  }
}

@media screen and (max-width: 480px) {
  .hidden-sp {
    display: none !important;
  }
}

@media screen and (max-width: 1180px) {
  .display-pc {
    display: block !important;
  }
}

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

@media screen and (max-width: 480px) {
  .display-sp {
    display: block !important;
  }
}

.hover-img {
  position: relative;
  overflow: hidden;
}
.hover-img > img {
  position: relative;
  z-index: 0;
  transform: scale(1);
  transition: transform 600ms ease-out;
}
.hover-img::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0px solid transparent;
  transform: translate3d(0, 0, 1px);
  transition: border 250ms ease-out;
}

*:hover > .hover-img > img {
  transform: scale(1.05);
}
*:hover > .hover-img::before {
  border: 10px solid var(--base_color);
}

.radius {
  border-radius: 100%;
}

.border-radius-s {
  border-radius: 4px;
}

.border-radius-m {
  border-radius: 8px;
}

.border-radius-l {
  border-radius: 12px;
}

.gray-box {
  display: inline-flex;
  align-items: center;
  background-color: #efefef;
  padding: 5px 14px;
}

.radius-box {
  padding: 20px 20px;
  border-radius: 6px;
}

.box {
  padding: 15px;
  border-width: 1px;
  border-style: solid;
}

.box-solid {
  padding: 20px;
  padding: clamp(20px, 5vw, 30px);
}

.box-solid-narrow {
  padding: 5px;
  padding: clamp(5px, 2vw, 15px);
}

.object-cover {
  width: inherit;
  object-fit: cover !important;
  width: 100%;
  height: 100%;
}

.object-cover-child > * {
  width: inherit;
  object-fit: cover !important;
  width: 100%;
  height: 100%;
}

.object-contain {
  width: inherit;
  object-fit: contain !important;
  width: 100%;
  height: 100%;
}

.object-fit-cover {
  object-fit: cover;
}

.object-fit-contain {
  object-fit: contain;
}

hr {
  margin: 50px 0;
  padding: 0;
  border: none;
}

hr.border {
  border-top: 1px solid var(--base_color);
}

.no-bg {
  background: none !important;
}

@media screen and (max-width: 480px) {
  .sp-img-full {
    width: 100%;
    height: auto;
  }
}
.content-visibility {
  content-visibility: auto;
  contain-intrinsic-size: 1000px;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 10px;
  color: #231815;
  font-family: "Yu Gothic", sans-serif;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  body {
    -webkit-text-size-adjust: 100%;
  }
}

a {
  text-decoration: none;
  color: #231815;
}
a:hover {
  color: #0db4b4;
}

*:focus {
  outline: none;
}

p {
  font-size: 16px;
  font-size: 1.5rem;
  line-height: 1.7;
  text-align: justify;
}

.page-block > article p:not(:last-of-type) {
  margin-bottom: 1.6em;
}

.page {
  position: relative;
}
@media screen and (max-width: 767px) {
  .page {
    position: relative;
    overflow: hidden;
  }
}

@media screen and (max-width: 767px) {
  .is-sp-open .page {
    overflow-x: hidden;
  }
  .is-sp-open .page::before {
    transform: translateX(0%);
    transition: transform 200ms ease-out;
  }
  .is-sp-open .first-view-area {
    pointer-events: none;
  }
}

.page-block {
  position: relative;
  margin-top: 130px;
  margin-bottom: 458px;
}
@media screen and (max-width: 767px) {
  .page-block {
    margin-top: 0;
    margin-bottom: 0;
  }
}

@media screen and (max-width: 767px) {
  .parallax-target {
    position: fixed;
    top: 0;
    left: 0;
    width: auto;
    height: inherit;
  }
  .parallax-target:not(:first-of-type) {
    display: none;
  }
}

#group-nav-trigger {
  position: relative;
  z-index: 1;
}

.contents-block {
  max-width: 1180px;
  margin: 0 auto;
}

body:not(.home) .contents-block {
  padding-top: 130px;
}
@media screen and (max-width: 767px) {
  body:not(.home) .contents-block {
    padding-top: 54px;
  }
}

.container {
  padding-top: 50px;
}
@media screen and (max-width: 767px) {
  .container {
    padding-top: 95px;
  }
}

.container__inner {
  padding-left: 30px;
  padding-right: 30px;
}
@media screen and (max-width: 767px) {
  .container__inner {
    padding-left: 5.3333vw;
    padding-right: 5.3333vw;
  }
}

.header {
  position: absolute;
  z-index: 2;
  width: 100%;
  height: 130px;
  background-color: #fff;
}
.header.is-fixed {
  position: fixed;
  top: 0;
}
@media screen and (max-width: 767px) {
  .header {
    position: fixed;
    z-index: 900;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    scroll-behavior: smooth;
    transform: translateX(100%);
    transition: transform ease-in-out 300ms;
  }
}

.is-sp-open .header {
  transform: translate(0%);
  transition: transform ease-in-out 300ms;
}

@media screen and (max-width: 767px) {
  .sp-scroll-container {
    width: 100%;
    -webkit-overflow-scrolling: touch;
  }
}

.fixed {
  position: fixed;
  transform: translateY(0);
  top: 0;
}

/*
.container-header {
  position: fixed;
  top:0;
  right:0;
  //width: 100%;
  height: g.$header_height;
  transition: transform 400ms ease-in;

  //background-color: g.$header_bg;
  // display: flex;
  // align-items: center;

  // position: fixed;
  // z-index: 110;

  // width: 100%;
  // height: g.$header_height;
  // background-color: rgba(255, 255, 255, 0);
  // padding-left: g.$margin; //20px;
  // padding-right: g.$margin; //20px;
  //transition: background-color 100ms ease-in-out, height 200ms ease-in-out;

  // @include g.mq(md) {
  //   height: g.$sp_header_height;
  //   height: clamp(g.$sp_header_height, calc(70px + 1vw), g.$header_height);
  // }
  // @include g.mq(sm) {
  //   padding-left: clamp(20px, 1vw, g.$sp_margin);
  //   padding-right: clamp(20px, 1vw, g.$sp_margin);
  //   height: g.$sp_header_height;
  //   background-color: rgba(255, 255, 255, 0.9);
  // }
  // @include g.mq(xs) {
  //   padding-left: 10px;
  //   padding-right: 10px;
  // }
  // &__inner {
  //   //max-width: g.$base_width;
  //   display: flex;
  //   width: inherit;
  //   //margin: 0 auto;
  //   //position: relative;
  //   padding: 5px 0;
  //   height: 100%;
  // }
  &.translucent {
    //background-color: rgba(255, 255, 255, 0.9);
    //height: g.$sp_header_height;
    transform: translateY(-130px);
    @include g.mq(md) {
      transform:none;
    }
  }
}
@include g.mq(md) {
  .container-header{
    position: static;
    height: auto;
  }
}
// @include g.mq(md) {
//   .header {
//     .link-list > li {
//       @include g.fts(13, 1.2);
//     }
//   }
// }
//gNav
*/
.container-nav {
  display: flex;
  flex-direction: column-reverse;
  width: 100%;
  max-width: var(--base-width);
  margin: 0 auto;
  padding: 0 30px;
}
@media screen and (max-width: 767px) {
  .container-nav {
    display: block;
    position: relative;
    top: 70px;
    width: auto;
    height: calc(100vh - 70px);
    background-color: #6b849c;
  }
}
.container-nav .target-nav {
  position: relative;
  z-index: 3;
  height: 65px;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .container-nav .target-nav {
    display: block;
    height: auto;
    text-align: center;
  }
  .container-nav .target-nav a,
  .container-nav .target-nav a:hover {
    color: #fff;
  }
}

.logo {
  width: 100%;
  max-width: 1180px;
  padding: 0 30px;
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 2;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .logo {
    display: none;
  }
}

.logo-mark {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 217px;
  height: 65px;
}

.sp-header {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp-header {
    display: block;
    position: fixed;
    z-index: 4;
    top: 0;
    left: 0;
    width: 100%;
    height: 54px;
    padding: 0 5.3333vw;
    background-color: #6b849c;
  }
  .sp-header .logo-mark {
    width: 154px;
    height: inherit;
  }
}

.gnav {
  display: flex;
  justify-content: center;
  position: relative;
}
.gnav::before {
  content: "";
  display: block;
  height: 65px;
  position: absolute;
  bottom: 0;
  z-index: -1;
  border-image-source: linear-gradient(#6b849c, #6b849c);
  border-image-slice: 0 fill;
  border-image-outset: 0 100vw 0 100vw;
  border-image-width: auto auto auto auto;
}
@media screen and (max-width: 767px) {
  .gnav {
    display: block;
  }
  .gnav::before {
    display: none;
  }
}

.gnav__item {
  width: 25%;
}
@media screen and (max-width: 767px) {
  .gnav__item {
    width: 100%;
  }
}
.gnav__item > span > a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  height: 65px;
  padding: 1em;
  position: relative;
  letter-spacing: 0.05em;
  transition: all 200ms ease-in-out;
  background-color: #6b849c;
}
.gnav__item > span > a:hover {
  color: #6b849c;
  background-color: #fff;
}
.gnav__item:not(:first-child) > span > a::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 30px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: -0.5px;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .gnav__item:not(:first-child) > span > a::before {
    display: none;
  }
}

.gnav__item-text {
  font-size: 20px;
  font-size: 2rem;
  font-size: clamp(1.5rem, 1.8vw, 2rem);
  line-height: 1;
}

/*
@include g.mq(cb){
  .nav-sub {
    width: 180px;
    //left:calc(180px + 5vw);

    left:clamp(180px+20px, calc(180px + 5vw), 180px+40px);
    //left:clamp(180px, calc(180px + 5vw), 260px)
    top: clamp(110px, 10vh, 297px);
  }
  .nav-sub__inner{

    li > a{
      font-size: clamp(1.2rem, 1.8vh, 1.6rem);
      // padding-top: clamp(0.2em,1vh,0.7em);
      // padding-bottom: clamp(0.2em,1vh,0.7em);
    }
  }
  .nav-sub__inner{
    // transform: translate(-101%, 200px);
    // transform: translate(-101%, clamp(160px, 24vh, 297px));
  }
  .gnav__item:hover .nav-sub__inner{
    // transform: translate(0, 200px);
    // transform: translate(0, clamp(160px, 24vh, 297px));
  }
}
*/
.target-nav {
  display: flex;
}
.target-nav__item {
  justify-content: flex-start;
  align-items: center;
}
.target-nav__item a {
  display: inline-block;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
  padding: 1.6em 1em;
  white-space: nowrap;
}
.target-nav__item a:hover {
  color: #6b849c;
}

.sp-menu-block {
  display: none;
}

.sp-menu-btn,
.sp-menu__label {
  display: none;
}

@media screen and (max-width: 767px) {
  .sp-menu-block {
    pointer-events: auto !important;
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 990;
    cursor: pointer;
    width: 70px;
    height: 70px;
    background-color: #000;
    transition: transform 400ms ease-in-out;
  }
  .sp-menu-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 48px;
    height: 39px;
    will-change: transition, position;
  }
  .sp-menu-btn label {
    display: block;
    width: 48px;
    height: 39px;
    cursor: pointer;
  }
}
@media screen and (max-width: 767px) {
  .sp-menu-btn svg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .sp-menu-btn input[type=checkbox] {
    border: none;
    width: inherit;
    height: inherit;
    -webkit-appearance: none;
  }
  .sp-menu-btn input[type=checkbox]::after {
    display: none;
  }
  .sp-menu-btn .line--1,
  .sp-menu-btn .line--3 {
    --total-length: 100;
    --offset: -27;
    --length: 30;
  }
  .sp-menu-btn .line--2 {
    --total-length: 100;
    --offset: -46.5;
    --length: 26;
  }
  .sp-menu-btn path {
    fill: none;
    stroke: #ffffff;
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: var(--length) var(--total-length);
    stroke-dashoffset: var(--offset);
    transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
    transform: translateX(15px);
  }
  .sp-menu-block[aria-expanded=true] svg path {
    transform: translateX(-9px);
  }
  .sp-menu-block[aria-expanded=true] svg .line--1,
  .sp-menu-block[aria-expanded=true] svg .line--3 {
    --offset: 0;
    --length: 25;
  }
  .sp-menu-block[aria-expanded=true] svg .line--2 {
    --offset: -36;
    --length: 0;
  }
}
.bread-crumb {
  margin-left: 63px;
}
.bread-crumb ul {
  display: flex;
  flex-flow: row wrap;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .bread-crumb ul {
    margin: 0 5.3333vw;
  }
}
.bread-crumb .is-current {
  font-weight: bold;
}
.bread-crumb a,
.bread-crumb span {
  color: #603813;
  display: inline-flex;
  align-items: center;
  font-size: 14px;
  font-size: 1.4rem;
  padding-right: 10px;
}
.bread-crumb li:last-child a,
.bread-crumb li:last-child span {
  font-weight: bold;
}
.bread-crumb a:after,
.bread-crumb span:after {
  content: "";
  color: inherit;
  display: inline-block;
  height: 9px;
  width: 9px;
  border-right: 1px solid #603813;
  border-top: 1px solid #603813;
  transform: translate(-10px, -1px) rotate(45deg) skew(-5deg, -5deg);
  height: 8px;
  width: 8px;
  margin-right: 8px;
  margin-left: 10px;
  transform: translate(0, -1px) rotate(45deg) skew(-10deg, -10deg);
}
.bread-crumb a:hover {
  color: #0db4b4;
}
.bread-crumb li:last-child span:after {
  display: none;
}
@media screen and (max-width: 767px) {
  .bread-crumb {
    margin: 0 0 10px 0;
  }
  .bread-crumb a,
  .bread-crumb span,
  .bread-crumb a:after,
  .bread-crumb span:after {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1;
  }
}

.pagination {
  margin-top: 5px;
  display: flex;
  justify-content: center;
}
.pagination__pages {
  display: flex;
}
.pagination li {
  margin-right: 5px;
  margin-left: 5px;
}
.pagination li > a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  width: 32px;
  height: 100%;
  padding-top: 1px;
  background-color: #c9caca;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
  transition: background-color 200ms ease-in-out;
}
.pagination li > a:hover {
  color: #fff;
  background-color: #6b849c;
}
.pagination li.current a {
  color: #fff;
  background-color: #6b849c;
  border-color: #6b849c;
}
.pagination li.current a:hover {
  background-color: #8a9db0;
}

.pagination__prev,
.pagination__next {
  min-width: 32px;
  height: 32px;
}
@media screen and (max-width: 480px) {
  .pagination__prev,
  .pagination__next {
    width: auto;
  }
}
.pagination__prev .prev,
.pagination__prev .next,
.pagination__next .prev,
.pagination__next .next {
  display: inline-flex;
  align-items: center;
  height: inherit;
  min-width: 32px;
  color: #fff;
  background-color: #c9caca;
  transition: background-color 200ms ease-in-out;
}
.pagination__prev .prev:hover,
.pagination__prev .next:hover,
.pagination__next .prev:hover,
.pagination__next .next:hover {
  background-color: #6b849c;
}
.pagination__prev .prev,
.pagination__next .prev {
  justify-content: flex-start;
  margin-right: 5px;
}
.pagination__prev .prev:hover .arrow-circle,
.pagination__next .prev:hover .arrow-circle {
  transform: scale(-1) translateX(5px);
}
.pagination__prev .next,
.pagination__next .next {
  justify-content: flex-end;
  margin-left: 5px;
}
.pagination__prev .next:hover .arrow-circle,
.pagination__next .next:hover .arrow-circle {
  transform: translateX(5px);
}

.after-arrow,
.prev-arrow {
  position: relative;
  display: inline-block;
  width: 32px;
  height: 32px;
}
.after-arrow::after,
.prev-arrow::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) translateX(-3px) rotate(42deg) skew(-9deg);
}

.prev-arrow::after {
  transform: translate(-50%, -50%) translateX(2px) rotate(42deg) skew(-9deg) scale(-1, -1);
}

.page-nav {
  max-width: 645px;
  padding-top: 75px;
  display: grid;
  gap: 0 50px;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-areas: "prev pageback next";
  margin: 0 auto 0 auto;
}
@media screen and (max-width: 767px) {
  .page-nav {
    gap: 0 17px;
  }
}
.page-nav .page-nav__left,
.page-nav .page-nav__right,
.page-nav .page-nav__back {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  color: var(--base-color);
  font-size: 16px;
  font-size: 1.6rem;
  height: 50px;
  transition: all 300ms ease-in-out;
  border: 1px solid #cccccc;
  padding: 3px 30px 0 30px;
}
@media screen and (max-width: 767px) {
  .page-nav .page-nav__left,
  .page-nav .page-nav__right,
  .page-nav .page-nav__back {
    padding-left: 10px;
    padding-right: 10px;
  }
}
.page-nav .page-nav__left {
  grid-area: prev;
}
.page-nav .page-nav__left .text {
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .page-nav .page-nav__left {
    padding-left: 15px;
  }
}
.page-nav .page-nav__right {
  grid-area: next;
}
.page-nav .page-nav__right .text {
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .page-nav .page-nav__right {
    padding-right: 15px;
  }
}
.page-nav__back {
  grid-area: pageback;
}
.page-nav .text {
  display: inline-block;
  transition: all 200ms ease-out;
}
.page-nav .prev,
.page-nav .next {
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url(/assets/images/pict/arrow-base.svg);
  background-repeat: no-repeat;
  background-position: center;
  transition: all 200ms ease-out;
}
.page-nav .prev {
  margin-right: auto;
  transform: scale(-1, 1);
}
.page-nav .next {
  margin-left: auto;
}
.page-nav a:hover {
  border: 1px solid var(--base-color);
  background-color: var(--base-color);
}
.page-nav a:hover .text {
  color: #fff;
}
.page-nav a:hover .prev,
.page-nav a:hover .next {
  background-image: url(/assets/images/pict/arrow-white.svg);
}
.page-nav a:hover .prev {
  transform: scale(-1, 1) translateX(5px);
}
.page-nav a:hover .next {
  transform: translateX(5px);
}

.property-page-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.property-page-nav a {
  width: 50%;
  position: relative;
  color: #231815;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
  border: 2px solid var(--key-color);
  transition: all 200ms ease-in-out;
  padding-top: 1em;
  padding-bottom: 1em;
}
.property-page-nav a:hover {
  color: #0db4b4;
}
.property-page-nav .prev {
  border-right-width: 1px;
}
.property-page-nav .prev:before {
  position: relative;
  left: -20px;
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.3px 7.5px 4.3px 0;
  border-color: transparent var(--key-color) transparent transparent;
  transition: all 200ms ease-in-out;
}
.property-page-nav .next {
  border-left-width: 1px;
}
.property-page-nav .next:after {
  position: relative;
  right: -20px;
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.3px 0 4.3px 7.5px;
  border-color: transparent transparent transparent var(--key-color);
  transition: all 200ms ease-in-out;
}
.property-page-nav .prev:hover:before {
  left: -24px;
  border-color: transparent #6b849c transparent transparent;
}
.property-page-nav .next:hover:after {
  right: -24px;
  border-color: transparent transparent transparent #6b849c;
}

.back-list-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding-top: 1em;
  padding-bottom: 1em;
  color: #fff;
  border: 2px solid transparent;
  margin-top: -2px;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1;
  font-weight: bold;
  background-color: var(--key-color);
  transition: all ease-in-out 200ms;
}
.back-list-btn:hover {
  color: #6b849c;
  background-color: #fff;
  border-color: #6b849c;
}

.container-pagetop {
  pointer-events: none;
  position: fixed;
  display: flex;
  justify-content: flex-end;
  width: 100%;
  z-index: 1;
  bottom: 0px;
}

.pagetop-btn {
  opacity: 0;
  transition: opacity 300ms ease-in;
  pointer-events: auto;
  display: inline-block;
  width: 35px;
  height: 35px;
  background-repeat: no-repeat;
  background-size: 20px;
  background-position: center 14px;
  background-image: url(data:image/svg+xml;base64,PHN2ZyBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxOCA4LjYiIGhlaWdodD0iOSIgdmlld0JveD0iMCAwIDE4IDguNiIgd2lkdGg9IjE4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Im0xNy40IDguNi04LjQtNy4zLTguMyA3LjMtLjctLjcgOS03LjkgOSA3Ljl6IiBmaWxsPSIjZmZmZmZmIi8+PC9zdmc+);
}

.btn-pagetop-scroll.is-active .pagetop-btn {
  opacity: 1;
  background-color: var(--base-color);
}

.container-pagetop.is-bottom {
  position: absolute;
}

.pagetop-btn-block {
  display: flex;
  align-items: flex-end;
}

.footer {
  position: relative;
  display: flex;
}
@media screen and (max-width: 767px) {
  .footer {
    flex-wrap: wrap;
  }
}

.footer-info {
  width: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .footer-info {
    width: 100%;
  }
}

.footer-map {
  width: 50%;
  height: inherit;
  background-color: #ddd;
}
@media screen and (max-width: 767px) {
  .footer-map {
    width: 100%;
  }
}

.footer-map iframe {
  width: 100%;
  height: 100%;
  filter: grayscale(100%);
  -webkit-filter: grayscale(100%);
}
@media screen and (max-width: 767px) {
  .footer-map iframe {
    height: auto;
    aspect-ratio: 16/9;
  }
}

.copyright {
  font-size: 12px;
  font-size: 1.2rem;
}

.footer-nav {
  display: flex;
}
.footer-nav li:not(:first-child) {
  border-left: 1px solid var(--base-color);
}
.footer-nav a {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  color: var(--base-color);
  display: inline-block;
  padding: 0.45em 2em;
}

.group-nav-space {
  height: 457px;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .group-nav-space {
    height: auto;
    z-index: 3;
  }
}
.group-nav-space::before {
  pointer-events: none;
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: -458px;
  width: 100%;
  height: 458px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .group-nav-space::before {
    display: none;
  }
}

.group-nav-wrap {
  position: relative;
  z-index: -2;
}

.group__item-cover {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: 100%;
  background-color: #acd0d0;
  z-index: 1;
  mix-blend-mode: multiply;
  pointer-events: none;
  cursor: pointer;
  transition: all 600ms ease-out;
}
*:hover > .group__item-cover {
  opacity: 0;
  transition: all 600ms ease-out;
}

.group__item-name {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: 2;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  padding: 0 1.4em;
}
.group__item-name span {
  display: inline-block;
  color: #fff;
  font-size: 19px;
  font-size: 1.9rem;
  transition: color 600ms ease-out;
  padding: 0.3em 0;
  text-align: center;
  width: inherit;
}
@media screen and (max-width: 767px) {
  .group__item-name span {
    font-size: 13px;
    font-size: 1.3rem;
  }
}

.group__item-logo {
  display: inline-block;
}
.group__item-logo img {
  max-width: -webkit-fill-available;
}
@media screen and (max-width: 480px) {
  .group__item-logo img {
    max-width: 100%;
    height: auto;
  }
}

.group-item-copy {
  font-size: 19px;
  font-size: 1.9rem;
  position: absolute;
  z-index: 2;
  bottom: 1em;
  color: #fff;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 767px) {
  .group-item-copy {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
.group-item-copy--left {
  left: 1em;
}
.group-item-copy--right {
  right: 1em;
}
@media screen and (max-width: 767px) {
  .group-item-copy--right {
    right: auto;
    left: 1em;
  }
}

.group-nav {
  position: fixed;
  bottom: 0;
  z-index: 0;
  width: 100%;
  padding-top: 50px;
  background-color: var(--base-color);
  overflow: hidden;
  visibility: hidden;
  opacity: 0;
}
.group-nav.is-active {
  visibility: visible;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .group-nav {
    position: relative;
    visibility: visible;
    opacity: 1;
  }
}

.group-nav__inner {
  height: 408px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .group-nav__inner {
    height: 568px;
    flex-wrap: wrap;
  }
}

.group-nav__item {
  width: 25%;
  position: relative;
}
.group-nav__item .click-expand::before {
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .group-nav__item {
    width: 50%;
    height: 50%;
  }
}

.group-nav__item-img {
  width: 100%;
  height: 100%;
  object-position: center 20%;
}

.important {
  color: #c30d23;
}

.require {
  color: var(--base-color);
}

.c-base {
  color: var(--base-color);
}

.c-black {
  color: #000 !important;
}

.c-white {
  color: #fff !important;
}

.c-hover {
  color: #0db4b4;
}

.bg-base {
  background-color: var(--base-color);
}

.c-red {
  color: #e60012;
}

.bg-white {
  background-color: #fff;
}

.bg-red {
  background-color: #e60012;
}

.c-high {
  color: var(--high) !important;
}

.c-juniorhigh {
  color: var(--juniorhigh) !important;
}

.c-kindergarten {
  color: var(--kindergarten) !important;
}

.c-nursery {
  color: var(--nursery) !important;
}

.c-general {
  color: var(--gnenral) !important;
}

.bdc-high {
  border-color: var(--high);
}

.bdc-juniorhigh {
  border-color: var(--juniorhigh);
}

.bdc-kindergarten {
  border-color: var(--kindergarten);
}

.bdc-nursery {
  border-color: var(--nursery);
}

.bdc-general {
  border-color: var(--gnenral);
}

.bg-base-light {
  background-color: #f0f3f5;
}

.bdc-base {
  border-color: var(--base-color);
}

.bg-high {
  background-color: var(--high);
}

.bg-juniorhigh {
  background-color: var(--juniorhigh);
}

.bg-kindergarten {
  background-color: var(--kindergarten);
}

.bg-nursery {
  background-color: var(--nursery);
}

.bg-general {
  background-color: var(--gnenral);
}

.bg-dark-gray {
  background-color: #e4e9ed;
}

.init-transparent {
  opacity: 0;
  transform: translateY(30px);
  transition: all 800ms ease-in-out;
}
.init-transparent.is-active {
  transition: all 800ms ease-in-out;
  opacity: 1;
  transform: translateY(0);
}

.fade-in {
  animation: fadeIn 150ms ease-in-out 1 forwards;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fade-out {
  animation: fadeOut 400ms ease-in-out 1 forwards;
}

@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.clip-to-right {
  clip-path: inset(0 100% 0 0);
  transition: 0.8s ease-in;
  transition: clip-path 800ms ease-in-out;
}
.clip-to-right.is-visible {
  clip-path: inset(0);
}

.clip-to-left {
  clip-path: inset(0 0 0 100%);
  transition: 0.8s ease-in;
  transition: clip-path 800ms ease-in-out;
}
.clip-to-left.is-visible {
  clip-path: inset(0);
}

@keyframes border-anime {
  0% {
    background-position: 200% 100%;
  }
  100% {
    background-position: 0% 100%;
  }
}
.btn {
  display: inline-flex;
  align-items: center;
  transition: all 200ms ease-in-out;
  padding: 0.6em 1em 0.5em 1em;
  line-height: 1;
}

input.btn {
  cursor: pointer;
  user-select: none;
}

.click-expand::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: all 150ms ease-in;
}

.btn-m {
  width: 250px;
}

.btn-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-size: 1.6rem;
  padding: 0.85em 2em 0.8em 2em;
  color: #fff;
  letter-spacing: 0.1em;
  font-style: bold;
  background-color: #6b849c;
  position: relative;
  border: 1px solid currentColor;
  transition: all 200ms ease-out;
}
.btn-more:hover {
  color: #6b849c;
  background-color: #fff;
}
.btn-more .pict-tri-arrow {
  position: absolute;
  right: 0;
}

.arrow-pict {
  position: relative;
  padding-right: 20px;
}
.arrow-pict::after {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(0, -50%);
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 9px;
  border-color: transparent transparent transparent currentColor;
  transition: transform 200ms ease-out;
}

.arrow-pict--stretch::before {
  position: absolute;
  right: 1px;
  top: calc(50% - 1px);
  transform: translate(0, -50%);
  transform-origin: top left;
  content: "";
  display: inline-block;
  width: 1px;
  height: 1px;
  background-color: currentColor;
  transition: transform 200ms ease-out;
}
*:hover > .arrow-pict--stretch::before {
  transform: translate(0, -50%) scaleX(30);
}
*:hover > .arrow-pict--stretch::after {
  transform: translate(36px, -50%);
}

.arrow-pict-vertical {
  position: relative;
  padding-right: 20px;
  margin-left: 10px;
}
.arrow-pict-vertical::after {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(0, -50%);
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 5px 0 5px;
  border-color: currentColor transparent transparent transparent;
  transition: transform 200ms ease-out;
}

.arrow-pict-vertical--stretch::before {
  position: absolute;
  left: calc(50% + 5px);
  top: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center center;
  content: "";
  display: inline-block;
  width: 1px;
  height: 1px;
  background-color: currentColor;
  transition: transform 200ms ease-out;
}
*:hover > .arrow-pict-vertical--stretch::before {
  transform: translate(-50%, -50%) scaleY(25);
}
*:hover > .arrow-pict-vertical--stretch::after {
  transform: translate(0, 100%);
}

.btn-solid {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 240px;
  transition: all 200ms ease-in-out;
  padding: 0.8em 2em 0.8em 2em;
  color: #fff;
  background-color: var(--key-color);
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.2;
  letter-spacing: 2px;
  font-family: Garamond, sans-serif;
}
.btn-solid .arrow-pict--stretch::before {
  top: 50%;
}
.btn-solid:hover {
  color: #fff;
  background-color: #6b849c;
}

.btn-solid--large {
  padding-top: 1.7em;
  padding-bottom: 1.7em;
  width: 100%;
  max-width: 585px;
}

.btn-border {
  display: inline-block;
  font-size: 18px;
  font-size: 1.8rem;
  min-width: 160px;
  padding: 1.2em 0 1.1em 0;
  color: #6b849c;
  border: 1px solid currentColor;
  text-align: center;
  transition: all 200ms ease-in-out;
}
.btn-border:hover {
  color: #fff;
  background-color: #6b849c;
  border-color: #6b849c;
}
.plus-btn {
  display: inline-block;
  width: 40px;
  height: 40px;
  border: 1px solid #fff;
  border-radius: 100%;
  position: relative;
}
.plus-btn::before, .plus-btn::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 22px;
  height: 1px;
  background-color: #fff;
  transition: all 400ms ease-in-out;
}
.plus-btn::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

*:hover > .plus-btn--minus::before {
  transform: translate(-50%, -50%) rotate(-180deg);
}
*:hover > .plus-btn--minus::after {
  transform: translate(-50%, -50%) rotate(180deg);
}

.plus-btn-arrow {
  display: inline-block;
  width: 40px;
  height: 40px;
  border: 1px solid #fff;
  border-radius: 100%;
  position: relative;
}
.plus-btn-arrow::before, .plus-btn-arrow::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center right;
  width: 22px;
  height: 1px;
  background-color: #fff;
  transition: all 300ms ease-in-out;
}
.plus-btn-arrow::after {
  transform: translate(-50%, -50%) rotate(-90deg);
  top: calc(50% - 11px);
  left: calc(50% - 11px);
}

*:hover > .plus-btn-arrow::before {
  transform: translate(-62%, -50%) rotate(45deg) scale(0.7);
}
*:hover > .plus-btn-arrow::after {
  transform: translate(-62%, -50%) rotate(-45deg) scale(0.7);
  top: 50%;
  left: 50%;
}

.noborder {
  border: none !important;
}

.top-noborder {
  border-top: none !important;
}

.border-solid {
  border-style: solid;
}

.border-dashed {
  border-style: dashed;
}

.border-dot {
  border-style: dotted;
}

.border-style-dot {
  border-bottom: 1px dotted #000 !important;
}

.border-top {
  border-top-width: 1px;
  border-top-style: solid;
}

.border-bottom-solid {
  border-bottom: 1px solid;
}

.border-left-solid {
  border-left: 1px solid;
}

.border-top-dashed {
  border-top-style: dashed !important;
}

.border-bottom-dashed {
  border-bottom-style: dashed !important;
}

.border-width-1 {
  border-width: 1px !important;
}

.border-width-2 {
  border-width: 2px !important;
}

ol {
  list-style-position: outside;
  list-style-type: decimal;
  margin-left: 2em;
}

.dl-list {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-column-gap: 15px;
  column-gap: 1.5em;
  grid-row-gap: 0.3em;
  row-gap: 0.3em;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
}
.dl-list dt {
  color: #6b849c;
}
.dl-list dd {
  justify-self: start;
}

.arrow-after-list > li a {
  transition: color 150ms ease-in;
  position: relative;
}
.arrow-after-list > li a::after {
  position: absolute;
  right: 0;
  top: 47%;
  transform: translate(10px, -50%);
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 8px;
  border-color: transparent transparent transparent #6b849c;
  transition: transform 200ms ease-out;
}
.arrow-after-list > li a:hover::after {
  transform: translate(15px, -50%);
}

.link-list {
  margin-left: 7px;
}
.link-list > li {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
}
.link-list > li a {
  transition: color 150ms ease-in;
}
.link-list > li:not(:first-child) {
  margin-top: 5px;
}
.link-list > li::before {
  transition: transform 150ms ease-in;
}
.link-list > li:hover::before {
  transform: translate(-7px, -1px) rotate(45deg) skew(-5deg, -5deg);
}

.sns-list {
  display: flex;
  justify-content: flex-end;
}
@media screen and (max-width: 480px) {
  .sns-list {
    justify-content: center;
  }
}
.sns-list li {
  margin-left: 17px;
}
.sns-list a[href^=http]::after {
  display: none;
}

img[src*="img/common/facebook.svg"] {
  background: #fff;
  border-radius: 100%;
}

.column-list {
  column-count: 2;
  column-gap: 16px;
}
.column-list > li {
  break-inside: avoid;
  margin-bottom: 8px;
  padding: 8px;
}

.dot-list {
  list-style-type: none;
}
.dot-list > li {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  padding-left: 1em;
  text-indent: -1em;
}
.dot-list > li:not(:first-child) {
  margin-top: 5px;
}
.dot-list > li:before {
  content: "・";
}

.list-circle {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  list-style: none;
}
.list-circle li {
  margin-left: 1.5em;
  position: relative;
}
.list-circle li:before {
  display: inline-block;
  content: "";
  width: 8px;
  height: 8px;
  background-color: #6b849c;
  border-radius: 100%;
  margin-left: -1em;
  position: absolute;
  top: 0.43em;
}
.list-circle li li::before {
  width: 3px;
  height: 3px;
  top: 1em;
  margin-left: -0.6em;
}

.list-no {
  list-style-position: outside;
  counter-reset: number;
  margin-left: 0;
}
.list-no > li {
  list-style-type: none;
  margin-left: 26px;
  line-height: 2;
}
.list-no > li:not(:first-child) {
  margin-top: 0.5em;
}
.list-no > li:before {
  color: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 20px;
  display: inline-block;
  counter-increment: number;
  content: counter(number);
  background-color: #6b849c;
  width: 20px;
  height: 20px;
  text-align: center;
  position: relative;
  top: -1px;
  font-family: Arial;
  font-weight: normal;
  margin-left: -28px;
  margin-right: 4px;
}

.flex {
  display: flex;
}

@media screen and (max-width: 480px) {
  .sp-flex {
    display: flex;
  }
}
.inline-flex {
  display: inline-flex;
}

@media screen and (max-width: 480px) {
  .sp-inline-flex {
    display: inline-flex;
  }
}
.flex-row-wrap {
  flex-flow: row wrap;
}

.flex-row-nowrap {
  flex-flow: row nowrap;
}

.flex-column-wrap {
  flex-flow: column wrap;
}

.flex-column-nowrap {
  flex-flow: column nowrap;
}

@media screen and (max-width: 767px) {
  .md-flex-row-wrap {
    flex-flow: row wrap;
  }
}

@media screen and (max-width: 480px) {
  .sp-flex-row-wrap {
    flex-flow: row wrap;
  }
}

@media screen and (max-width: 767px) {
  .md-flex-column-nowrap {
    flex-flow: column nowrap;
  }
}

@media screen and (max-width: 480px) {
  .sp-flex-column-nowrap {
    flex-flow: column nowrap;
  }
}

.direction-row {
  flex-direction: row;
}

@media screen and (max-width: 480px) {
  .sp-direction-row {
    flex-direction: row;
  }
}

.direction-column {
  flex-direction: column;
}

@media screen and (max-width: 480px) {
  .sp-direction-column {
    flex-direction: column;
  }
}

.direction-column-reverse {
  flex-direction: column-reverse !important;
}

@media screen and (max-width: 767px) {
  .md-direction-column-reverse {
    flex-direction: column-reverse !important;
  }
}

.flex-wrap {
  flex-wrap: wrap !important;
}

.flex-nowrap {
  flex-wrap: nowrap !important;
}

@media screen and (max-width: 767px) {
  .md-flex-wrap {
    flex-wrap: wrap !important;
  }
}

@media screen and (max-width: 480px) {
  .sp-flex-wrap {
    flex-wrap: wrap !important;
  }
}

.row-reverse {
  flex-direction: row-reverse;
}

.justify-spacebetween {
  justify-content: space-between !important;
}

@media screen and (max-width: 480px) {
  .sp-justify-spacebetween {
    justify-content: space-between !important;
  }
}

.justify-center {
  justify-content: center !important;
}

@media screen and (max-width: 480px) {
  .sp-justify-center {
    justify-content: center !important;
  }
}

.justify-spacearound {
  justify-content: space-around !important;
}

@media screen and (max-width: 480px) {
  .sp-justify-spacearound {
    justify-content: space-around !important;
  }
}

.justify-flexstart {
  justify-content: flex-start !important;
}

@media screen and (max-width: 480px) {
  .sp-justify-flexstart {
    justify-content: flex-start !important;
  }
}

.justify-flexend {
  justify-content: flex-end !important;
}

@media screen and (max-width: 480px) {
  .sp-justify-flexend {
    justify-content: flex-end !important;
  }
}

.align-content-spacebetween {
  align-content: space-between;
}

.align-content-strech {
  align-content: strech;
}

.flex-grow {
  flex-grow: 1 !important;
}

.flex-grow-off {
  flex-grow: 0 !important;
}

.flex-shrink {
  flex-shrink: 1 !important;
}

.flex-shrink-off {
  flex-shrink: 0 !important;
}

@media screen and (max-width: 480px) {
  .sp-flex-grow {
    flex-grow: 1 !important;
  }
  .sp-flex-grow-off {
    flex-grow: 0 !important;
  }
  .sp-flex-shrink {
    flex-shrink: 1 !important;
  }
  .sp-flex-shrink-off {
    flex-shrink: 0 !important;
  }
}
.align-items-start {
  align-items: flex-start;
}

.align-items-end {
  align-items: flex-end;
}

.align-items-strech {
  align-items: strech;
}

.align-items-center {
  align-items: center;
}

@media screen and (max-width: 480px) {
  .sp-align-item-center {
    align-items: center;
  }
  .sp-align-item-start {
    align-items: flex-start;
  }
  .sp-align-item-end {
    align-items: flex-end;
  }
}
.align-self-center {
  align-self: center;
}

.align-self-start {
  align-self: flex-start;
}

.align-self-end {
  align-self: flex-end;
}

.flex-content {
  display: flex;
  margin-left: -5px;
  margin-right: -5px;
  flex-wrap: wrap;
}
.flex-content > * {
  flex-grow: 1;
  flex-shrink: 1;
  padding-right: 5px;
  padding-left: 5px;
}
@media screen and (max-width: 480px) {
  .flex-content {
    flex-direction: column;
    margin-left: 0;
    margin-right: 0;
  }
}

.flex-content--2 > * {
  max-width: 50%-10px;
}

.flex-content--3 > * {
  max-width: 33.3%-10px;
}

.flex-content--4 > * {
  max-width: 25%-15px;
}

@media screen and (max-width: 480px) {
  .sp-flex-content--auto > * {
    max-width: inherit !important;
  }
}

@media screen and (max-width: 480px) {
  .sp-flex-content--2 > * {
    max-width: 50%-10px;
  }
}

.order1 {
  order: 1;
}

.order2 {
  order: 2;
}

.order3 {
  order: 3;
}

.order4 {
  order: 4;
}

.order5 {
  order: 6;
}

.order6 {
  order: 6;
}

@media screen and (max-width: 767px) {
  .md-order1 {
    order: 1 !important;
  }
  .md-order2 {
    order: 2 !important;
  }
  .md-order3 {
    order: 3 !important;
  }
  .md-order4 {
    order: 4 !important;
  }
}
@media screen and (max-width: 480px) {
  .sp-order1 {
    order: 1 !important;
  }
  .sp-order2 {
    order: 2 !important;
  }
  .sp-order3 {
    order: 3 !important;
  }
  .sp-order4 {
    order: 4 !important;
  }
  .sp-order5 {
    order: 5 !important;
  }
  .sp-order6 {
    order: 6 !important;
  }
}
.grid {
  display: grid;
}

@media screen and (max-width: 480px) {
  .sp-grid {
    display: grid !important;
  }
}

.grid-gap {
  grid-gap: 1%;
}

.grid-columns2 {
  grid-template-columns: 1fr 1fr;
}

.grid-columns3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.grid-columns4 {
  grid-template-columns: 1fr 1fr 1fr 1fr;
}
@media screen and (max-width: 480px) {
  .grid-columns4 {
    grid-template-columns: 1fr 1fr;
  }
}

.grid-rows3 {
  grid-template-rows: 1fr 1fr 1fr;
}

.grid-auto-rows {
  grid-auto-rows: minmax(100px, auto);
}

.grid-auto-fill {
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

.grid-auto-fit {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.grid-dir-column {
  min-height: 613px;
  grid-auto-flow: column;
  grid-template-rows: repeat(auto-fit, minmax(200px, 1fr));
  grid-template-columns: repeat(auto-fit, minmax(49%, 1fr));
}
.grid-dir-column > .item {
  border-radius: 10px;
  background: #edf;
  padding: 15px;
  text-align: center;
}

.table-fixed {
  table-layout: fixed;
}

table {
  margin: 0 0 20px 0;
  border-collapse: collapse;
  font-size: 14px;
  font-size: 1.4rem;
}
table caption {
  text-align: left;
  margin-bottom: 5px;
}
table th,
table td {
  padding: 0.7% 1%;
}

.table-border {
  border-bottom: 1px solid #dcdddd;
}
.table-border th,
.table-border td {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  border-top: 1px solid #dcdddd;
  padding: 1em 0;
  text-align: left;
  vertical-align: top;
}
@media screen and (max-width: 480px) {
  .table-border th,
  .table-border td {
    padding: 0.6em 0.2em;
  }
}
.table-border th {
  color: #6b849c;
  padding-right: 60px;
}
@media screen and (max-width: 767px) {
  .table-border th {
    padding-right: 18px;
    min-width: 6em;
  }
}
.table-border .inline-flex {
  display: inline-flex;
  justify-content: space-between;
  min-width: 6em;
}
@media screen and (max-width: 767px) {
  .table-border .inline-flex {
    display: inline;
  }
}

.stripe-table th,
.stripe-table td {
  padding: 0.8em 1em 0.7em 1em;
  border-top: 1px solid #999999;
  border-bottom: 1px solid #999999;
}
.stripe-table th {
  background-color: #e4f2ed;
}
.stripe-table tr:nth-child(2n+1) td {
  background-color: #e4f2ed;
}

.common-table th,
.common-table td {
  font-size: 14px;
  font-size: 1.4rem;
  border: 1px solid #ccc;
  padding: 0.6em 0.6em 0.4em 0.6em;
}
@media screen and (max-width: 480px) {
  .common-table th,
  .common-table td {
    padding: 0.6em 0.2em;
  }
}
.common-table th {
  font-weight: normal;
  vertical-align: middle;
}
.common-table td {
  text-align: left;
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  margin-left: 2px;
  margin-right: 2px;
}
.tag-list .tag {
  margin-bottom: 4px;
}

.tag {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  font-size: 1.2rem;
  min-height: 12px;
  line-height: 1;
  padding: 0px 7px;
  color: var(--gray-color);
  border-right: 1px solid var(--gray-color);
  min-width: 65px;
}
.tag:first-child {
  border-left: 1px solid var(--gray-color);
}
.tag + .category {
  border-left: none;
}
.tag a {
  display: block;
  color: #6b849c;
  transition: all 150ms ease-in;
}

.tag-list-md {
  display: flex;
  align-items: center;
}
.tag-list-md > *:first-child {
  margin-right: 10px;
}
.tag-list-md .tag {
  min-width: 80px;
}

.border-label {
  min-width: 55px;
  border-bottom-width: 2px;
  border-bottom-style: solid;
}

input,
select,
textarea {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.5;
}
@media screen and (max-width: 480px) {
  input,
  select,
  textarea {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

.label {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
}
@media screen and (max-width: 480px) {
  .label {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

input,
textarea {
  appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px white inset;
}

input {
  line-height: 1.6;
  appearance: none;
  outline: 0;
  border-radius: 4px;
  border: 1px solid #aaa;
}

input[type=checkbox],
input[type=radio] {
  width: 20px;
  height: 20px;
  outline: none;
  display: inline-block;
  vertical-align: top;
  position: relative;
  margin: 0;
  cursor: pointer;
  border: 1px solid var(--base-color);
  transition: background 0.3s, border-color 0.3s;
}
input[type=checkbox]:after,
input[type=radio]:after {
  content: "";
  display: block;
  left: 0;
  top: 0;
  position: absolute;
  width: 20px;
  height: 20px;
}
input[type=checkbox]:checked,
input[type=radio]:checked {
  position: relative;
  z-index: 0;
}

input[type=radio] {
  border-radius: 100%;
}
input[type=radio]:after {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
input[type=radio]:focus, input[type=radio]:checked {
  background-color: var(--base-color);
}
input[type=radio]:focus:after, input[type=radio]:checked:after {
  opacity: 1;
}

input[type=checkbox]:checked {
  background-color: var(--base-color);
  background-image: url("data:image/svg+xml;base64,PHN2ZyBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAyMSAyMSIgdmlld0JveD0iMCAwIDIxIDIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Im00IDEyIDUgNCA3LTEwIiBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjIiLz48L3N2Zz4=");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

select {
  outline: none;
  text-indent: 0.01px;
  text-overflow: "";
  background: none transparent;
  vertical-align: middle;
  color: inherit;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

textarea:not([rows]) {
  height: 10em;
  min-height: 8em;
  max-height: 24em;
}

textarea::placeholder,
input::placeholder {
  color: #b5b5b6;
}

.label-require {
  background-color: #b9303e;
  min-width: auto;
  margin-left: 5px;
}

.form {
  max-width: 660px;
  margin: 0 auto;
  margin-top: 20px;
}

.input {
  width: 100%;
  align-items: center;
  border: 1px solid #dbdbdb;
  border-radius: 4px;
  box-shadow: none;
  display: inline-flex;
  justify-content: flex-start;
  padding-bottom: calc(0.5em - 1px);
  padding-left: calc(0.75em - 1px);
  padding-right: calc(0.75em - 1px);
  padding-top: calc(0.5em - 1px);
  position: relative;
  vertical-align: top;
}
.input:focus {
  border: 1px solid var(--base-color);
}

.input[name=zip] {
  width: 50%;
  min-width: 9em;
}

.select-input {
  position: relative;
  width: fit-content;
  width: -moz-fit-content;
}
.select-input select {
  width: 100%;
  padding-bottom: calc(0.5em - 1px);
  padding-left: calc(0.75em - 1px);
  padding-right: calc(0.75em - 1px);
  padding-top: calc(0.5em - 1px);
  border: 1px solid #dbdbdb;
  border-radius: 4px;
  position: relative;
  padding-right: 2em;
}
.select-input select:focus {
  border: 1px solid var(--base-color);
}
.select-input::after {
  content: "";
  display: block;
  width: 0.9em;
  height: 0.9em;
  position: absolute;
  top: 50%;
  transform: rotate(-45deg) translateY(-50%);
  transform-origin: center;
  border: 3px solid var(--base-color);
  border-radius: 2px;
  border-right: 0;
  border-top: 0;
  right: 1.125em;
  z-index: 1;
  pointer-events: none;
}

.form-title {
  font-size: 16px;
  font-size: 1.6rem;
  padding-bottom: 0.5em;
}
.form-title:not(:first-child) {
  margin-top: 3em;
}
@media screen and (max-width: 480px) {
  .form-title:not(:first-child) {
    margin-top: 1.5em;
  }
}

.form-item {
  margin-bottom: 1em;
}

.form-item-child {
  display: flex;
  align-items: center;
}
.form-item-child :not(:first-child) {
  margin-left: 0.5em;
}

.form-item-list {
  display: flex;
  flex-wrap: wrap;
  margin-left: -10px;
  padding-right: -10px;
}
.form-item-list > * {
  display: inline-flex;
  align-items: center;
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 0.8em;
}
.form-item-list .label {
  margin-left: 5px;
  cursor: pointer;
  padding-top: 0.2em;
}

.zip-text {
  font-size: 16px;
  font-size: 1.6rem;
}

.required::after {
  content: "";
  display: inline-block;
  padding: 3px 4px 3px 4px;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  background-color: #333;
  border-radius: 2px;
  transform: translateY(-1px);
  margin-left: 5px;
}

.required::after {
  content: "必須";
  background-color: #c30d23;
}

.form .btn-more {
  border: none;
}

/* Error Placeholder */
input.error,
select.error,
textarea.error {
  border-color: rgba(255, 17, 68, 0.4);
}

.form-confirm .form-item {
  font-size: 20px;
  font-size: 2rem;
  background-color: #f6f6f6;
  padding: 0.5em 1em;
}

@keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@-moz-keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@-webkit-keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@-o-keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@-moz-keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@-webkit-keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@-o-keyframes rotate-loading {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
  }
}
@keyframes loading-text-opacity {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-moz-keyframes loading-text-opacity {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes loading-text-opacity {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-o-keyframes loading-text-opacity {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.loading-container,
.loading {
  height: 100px;
  position: relative;
  width: 100px;
  border-radius: 100%;
}

.loading {
  border: 2px solid transparent;
  border-color: transparent #fff transparent #FFF;
  animation: rotate-loading 1.5s linear 0s infinite normal;
  transform-origin: 50% 50%;
}

.loading-container:hover .loading {
  border-color: transparent #E45635 transparent #E45635;
}

.loading-container:hover .loading,
.loading-container .loading {
  transition: all 0.5s ease-in-out;
}

#loading-text {
  animation: loading-text-opacity 2s linear 0s infinite normal;
  color: #ffffff;
  font-family: "Helvetica Neue, " Helvetica ", " "arial";
  font-size: 10px;
  font-weight: bold;
  margin-top: 45px;
  opacity: 0;
  position: absolute;
  text-align: center;
  text-transform: uppercase;
  top: 0;
  width: 100px;
}

.pict {
  display: inline-block;
  width: 22px;
  height: 22px;
  background-size: contain;
  background-repeat: no-repeat;
  transition: background 200ms ease-in-out;
}

.pict-after-arrow-short {
  width: 15px;
  height: 7px;
  background-size: contain;
  background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI0LjMuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IuODrOOCpOODpOODvF8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiCgkgeT0iMHB4IiB2aWV3Qm94PSIwIDAgMTQuMyA2LjYiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDE0LjMgNi42OyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+CjxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+Cgkuc3Qwe2ZpbGw6I0ZGRkZGRjt9Cjwvc3R5bGU+CjxnPgoJPHBhdGggY2xhc3M9InN0MCIgZD0iTTEzLjcsNi42SDAuNkMwLjMsNi42LDAsNi4zLDAsNnMwLjMtMC42LDAuNi0wLjZoMTEuN0w4LjUsMUM4LjIsMC43LDguMywwLjQsOC41LDAuMUM4LjgtMC4xLDkuMSwwLDkuMywwLjIKCQlsNC44LDUuNGMwLjIsMC4yLDAuMiwwLjQsMC4xLDAuNkMxNC4xLDYuNCwxMy45LDYuNiwxMy43LDYuNnoiLz4KPC9nPgo8L3N2Zz4K);
}

.pict--bottom-solid-tri-brown {
  position: relative;
}
.pict--bottom-solid-tri-brown::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 13px 13px 0 13px;
  border-color: #603813 transparent transparent transparent;
}

.pict-right-solid-arrow-green {
  width: 14px;
  height: 17px;
  background-size: contain;
  background-image: url(/assets/images/pict/right-solid-arrow-green.svg);
}

.pict-right-solid-arrow-orange {
  width: 14px;
  height: 17px;
  background-size: contain;
  background-image: url(/assets/images/pict/right-solid-arrow-orange.svg);
}

.pict-bottom-solid-arrow-green {
  width: 34px;
  height: 29px;
  background-size: contain;
  background-image: url(/assets/images/pict/bottom-solid-arrow-green.svg);
}

.pict-bottom-solid-arrow-blue {
  width: 34px;
  height: 29px;
  background-size: contain;
  background-image: url(/assets/images/pict/bottom-solid-arrow-blue.svg);
}

.pict-bottom-solid-arrow-blue-s {
  width: 16px;
  height: 14px;
  background-size: contain;
  background-image: url(/assets/images/pict/bottom-solid-arrow-blue-small.svg);
}

.pict-bottom-solid-arrow-blue-m {
  width: 26px;
  height: 18x;
  background-size: contain;
  background-image: url(/assets/images/pict/bottom-solid-arrow-blue-small.svg);
}

.pict-bottom-solid-arrow-gray {
  width: 17px;
  height: 15px;
  background-size: contain;
  background-image: url(/assets/images/pict/bottom-solid-arrow-gray.svg);
}

.pict-plus-gray {
  width: 15px;
  height: 15px;
  background-size: contain;
  background-image: url(/assets/images/pict/plus.svg);
}

.pict-before-circle:before {
  content: "";
  display: inline-block;
  font-size: inherit;
  width: 1em;
  height: 1em;
  background-color: #6b849c;
  border-radius: 100%;
  color: #6b849c;
  margin-right: 0.02em;
  transform: scale(0.7) translateY(20%);
}

.pict-arrow {
  transform: rotate(37deg);
  position: relative;
}
.pict-arrow:before {
  content: "";
  display: inline-block;
  width: 9px;
  height: 9px;
  border-top: 1px solid #6b849c;
  border-right: 1px solid #6b849c;
  position: absolute;
  top: calc(50% + 3px);
  transform: translateY(-50%) skew(-15deg);
}
*:hover > .pict-arrow:before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

.pict-tri-arrow {
  position: relative;
}
.pict-tri-arrow:before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.3px 0 4.3px 7.5px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: border 200ms ease-out;
}
*:hover > .pict-tri-arrow:before {
  border-color: transparent transparent transparent #6b849c;
}

.overflow-x-scroll {
  overflow-x: scroll;
}

@media screen and (max-width: 480px) {
  .sp-overflow-x-scroll {
    overflow-x: scroll;
  }
}

.inquiry-btn {
  position: absolute;
  top: 12px;
  right: 7px;
}
@media screen and (max-width: 767px) {
  .inquiry-btn {
    display: none;
  }
}

.stack__item {
  position: relative;
  width: 100%;
  height: 630px;
}
@media screen and (max-width: 767px) {
  .stack__item {
    height: 445px;
  }
}

.stack-img {
  width: 100%;
  height: 630px;
  object-fit: cover;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .stack-img {
    height: 280px;
  }
}

.stack-content-bg {
  background-color: #6b849c;
  mix-blend-mode: multiply;
  position: absolute;
  top: 50%;
  width: 450px;
  height: 450px;
  transform: translate(17px, -50%);
}
@media screen and (max-width: 767px) {
  .stack-content-bg {
    max-width: 355px;
    max-height: 310px;
    width: calc(100vw - 40px);
    height: calc(100vw - 80px);
    top: auto;
    bottom: 0;
    transform: translate(0, 0);
  }
}
@media screen and (max-width: 480px) {
  .stack-content-bg {
    max-height: 280px;
    height: calc(100vw - 60px);
  }
}

.stack-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  border: 1px solid currentColor;
  position: absolute;
  top: 50%;
  width: 430px;
  height: 430px;
  transform: translate(27px, -50%);
}
@media screen and (max-width: 767px) {
  .stack-content {
    max-width: 336px;
    max-height: 291px;
    width: calc(100vw - 60px);
    height: calc(100vw - 100px);
    top: auto;
    bottom: 10px;
    transform: translate(10px, 0);
  }
}
@media screen and (max-width: 480px) {
  .stack-content {
    max-height: 261px;
    height: calc(100vw - 80px);
  }
}
.stack-content .en-text {
  font-family: Garamond, sans-serif;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 2px;
  padding-top: 25px;
}
@media screen and (max-width: 767px) {
  .stack-content .en-text {
    font-size: 10px;
    font-size: 1rem;
    padding-top: 0;
  }
}

.stack__item--rev .stack-content-bg {
  right: 0;
  transform: translate(-17px, -50%);
}
@media screen and (max-width: 767px) {
  .stack__item--rev .stack-content-bg {
    transform: translate(0px, 0);
  }
}
.stack__item--rev .stack-content {
  right: 0;
  transform: translate(-27px, -50%);
}
@media screen and (max-width: 767px) {
  .stack__item--rev .stack-content {
    transform: translate(-10px, 0);
  }
}

.stack-content .pict-tri-arrow {
  position: relative;
  left: 0;
  transition: left 200ms ease-in-out;
}
.stack-content:hover .pict-tri-arrow {
  left: 5px;
}
.stack-content:hover .pict-tri-arrow::before {
  border-color: transparent transparent transparent #fff;
}

.no {
  font-family: Garamond, sans-serif;
  font-size: 78px;
  font-size: 7.8rem;
  line-height: 1;
  height: 55px;
  text-indent: -5px;
}
@media screen and (max-width: 767px) {
  .no {
    font-size: 47px;
    font-size: 4.7rem;
  }
}
@media screen and (max-width: 480px) {
  .no {
    height: 45px;
  }
}

.stack-content__title {
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 4px;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-bottom: 25px;
  width: 90px;
  text-align: center;
  border-bottom: 4px solid currentColor;
}
@media screen and (max-width: 767px) {
  .stack-content__title {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 480px) {
  .stack-content__title {
    padding-top: 5px;
    padding-bottom: 5px;
    margin-bottom: 12px;
  }
}

.stack-content__text {
  font-size: 21px;
  font-size: 2.1rem;
  line-height: 1.7;
  letter-spacing: 4px;
  font-feature-settings: "palt";
  text-align: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .stack-content__text {
    margin-bottom: 1em;
  }
}
@media screen and (max-width: 480px) {
  .stack-content__text {
    font-size: clamp(1.4rem, 5.4vw, 2.1rem);
  }
}

.contact-block {
  width: fit-content;
  margin: 0 auto;
  padding: 30px 0;
  border-top: 1px dotted #6b849c;
  border-bottom: 1px dotted #6b849c;
}
@media screen and (max-width: 480px) {
  .contact-block {
    padding: 25px 0;
  }
}
.contact-block .contact-no {
  font-size: 41px;
  font-size: 4.1rem;
  margin: 0 2vw 20px 2vw;
}
.contact-block .contact-no span {
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 480px) {
  .contact-block .contact-no {
    font-size: 31px;
    font-size: 3.1rem;
    margin-bottom: 10px;
  }
  .contact-block .contact-no span {
    font-size: 14px;
    font-size: 1.4rem;
  }
}

.contact-item {
  display: grid;
  grid-template-columns: minmax(auto, 350px) auto 150px;
  border: 1px solid var(--base-color);
  margin-bottom: 30px;
  min-height: 145px;
}
@media screen and (max-width: 767px) {
  .contact-item {
    grid-template-columns: auto;
  }
}

.contact-item__title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #3e3a39;
}
@media screen and (max-width: 767px) {
  .contact-item__title {
    padding-top: 30px;
  }
}
.contact-item__title h2 {
  padding-bottom: 5px;
  letter-spacing: 0.1em;
}

.contact-item__child {
  padding-top: 20px;
  padding-bottom: 25px;
  padding-right: 15px;
  align-self: center;
}
@media screen and (max-width: 767px) {
  .contact-item__child {
    padding: 10px 20px 15px 20px;
  }
  .contact-item__child p {
    text-align: center;
  }
}
.contact-item__child .tel {
  font-size: 26px;
  font-size: 2.6rem;
  font-family: Garamond, sans-serif;
  color: var(--base-color);
}

.address-list {
  margin-top: 10px;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .address-list {
    margin-left: auto;
    margin-right: auto;
  }
  .address-list tr {
    display: flex;
    flex-direction: column;
    padding-bottom: 10px;
  }
}
.address-list th,
.address-list td {
  font-weight: normal;
}
.address-list th {
  text-align: justify;
  text-align-last: justify;
  padding: 5px 15px 0 0;
  max-width: 90px;
}
.address-list td {
  text-align: left;
  padding: 5px 0 0 0;
}
.address-list a {
  color: var(--base-color);
}
.address-list a:hover {
  text-decoration: underline;
}

.contact-item__form:not(:empty) {
  position: relative;
}
.contact-item__form:not(:empty) a {
  display: inline-grid;
  justify-items: center;
  align-content: center;
  gap: 10px 0;
  font-size: 14px;
  font-size: 1.4rem;
  color: var(--base-color);
  text-align: center;
  width: 100%;
  height: 100%;
  transition: background-color 150ms ease-in-out;
}
@media screen and (max-width: 767px) {
  .contact-item__form:not(:empty) a {
    padding-top: 16px;
    padding-bottom: 17px;
  }
}
.contact-item__form:not(:empty) a:hover {
  color: #fff;
  background-color: var(--base-color);
}
.contact-item__form:not(:empty)::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  content: "";
  display: inline-block;
  width: 1px;
  height: 105px;
  background-color: var(--base-color);
}
@media screen and (max-width: 767px) {
  .contact-item__form:not(:empty)::before {
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: 105px;
    height: 1px;
  }
}

.form-icon {
  display: inline-block;
  width: 43px;
  height: 45px;
  background-image: url(/assets/images/pict/form.svg);
  background-repeat: no-repeat;
  background-size: contain;
  transition: background-image 150ms ease-in-out;
}

.contact-item__form a:hover .form-icon {
  background-image: url(/assets/images/pict/form_r.svg);
}

h1 {
  font-size: 23px;
  font-size: 2.3rem;
  line-height: 1.4;
  margin-bottom: 20px;
}

h2 {
  font-size: 21px;
  font-size: 2.1rem;
  line-height: 1.5;
  padding-bottom: 20px;
}

h3 {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  margin-bottom: 20px;
}

h4 {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.4;
  font-weight: normal;
  padding-bottom: 10px;
}

.h1 {
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  align-items: flex-end;
  color: #6b849c;
  margin-bottom: 0;
}
.h1 .mincho {
  line-height: 1;
}
.h1 .en-title {
  padding-right: 30px;
}
@media screen and (max-width: 767px) {
  .h1 .en-title {
    padding-right: 20px;
  }
}

.h2 {
  display: flex;
  padding-bottom: 7px;
  margin-bottom: 15px;
  border-bottom: 3px solid currentColor;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4;
  width: fit-content;
  margin-top: 45px;
}

.h3 {
  font-feature-settings: "palt";
  padding-bottom: 15px;
  margin-bottom: 0;
}

.h4 {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.1em;
  font-feature-settings: "palt";
  border-left: 15px solid #6b849c;
  padding-left: 10px;
}

.h5 {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4;
}

.en-title {
  font-family: Garamond, sans-serif;
  font-weight: 400;
  font-size: 48px;
  font-size: 4.8rem;
  height: 40px;
  line-height: 1;
}

.en-title-thin {
  font-family: Garamond, sans-serif;
  font-size: 48px;
  font-size: 4.8rem;
  height: 48px;
  letter-spacing: 0.08em;
}

.title-bottom-border {
  position: relative;
  padding-bottom: 20px;
  margin-bottom: 25px;
}
.title-bottom-border::after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  width: 145px;
  height: 15px;
  background-color: #6b849c;
}

.page-title {
  color: #fff;
  background-color: var(--key-color);
  padding: 17px 30px 18px 30px;
  height: 88px;
  margin-bottom: 0;
}
.page-title--fixed {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .page-title--fixed {
    position: static;
  }
}
.page-title-sub {
  font-size: 14px;
  font-size: 1.4rem;
  padding-bottom: 7px;
}
.page-title-text {
  font-size: 28px;
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1.2;
  letter-spacing: 0.07em;
  height: 100%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 480px) {
  .page-title {
    padding: 16px 5.3333vw;
  }
  .page-title-text {
    font-size: clamp(2.4rem, 7vw, 2.8rem);
    letter-spacing: 0.02em;
  }
}

.news-title {
  font-size: 30px;
  font-size: 3rem;
  font-weight: bold;
  margin-top: 65px;
}
@media screen and (max-width: 480px) {
  .news-title {
    margin-top: 45px;
  }
  .news-title br {
    display: none;
  }
}

.lead {
  font-size: 30px;
  font-size: 3rem;
  letter-spacing: 0.1rem;
  font-weight: lighter;
  padding-bottom: 40px;
}

.index-menu {
  display: flex;
  flex-wrap: wrap;
  gap: 2%;
}
.index-menu__item {
  position: relative;
  width: 32%;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  margin-top: 2%;
  transition: all 150ms ease-in;
}
@media screen and (max-width: 480px) {
  .index-menu__item {
    box-shadow: none !important;
  }
}
.index-menu__item:hover {
  background-color: #ddeff7;
  box-shadow: 0 0 4px rgba(37, 92, 163, 0.2), 0 0 30px -15px rgba(37, 92, 163, 0.9);
}
@media screen and (max-width: 480px) {
  .index-menu {
    flex-flow: column nowrap;
    margin-bottom: 0;
  }
  .index-menu__item {
    width: auto;
    padding: 35px 5.3333vw 25px 5.3333vw;
    margin: 0 !important;
    box-shadow: none;
    border-bottom: 1px solid #c9caca;
  }
  .index-menu__item .sp-flex-row__item:first-child {
    margin-right: 35px;
    margin-right: clamp(20px, 5vw, 35px);
  }
  .index-menu__item .sp-flex-row__item img {
    width: 100%;
    max-width: 110px;
  }
}

.index-menu__title {
  font-size: 28px;
  font-size: 2.8rem;
  font-size: clamp(1.6rem, 2.4vw, 2.8rem);
  line-height: 1.2;
  margin-top: 1em;
  text-align: center;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 480px) {
  .index-menu__title {
    margin-top: 0;
    text-align: left;
    letter-spacing: 0.2em;
  }
}

.date {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  font-family: Garamond, sans-serif;
  display: inline-flex;
  align-items: center;
  height: 23px;
}
.date.--right {
  margin-left: auto;
}

.category {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  font-size: 1.2rem;
  min-height: 12px;
  line-height: 1;
  padding: 0px 7px;
  color: var(--gray-color);
  border-left: 1px solid var(--gray-color);
  border-right: 1px solid var(--gray-color);
  white-space: nowrap;
}

.news-block {
  padding: 8px 18px 13px 18px;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .news-block {
    display: flex;
    align-items: center;
    margin-top: 8px;
    margin-bottom: 8px;
    padding: 14px 5.3333vw;
  }
  .news-block .text-20 {
    display: none;
  }
  .news-block .news-block-row {
    margin-top: 0;
    margin-left: 7px;
    flex-grow: 1;
  }
}

.news-list .tag {
  height: auto;
  color: var(--base-color);
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  padding: 4px 9px 3px 9px;
  border: 1px solid currentColor;
  min-width: 70px;
  margin-right: clamp(10px, 5vw, 20px);
  flex: 0 0 auto;
  white-space: nowrap;
  align-self: flex-start;
}
@media screen and (max-width: 767px) {
  .news-list .tag {
    margin-top: 3px;
    align-self: start;
    margin-bottom: 1.2em;
  }
}

.news-list.--index {
  margin-top: 50px;
}

.news-list__item {
  position: relative;
  display: flex;
  padding: 2.5em 2em 2.1em 3em;
}
@media screen and (max-width: 767px) {
  .news-list__item {
    flex-direction: column;
    padding: 3em 1em 2.5em 1em;
  }
}
.news-list__item:not(:first-child) {
  border-bottom: none;
  border-top: 1px dotted var(--base-color);
}
.news-list__item:last-child {
  border-bottom: 1px dotted var(--base-color);
}
@media screen and (max-width: 767px) {
  .news-list__item {
    flex-wrap: wrap;
  }
}
.news-list__item .date {
  font-size: 1.6rem;
  font-size: 16px;
  margin-right: clamp(10px, 5vw, 20px);
  flex: 0 0 auto;
}
@media screen and (max-width: 767px) {
  .news-list__item .date {
    align-self: start;
    padding-bottom: 0.2em;
  }
}
.news-list__item .news-text {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  margin-bottom: 0;
  flex: 1 1 auto;
}
@media screen and (max-width: 767px) {
  .news-list__item .news-text {
    align-self: self-start;
  }
}
.news-list__item:hover {
  background-color: var(--base-light-color);
}

.full-img {
  display: block;
  width: 100%;
  height: inherit;
}
.full-img img {
  width: 100%;
  object-fit: cover;
  vertical-align: top;
}

.empty-img {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  background-image: url(/assets/images/common/logo-bk.svg);
  background-repeat: no-repeat;
  background-position: center 40%;
  background-color: var(--base-light-color);
  text-align: center;
  position: relative;
}
.empty-img::before {
  content: "No Image";
  color: var(--gray-color);
  font-family: arial;
  font-size: 10px;
  font-size: 1rem;
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translate(-50%, 80%);
}
@media screen and (max-width: 480px) {
  .empty-img {
    width: 145px;
    height: 117px;
  }
}

.checkbox-list {
  display: grid;
  grid-template-columns: repeat(6, auto);
  gap: 0 30px;
}
@media screen and (max-width: 767px) {
  .checkbox-list {
    gap: 0 5px;
  }
}
.checkbox-list__child {
  display: inline-flex;
  align-items: center;
  font-size: 14px;
  font-size: 1.4rem;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .checkbox-list__child {
    font-size: 12px;
    font-size: 1.2rem;
    margin-right: 2px;
    margin-left: 2px;
  }
}

.checkbox-item {
  opacity: 0;
  width: 0 !important;
}
.checkbox-item::after {
  display: none !important;
}

.checkbox-btn {
  text-align: center;
  transition: all 200ms ease-in;
}
@media screen and (max-width: 767px) {
  .checkbox-btn {
    min-width: 52px;
  }
}
.checkbox-item:checked + .checkbox-btn {
  font-weight: 600;
}
*:hover > .checkbox-btn.c-all, .checkbox-item:checked + .checkbox-btn.bdc-all {
  color: var(--gnenral);
}
*:hover > .checkbox-btn.c-hs, .checkbox-item:checked + .checkbox-btn.bdc-high {
  color: var(--high);
}
*:hover > .checkbox-btn.c-combined, .checkbox-item:checked + .checkbox-btn.bdc-juniorhigh {
  color: var(--juniorhigh);
}
*:hover > .checkbox-btn.c-kindergarten, .checkbox-item:checked + .checkbox-btn.bdc-kindergarten {
  color: var(--kindergarten);
}
*:hover > .checkbox-btn.c-nursery, .checkbox-item:checked + .checkbox-btn.bdc-nursery {
  color: var(--nursery);
}
*:hover > .checkbox-btn.c-general, .checkbox-item:checked + .checkbox-btn.bdc-general {
  color: var(--gnenral);
}

.news-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0 42px;
}
@media screen and (max-width: 1180px) {
  .news-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.news-grid.--breaking-news {
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 767px) {
  .news-grid.--breaking-news {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 480px) {
  .news-grid {
    grid-template-columns: 1fr;
  }
}

.news-item {
  position: relative;
  margin-bottom: 30px;
  transition: all ease-in 200ms;
}
@media screen and (max-width: 767px) {
  .news-item {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 5.3333vw;
  }
}
.news-item img {
  width: 100%;
  object-fit: cover;
  vertical-align: top;
}

.news-item__img {
  display: block;
  height: 155px;
  overflow: hidden;
}
.news-item__img img {
  height: 100%;
  position: relative;
  transition: transform 200ms ease-in-out;
}
@media screen and (max-width: 480px) {
  .news-item__img {
    grid-column: 1/2;
    grid-row: 1/2;
    height: 117px;
  }
}

.news-item-caption {
  display: flex;
  flex-direction: column;
  padding: 16px 15px 12px 15px;
  height: 165px;
  border-bottom: 1px solid #b4b4b5;
}
.news-item-caption__date {
  display: inline-flex;
  align-items: center;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  font-family: Garamond, sans-serif;
  padding-left: 12px;
}

.news-item-caption__taglist {
  display: flex;
  margin-left: 5px;
  margin-right: 5px;
}

.news-item.breaking-news-item {
  height: 425px;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .news-item.breaking-news-item {
    width: 100%;
    height: 325px;
  }
}
.news-item.breaking-news-item .news-item-caption {
  min-height: 110px;
  position: relative;
  transform: translateY(-55px);
  width: fit-content;
  max-width: 80%;
  height: auto;
  background-color: #fff;
  border-bottom: none;
  padding: 16px 20px 12px 20px;
}
@media screen and (max-width: 767px) {
  .news-item.breaking-news-item .news-item-caption {
    transform: translateY(-30px);
  }
}
@media screen and (max-width: 480px) {
  .news-item.breaking-news-item .news-item-caption {
    min-width: 260px;
    height: 136px;
  }
}
.news-item.breaking-news-item .news-item-caption__title {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.7;
  font-weight: 500;
  padding-top: 10px;
  margin-bottom: 0;
}
.news-item.breaking-news-item .date {
  margin-left: 0;
  margin-top: 0;
}

.breaking-news-item__img {
  overflow: hidden;
  height: 370px;
}
@media screen and (max-width: 767px) {
  .breaking-news-item__img {
    height: 100%;
  }
}
.breaking-news-item__img .full-img {
  height: 100%;
}
@media screen and (max-width: 767px) {
  .breaking-news-item__img .full-img {
    height: 220px;
    object-position: top center;
  }
}

.item-content:hover .hover-img > img {
  transform: scale(1.05);
}

@media screen and (max-width: 480px) {
  #news-contents .news-item {
    border-bottom: 1px solid #b4b4b5;
    padding-bottom: 5.3333vw;
  }
  #news-contents .item-content {
    display: grid;
    grid-template-columns: 0.4fr 0.6fr;
    gap: 0 15px;
  }
  #news-contents .item-content .news-item__img {
    grid-column: 1/2;
    grid-row: 1/2;
  }
  #news-contents .item-content .news-item-caption {
    grid-column: 2/3;
    grid-row: 1/2;
    padding: 0;
    height: auto;
    border-bottom: none;
  }
  #news-contents .item-content .news-item-header {
    justify-content: flex-start;
  }
  #news-contents .item-content .news-item-caption__text {
    font-size: 14px;
    font-size: 1.4rem;
  }
}

.news-item-header {
  display: grid;
  grid-template-columns: auto auto;
  justify-content: center;
  padding-bottom: 15px;
}
.news-item-caption__text {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.7;
  padding-bottom: 10px;
  font-weight: 400;
  margin-bottom: 0;
  flex-grow: 1;
}
.safari .news-item-caption__text {
  font-weight: 200;
}

.news-title {
  font-size: 26px;
  font-size: 2.6rem;
  font-weight: bold;
  margin-top: 20px;
}
@media screen and (max-width: 480px) {
  .news-title {
    font-size: 14px;
    font-size: 1.4rem;
  }
}

.news-top-img {
  text-align: center;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 50px;
}
.news-top-img img {
  width: 100%;
  height: 100%;
}

.thumb-unit {
  display: flex;
  flex-wrap: wrap;
  margin-left: -10px;
  margin-right: -10px;
}
.thumb-unit > * {
  width: calc(33.3% - 20px);
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 20px;
}
@media screen and (max-width: 480px) {
  .thumb-unit > * {
    width: calc(50% - 20px);
  }
}
.thumb-unit > * img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gakuen-news {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
}
.gakuen-news__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 300px;
  width: 21vw;
}
@media screen and (max-width: 767px) {
  .gakuen-news__title {
    width: auto;
    flex-flow: row wrap;
    max-width: none;
  }
}
@media screen and (max-width: 767px) {
  .gakuen-news {
    padding-top: 40px;
    grid-template-columns: auto;
    grid-template-rows: auto auto;
  }
}

.gakuen-news-title {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 400;
  color: var(--base-color);
  letter-spacing: 0.05em;
  font-family: "Yu Mincho", YuMincho, serif;
  margin-bottom: 10px;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .gakuen-news-title {
    margin-bottom: 0;
  }
}

.gakuen-news-link {
  display: inline-flex;
  align-items: center;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  color: #3e3a39;
}
@media screen and (max-width: 767px) {
  .gakuen-news-link {
    margin-left: auto;
  }
}
.gakuen-news-link__text {
  display: inline-block;
  padding-top: 3px;
}
@media screen and (max-width: 767px) {
  .gakuen-news-link__text {
    padding: 0;
  }
}
.gakuen-news-link:hover {
  color: var(--base-color);
}
.gakuen-news-link:hover .gakuen-news-link__icon {
  background-color: var(--base-color);
}
.gakuen-news-link:hover .gakuen-news-link__icon::before, .gakuen-news-link:hover .gakuen-news-link__icon::after {
  background-color: #fff;
}

.gakuen-news-link__icon {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 1px solid var(--base-color);
  border-radius: 100%;
  position: relative;
  margin-left: 5px;
  transition: all 100ms ease-in;
}
.gakuen-news-link__icon::before, .gakuen-news-link__icon::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 9px;
  background-color: var(--base-color);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: all 100ms ease-in;
}
.gakuen-news-link__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.news-list.--gakuen-news {
  padding-top: 40px;
  padding-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .news-list.--gakuen-news {
    padding-top: 20px;
    padding-bottom: 15px;
  }
}
.news-list.--gakuen-news .news-list__item {
  padding-top: 15px;
  padding-bottom: 15px;
  border: none !important;
}
.news-list.--gakuen-news .news-list__item:hover .date,
.news-list.--gakuen-news .news-list__item:hover .news-text {
  color: var(--base-color);
}
@media screen and (max-width: 767px) {
  .news-list.--gakuen-news .news-list__item {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 15px 0;
    padding: 10px 0;
  }
  .news-list.--gakuen-news .news-list__item .date {
    grid-row: 1/2;
    grid-column: 1/2;
  }
  .news-list.--gakuen-news .news-list__item .tag {
    grid-row: 1/2;
    grid-column: 2/3;
    justify-self: start;
    margin-top: 0;
    margin-bottom: 0;
  }
  .news-list.--gakuen-news .news-list__item .news-text {
    grid-row: 2/3;
    grid-column: 1/3;
  }
}
.news-list.--gakuen-news .date,
.news-list.--gakuen-news .news-text {
  color: #3e3a39;
}

.edit-block {
  margin-top: 50px;
  margin-bottom: 18px;
}
@media screen and (max-width: 480px) {
  .edit-block {
    margin-top: 30px;
    margin-bottom: 25px;
  }
}
.edit-block.border-end {
  border-bottom: 5px solid #dcdddd;
  padding-bottom: 45px;
}
.edit-block p {
  line-height: 1.8;
  text-align: justify;
}
.edit-block p + p {
  margin-top: 1em;
}
.edit-block p + *:not(p) {
  margin-top: 2em;
}
.edit-block hr {
  clear: both;
}
.edit-block h1 {
  color: #6b849c;
  font-size: 22px;
  font-size: 2.2rem;
  padding-bottom: 10px;
  margin-top: 1em;
  margin-bottom: 20px;
  border-bottom: 1px solid currentColor;
}
.edit-block h2 {
  display: flex;
  padding-top: 1em;
  padding-bottom: 7px;
  margin-bottom: 20px;
  border-bottom: 3px solid currentColor;
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.6;
  width: fit-content;
}
.edit-block h3 {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.2em;
  font-feature-settings: "palt";
  border-left: 15px solid #6b849c;
  padding-left: 10px;
  padding-bottom: 0;
  margin: 0 0 20px 0;
}
.edit-block h4 {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.4;
  font-weight: normal;
  position: relative;
  padding-left: 28px;
  margin-top: 20px;
  margin-bottom: 17px;
  margin: 0 0 15px 0;
  padding: 0 0 0 28px;
}
.edit-block h4::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  display: inline-block;
  width: 20px;
  height: 6px;
  background-color: var(--base-color);
}
.edit-block h5 {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.4;
  color: var(--base-color);
  padding-bottom: 10px;
  margin: 0 0 10px 0;
  padding: 0;
}
.edit-block ul {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  list-style: none;
}
.edit-block ul li {
  margin-left: 1.5em;
  position: relative;
}
.edit-block ul li:before {
  display: inline-block;
  content: "";
  width: 8px;
  height: 8px;
  background-color: #6b849c;
  border-radius: 100%;
  margin-left: -1em;
  position: absolute;
  top: 0.43em;
}
.edit-block ul li li::before {
  width: 3px;
  height: 3px;
  top: 1em;
  margin-left: -0.6em;
}
.edit-block ol {
  list-style-position: outside;
  counter-reset: number;
  margin-left: 0;
}
.edit-block ol > li {
  list-style-type: none;
  margin-left: 26px;
  line-height: 2;
}
.edit-block ol > li:not(:first-child) {
  margin-top: 0.5em;
}
.edit-block ol > li:before {
  color: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 20px;
  display: inline-block;
  counter-increment: number;
  content: counter(number);
  background-color: #6b849c;
  width: 20px;
  height: 20px;
  text-align: center;
  position: relative;
  top: -1px;
  font-family: Arial;
  font-weight: normal;
  margin-left: -28px;
  margin-right: 4px;
}
.edit-block dl {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
}
.edit-block dl dt {
  min-width: 160px;
}
.edit-block dl dt,
.edit-block dl dd {
  margin-bottom: 4px;
}
.edit-block .link {
  margin-bottom: 20px;
}
.edit-block .link > li a {
  transition: color 150ms ease-in;
  position: relative;
}
.edit-block .link > li a::after {
  position: absolute;
  right: 0;
  top: 47%;
  transform: translate(10px, -50%);
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 8px;
  border-color: transparent transparent transparent #6b849c;
  transition: transform 200ms ease-out;
}
.edit-block .link > li a:hover::after {
  transform: translate(15px, -50%);
}
.edit-block .link li {
  margin-left: 0;
}
.edit-block .link li::before {
  display: none;
}
.edit-block .btn {
  position: relative;
  font-size: 16px;
  font-size: 1.6rem;
  padding: 0 1em 0 0;
  color: #6b849c;
}
.edit-block .btn::before {
  position: absolute;
  right: 1px;
  top: calc(50% - 1px);
  transform: translate(0, -50%);
  transform-origin: top left;
  content: "";
  display: inline-block;
  width: 1px;
  height: 1px;
  background-color: currentColor;
  transition: transform 200ms ease-out;
}
.edit-block .btn:hover::before {
  transform: translate(0, -50%) scaleX(30);
}
.edit-block .btn::after {
  position: absolute;
  right: 0;
  top: 47%;
  transform: translate(0, -50%);
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 8px;
  border-color: transparent transparent transparent currentColor;
  transition: transform 200ms ease-out;
}
.edit-block .btn:hover::after {
  transform: translate(36px, -50%);
}
.edit-block table.table-border {
  border-bottom: 1px solid #dcdddd;
}
.edit-block table.table-border th,
.edit-block table.table-border td {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  border-top: 1px solid #dcdddd;
  padding: 1em 0;
  text-align: left;
  vertical-align: top;
}
@media screen and (max-width: 480px) {
  .edit-block table.table-border th,
  .edit-block table.table-border td {
    padding: 0.6em 0.2em;
  }
}
.edit-block table.table-border th {
  color: #6b849c;
  padding-right: 60px;
}
@media screen and (max-width: 767px) {
  .edit-block table.table-border th {
    padding-right: 18px;
    min-width: 6em;
  }
}
.edit-block table {
  border-collapse: separate;
  border-spacing: 1px;
}
.edit-block table th {
  background-color: #6b849c;
  color: #fff;
  font-size: 16px;
  font-size: 1.6rem;
  padding: 1.2em 0.8em 1.1em;
  text-align: left;
}
.edit-block table td {
  font-size: 16px;
  font-size: 1.6rem;
  border-top: 1px solid var(--base-color);
  padding: 1.2em 0.8em 1.1em;
}
.edit-block table tr:last-child td {
  border-bottom: 1px solid var(--base-color);
}
.edit-block .main-photo {
  float: right;
  margin-left: 60px;
  margin-bottom: 1.5em;
  margin-left: clamp(20px, 3.5vw, 60px);
}
@media screen and (max-width: 767px) {
  .edit-block .main-photo {
    float: none;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    margin-bottom: 40px;
  }
}
.edit-block .main-photo img {
  width: 100%;
  max-width: fit-content;
  height: auto;
  object-fit: cover;
}
.edit-block .thumbnail {
  display: flex;
  flex-wrap: wrap;
  margin-left: -10px;
  margin-right: -10px;
}
.edit-block .thumbnail > * {
  width: calc(33% - 10px);
  margin-left: 5px;
  margin-right: 5px;
  margin-bottom: 10px;
  overflow: hidden;
}
@media screen and (max-width: 480px) {
  .edit-block .thumbnail > * {
    width: calc(50% - 10px);
  }
}
.edit-block .thumbnail img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  .table-row {
    display: flex;
    flex-direction: column;
  }
  .table-row tbody,
  .table-row tr {
    display: contents;
  }
  .table-row td {
    margin-bottom: 30px;
    border: none !important;
  }
}

.lightboxOverlay {
  opacity: 1;
  background-color: rgba(0, 0, 0, 0.8);
}

.lb-number {
  margin-top: 5px;
}

.lb-data .lb-close {
  position: fixed;
  top: 0;
  right: 0;
  opacity: 1;
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0.4em 2em 0.3em 2em;
  cursor: pointer;
  color: #fff;
  background-image: none;
  background-color: #005177;
  letter-spacing: 0.1em;
  transition: background-color 200ms ease-out;
}
.lb-data .lb-close::before {
  content: "×";
  font-family: Roboto;
  font-weight: 400;
}
.lb-data .lb-close:hover {
  background-color: #afa161;
}
@media screen and (max-width: 767px) {
  .lb-data .lb-close {
    align-self: flex-end;
    margin: 0;
  }
}
@media screen and (max-width: 480px) {
  .lb-data .lb-close {
    margin: 10px 0;
  }
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}
.swiper-container-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}
.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-container-fade .swiper-slide-active, .swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

@font-face {
  font-family: "swiper-icons";
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color: #007aff;
}

.swiper-container {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
}

.swiper-container-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.swiper-container-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-container-multirow > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-container-multirow-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-container-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-container-pointer-events {
  touch-action: pan-y;
}
.swiper-container-pointer-events.swiper-container-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */
.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
  height: auto;
}
.swiper-container-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

/* 3D Effects */
.swiper-container-3d {
  perspective: 1200px;
}
.swiper-container-3d .swiper-wrapper,
.swiper-container-3d .swiper-slide,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}
.swiper-container-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-container-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-container-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

/* CSS Mode */
.swiper-container-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none; /* For Firefox */
  -ms-overflow-style: none; /* For Internet Explorer and Edge */
}
.swiper-container-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}
.swiper-container-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-container-horizontal.swiper-container-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-container-vertical.swiper-container-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  */
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 300ms opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}
.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

/* Common Styles */
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 10px;
  left: 0;
  width: 100%;
}

/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  display: inline-block;
  border-radius: 50%;
  background: #000;
  opacity: 0.2;
}
button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-container-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}
.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 6px 0;
  display: block;
}
.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}
.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 200ms transform, 200ms top;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 4px;
}
.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms left;
}
.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms right;
}

/* Progress */
.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}
.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}
.swiper-container-horizontal > .swiper-pagination-progressbar, .swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}
.swiper-container-vertical > .swiper-pagination-progressbar, .swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-white {
  --swiper-pagination-color: #ffffff;
}

.swiper-pagination-black {
  --swiper-pagination-color: #000000;
}

.swiper-pagination-lock {
  display: none;
}

:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}
.swiper-button-prev:after,
.swiper-button-next:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  text-transform: none;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev,
.swiper-container-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}
.swiper-button-prev:after,
.swiper-container-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next,
.swiper-container-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}
.swiper-button-next:after,
.swiper-container-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-button-prev.swiper-button-white,
.swiper-button-next.swiper-button-white {
  --swiper-navigation-color: #ffffff;
}

.swiper-button-prev.swiper-button-black,
.swiper-button-next.swiper-button-black {
  --swiper-navigation-color: #000000;
}

.swiper-button-lock {
  display: none;
}

.top-container {
  display: grid;
  justify-content: center;
  align-items: center;
  grid-template-areas: "areaLT areaC areaRT" "areaLB areaC areaRB";
}
@media screen and (max-width: 767px) {
  .top-container {
    grid-template-areas: "areaLT areaRT" "areaLB areaRB";
    height: calc(100vh - 54px);
  }
}
.top-container__item {
  position: relative;
  background-color: #6b849c;
  width: calc(50vw - 45px);
  height: 50vh;
  align-self: center;
}
@media screen and (max-width: 767px) {
  .top-container__item {
    width: 50vw;
    height: calc(50vh - 27px);
  }
}
.top-container__item .click-expand::before {
  z-index: 3;
}
.top-container .group__item-name span {
  padding-left: 10px;
  font-size: 25px;
  font-size: 2.5rem;
}
@media screen and (max-width: 767px) {
  .top-container .group__item-name span {
    font-size: 13px;
    font-size: 1.3rem;
    padding-left: 3px;
  }
}
.top-container .group-item-copy {
  font-size: 23px;
  font-size: 2.3rem;
}
@media screen and (max-width: 767px) {
  .top-container .group-item-copy {
    font-size: 12px;
    font-size: 1.2rem;
    left: 1em;
  }
}

.top-container__item .group__item-cover {
  opacity: 0.5;
  mix-blend-mode: multiply;
  background-color: #458b8b;
}

.top-container__item__logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  height: 52px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .top-container__item__logo {
    width: 100%;
    height: auto;
    padding: 0 1.4em;
  }
  .top-container__item__logo span {
    text-align: center;
  }
}

.tsukinousagi-logo {
  display: inline-block;
  width: 300px;
  height: 52px;
  background-image: url(/assets/images/home/hoikuen-logo.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .tsukinousagi-logo {
    width: 100%;
    max-width: 205px;
    height: 41px;
  }
}

.ryutokukan-logo {
  display: inline-block;
  width: 300px;
  height: 52px;
  background-image: url(/assets/images/home/ryutokukan-logo.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .ryutokukan-logo {
    width: 100%;
    max-width: 186px;
    height: 43px;
  }
}

.gyokusui-logo {
  display: inline-block;
  width: 300px;
  height: 52px;
  background-image: url(/assets/images/home/gyokusui-logo.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .gyokusui-logo {
    width: 100%;
    max-width: 149px;
    height: 41px;
  }
}

.highschool-logo {
  display: inline-block;
  width: 300px;
  height: 52px;
  background-image: url(/assets/images/home/high-school-logo.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .highschool-logo {
    width: 100%;
    max-width: 196px;
    height: 37px;
  }
}

.o-center {
  grid-area: areaC;
  width: 90px;
  height: 100vh;
}
.o-center a {
  height: 100%;
}
@media screen and (max-width: 767px) {
  .o-center {
    display: none;
  }
}

.o-lefttop {
  grid-area: areaLT;
}

.o-righttop {
  grid-area: areaRT;
}

.o-leftbottom {
  grid-area: areaLB;
}

.o-rightbottom {
  grid-area: areaRB;
}

.body-scroll {
  position: relative;
  z-index: 3;
  width: 100%;
  overflow: hidden;
  margin-top: 100vh;
  background-color: #fff;
}
.body-scroll.is-set {
  position: absolute;
  top: 6px;
}
@media screen and (max-width: 767px) {
  .body-scroll {
    position: relative;
  }
}
.is-sp-open .body-scroll {
  cursor: pointer;
  overflow: hidden;
  pointer-events: none;
}
.is-sp-open .body-scroll > * {
  pointer-events: none;
}
.is-sp-open .body-scroll .header {
  pointer-events: auto;
}

.home .first-view-area {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100vh;
}
@media screen and (max-width: 767px) {
  .home .first-view-area {
    top: 54px;
    height: calc(100vh - 54px);
  }
}

.scrollto-btn {
  position: absolute;
  bottom: 0;
  left: 57%;
  z-index: 1;
  transform: translate(-50%, -20px);
  display: inline-block;
  width: 15px;
  height: auto !important;
  transition: transform 150ms ease-in;
}
.scrollto-btn:hover {
  transform: translate(-50%, -10px);
}
.scrollto-btn img {
  width: 15px;
  height: auto;
  object-fit: contain;
}
