@charset "UTF-8";
/* base */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

:focus {
  outline: 0;
}

ins {
  text-decoration: none;
}

del {
  text-decoration: line-through;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/*  base scss  */
/* base 共用 */
._c:after {
  content: "";
  display: block;
  clear: both;
}

.c {
  clear: both;
}

.hide {
  display: none;
}

.vhide {
  visibility: hidden;
}

.table {
  display: table;
  table-layout: fixed;
  width: 100%;
}

.tr {
  display: table-row;
}

.td {
  display: table-cell;
}

a {
  display: block;
  text-decoration: none;
}

img {
  width: 100%;
  display: block;
}

/* pc */
/* mixins */
/** mixin ani **/
@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes glitter {
  0% {
    width: 10.5%;
    height: 16%;
  }
  100% {
    width: 13%;
    height: 20%;
  }
}
@keyframes glitter {
  0% {
    width: 10.5%;
    height: 16%;
  }
  100% {
    width: 13%;
    height: 20%;
  }
}
@-webkit-keyframes glittermb {
  0% {
    width: 11%;
    height: 14%;
  }
  100% {
    width: 13.5%;
    height: 18%;
  }
}
@keyframes glittermb {
  0% {
    width: 11%;
    height: 14%;
  }
  100% {
    width: 13.5%;
    height: 18%;
  }
}
/* main */
@media screen and (min-width: 1221px) {
  ._mb {
    display: none !important;
  }
}

._pc {
  display: none;
}
@media screen and (min-width: 1221px) {
  ._pc {
    display: block !important;
  }
}

/* -------------
BODY HTML
------------- */
body,
html {
  width: 100%;
  background: #f1edea;
  /* Old browsers */
  font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "微軟正黑體", "新細明體", "蘋果儷黑體", Verdana, sans-serif;
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  font-size: 16px;
}
body::-webkit-scrollbar,
html::-webkit-scrollbar {
  width: 0;
  height: 0;
}

/* ----------------------------------------------------
maincontainer
---------------------------------------------------- */
.maincontainer {
  width: 100%;
  max-width: 1220px;
  overflow: hidden;
  margin: auto;
}

.conatainer {
  max-width: 1220px;
  width: 100%;
  margin: auto;
  position: relative;
}

._inner {
  width: 1260px;
  margin: 0 auto;
  position: relative;
}
@media screen and (min-width: 1221px) {
  ._inner {
    width: 1260px;
  }
}

.video-container {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 */
    height: 0;
}
.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.area {
  position: relative;
}
.area > div {
  position: absolute;
  z-index: 1;
}

.area00 .logo {
  max-width: 175px;
  width: 28.09%;
  position: absolute;
  top: 0;
  left: 5%;
  z-index: 5;
}
@media screen and (min-width: 1221px) {
  .area00 .logo {
    width: 9.12%;
    left: 6.25%;
  }
}
.area00 > div {
  width: 100%;
}
@media screen and (min-width: 1221px) {
  .area00 > div {
    max-width: 622px;
    width: 32.4%;
    left: 6.25%;
  }
}
.area00 .title-1 {
  top: 18%;
}
@media screen and (min-width: 1221px) {
  .area00 .title-1 {
    top: 35%;
  }
}
.area00 .title-1 .light-box {
  width: 11%;
  height: 14%;
  position: absolute;
  bottom: 53%;
  left: -73%;
  right: 0;
  margin: auto;
  -webkit-animation: ease-in-out 0.5s alternate infinite;
          animation: ease-in-out 0.5s alternate infinite;
}
@media screen and (min-width: 1221px) {
  .area00 .title-1 .light-box {
    width: 10.5%;
    height: 16%;
    -webkit-animation-name: glitter;
            animation-name: glitter;
    bottom: 70%;
    left: -11.5%;
  }
}
.area00 .title-1 .light-box.glitter {
  -webkit-animation-name: glittermb;
          animation-name: glittermb;
}
@media screen and (min-width: 1221px) {
  .area00 .title-1 .light-box.glitter {
    -webkit-animation-name: glitter;
            animation-name: glitter;
  }
}
.area00 .title-1 .light-box div {
  width: 0.75vw;
  height: 2.75vw;
  border-radius: 6px;
  position: absolute;
  -webkit-transform-origin: center bottom;
          transform-origin: center bottom;
  border: 1px solid #ff9d00;
}

@media screen and (min-width: 1221px) {
  .area00 .title-1 .light-box div {
    width: 5px;
    height: 18px;
    border-radius: 6px;
  }
}
.area00 .title-1 .light-box div:nth-child(1) {
  -webkit-transform: rotate(-55deg);
          transform: rotate(-55deg);
  background: -webkit-gradient(linear, left top, left bottom, from(#ff9d00), color-stop(66%, #ffe600), to(#ffe600));
  background: linear-gradient(to bottom, #ff9d00 0%, #ffe600 66%, #ffe600 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#ff9d00", endColorstr="#ffe600",GradientType=0 );
  bottom: 50%;
  left: 0;
}
.area00 .title-1 .light-box div:nth-child(2) {
  -webkit-transform: rotate(-20deg);
          transform: rotate(-20deg);
  background: -webkit-gradient(linear, left top, left bottom, from(#ffbb00), color-stop(33%, #ff9d00), to(#ffe600));
  background: linear-gradient(to bottom, #ffbb00 0%, #ff9d00 33%, #ffe600 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#ffbb00", endColorstr="#ffe600",GradientType=0 );
  bottom: 100%;
  left: 31%;
}
.area00 .title-1 .light-box div:nth-child(3) {
  -webkit-transform: rotate(20deg);
          transform: rotate(20deg);
  background: -webkit-gradient(linear, left top, left bottom, from(#ffe600), color-stop(66%, #ff9d00), to(#ffbb00));
  background: linear-gradient(to bottom, #ffe600 0%, #ff9d00 66%, #ffbb00 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#ffe600", endColorstr="#ffbb00",GradientType=0 );
  bottom: 100%;
  left: 60%;
}
.area00 .title-1 .light-box div:nth-child(4) {
  -webkit-transform: rotate(55deg);
          transform: rotate(55deg);
  background: -webkit-gradient(linear, left top, left bottom, from(#ffe600), color-stop(33%, #ffe600), to(#ff9d00));
  background: linear-gradient(to bottom, #ffe600 0%, #ffe600 33%, #ff9d00 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#ffe600", endColorstr="#ff9d00",GradientType=0 );
  bottom: 50%;
  right: 0;
}
.area00 .title-2 {
  top: 84%;
}

.iframe-container {
  position: relative; /* 讓 iframe 的絕對定位生效 */
  width: 50%; /* 容器的寬度 */
  height: 0; /* 容器的高度先設為0 */
  padding-bottom: 30%; /* 以寬度為基準，撐出高寬比2:3的空間 */
  overflow: hidden; /* 隱藏超出部分的內容 */
}

.iframe-container iframe {
  position: absolute; /* 讓 iframe 可以絕對定位 */
  top: 0;
  left: 0;
  width: 100%; /* iframe 的寬高設為容器的100% */
  height: 100%;
  transform: scale(0.5); /* 設定縮放比例，例如縮小到原來的50% */
  transform-origin: left top; /* 設定縮放的基準點在左上角 */
  border: none; /* 可選：移除邊框 */
}
@media screen and (min-width: 1221px) {
  .area00 .title-2 {
    top: 73%;
  }

}

.area01 .title {
  max-width: 851px;
  width: 92%;
  top: 4.25%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area01 .title {
    width: 44.33%;
    top: 5%;
  }
}

.area02 .title {
  max-width: 836px;
  width: 78%;
  top: 1.875%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area02 .title {
    width: 43.55%;
    top: 3.5%;
  }
}

.area03 .title {
  max-width: 602px;
  width: 92%;
  top: 2%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area03 .title {
    max-width: 1089px;
    width: 56.72%;
    top: 5%;
  }
}
.area03 .box {
  width: 80%;
  margin: auto;
  left: 0;
  right: 0;
}
@media screen and (min-width: 1221px) {
  .area03 .box {
    max-width: 540px;
    width: 28%;
  }
}
.area03 .box.box1 a:nth-child(3) {
  bottom: 0.875%;
  right: 35%;
}
@media screen and (min-width: 1221px) {
  .area03 .box.box1 a:nth-child(3) {
    bottom: 0.875%;
    right: 32%;
  }
}
.area03 .box.box4 a:nth-child(3) {
  bottom: 0.875%;
  right: 24%;
}
@media screen and (min-width: 1221px) {
  .area03 .box.box4 a:nth-child(3) {
    bottom: 0.875%;
    right: 22.5%;
  }
}
.area03 .box a {
  display: block;
  width: 33%;
  height: 8.25%;
  position: absolute;
  bottom: 0.875%;
  right: 0.75%;
}
@media screen and (min-width: 1221px) {
  .area03 .box a {
    width: 30%;
    height: 7.25%;
  }
}
.area03 .box a::before {
  content: "";
  display: block;
  width: 7%;
  height: 44%;
  background-image: url(../images/arr_white.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  right: 10%;
  top: 33%;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 1221px) {
  .area03 .box a::before {
    width: 5.53%;
    height: 36.15%;
    right: 13%;
    top: 35%;
  }
}
.area03 .box a:hover::before {
  right: 10%;
}


@media (min-width: 1200px) {
  .aa032 iframe {
    width: 910px;
    height: 530px;
    display: block;
  }
  .mobile-banner {
    display: none;
  }
}

@media (max-width: 1199px) {
  .aa032 iframe {
    display: none;
  }

  .mobile-banner {
    display: block;
    width: 73.6vw;   /* 883px ÷ 1200px ≈ 0.736，等於螢幕寬度的 73.6% */
    height: auto;    /* 等比縮放 */
    max-width: 883px; /* 當螢幕寬於883px時，不會再放大 */
  }
}

@media screen and (max-width: 1221px) {
  .area03 .box0 {
    top: 9.75%;
  }
  .area03 .box1 {
    top: 27.5%;
  }
  .area03 .box2 {
    top: 46.5%;
  }
  .area03 .box3 {
    top: 64.3%;
  }
  .area03 .box4 {
    top: 82.3%;
  }

}
@media screen and (min-width: 1221px) {
  .area03 .box0, .area03 .box1 {
    top: 18%;
  }
  .area03 .box2, .area03 .box3, .area03 .box4 {
    top: 60%;
    max-width: 28%;
  }
  .area03 .box0 {
    left: 21.5%;
    right: auto;
  }
  .area03 .box2 {
    left: 6.4%;
    right: auto;
  }
  .area03 .box1 {
    left: auto;
    right: 21.5%;
  }
  .area03 .box4 {
    left: auto;
    right: 6.5%;
  }
}

.area04 {
  overflow: hidden;
}
.area04 .title {
  max-width: 591px;
  width: 90%;
  top: 3%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area04 .title {
    max-width: 1089px;
    width: 56.72%;
    top: 7%;
  }
}
.area04 .video {
  width: 67%;
  height: 10%;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area04 .video {
    width: 19.85%;
    height: 19.6%;
    left: 60.4%;
    right: auto;
  }
}
.area04 .video.v1 {
  top: 17.4%;
}
@media screen and (min-width: 1221px) {
  .area04 .video.v1 {
    top: 43%;
  }
}
.area04 .video.v2 {
  top: 32.2%;
}
@media screen and (min-width: 1221px) {
  .area04 .video.v2 {
    top: 72%;
  }
}

/* layout */