@charset "utf-8";

/*@header*/
.header-bg {
  width: 100%;
  position: relative;
  display: block;
}
.header-bg h1 {
  position: absolute;
  top: 55%;
  left: 50%;
  transform: translate(-50%,-50%);
  color: #fff;
  text-align: center;
  font-size: 44px;
  font-weight: normal;
  letter-spacing: 2px;
  line-height: 50px;
}
.header-bg span {
  font-size: 20px;
}

@keyframes flash {
  0%,100% {
    filter: drop-shadow(0 0 6px #ffb1d6)
  }
  50% {
    filter: none
  }
}

@media screen and (max-width:640px){
  .header-bg img {
    object-fit: cover;
    height: 250px;
    width: 100%;
  }
}

/*end@header*/

/*@section-common*/
#section-1,
#section-2,
#section-3,
#section-4 {
  padding: 0;
  width: 100%;
  position: relative;
}
/* #section-2,
#section-3 {
  margin: 0 100px;
} */
#title-box-1{
  background-color: rgba(47, 49, 49, 0.9);
  width: 45%;
  clip-path: polygon(0 0, 100% 0, 83% 100%, 0% 100%);
  transform: none;
  position: unset;
}
.title{
  flex-direction: column;
  margin-left: 100px;
}
#title-box-1 p {
  padding-bottom: 30px;
}
#section-1 h2{
  line-height: 0.3;
  font-size: 1.7rem;
  padding-top: 40px;
  padding-bottom: 20px;
  border-bottom: 2px solid #f07fb4;
  letter-spacing: 0.05em;
  max-width: 30px;
  color: #fff;
  font-weight: normal;
  margin-bottom: 10px;
}
#section-1 h3{
  font-size: 1rem;
  letter-spacing: 0.05em;
  background-color: #f9ba32;
  color: #2f3131;
  padding: 5px 10px;
  padding-right: 8px;
  max-width: 70px;
}
#title-2,
#title-3 {
  text-align: center;
}
#title-2 h2,
#title-3 h2 {
  line-height: 1;
  margin: 0 auto 60px;
  font-size: 1.85rem;
  padding-top: 60px;
  padding-bottom: 20px;
  letter-spacing: 0.05em;
  color: #f07fb4;
}
#title-2 img,
#title-3 img  {
  position: absolute;
  border-bottom: #dbae58 1px solid;
  transform: translate(-50%,-130px);
  width: 20%;
}
#title-2 img {
  transform: translate(-128%, 40px);
}

#title-2 img {
  width: 28%;
}
/* .button {
  position: relative;
  margin-right: 100px;
  transform: translateY(-250px);
} */
.button {
  position: relative;
  margin-right: 100px;
  margin-top: 0;
  transform: translateY(-70px);
  width: calc(100% - 177px);
  height: 85px;
  border: none;
}
.button:hover{
  background-color: unset;
  color:unset;
}
.button p {
  display: inline-block;
  font-size: 1.3rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  cursor: pointer;
  overflow: hidden;
  position: absolute;
  border-radius: 10px;
  right: 0;
  transform: translate(-45px,13px);
}
.button span {
  font-weight: normal;
  font-size: 0.84rem;
  letter-spacing: 0.03em;
  color: #f07fb4;
}
.button a:hover{
  background-image: linear-gradient(
		70deg,
		#f07fb4 45%, /* font color */
		#FFF 50%,
		#f07fb4 55% /* font color */
	);
	background-size: 500% 100%;
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	animation: shine 2s infinite;
}
.button img {
  width: 330px;
  position: absolute;
  z-index: -1;
  right: 0;
  max-width: none;
}
@keyframes shine {
	0% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}
/*end@section-common*/


/*@#section-1*/
#section-1 {
  margin-top: 120px;
}
#top-sec1 {
  position: relative;
}
#title-box-1 {
  margin-bottom: 80px;
}
#greeting-img {
  justify-content: right;
  margin-left: 40%;
  /* margin-left: 450px; */
  min-width: 600px;
}
.greeting-text {
/*  background-color: cyan;*/
  text-align: left;
  padding-bottom: 0;
}
#greeting-first {
  font-size: 0.9rem;
  line-height: 2;
  color: #2f3131;
  letter-spacing: 0.05em;
  margin-left: 100px;
}
#greeting-img img {
  max-width: 300px;
  position: absolute;
  right: 0;
  margin-right: 100px;
  transform: translateY(-200px);
}
#greeting-box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 20px;
  margin: 50px 100px;
  /* margin: 130px; */
  align-items: flex-start;
  background-color: white;
  box-shadow:  0 0 3px #f07fb4;
  border-radius: 10px;
}
#greeting-box .content {
  width: 30%;
  text-align: center;
  text-justify: inter-ideograph;
}
#greeting-box .content img {
  margin-top: 1rem;
  margin-bottom: 1rem;
  box-sizing: border-box;
  width: 70%;
  object-fit: cover;
}
#greeting-box .content h4 {
  font-size: 1.1rem;
  border-bottom: #f07fb4 solid 1.5px;
  font-weight: 500;
  display: inline-block;
  margin-bottom: 10px;
}
#greeting-box .content-title {
  text-align: center;
}
#greeting-box .content p {
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 2em;
}
#greeting-second {
  font-size: 0.9rem;
  color: #2f3131;
  letter-spacing: 0.05em;
  margin-left: 100px;
}

@media screen and (max-width:1100px){
  #greeting-img img {
    display: none;
  }

  .button {
    transform: translateY(-200px);
  }
  .button p {
    transform: translate(-57px,15px);
  }
  .button img {
    width: 330px;
    position: absolute;
    z-index: -1;
    right: 0;
  }

  #title-2 img,
  #title-3 img  {
  display: none;
}
}

@media screen and (max-width:860px){
  .button {
    transform: translateY(0px);
  }
}

@media screen and (max-width:640px){
  #title-box-1{
    width: 70%;
  }
  .title{
    margin-left: 30px;
  }
  #title-box-1 p {
    padding-bottom: 20px;
  }
  #section-1 h2{
    line-height: 0;
    font-size: 1.5rem;
    padding-top: 30px;
    padding-bottom: 20px;
    max-width: 20px;
    margin-bottom: 10px;
  }
  #section-1 h3{
    font-size: 0.9rem;
    max-width: 60px;
  }
  #title-box-1 {
    margin-bottom: 40px;
  }
  .greeting-text {
    padding-bottom: 10%;
    text-align: justify;
  }
  #greeting-first {
    font-size: 0.85rem;
    margin-left: 30px;
    margin-right: 30px;
  }
  #greeting-box {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px;
    margin: 40px 40px 20px 30px;
  }
  #greeting-box .content {
    width: 100%;
    margin-bottom: 30px;
  }
  #greeting-box .content img {
    margin-top: 20px;
    width: 55%;
  }
  #greeting-box .content h4 {
    width: 50%;
  }
  #greeting-second {
    font-size: 0.85rem;
    margin-left: 30px;
    margin-right: 30px;
  }

  .button {
    margin-right: 20%;
    transform: translateY(0);
  }
  .button p {
    transform: translate(-41px,11px);
    font-size: 1.1rem;
  }
  .button img {
    width: 260px;
  }
  .button span {
    font-size: 0.71rem;
  }
}
/*end@#section-1*/


/*@#section-2*/
.overview-list {
  background-color: #648c9c;
  margin: 0 100px;
  border-radius: 10px;
  padding-bottom: 50px;
}
.overview-list dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  color: #FFF;
  font-size: 16.5px;
  letter-spacing: 0.5px;
  margin: 0 100px;
  padding-top: 40px;
  text-align: left;
}
.overview-list dt {
  padding-bottom: 20px;
  margin-top: 20px;
  width: 25%;
  border-bottom: dotted #fff 3px;
  padding-left: 80px;
}
.overview-list dd {
  width: 50%;
  padding-bottom: 20px;
  margin-top: 20px;
  line-height: 25px;
  border-bottom: dotted #fff 3px;
}

@media screen and (max-width:1100px){
  .overview-list {
    height: 100%;
  }
  .overview-list dl {
    font-size: 12px;
    width: 100%;
    margin: 0 40px;
    padding-top: 10px;
    padding-bottom: 30px;
  }
  .overview-list dt {
    padding-bottom: 10px;
    margin-top: 20px;
    width: 100%;
    border-bottom: none;
    margin-right: 80px;
    padding-left: 0;
    font-weight: bold;
    font-size: 13.5px;
  }
  .overview-list dd {
    width: 100%;
    padding-bottom: 15px;
    margin-top: 0;
    border-bottom: dotted #fff 3px;
    margin-right: 80px;
  }
}

@media screen and (max-width:640px){
#section-2 {
  /* margin-top: 150px; */
}
#title-2 h2 {
  font-size: 1.75rem;
  padding-bottom: 17px;
}
#title-2 img {
  width: 70%;
}
.overview-list {
  margin: 0 40px 30px 30px;
}
}
/*end@#section-2*/


/*@#section-3*/
#title-3 {
  margin-top: 100px;
}
.access {
  margin: 0 100px;
}
.access h3 {
  padding-bottom: 10px;
}
.access-text {
  margin-top: 15px;
  margin-bottom: 55px;
  font-size: 14px;
}
#access-top {
  display: flex;
  position: relative;
}
#access-list-under {
  display: flex;
  flex-wrap: wrap;
}
#access-list-under h3 {
  margin-top: 80px;
}
.access-left {
  width: 33%;
}
#access-top .access-left {
  width: 100%;
}
.access-right {
  width: 33%;
}
.access-left h3,
.access-right h3 {
  font-size: 22px;
  letter-spacing: 0.7px;
}
.access-left h3 {
  border-bottom: solid #f07fb4 3px;
}
.access-right h3 {
  border-bottom: solid #dbae58 3px;
}
.map-btn a {
  border: #999 solid 1.5px;
  width: 150px;
  padding: 15px 30px;
}
.map-btn a:hover {
  color: #fff;
  transition: 0.2s;
  background-color: #999;
}
iframe {
  height: 250px;
  position: absolute;
  right: 0;
  width: 650px;
}

@media screen and (max-width:1100px){
  iframe {
    position: relative;
    margin-top: 50px;
  }
  #access-top {
    display: flex;
    flex-direction: column;
  }
  .access-left {
    width: 50%;
  }
  .access-right {
    width: 50%;
  }
}

@media screen and (max-width:640px){
  #title-3 h2 {
    font-size: 1.75rem;
    padding-bottom: 17px;
  }
  #title-3 img {
    width: 50%;
  }


  #title-3 {
    margin-top: 80px;
  }
  .access {
    margin: 0 30px 100px;
  }
  .access h3 {
    padding-bottom: 10px;
  }
  .access-text {
    margin-top: 15px;
    margin-bottom: 30px;
  }
  #access-list-under h3 {
    margin-top: 60px;
  }
  .access-left {
    width: 100%;
  }
  .access-right {
    width: 100%;
  }
  .access-left h3,
  .access-right h3 {
    font-size: 20px;
  }
  .map-btn a {
    width: 130px;
    padding: 10px 25px;
  }
  iframe {
    display: none;
  }
  }

