/* 設定源樣黑體 */
/* @font-face {
  font-family: genYoGothic;
  src: url(../font/GenYoGothic-M.ttc);
}

@font-face {
  font-family: genYoGothicN;
  src: url(../font/GenYoGothic-N.ttc);
} */

* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  font-family: 'genYoGothic', 'Noto Sans TC', 'Arial', 'sans-serif';
  font-family: 'Noto Sans TC', 'Arial', 'sans-serif';
}

img {
  object-fit: cover;
  display: block;
}

.container {
  width: 100%;
}

.paddingW70 {
  padding-left: 100px;
  padding-right: 100px;
}

.bg {
  background-image: linear-gradient(to bottom, rgb(128, 183, 0) 0, rgb(53, 121, 118) 30%, rgb(25, 69, 153));
}

.computerShowF {
  display: flex !important;
}

.mobileShowF {
  display: none !important;
}

.computerShow {
  display: block !important;
}

.mobileShow {
  display: none !important;
}

.underLine {
  padding-bottom: 30px;
  margin-bottom: 30px;
  border-bottom: 2px solid #fff;
}

.titleY {
  font-size: 80px;
  color: #fff100;
}

.titleW {
  color: #fff;
  font-size: 60px;
  padding-top: 50px;
  line-height: 1.2;
}

.description {
  font-family: 'Noto Sans TC';
  font-weight: 300;
  font-size: 30px;
  color: #fff;
  line-height: 2;
}

@media (max-width:1440px) {
  .titleY {
    font-size: 60px;
  }

  .titleW {
    font-size: 45px;
  }

  .description {
    font-size: 25px;
  }
}

@media (max-width:1024px) {
  .titleY {
    font-size: 45px;
  }

  .titleW {
    font-size: 30px;
  }


  .description {
    font-size: 20px;
  }

}

@media (max-width:768px) {
  .computerShowF {
    display: none !important;
  }

  .mobileShowF {
    display: flex !important;
  }

  .computerShow {
    display: none !important;
  }

  .mobileShow {
    display: block !important;
  }

  .titleY {
    font-size: 40px;
  }

  .titleW {
    padding-top: 30px;
  }

  .description {
    font-size: 15px;

  }

}

@media (max-width:439px) {
  .titleY {
    font-size: 32px;
  }

  .titleW {
    font-size: 26px;
  }
}

/* cover */
#cover {
  padding-bottom: 50px;
  position: relative;
}

#cover .logoBox {
  padding-top: 70px;
  width: 100%;
}

#cover .logoBox .text {
  margin-top: 80px;
  font-size: 80px;
  padding-bottom: 5px;
  margin-bottom: 35px;
  /* text-decoration: underline 4px;
  text-underline-offset:15px; */
  border-bottom: 2px solid #fff;
  color: #fff;
  text-shadow: 5px 5px 5px #333;
  float: left;
}

#cover .logoBox .logo {
  width: 100%;
  max-width: 450px;
  float: right;
}

#cover .slogan {
  width: 100%;
  padding-right: 20px;
  padding-bottom: 5px;
  border-bottom: 2px solid #fff;
  clear: both;
  max-width: 1178px;
}

#cover .description {
  display: inline-block;
  font-size: 45px;
  color: #fff;
  padding: 15px 0;
  text-shadow: 5px 5px 5px #333;
}

#cover .underLine {
  border-bottom: 2px solid #fff;
}

#cover .contact {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  text-shadow: 5px 5px 5px #333;
  color: #fff;
  align-items: flex-end;
}

#cover .contact .phoneNum {
  font-size: 80px;
  text-decoration: none;
  color: #fff;
}
/* safari 會把電話抓成可撥打 */
#cover .contact .phoneNum a {
  text-decoration: none;
  color: #fff;
}

#cover .contact .location {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 5px;
}

#cover .contact .location .top {
  display: flex;
  gap: 5px;
  font-size: 18px;
}

#cover .contact .location .top .anchor {
  width: 40px;
}

#cover .contact .location .top .remark {
  font-size: 18px;
  padding-top: 25px;
}

#cover .contact .location .bottom {
  font-size: 30px;
  padding-right: 40px;
}

@media (max-width:1440px) {
  #cover .logoBox .text {
    font-size: 60px;
  }
  #cover .description{
    font-size: 40px;
    margin-bottom: unset;
    padding: 10px 0;
  }
  #cover .contact .phoneNum{
    font-size: 60px;
  }
  #cover .contact .location .bottom{
    font-size: 30px;
  }
  #cover .contact .location .top .remark{
    font-size: 15px;
  }
}

@media (max-width:1024px) {
  #cover {
    padding: 0 40px 50px;
  }

  #cover .logoBox .text {
    font-size: 45px;
    margin-top: 130px;
  }

  #cover .slogan {
    max-width: 720px;
  }

  #cover .description {
    font-size: 30px;
  }

  #cover .contact .phoneNum {
    font-size: 30px;
  }

  #cover .contact .location .bottom {
    font-size: 20px;
    padding-right: 0;
  }

  #cover .contact .location .top .remark {
    font-size: 13px;
    padding-top: 10px;
  }

  #cover .contact .location .top .anchor {
    width: 20px;
  }
}

@media (max-width:768px) {
  #cover {
    padding: 0 20px 10px;
  }

  #cover .description {
    display: none;
  }

  #cover .logoBox {
    display: flex;
    justify-content: center;
  }

  #cover .logoBox .logo {
    float: unset;
  }

  #cover .mobileCoverBox {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 50px 20px;
    position: relative;
  }

  #cover .mobileCoverBox .mobileCover {
    width: 100%;
    max-width: 450px;
  }

  #cover .mobilePhone {
    width: 100%;
  }

  #cover .rightText {
    top: 30%;
    position: absolute;
    right: 0px;
    text-align: center;
    font-size: 20px;
    color: #fff;
    text-shadow: 5px 5px 5px #333;
    /* 文字垂直 */
    -webkit-writing-mode: vertical-lr;
    writing-mode: vertical-lr;
  }

  #cover .contact {
    justify-content: center;
  }
}

@media (max-width:600px) {
  #cover .contact .phoneNum {
    font-size: 30px;
  }

  #cover .contact .location .bottom {
    font-size: 16px;
  }
}

/* carousel */
#carousel {
  height: 620px;
  width: 100%;
}

/* swiper */
.swiper-button-next,
.swiper-button-prev {
  color: #fff;
}

.swiper-slide {
  overflow: hidden;
}

.swiper-slide img {
  height: 100%;
  /* width: 100%; */
}
#carousel .swiper-slide img {
  width: 100%;
}
#carousel .swiper1L {
  padding-left: 100px;
}
#carousel .swiper1R {
  padding-right: 100px;
}

@media (max-width:768px) {
  #carousel .swiper1L {
    padding-left: unset;
  }
  #carousel .swiper1R {
    padding-right: unset;
  }
}

/* section1 */

#section1 {
  /* padding: 30px 50px; */
  padding: 30px 100px;
  background-image: linear-gradient(to bottom, rgb(53, 121, 118), rgb(25, 69, 153));
}

#section1 .underLine {
  width: 100%;
  max-width: 65%;
}
#section1 .titleY {
  font-weight: 400;
}

@media (max-width:1440px) {}

@media (max-width:1024px) {}

@media (max-width:768px) {
  #section1 {
    padding: 30px 20px;
  }

  #section1 .underLine {
    max-width: 397px;
    display: inline-block;
  }
}

@media (max-width:480px) {
  #carousel {
    height: 475px;
  }
}

/* section2 */

#section2 {
  /* padding: 200px 50px; */
  padding: 200px 100px;
  display: flex;
  justify-content: space-between;
  background-image: linear-gradient(to bottom, rgb(53, 121, 118), rgb(25, 69, 153));
}

#section2 .left {
  width: 45%;
  padding-right: 50px;
}

.section2Swiper {
  width: 55%;
}

#carousel2 {
  width: 100%;
}

#carousel2 img {
  width: 100%;
}

@media (max-width:1024px) {
  /* #section2 .titleW {
  padding-top: 15px;
  } */
  #section2 .underLine {
    padding-bottom: 50px;
    /* margin-bottom: 15px; */
  }
}

@media (max-width:768px) {
  #section2 .titleW {
    padding-top: 30px;
    }
    #section2 .underLine {
      padding-bottom: 30px;
      margin-bottom: 30px;
    }
  #section2 {
    flex-direction: column-reverse;
    padding: 0;
  }

  #section2 .left,
  .section2Swiper {
    width: 100%;
  }

  #carousel2 {
    width: unset;
    height: 500px;
  }

  #carousel2 img {
    height: 100%;
  }

  #section2 .left {
    padding: 30px 20px;
  }
}

@media (max-width:480px) {
  #carousel2 {
    height: 475px;
  }
}

/* section3 */

#section3 {
  background-color: rgb(25, 69, 153);
  display: flex;
  flex-direction: column;
}

#section3 .top {
  /* padding: 30px 50px 150px; */
  padding: 30px 100px 150px;
}

#section3 .top .underLine {
  display: inline-block;
}

#section3 .top .detailContainer {
  width: 100%;
  display: flex;
  padding-top: 110px;
  justify-content: space-between;
}

#section3 .top .detailContainer .detail {
  width: 42%;
  font-size: 30px;
  color: #fff;
  line-height: 2;
  font-weight: 300;
  font-family: 'Noto Sans TC';
}

#section3 .bottom {
  display: flex;
  width: 100%;
  padding-bottom: 150px;
  flex-wrap: wrap;
}

#section3 .bottom .imgBox {
  width: 25%;
  height: auto;
  position: relative;
}

#section3 .bottom .imgBox img {
  width: 100%;
  height: auto;
}
#section3 .bottom .imgBox .imgText {
  position: absolute;
  right: 10px;
  bottom: 10px;
  color: #fff;
  font-size: 30px;
}

@media (max-width:1440px) {
  #section3 .top .detailContainer {
    padding-top: 75px;
  }
  #section3 .top .detailContainer .detail{
    font-size: 25px;
  }
  #section3 .bottom .imgBox .imgText{
    font-size: 25px;
  }
}

@media (max-width:1024px) {
  #section3 .top .detailContainer {
    padding-top: 75px;
  }

  #section3 .top {
    padding-bottom: 110px;
  }

  #section3 .bottom {
    padding-bottom: 110px;
  }

  #section3 .top .detailContainer .detail {
    width: 40%;
    font-size: 20px;
  }
  #section3 .bottom .imgBox .imgText{
    font-size: 20px;
  }
}

@media (max-width:768px) {
  #section3 {
    flex-direction: column-reverse;
  }

  #section3 .top {
    padding: 0 20px 80px;
  }

  #section3 .bottom {
    padding: 80px 0;
  }

  #section3 .bottom .imgBox {
    width: 50%;
  }

  #section3 .top .detailContainer {
    flex-direction: column;
    gap: 40px;
    padding-top: 40px;
  }

  #section3 .top .detailContainer .detail {
    width: 100%;
    font-size: 15px;
  }
  #section3 .bottom .imgBox .imgText {
    font-size: 15px;
  }
}

/* section4 */

#section4 {
  display: flex;
  background-color: rgb(25, 69, 153);
  /* padding: 0 50px 80px; */
  padding: 0 100px 80px;

}

#section4 .left {
  width: 55%;
  padding-top: 60px;
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding-right: 20px;
}

#section4 .left .detail {
  font-size: 30px;
  line-height: 2;
  color: #fff;
  font-weight: 300;
  font-family: 'Noto Sans TC';
}
.detail {
  letter-spacing: 5px;
}
#section4 .right {
  width: 45%;
  display: flex;
  flex-wrap: wrap;
}

#section4 .right .imgBox {
  width: 50%;
  height: auto;
  position: relative;
}

#section4 .right .imgBox img {
  width: 100%;
  height: 100%;
}
#section4 .right .imgBox .imgText {
  position: absolute;
  right: 10px;
  bottom: 10px;
  color: #fff;
  font-size: 30px;
}
@media (max-width:1440px) {
  #section4 .left .detail {
    font-size: 25px;
  }
  #section4 .right .imgBox .imgText{
    font-size: 25px;
  }
}

@media (max-width:1024px) {
  #section4 .titleY {
    font-size: 45px;
  }
  #section4 .left {
    padding-top: 0;
    padding-right: 10px;
    gap: 20px;
  }

  #section4 .left .detail {
    font-size: 20px;
  }
  #section4 .right .imgBox .imgText{
    font-size: 20px;
  }
}

@media (max-width:768px) {
  #section4 {
    flex-direction: column-reverse;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 40px;
  }

  #section4 .right {
    width: 100%;
  }

  #section4 .left {
    padding-top: 60px;
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
  #section4 .titleY {
    font-size: 30px;
  }
  #section4 .right .imgBox .imgText{
    font-size: 15px;
  }
  #section4 .left .detail {
    font-size: 15px;
  }
}

/* section5 */

#section5 {
  position: relative;
  width: 100%;
}

#carousel3 {
  width: 100%;
  height: 100%;
}

#carousel3 img {
  height: 100%;
}

.floatContainer {
  z-index: 1;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
}

.floatContainer .left {
  height: 100%;
  width: 52%;
  display: flex;
  align-items: center;
}

.floatContainer .left .arrowContainer {
  width: 100%;
  height: 60px;
  display: flex;
  justify-content: space-between;
  /* padding: 0 20px; */
  padding: 0 100px;
}

.floatContainer .left .arrowContainer .arrowL {
  height: 100%;
  width: 40px;
  rotate: 180deg;
}

.floatContainer .left .arrowContainer .arrowR {
  height: 100%;
  width: 40px;
}

.floatContainer .right {
  width: 48%;
  height: 100%;
  background-image: linear-gradient(to bottom, rgb(128, 183, 0), rgba(128, 183, 0, 0.5) 40%, rgba(128, 183, 0, 0));
  padding: 140px 100px 0 20px;
}

.floatContainer .right .titleY {
  color: #fff;
  text-align: end;
}

.floatContainer .right .detail {
  font-size: 30px;
  line-height: 2;
  color: #fff;
  font-weight: 300;
  font-family: 'Noto Sans TC';
}
@media (max-width:1440px) {
  .floatContainer .right .detail {
    font-size: 25px;
  }
}
@media (max-width:1024px) {
  .floatContainer .right .detail {
    font-size: 20px;
  }
}

@media (max-width:768px) {
  .floatContainer .left .arrowContainer {
    padding: 0 20px;
  }
  .floatContainer .right {
    padding: 40px 20px;
  }

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

  .floatContainer .right {
    width: 100%;
    height: 50%;
    background-image: linear-gradient(to bottom, rgb(128, 183, 0) 30%, rgba(128, 183, 0, 0));

  }
  .floatContainer .right .titleY {
    font-size: 40px;
  }

  .floatContainer .left {
    width: 100%;
    height: 50%;
  }
  #section5 img {
    width: 100%;
  }
  .floatContainer .right .detail {
    font-size: 15px;
  }
}

/* section6 */

#section6 {
  position: relative;
  width: 100%;
}

#section6 .floatContainer {
  flex-direction: row-reverse;
}

#section6 .floatContainer .right .titleY {
  text-align: left;
}


#section6 .floatContainer .right {
  background-image: linear-gradient(to bottom, rgb(26, 55, 140) 30%, rgba(26, 55, 140, 0));
  /* padding: 140px 20px 0 50px; */
  padding: 140px 20px 0 100px;
}


#carousel4 .imgNameContainer {
  position: relative;
}

#carousel4 .imgNameContainer .nameBox {
  position: absolute;
  bottom: 30px;
  right: 30px;
  color: #fff;
  font-size: 30px;
}
@media (min-width:1918) {
  #carousel3 img {
    width: 100%;
  }
}
@media (max-width:1440px) {
  #carousel4 .imgNameContainer .nameBox {
    font-size: 20px;
  }
}
@media (max-width:1024px) {
  #carousel4 .imgNameContainer .nameBox {
    font-size: 15px;
  }
}

@media (max-width:768px) {
  #section6 .floatContainer {
    flex-direction: column-reverse;
  }

  #section6 .floatContainer .right {
    padding: 40px 20px 0;
  }
  #section6 img {
    width: 100%;
  }
}


/* section7 */

#section7 {
  width: 100%;
  display: flex;
  background-color: #000;
}

#section7 .right {
  width: 50%;
  position: relative;
  background-image: url(../image/section7.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

#section7 .right img {
  position: absolute;
  width: 40%;
  top: 0px;
  right: 20px;
}

#section7 .left {
  /* padding: 0 20px 80px 50px; */
  padding: 0 20px 80px 100px;
  width: 50%;
  background-image: linear-gradient(to bottom, rgb(128, 183, 0), rgb(30, 81, 153));
}

#section7 .left .underLine {
  margin-bottom: 60px;
}

.list {
  font-size: 30px;
  color: #fff;
  position: relative;
  margin-left: 40px;
  padding-left: 40px;
  line-height: 1.5;
  margin-bottom: 50px;
  font-weight: 300;

}

.list::before {
  content: '';
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #fff;
  position: absolute;
  top: 10px;
  left: 0;

}
.list span {
  font-size: 30px;
}

.list:last-child {
  margin-bottom: unset;
}

@media (max-width:1440px) {
  .list {
    font-size: 25px;
  }
  .list span {
    font-size: 25px;
  }
}

@media (max-width:1024px) {
  .list {
    font-size: 20px;
  }
  .list span {
    font-size: 20px;
  }
}

@media (max-width:768px) {
  #section7 {
    flex-direction: column-reverse;
  }

  #section7 .right {
    height: 700px;
    width: 100%;
  }

  #section7 .left {
    width: 100%;
    padding: 0 20px 80px;
  }

  .list {
    margin-left: 0;
    font-size: 15px;
  }
  .list span {
    font-size: 15px;
  }
}

@media (max-width:480px) {
  #section7 .right {
    height: 478px;
  }
}

#section8 {
  padding: 100px 100px 180px;
  background-image: linear-gradient(to bottom, rgb(30, 81, 153), rgb(128, 183, 0));
  display: flex;
}

#section8 .left {
  width: 60%;
  display: flex;
  align-items: flex-end;
  gap: 20px;
}

#section8 .right {
  width: 40%;
}

#clientInfo {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

#clientInfo input,
select {
  font-size: 30px;
  color: #fff;
  border-radius: 8px;
  background-color: #fff3;
  padding: 15px 25px;
  border: unset;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: inline-block;
}

#clientInfo option {
  color: #000;
}

.submit{
    font-size: 35px;
    color: #fff;
    border-radius: 8px;
    background-color: #fff3;
    padding: 7px;
    border: unset;
}

#clientInfo .title {
  color: #fff;
  font-size: 60px;
  text-align: center;

}

::placeholder {
  color: #fff;
}

select {
  /*移除箭頭樣式*/
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;

  /*改變右邊箭頭樣式*/
  background: url("../image/arrowD.svg") no-repeat right center transparent;
  background-size: 3%;
  background-position: 98% 50%;
  /* height: 39px; */
  background-color: #fff3;
}

label {
  font-size: 25px;
  text-align: center;
  color: #fff;
}

input#agree {
  width: 20px;
  height: 20px;
}

#section8 .left .mapContainer {
  /* height: 500px; */
  width: calc(100% - 510px);
  display: flex;
  flex-direction: column;
  align-items: center;
}

#section8 .left .mapContainer img {
  width: 80%;
  margin-bottom: 20px;
}

#section8 .left .mapContainer .mapBox {
  width: 100%;
  height: 350px;
}

#section8 .left .textContainer {
  width: 510px;
  font-size: 25px;
  display: flex;
  flex-direction: column;
  gap: 30px;
  color: #fff;
}

#section8 .left .textContainer div {
  font-family: 'Noto Sans TC';
  font-weight: 300;

}

.info{
  color: #fff;
  line-height: 1.4;
}

@media (max-width:1440px) {
  #clientInfo .title{
    font-size: 45px;
  }
  #clientInfo input, select{
    font-size: 25px;
  }
  label{
    font-size: 20px;
  }
  #section8 {
    align-items: end;
  }
  #section8 .right {
    width: 50%;
    padding-left: 20px;
  }
  #section8 .left {
    width: 50%;
    flex-direction: column;
    align-items: center;
    padding-right: 20px;
  }
  #section8 .left .mapContainer{
    width: 100%;
  }
  #section8 .left .textContainer {
    width: 100%;
    font-size: 20px;
  }
  .submit{
    font-size: 25px;
  }
}

@media (max-width:1024px) {
  #clientInfo .title {
    font-size: 30px;
  }

  #clientInfo input,
  select {
    font-size: 20px;
  }

  label {
    font-size: 15px;
  }
  input#agree {
    width: 13px;
    height: 13px;
  }

  #section8 .left .textContainer {
    font-size: 13px;

  }

  #section8 .left .mapContainer .mapBox{
    height: 250px;
  }
  .submit{
    font-size: 20px;
  }
}
@media (max-width:768px) {
  #section8 {
    flex-direction: column-reverse;
    align-items: center;
    padding: 80px 20px;
  }
  #section8 .right{
    width: 70%;
    margin-bottom: 60px;
    padding-left: unset;
  }
  #section8 .left {
    width: 70%;
    margin-bottom: 60px;
    padding-right: unset;
  }
  label{
    font-size: 15px;
  }
  #section8 .left .textContainer {
    font-size: 15px;
  }
}

@media (max-width:480px) {
  #section8 .right{
    width: 100%;
  }
  #section8 .left {
    width: 100%;
  }
  #section8 .left .mapContainer {
    width: 100%;
  }
}