.pc {
  display: block !important;
}
.sp {
  display: none !important;
}
html {
  font-size: 62.5%;
}
body {
  background: #fff;
  color: #1f1f1f;
  font-family: Roboto, "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  font-size: 1.6rem;
  font-weight: 400;
  font-style: normal;
  line-height: 1.8;
  margin: 0;
}
.wrap {
  margin: auto;
  max-width: 100%;
}
.clearfix:after {
  content: "";
  clear: both;
  display: block;
}
img {
  width: 100%;
  vertical-align: bottom;
}
ul {
  list-style: none;
}
a:link,a:visited,a:hover,a:active {
  color: #019fd8;
}
a img:hover {
  filter: brightness(1.2);
  -webkit-transition: 0.8s;
  transition: 0.8s;
}
@media only screen and (max-width: 1200px) {
  html {
    font-size: 0.8333333333333334vw;
  }
}
@media only screen and (max-width: 749px) {
  html {
    font-size: 2.67022696929239vw;
  }
}

/*notes*/
header {
  background: center center / cover url(../img/0000.webp) no-repeat;
}
header .header__top__wrap {
  padding: 1rem;
}
header .header__top__wrap .logo {
  width: 52rem;
}
header .header__main__wrap {
  margin: auto;
  padding: 2rem 0 4rem;
  width: 100rem;
}
header .header__main__wrap .box__wrap {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
header .header__main__wrap .box__wrap p {
  color: #fff;
  font-size: 2.4rem;
  font-weight: 700;
}
h1 {
  color: #f8ee50;
  font-size: 6.0rem;
  font-weight: 900;
  line-height: 1.3;
}
h1 span {
  font-size: 8.0rem;
}
header .header__main__wrap .box__wrap img {
  filter: drop-shadow(0 0 4.6rem rgba(35,186,213,0.64));
  width: 30rem;
}
header .header__main__wrap ul {
  display: flex;
  justify-content: space-between;
  margin-bottom: 2rem;
  width: 92rem;
}
header .header__main__wrap ul li {
  text-align: center;
  width: 23rem;
}
header .header__main__wrap ul li img {
  width: 14rem;
}
header .header__main__wrap ul li h3 {
  color: #fff;
  font-size: 2.0rem;
  line-height: 1.3;
  margin-top: 1em;
}
header .header__main__wrap ul li h3 span {
  color: #f8ee50;
}
header .header__main__wrap ul li h3 span span {
  font-size: 2.6rem;
  font-weight: 900;
}
header .header__main__wrap ul li h3 span span span {
  font-size: 3.2rem;
}

/*notes*/
.s01__wrap {
  padding: 9rem 0;
  text-align: center;
}
h2 {
  color: #1d5498;
  font-size: 3.6rem;
  font-weight: 900;
  letter-spacing: .05em;
  line-height: 1.3;
  margin-bottom: 1.5em;
  text-align: center;
}
.s01__wrap h2 {
  font-size: 4.6rem;
}
.s01__wrap p {
  font-size: 2.0rem;
  font-weight: 700;
  margin-bottom: 1em;
}
.s01__wrap img {
  margin: auto;
  width: 69rem;
}

/*notes*/
.s02__wrap {
  background: center center / cover url(../img/0200.webp) no-repeat;
  padding: 9rem 0;
}
.s02__wrap .box__wrap {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 0 auto 5rem;
  width: 92rem;
}
.s02__wrap .box__wrap img {
  width: 46rem;
}
.s02__wrap .box__wrap div {
  width: 42rem;
}
.s02__wrap .box__wrap div h3 {
  color: #1d5498;
  font-size: 2.4rem;
  margin-bottom: .5em;
}
.btn {
  align-items: center;
  display: flex;
  justify-content: center;
  background: center center / cover url(../img/0202.webp) no-repeat;
  color: #fff;
  font-size: 2.8rem;
  font-weight: 700;
  margin: auto;
  height: 8rem;
  width: 35rem;
}
a.btn:link,a.btn:visited {
  color: #fff;
  text-decoration: none;
}

.btn-02 {
  align-items: center;
  display: flex;
  justify-content: center;
  background: center center / cover url(../img/0202.webp) no-repeat;
  color: #fff;
  font-size: 2.8rem;
  font-weight: 700;
  margin: auto;
  height: 8rem;
  width: 35rem;
/* ADDED: 增加過渡效果，使動畫更平滑 */
  transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}
a.btn-02:link,a.btn-02:visited {
  color: #fff;
  text-decoration: none;
}

.floating {
  font-size: 5.4rem;
  font-weight: 900;
  line-height: 1.5;
  padding: .15em;
  text-align: center;
  width: 100%;
}
a.floating:link,a.floating:visited {
  color: #fff;
  text-decoration: none;
}

@media screen and (max-width:749px){
/* ... (手機版樣式不變) ... */

/*notes*/
.s02__wrap .box__wrap div h3 {
  font-size: 2.0rem;
  text-align: center;
}
.btn {
  font-size: 1.8rem;
  height: 6rem;
  width: 80%;
}

/*notes*/
.s03__wrap {
  padding: 5rem 4% 0;
}

/*notes*/
footer {
  padding: 0 4% 10rem;
}
footer div {
  padding: 1rem;
  width: 100%;
}
footer div h3 {
  font-size: 1.6rem;
}
footer div p {
  font-size: 1.3rem;
}

.floating {
  font-size: 2.8rem;
  padding: .5em 0;
}
} /* <-- 這裡才是手機版樣式的正確結束位置 */


/* =================================================== */
/* 動畫程式碼 (保持不變，並確保在媒體查詢外部) */
/* =================================================== */

/* 1. 定義閃動放大的動畫 */
@keyframes pulse-grow {
  0% {
    transform: scale(1);
    box-shadow: 0 0 0 rgba(255, 255, 255, 0);
  }
  50% {
    transform: scale(1.05);
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.8), 0 0 10px rgba(255, 255, 255, 0.5);
  }
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 rgba(255, 255, 255, 0);
  }
}

/* 2. 將常時動畫直接應用到 .btn-02 (替換原來的 hover 規則) */
.btn-02 {
  align-items: center;
  display: flex;
  justify-content: center;
  background: center center / cover url(../img/0202.webp) no-repeat;
  color: #fff;
  font-size: 2.4rem; /* 假設您已採用了放大的尺寸 */
  font-weight: 700;
  margin: auto;
  height: 8rem; /* 假設您已採用了放大的尺寸 */
  width: 35rem; /* 假設您已採用了放大的尺寸 */
  
  transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
  
  /* 關鍵修改: 常時應用動畫 */
  animation: pulse-grow 0.8s ease-in-out infinite alternate;
}

/* 3. 移除或清空 :hover 規則，或讓它保持不變 */
/* 如果您想要滑鼠懸停時仍有輕微額外放大效果，可以保留以下規則 */
.btn-02:hover {
  transform: scale(1.03); 
}
/* 如果您不想要任何 hover 效果，請移除或註釋掉 .btn-02:hover { ... } 整個區塊。 */

/*notes*/
.s03__wrap {
  padding: 9rem 0 0;
}
.movie {
  margin: auto;
  width: 64rem;
}
.karim-wrap {
  position: relative;
  border-radius: 1rem;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}
.karim-wrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

/*notes*/
.s04__wrap {
  padding: 9rem 0;
}
.s04__wrap ul {
  margin: 0 auto 4rem;
  width: 92rem;
}
.s04__wrap ul li {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  margin-bottom: 6rem;
}
.s04__wrap ul li:nth-child(even) {
  flex-direction: row-reverse;
}
.s04__wrap ul li:last-child {
  margin-bottom: 0;
}
.s04__wrap ul li img {
  width: 36rem;
}
.s04__wrap ul li .box__wrap {
  width: 52rem;
}
.s04__wrap ul li .box__wrap div {
  align-items: center;
  display: flex;
  margin-bottom: 1em;
}
.s04__wrap ul li .box__wrap div p {
  align-items: center;
  display: flex;
  justify-content: center;
  border: .1rem solid #1d5498;
  color: #1d5498;
  font-size: 4.2rem;
  margin-right: .25em;
  height: 6rem;
  width: 6rem;
}
.s04__wrap ul li .box__wrap div h3 {
  color: #1d5498;
  font-size: 2.8rem;
  line-height: 1.1;
}
.s04__wrap ul li .box__wrap span {
  background: linear-gradient(transparent 0%, #f7ed00 0%);
  font-weight: 700;
}
.s04__wrap ul li .box__wrap .t1 {
  background: #f6f6f6;
  border-radius: .6rem;
  font-size: 1.4rem;
  margin-top: 1em;
  padding: .75em;
}

/*notes*/
.s05__wrap {
  background: #f6f6f6;
  border-radius: .6rem;
  margin: auto;
  padding: 0 0 6rem;
  width: 100rem;
}
.s05__wrap h2 {
  position: relative;
  background: #1d5498;
  border-radius: .6rem .6rem 0 0;
  color: #ffca1d;
  margin-bottom: 1em;
  padding: .75em 0;
}
.s05__wrap h2 span {
  color: #fff;
  font-size: 2.8rem;
  font-weight: 700;
}
.s05__wrap h2:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 50%;
  margin-left: -2.5rem;
  border: 2.5rem solid transparent;
  border-top: 2rem solid #1d5498;
}
.s05__wrap ul {
  margin: auto;
  width: 72rem;
}
.s05__wrap ul li {
  position: relative;
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 6rem;
}
.s05__wrap ul li:last-child {
  margin-bottom: 0;
}
.s05__wrap ul li:before {
  position: absolute;
  content: '';
  background: 100% / 100% url(../img/0504.webp) no-repeat;
  width: 4.6rem;
  height: 1.8rem;
  bottom: -25%;
  left: 18%;
}
.s05__wrap ul li:last-child:before {
  display: none;
}
.s05__wrap ul li img {
  width: 30rem;
}
.s05__wrap ul li div {
  width: 38rem;
}
.s05__wrap ul li div p:nth-child(1) {
  color: #1d5498;
  font-size: 8.6rem;
}

/*notes*/
.s06__wrap {
  padding: 4rem 0;
  text-align: center;
}
.s06__wrap h2 {
  color: #ea5513;
  letter-spacing: .2em;
  margin-top: 9rem;
}
.s06__wrap h2 img {
  width: 24rem;
}
.s06__wrap h2 span {
  color: #1d5498;
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 0;
}
.s06__wrap p.t1 {
  font-size: 2.0rem;
  font-weight: 700;
  margin-bottom: .5em;
}
dl {
  display: table;
  font-weight: 700;
  margin: auto;
}
dl div {
  align-items: center;
  display: flex;
  padding: .1em;
}
dt {
  background: #52c4da;
  border-radius: 2em;
  color: #fff;
  margin-right: 1em;
  width: 19rem;
}
dd {
  font-size: 2.2rem;
  font-weight: 700;
}
.s06__wrap p.t2 {
  font-size: 1.4rem;
  margin-top: 2em;
}
.s06__wrap .box__wrap {
  align-items: center;
  display: flex;
  justify-content: center;
  margin: 2em 0;
}
.s06__wrap .box__wrap p {
  font-size: 1.8rem;
  font-weight: 700;
}
.s06__wrap .box__wrap div {
  border-left: .1rem solid #222;
  margin-left: 2em;
  padding-left: 2em;
  text-align: left;
}
.s06__wrap .box__wrap div h3 {
  font-size: 1.8rem;
}
.s06__wrap .box__wrap div li {
  position: relative;
  padding-left: 1.5em;
}
.s06__wrap .box__wrap div li:before {
  position: absolute;
  content: '';
  background: 100% / 100% url(../img/0602.webp) no-repeat;
  width: 2.0rem;
  height: 2.0rem;
  top: 25%;
  left: 0;
}
.s06__wrap .box__wrap div li:nth-child(2):before {
  background: 100% / 100% url(../img/0603.webp) no-repeat;
}

/*notes*/
footer {
  padding-bottom: 20rem;
}
footer div {
  background: #f6f6f6;
  box-sizing: border-box;
  margin: auto;
  padding: 2rem;
  width: 92rem;
}
footer div h3 {
  border-bottom: .1rem solid #222;
  font-size: 1.8rem;
  margin-bottom: 1em;
  text-align: center;
}
footer div p {
  font-size: 1.4rem;
}
footer div p span {
  font-weight: 700;
}

.floating {
  position: fixed;
  bottom: 0;
  display: block;
  background: #ea5513;
  font-size: 5.4rem;
  font-weight: 900;
  line-height: 1.5;
  padding: .15em;
  text-align: center;
  width: 100%;
}
a.floating:link,a.floating:visited {
  color: #fff;
  text-decoration: none;
}









@media screen and (max-width:749px){
.pc {
  display: none !important;
}
.sp {
  display: block !important;
}
body {
  font-size: 1.5rem;
}

/*notes*/
header {
  background: left center / cover url(../img/0000.webp) no-repeat;
}
header .header__top__wrap .logo {
  width: 100%;
}
header .header__main__wrap {
  margin: auto;
  padding: 3rem 0;
  width: 100%;
}
header .header__main__wrap .box__wrap {
  display: block;
  text-align: center;
}
header .header__main__wrap .box__wrap p {
  font-size: 1.4rem;
}
h1 {
  font-size: 3.0rem;
}
h1 span {
  font-size: 4.6rem;
}
header .header__main__wrap .box__wrap img {
  margin-top: 1em;
  width: 16rem;
}
header .header__main__wrap ul {
  flex-wrap: wrap;
  margin: 0 auto 1em;
  width: 80%;
}
header .header__main__wrap ul li {
  margin-top: .5em;
  text-align: center;
  width: 50%;
}
header .header__main__wrap ul li img {
  width: 8rem;
}
header .header__main__wrap ul li h3 {
  font-size: 1.4rem;
}
header .header__main__wrap ul li h3 span span {
  font-size: 1.6rem;
}
header .header__main__wrap ul li h3 span span span {
  font-size: 2.0rem;
}

/*notes*/
.s01__wrap {
  padding: 5rem 4%;
}
h2 {
  font-size: 2.6rem;
  margin-bottom: 1em;
}
.s01__wrap h2 {
  font-size: 3.6rem;
}
.s01__wrap p {
  font-size: 1.5rem;
}
.s01__wrap img {
  width: 100%;
}

/*notes*/
.s02__wrap {
  padding: 5rem 4%;
}
.s02__wrap .box__wrap {
  display: block;
  margin: 0 auto 3rem;
  width: 100%;
}
.s02__wrap .box__wrap img {
  margin-bottom: 1em;
  width: 100%;
}
.s02__wrap .box__wrap div {
  width: 100%;
}
.s02__wrap .box__wrap div h3 {
  font-size: 2.0rem;
  text-align: center;
}
.btn {
  font-size: 1.8rem;
  height: 6rem;
  width: 80%;
}

/*notes*/
.s03__wrap {
  padding: 5rem 4% 0;
}
.movie {
  width: 100%;
}

/*notes*/
.s04__wrap {
  padding: 5rem 4% 9rem;
}
.s04__wrap ul {
  width: 100%;
}
.s04__wrap ul li {
  display: block;
  margin-bottom: 4rem;
}
.s04__wrap ul li img {
  width: 100%;
}
.s04__wrap ul li .box__wrap {
  width: 100%;
}
.s04__wrap ul li .box__wrap div p {
  font-size: 3.2rem;
  height: 4rem;
  width: 4rem;
}
.s04__wrap ul li .box__wrap div h3 {
  font-size: 2.2rem;
}
.s04__wrap ul li .box__wrap .t1 {
  font-size: 1.3rem;
}

/*notes*/
.s05__wrap {
  padding: 0 0 3rem;
  width: 92%;
}
.s05__wrap h2 span {
  font-size: 2.2rem;
}
.s05__wrap ul {
  padding: 0 4% 0;
  width: 92%;
}
.s05__wrap ul li {
  display: block;
  margin-bottom: 4rem;
}
.s05__wrap ul li:before {
  bottom: -15%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.s05__wrap ul li img {
  display: block;
  margin: auto;
  width: 80%;
}
.s05__wrap ul li div {
  width: 100%;
}
.s05__wrap ul li div p:nth-child(1) {
  font-size: 4.6rem;
  line-height: 1.3;
  text-align: center;
}

/*notes*/
.s06__wrap {
  padding: 5rem 4%;
}
.s06__wrap h2 img {
  width: 16rem;
}
.s06__wrap h2 span {
  font-size: 1.6rem;
}
.s06__wrap p.t1 {
  font-size: 1.5rem;
}
dt {
  font-size: 1.4rem;
  margin-right: .5em;
  width: 16rem;
}
dd {
  font-size: 1.8rem;
}
.s06__wrap p.t2 {
  font-size: 1.2rem;
}
.s06__wrap .box__wrap {
  display: block;
}
.s06__wrap .box__wrap p {
  font-size: 1.6rem;
}
.s06__wrap .box__wrap div {
  border-left: none;
  border-top: .1rem solid #222;
  margin-left: 0;
  padding-left: 0;
  padding-top: .5em;
}
.s06__wrap .box__wrap div h3 {
  font-size: 1.6rem;
  text-align: center;
}
.s06__wrap .box__wrap div li {
  display: table;
  margin: auto;
}

/*notes*/
footer {
  padding: 0 4% 10rem;
}
footer div {
  padding: 1rem;
  width: 100%;
}
footer div h3 {
  font-size: 1.6rem;
}
footer div p {
  font-size: 1.3rem;
}

.floating {
  font-size: 2.8rem;
  padding: .5em 0;
}
}

#hiddenLink {
    display: none; /* 徹底隱藏元素，不佔用空間 */
}