@charset "UTF-8";
/* --------------- variables --------------------- */
/* Break Point */
/* Color */
/*サイトカラー*/
/* other */
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}
.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: transparent;
}
.slick-prev:hover:before, .slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}
.slick-prev:before,
.slick-next:before {
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}
[dir=rtl] .slick-prev {
  left: auto;
  right: -25px;
}
.slick-next {
  right: -25px;
}
[dir=rtl] .slick-next {
  left: -25px;
  right: auto;
}
/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

.Btn {
  text-align: center;
}
.Btn a {
  display: block;
  border: 1px solid #103d74;
  line-height: 1;
  font-weight: 500;
  margin-inline: auto;
}
.Btn a:hover {
  color: #fff;
  background-color: #103d74;
}

.BtnOrange {
  text-align: center;
}
.BtnOrange a {
  display: block;
  color: #fff;
  line-height: 1;
  font-family: "Noto Sans JP", sans-serif;
  background-color: #C14600;
  position: relative;
}
.BtnOrange a:before, .BtnOrange a:after {
  content: "";
  position: absolute;
  height: 1px;
  background-color: #fff;
}
.BtnOrange a:before {
  transform: rotate(45deg);
}
.BtnOrange a:after {
  transform: rotate(-45deg);
}
.BtnOrange a:hover {
  opacity: 0.7;
}

.secTitle {
  text-align: center;
}
.secTitle span {
  display: inline-block;
  position: relative;
  font-family: "EB Garamond", serif;
  font-weight: 500;
  letter-spacing: 0.1em;
}
.secTitle span:after {
  content: "";
  position: absolute;
  background-color: #C14600;
  right: -4px;
}

.lead_center {
  margin-top: 28px;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
}

.fv .text h2 {
  font-weight: 500;
}
.fv .text p {
  position: relative;
}
.fv .text p:before {
  content: "";
  position: absolute;
  left: 0;
  background: #C14600;
}

.lead {
  position: relative;
}
.lead:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: rgba(255, 255, 255, 0.8);
  top: 0;
  left: 0;
  z-index: 1;
  -webkit-backdrop-filter: blur(14px);
          backdrop-filter: blur(14px);
}
.lead .decoText {
  background-image: url(../images/home/decotext.png);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-clip: border-box;
  z-index: 3;
  position: absolute;
  bottom: 0;
  left: 0;
  overflow: hidden;
}
.lead .img {
  position: absolute;
  z-index: 2;
}
.lead .sectionWrap {
  position: relative;
  z-index: 2;
}
.lead .sectionWrap .inner .Btn a {
  margin-top: 0;
}
.lead .text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.lead .text .paragraph p {
  color: #010101;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (min-width: 1500px) {
  .lead .img {
    left: 0;
    right: -800px;
    margin: auto;
  }
}

.introduce {
  position: relative;
}
.introduce:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-color: #103d74;
  z-index: -1;
}
.introduce .secTitle {
  color: #fff;
}
.introduce .secTitle span {
  color: #fff;
}
.introduce .secTitle span:after {
  right: -4px;
}
.introduce .lead_center {
  color: #fff;
}

.teachers {
  background-color: #eeebe3;
}

.topics {
  position: relative;
}
.topics:before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  background-color: #103d74;
  z-index: -1;
}
.topics .topics_container li a .text h3 {
  color: #fff;
}
.topics .topics_container li a .text p {
  color: #fff;
}
.topics .topics_container li a .text .link {
  border-bottom: 1px solid #fff;
  color: #fff;
}
.topics .topics_container li a .text .link:before, .topics .topics_container li a .text .link:after {
  background-color: #fff;
}
.topics .Btn a {
  color: #fff;
  border: 1px solid #fff;
}
.topics .Btn a:hover {
  color: #103d74;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .commonSec {
    padding-block: 40px;
  }
  .Btn a {
    width: 275px;
    margin-top: 40px;
    padding-block: 20px;
  }
  .secTitle {
    text-align: center;
    font-size: 20px;
  }
  .secTitle span {
    display: inline-block;
    position: relative;
    font-family: "EB Garamond", serif;
    font-weight: 500;
    letter-spacing: 0.1em;
  }
  .secTitle span:after {
    content: "";
    position: absolute;
    background-color: #C14600;
    right: -4px;
  }
  .secTitle span {
    font-size: 11px;
    margin-bottom: 15px;
    padding-right: 12px;
  }
  .secTitle span:after {
    top: 6px;
    width: 10px;
    height: 1px;
  }
  .fv {
    height: max(80vh, 540px);
    background: url(../images/home/fv_sp.jpg) no-repeat 20% 50%/cover;
  }
  .fv .text h2 {
    padding-top: max(10.66vw, 40px);
    font-size: clamp(22px, 6.1vw, 32px);
    line-height: 1.36;
    letter-spacing: 0.2em;
  }
  .fv .text p {
    margin-top: 14px;
    padding-left: 22px;
    font-size: 10px;
  }
  .fv .text p:before {
    top: 8px;
    width: 18px;
    height: 2px;
  }
  .fv .text .BtnOrange a {
    width: 160px;
    margin-top: 24px;
    padding-block: 10px;
    padding-inline: 12px 0;
    font-size: 12px;
    text-align: left;
  }
  .fv .text .BtnOrange a:before, .fv .text .BtnOrange a:after {
    width: 7px;
  }
  .fv .text .BtnOrange a:before {
    top: 13px;
    right: 8px;
  }
  .fv .text .BtnOrange a:after {
    top: 18px;
    right: 8px;
  }
  .lead {
    background: url(../images/home/fv_sp.jpg) no-repeat 30% 50%/cover;
  }
}
@media screen and (max-width: 768px) and (min-width: 1500px) {
  .lead .img {
    left: 0;
    right: -800px;
    margin: auto;
  }
}
@media screen and (max-width: 768px) {
  .lead .decoText {
    background-size: 768px auto;
    width: 100%;
    height: 80px;
  }
  .lead .img {
    display: none;
  }
  .lead .sectionWrap .inner {
    padding-block: 48px 80px;
  }
  .lead .sectionWrap .inner .Btn a {
    margin-inline: auto;
  }
  .lead .text {
    display: flex;
    flex-direction: column;
    height: 320px;
  }
  .lead .text h2 {
    font-size: 20px;
    line-height: 1.65;
    letter-spacing: 0.08em;
  }
  .lead .text .paragraph p {
    line-height: 1.71;
  }
  .lead .text .paragraph p + p {
    margin-top: min(6.4vw, 24px);
  }
  .introduce:before {
    width: 100%;
    height: 285px;
  }
  .introduce .fieldList {
    margin-top: 25px;
    row-gap: 25px;
  }
  .introduce .fieldList > li {
    width: calc(50% - 4.26vw);
  }
  .topics:before {
    width: 100%;
    height: 83.78%;
  }
  .news .news_container {
    margin-top: 40px;
  }
  .news .Btn a {
    width: 165px;
    margin-top: 30px;
    padding-block: 12px;
  }
}
@media print, screen and (min-width: 769px) {
  .commonSec {
    padding-block: 80px;
  }
  .Btn a {
    width: 320px;
    margin-top: 50px;
    padding-block: 18px;
  }
  .secTitle {
    text-align: center;
    font-size: 34px;
  }
  .secTitle span {
    display: inline-block;
    position: relative;
    font-family: "EB Garamond", serif;
    font-weight: 500;
    letter-spacing: 0.1em;
  }
  .secTitle span:after {
    content: "";
    position: absolute;
    background-color: #C14600;
    right: -4px;
  }
  .secTitle span {
    font-size: 16px;
    margin-bottom: 20px;
    padding-right: 16px;
  }
  .secTitle span:after {
    top: 8px;
    width: 14px;
    height: 1px;
  }
  .fv {
    background: url(../images/home/fv_pc.jpg) no-repeat top left/cover;
    height: min(48.61vw, 800px);
  }
  .fv .sectionWrap {
    padding-inline: 0;
  }
  .fv .sectionWrap .inner {
    max-width: 1360px;
  }
  .fv .text {
    width: 50%;
    margin-block: auto;
    margin-left: auto;
    padding-left: 4.1%;
  }
  .fv .text h2 {
    padding-top: min(19.09vw, 275px);
    font-size: min(2.37vw, 43px);
    line-height: 1.36;
    letter-spacing: 0.2em;
    font-feature-settings: "palt";
  }
  .fv .text p {
    margin-top: 28px;
    padding-left: 40px;
  }
  .fv .text p:before {
    top: 13px;
    width: 28px;
    height: 2px;
  }
  .fv .text .BtnOrange a {
    width: 180px;
    padding-block: 10px;
    margin-top: 28px;
    padding-inline: 14px 0;
    font-size: 15px;
    text-align: left;
  }
  .fv .text .BtnOrange a:before, .fv .text .BtnOrange a:after {
    width: 9px;
    right: 10px;
  }
  .fv .text .BtnOrange a:before {
    top: 15px;
  }
  .fv .text .BtnOrange a:after {
    top: 21px;
  }
  .lead {
    background: url(../images/home/fv_pc.jpg) no-repeat 0% 50%/cover;
  }
  .lead .decoText {
    background-size: 100% auto;
    width: 100%;
    height: 170px;
  }
  .lead .img {
    top: 128px;
    right: 0px;
    width: 41.66vw;
    max-width: 600px;
    aspect-ratio: 600/426;
  }
  .lead .sectionWrap .inner {
    display: flex;
    padding-block: 128px 170px;
  }
  .lead .sectionWrap .inner .Btn a {
    margin-inline: 0 auto;
  }
  .lead .text {
    height: 29.58vw;
    max-height: 426px;
    min-height: 320px;
  }
  .lead .text h2 {
    font-size: min(2.63vw, 38px);
    line-height: 1.68;
  }
  .lead .text .paragraph p {
    font-size: clamp(14px, 1.11vw, 16px);
  }
  .lead .text .paragraph p + p {
    margin-top: 24px;
  }
}
@media screen and (min-width: 769px) and (min-width: 1500px) {
  .lead .img {
    left: 0;
    right: -800px;
    margin: auto;
  }
}
@media print, screen and (min-width: 769px) {
  .introduce:before {
    width: 84.72vw;
    height: max(56.26%, 400px);
  }
  .introduce .fieldList {
    max-width: 1080px;
    margin-top: 60px;
  }
  .introduce .fieldList > li {
    width: 21.85%;
    margin: 0;
  }
  .introduce .fieldList > li:not(:nth-child(4n)) {
    margin-right: 4.2%;
  }
  .introduce .fieldList > li .fieldListBtn {
    max-width: 195px;
  }
  .topics:before {
    width: 95.48vw;
    height: max(55.81%, 480px);
  }
  .news .inner {
    display: flex;
    justify-content: space-between;
  }
  .news .secTitle {
    text-align: left;
  }
  .news .titleWrap {
    width: 338px;
  }
  .news .news_container {
    width: calc(100% - 338px);
  }
  .news .Btn a {
    width: 150px;
    margin-inline: 0 auto;
    margin-top: 32px;
    padding-block: 12px;
  }
}
@media screen and (min-width: 769px) and (max-width: 980px) {
  .secTitle {
    text-align: center;
  }
  .secTitle span {
    display: inline-block;
    position: relative;
    font-family: "EB Garamond", serif;
    font-weight: 500;
    letter-spacing: 0.1em;
  }
  .secTitle span:after {
    content: "";
    position: absolute;
    background-color: #C14600;
    right: -4px;
  }
}
@media screen and (min-width: 769px) and (max-width: 980px) and (min-width: 1500px) {
  .lead .img {
    left: 0;
    right: -800px;
    margin: auto;
  }
}
@media screen and (min-width: 769px) and (max-width: 980px) {
  .lead .img {
    top: 176px;
    width: 35.76vw;
    aspect-ratio: 600/426;
  }
}
/*# sourceMappingURL=map/home.css.map */
