@charset "utf-8";
  .main {
    background-color: #e6faf3;
  }
  .section-top {
    background-image: url(../img/school-top-img_pc.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    height: 620px;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
  }
  .section-top h1 {
    background-color: #fff;
    font-size: 3.6rem;
    padding: 36px;
    margin: 255px auto;
    display: inline-block;
    font-weight: 500;
  }
  @media(min-width:768px) and (max-width:1279px) {
    .section-top {
      height: 620px;
      width: 100%;
      max-width: 768px;
    }
    .section-top h1 {
      font-size: 2.6rem;
      padding: 30px;
    }
  }
  @media(max-width:767px) {
    .section-top {
      height: 300px;
      width: 100%;
      max-width: 428px;
    }
    .section-top h1 {
      font-size: 2.0rem;
      margin: 124px auto;
      padding: 15px;
    }
  }
  .map-illust img {
    width: 1270px;
    margin: 300px auto 200px;
    display: block;
    max-width: 1280px;
  }
  .map-p__wrp {
    background-color: #fff;
    max-width: 845px;
    display: inline-block;
  }
  .map__about {
    background-color: #fff;
    font-size: 2.4rem;
    line-height: 3.6rem;
    /* margin: 95px auto 0; */
    padding: 95px 100px 0;
    text-align: left;
  }
  .map__discription {
    background-color: #fff;
    font-size: 2.4rem;
    line-height: 3.6rem;
    /* margin: 80px auto 0; */
    padding: 80px 100px 95px;
    text-align: left;
  }
  .map__discription a {
    text-decoration: none;
    color: #333;
  }
  @media(min-width:768px) and (max-width:1279px) {
    .map-illust img {
      display: none;
    }
    .map-illust__sp img {
      display: block;
      width: 624px;
      margin: 100px auto 200px;
      max-width: 768px;
    }
    .map-p__wrp {
      max-width: 672px;
    }
  }
  @media(max-width:767px) {
    .map-illust__sp img {
      display: block;
      width: 327px;
      margin: 100px auto 80px;
      max-width: 375px;
    }
    .map-p__wrp {
      background-color: #fff;
      max-width: 327px;
      display: inline-block;
    }
    .map__about {
      font-size: 1.8rem;
      line-height: 2.7rem;
      padding: 40px 20px 0;
    }
    .map__discription {
      font-size: 1.8rem;
      line-height: 2.7rem;
      padding: 40px 20px 40px;
    }
  }
  .school-list {
    margin: 0 auto;
    position: relative;
    max-width: 1280px;
  }
  .school-list::before {
    content: url(../img/grapes-left_pc.png);
    position: absolute;
    height: 145px;
    display: block;
    left: 110px;
    top: 270px;
  }
  .school-list::after {
    content: url(../img/grapes-right_pc.png);
    position: absolute;
    height: 145px;
    display: block;
    right: 110px;
    top: 270px;
  }
  .school-list__title {
    padding: 330px 0 190px;
    margin: 0 auto;
    display: inline-block;
    position: relative;
    z-index: 99;
  }
  .school-list__title::before {
    content: ""; 
    position: absolute;
    display: block;
    z-index: -10; 
    background-image: url(../img/title-circle.png);
    height: 105px;
    width: 105px;
    left: -68px;
    top: 290px;
    opacity: 0.5;
  }
  .school-title-line::before {
  position: absolute;
  display: block;
  left: calc(50% - 80px);
  width: 150px;
  height: 1px;
  content: '';
  border-radius: 3px;
  background: #333;
  top: 295px;
  }
  .school-title-line::after {
  position: absolute;
  display: block;
  left: calc(50% - 80px);
  width: 150px;
  height: 1px;
  content: '';
  border-radius: 3px;
  background: #333;
  top: 390px;
  }
  .school-list__wrp {
    display: inline-block;
    margin: 0 auto 200px;
  }
  .school {
    margin: 0 100px;
  }
  .school h2 {
    font-size: 2.4rem;
    color: #fff;
    background-color: #037146;
    padding: 30px 90px;
    display: inline-block;
    font-weight: 500;
    margin-bottom: 90px;
  }
  .school ul li {
    list-style: none;
    font-size: 2.4rem;
    padding: 40px;
    position: relative;
    z-index: 99;
  }
  .school ul li::before {
    content: ""; 
    position: absolute;
    display: inline-block; 
    background-image: url(../img/school-page-circle.png);
    height: 105px;
    width: 105px;
    left: 2px;
    top: 0px;
    transform: scale(0.8);
    z-index: -10;
  }
  .school ul li a {
    text-decoration: none;
    color: #333;
  }
  @media(min-width:768px) and (max-width:1279px) {
    .school-list {
      max-width: 672px;
    }
    .school-list::before {
      left: -30px;
      transform: scale(0.6);
    }
    .school-list::after {
      right: -30px;
      transform: scale(0.6);
    }
    .school-list__title::before {
      transform: scale(0.8);
      left: -75px;
    }
    .school-title-line::before {
      top: 305px;
    }
    .school-title-line::after {
      top: 380px;
    }
  }
  @media(max-width:767px) {
    .school-list {
      margin: 0 auto 100px;
      position: relative;
      max-width: 375px;
    }
    .school-list::before {
      left: 50px;
      top: 40px;
      transform: scale(0.5);
    }
    .school-list::after {
      right: 50px;
      bottom: -60px;
      top: auto;
      transform: scale(0.5);
    }
    .school-list__title {
      padding: 220px 0 100px;
    }
    .school-list__title::before {
      left: -62px;
      top: 180px;
      transform: scale(0.6);
    }
    .school-title-line::before {
    left: calc(50% - 55px);
    width: 110px;
    top: 205px;
    }
    .school-title-line::after {
    left: calc(50% - 55px);
    width: 110px;
    top: 260px;
    }
    .school-list__wrp {
      display: inline-block;
      max-width: 327px;
      margin: 0 auto 115px;
    }
    .school {
      margin: 0 auto;
    }
    .school h2 {
      font-size: 1.6rem;
      color: #fff;
      background-color: #037146;
      padding: 15px 55px;
      display: inline-block;
      font-weight: 500;
      margin-bottom: 60px;
    }
    .school ul li {
      font-size: 1.6rem;
      padding: 20px;
    }
    .school ul li::before {
      left: -20px;
      top: -20px;
      transform: scale(0.5);
      z-index: -10;
    }
  }
  .section-access {
    background-color: #fff;
    position: relative;
    padding-bottom: 180px;
    max-width: 1280px;
    margin: 0 auto;
  }
  .section-access::before {
    content: '';
    background-image: url(../img/bicycle-green.png);
    display: block;
    position: absolute;
    height: 460px;
    width: 670px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    right: 20px;
    top: 150px;
  }
  .custom-shape-divider-top-1665898836 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
  }
  .custom-shape-divider-top-1665898836 svg {
    position: relative;
    display: block;
    width: calc(116% + 1.3px);
    height: 49px;
  }
  .custom-shape-divider-top-1665898836 .shape-fill {
    fill: #e6faf3;
  }
  .section-access__title {
    padding-top: 200px;
    display: inline-block;
    z-index: 99;
    position: relative;
  }
  .section-access__title::before {
    content: ""; 
    position: absolute;
    display: block;
    z-index: -10; 
    background-image: url(../img/title-circle.png);
    height: 105px;
    width: 105px;
    left: -80px;
    top: 160px;
    opacity: 0.5;
  }
.iframe-wrp {
    position: relative;
    width: 100%;
    max-width: 560px;
    height: 560px;
  }
.iframe-wrp iframe{
    position: absolute;
    left: 130px;
    top: 450px;
  }
.section-access__address {
    font-size: 1.8rem;
    line-height: 3.6rem;
    text-align: left;
    margin-bottom: 150px;
    padding-top: 80px;
    padding-left: 506px;
  }
.section-access__discription {
    font-size: 1.8rem;
    line-height: 2.7rem;
    text-align: left;
    margin-bottom: 70px;
    padding-left: 506px;
  }
.section-access__holiday {
    font-size: 1.8rem;
    line-height: 2.7rem;
    text-align: left;
    padding: 0 0 115px 506px;
  }
.uline {
    padding-bottom: 5px;
    border-bottom: 1px solid #333;
    display: inline-block;
  }
.section-access__text-area {
    background-color: #e6faf3;
    width: 913px;
    height: 594px;
    margin: 0 212px 0 234px;
  }
  @media(min-width:767px) and (max-width:1279px) {
    .section-access {
      padding-bottom: 100px;
      max-width: 768px;
  }
  .section-access::before {
      right: -100px;
      top: 170px;
      transform: scale(0.6)
  }
  .section-access__title {
    padding-top: 200px;
    display: inline-block;
    z-index: 99;
    position: relative;
  }
  .section-access__title::before {
    transform: scale(0.8);
    left: -75px;
  }
  .iframe-wrp {
    max-width: 560px;
    height: 560px;
  }
  .iframe-wrp iframe{
    left:104px;
    top: 380px;
  }
  .section-access__address {
    padding: 80px 50px 0;
  }
  .section-access__discription {
    padding: 0 50px;
  }
  .section-access__holiday {
    padding: 0 50px;
  }
  .section-access__text-area {
    width: 624px;
    height: 570px;
    margin: 0 auto;
    margin-top: 450px;
  }
}
@media(max-width:767px) {
  .section-access {
    padding-bottom: 100px;
    max-width: 375px;
  }
  .section-access::before {
    right: -190px;
    top: 80px;
    transform: scale(0.4)
  }
  .section-access__title {
    padding-top: 150px;
    display: inline-block;
    z-index: 99;
    position: relative;
  }
  .section-access__title::before {
    transform: scale(0.6);
    left: -70px;
    top: 110px;
  }
  .iframe-wrp {
    max-width: 307px;
    height: 307px;
    width: 100%;
    margin: 0 auto;
  }
  .iframe-wrp iframe{
    left:0px;
    top: 280px;
  }
  .section-access__address {
    font-size: 1.6rem;
    line-height: 3.2rem;
    text-align: left;
    margin-bottom: 40px;
    padding: 50px 25px 0;
  }
  .section-access__discription {
    font-size: 1.6rem;
    line-height: 2.4rem;
    text-align: left;
    margin-bottom: 20px;
    padding: 0 25px;
  }
  .section-access__holiday {
    font-size: 1.6rem;
    line-height: 2.4rem;
    text-align: left;
    padding: 0 25px;
  }
  .uline {
    padding-bottom: 5px;
    border-bottom: 1px solid #333;
    display: inline-block;
  }
  .section-access__text-area {
    width: 307px;
    height: 335px;
    margin: 300px auto 0;
  }
  }
.section-contact {
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
  }
.section-contact::before {
    position: absolute;
    display: block;
    content: url(../img/flower-white-left_pc.png);
    width: 235px;
    height: 510px;
    z-index: 10;
    top: 0;
    left: 10%;
  }
.section-contact::after {
    position: absolute;
    display: block;
    content: url(../img/flower-white-right_pc.png);
    width: 235px;
    height: 510px;
    z-index: 10;
    bottom: 0;
    right: 10%;
  }
.contact {
    background-color: #037146;
    color: #FFFFFF;
    position: relative;
    padding: 200px 0 185px;
    text-align: center;
    display: flex;
    flex-direction: column;
  }
.section-contact__title {
    color: #FFFFFF;
    padding: 30px 0;
  }
.title-line__white::before {
    position: absolute;
    display: block;
    left: calc(50% - 80px);
    width: 150px;
    height: 1px;
    content: '';
    border-radius: 3px;
    background: #FFFFFF;
  }
  .title-line__white::after {
    position: absolute;
    display: block;
    left: calc(50% - 80px);
    width: 150px;
    height: 1px;
    content: '';
    border-radius: 3px;
    background: #FFFFFF;
  }
.section-contact__tel {
    margin-top: 100px;
    font-size: 2.4rem;
    display: inline-block;
    margin-left: 50px;
  }
.section-contact__tel::before {
    position: absolute;
    display: block;
    content: url(../img/tell-icon.svg);
    width: 71px;
    height: 72px;
    left: 430px;
    top: -25px;
  }
  .section-contact__tel a {
    text-decoration: none;
    color: #fff;
  }
.section-contact__time {
    font-size: 1.8rem;
    padding-top: 60px;
    text-align: left;
    margin: 0 auto;
    display: inline-block;
  }
.section-contact__holiday {
    font-size: 1.8rem;
    padding-top: 25px;
    line-height: 2.7rem;
    text-align: left;
    margin: 0 auto;
    display: inline-block;
  } 
  @media(min-width:767px) and (max-width:1279px) {
    .section-contact {
      max-width: 768px;
  }
  .section-contact::before {
      left: 10px;
      transform: scale(0.9);
      top: -30px;
  }
  .section-contact::after {
      right: 10px;
      transform: scale(0.9);
      bottom: -30px;
  }
  .contact {
    background-color: #037146;
    color: #FFFFFF;
    position: relative;
    padding: 110px 0;
    text-align: center;
    display: flex;
    flex-direction: column;
  }
  .section-contact__title {
    font-size: 2.4rem;
    padding: 25px 0;
  }
  .section-contact__tel {
    margin-left: 70px;
  }
  .section-contact__tel::before {
    left: 170px;
    top: -25px;
  }
  }
  @media(max-width:767px) {
    .section-contact {
      max-width: 375px;
  }
  .section-contact::before {
      content: url(../img/flower-white-top_sp.png);
      width: 235px;
      height: 107px;
      z-index: 10;
      top: 30px;
      left: 20%;
  }
  .section-contact::after {
      content: url(../img/flower-white-down_sp.png);
      width: 235px;
      height: 107px;
      z-index: 10;
      bottom: 30px;
      right: 20%;
  }
  .contact {
    color: #FFFFFF;
    position: relative;
    padding: 150px 0 185px;
    text-align: center;
    display: flex;
    flex-direction: column;
  }
  .section-contact__title {
    font-size: 1.8rem;
    color: #FFFFFF;
    padding: 15px 0;
  }
  .title-line__white::before {
    position: absolute;
    display: block;
    left: calc(50% - 55px);
    width: 110px;
    height: 1px;
    content: '';
    border-radius: 3px;
    background: #FFFFFF;
  }
  .title-line__white::after {
    position: absolute;
    display: block;
    left: calc(50% - 55px);
    width: 110px;
    height: 1px;
    content: '';
    border-radius: 3px;
    background: #FFFFFF;
  }
  .section-contact__tel {
    margin-top: 60px;
    font-size: 2.0rem;
    display: inline-block;
    margin-left: 50px;
  }
  .section-contact__tel::before {
    position: absolute;
    display: block;
    content: url(../img/tell-icon.svg);
    width: 61px;
    height: 62px;
    left: 15px;
    top: -20px;
  }
  .section-contact__time {
    font-size: 1.6rem;
    padding-top: 60px;
    text-align: left;
    margin: 0 auto;
    display: inline-block;
  }
  .section-contact__holiday {
    font-size: 1.6rem;
    padding-top: 12px;
    line-height: 2.7rem;
    text-align: left;
    margin: 0 auto;
    display: inline-block;
  }
  }
/* img */
@media(max-width:767px) {
  .sp img {
    display: block;
  }
  .pc img {
    display: none;
  }
}