@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: #fff;
  /* 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: 1920px;
  overflow: hidden;
  margin: auto;
}

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

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

.video {
  position: absolute;
}
.video iframe {
  width: 100%;
  height: 100%;
}

.area {
  position: relative;
}
.area > div {
  position: absolute;
  z-index: 1;
}

.area00 .logo {
  max-width: 200px;
  width: 28%;
  position: absolute;
  top: 0;
  left: 6.5%;
  z-index: 5;
}
@media screen and (min-width: 1221px) {
  .area00 .logo {
    width: 9.12%;
    left: auto;
    right: 6.25%;
  }
}
.area00 > .title-1, .area00 .title-2 {
  width: 100%;
}
@media screen and (min-width: 1221px) {
  .area00 > .title-1, .area00 .title-2 {
    max-width: 661px;
    width: 34.5%;
    left: 56%;
  }
}
.area00 .title-1 {
  top: 15%;
}
@media screen and (min-width: 1221px) {
  .area00 .title-1 {
    top: 14%;
  }
}
.area00 .title-1 .light-box {
  width: 11%;
  height: 14%;
  position: absolute;
  bottom: 53%;
  left: -54%;
  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: 38.5%;
}
@media screen and (min-width: 1221px) {
  .area00 .title-2 {
    top: 37%;
  }
}

.area01 .title {
  top: 2%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area01 .title {
    max-width: 1202px;
    width: 64.94%;
    top: 6%;
  }
}

.area02 .title {
  top: 5%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area02 .title {
    max-width: 1310px;
    width: 68.23%;
    top: 6%;
  }
}
.area02 .slider {
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.area02 .slick-prev,
.area02 .slick-next {
  width: 9vw;
  height: 9vw;
  background-size: contain;
  z-index: 5;
}
.area02 .slick-prev:before,
.area02 .slick-next:before {
  display: none;
}
.area02 .slick-prev.slick-disabled,
.area02 .slick-next.slick-disabled {
  opacity: 0.25;
}
.area02 .slick-prev {
  background-image: url(../images/arr_l.png);
  left: 1%;
}
.area02 .slick-next {
  background-image: url(../images/arr_r.png);
  right: 1%;
}
.area02 .slick-dots {
  bottom: 22.5%;
}
.area02 .slick-dots li {
  border: 1px solid #f7703b;
  width: 2.5vw;
  height: 2.5vw;
  margin: 0 2%;
  border-radius: 50%;
  background-color: #fff;
}
.area02 .slick-dots li button {
  display: none;
}
.area02 .slick-dots li.slick-active {
  background-color: #f7703b;
}

.area03 .title {
  top: 2.25%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area03 .title {
    max-width: 558px;
    width: 30.15%;
    top: 4%;
  }
}
.area03 .box {
  width: 82.2%;
  height: 12.46%;
  margin: auto;
  left: 0;
  right: 0;
}
@media screen and (min-width: 1221px) {
  .area03 .box {
    width: 27.4%;
    height: 19.4%;
  }
}
.area03 .box iframe {
  width: 100%;
  height: 100%;
  margin: auto;
}
.area03 .box a {
  display: block;
  width: 37%;
  height: 8.25%;
  position: absolute;
  bottom: -17%;
  right: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media screen and (min-width: 1221px) {
  .area03 .box a {
    width: 36%;
    height: 7.25%;
  }
}
.area03 .box a:hover {
  opacity: 0.75;
}
@media screen and (max-width: 1221px) {
  .area03 .box1 {
    top: 21.2%;
  }
  .area03 .box2 {
    top: 39.5%;
  }
  .area03 .box3 {
    top: 57.8%;
  }
  .area03 .box4 {
    top: 76.2%;
  }
}
@media screen and (min-width: 1221px) {
  .area03 .box1, .area03 .box2 {
    top: 33.3%;
  }
  .area03 .box3, .area03 .box4 {
    top: 62.2%;
  }
  .area03 .box1, .area03 .box3 {
    left: 18.8%;
    right: auto;
  }
  .area03 .box2, .area03 .box4 {
    left: auto;
    right: 18.85%;
  }
}

.area04 .title {
  top: 4.25%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area04 .title {
    max-width: 1310px;
    width: 68.23%;
    top: 4.5%;
  }
}
.area04 .btn {
  display: block;
  width: 22.9%;
  height: 3.5%;
  position: absolute;
  top: 65.5%;
  background-color: transparent;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media screen and (min-width: 1221px) {
  .area04 .btn {
    width: 12.3%;
    height: 3.5%;
    top: 73.3%;
  }
}
.area04 .btn:hover {
  background-color: rgba(255, 255, 255, 0.25);
}
.area04 .btn.silver {
  left: 23.3%;
}
@media screen and (min-width: 1221px) {
  .area04 .btn.silver {
    left: 32.9%;
  }
}
.area04 .btn.pink {
  left: 48.9%;
}
@media screen and (min-width: 1221px) {
  .area04 .btn.pink {
    left: 49.7%;
  }
}
.area04 .btn.gray {
  left: 74.1%;
}
@media screen and (min-width: 1221px) {
  .area04 .btn.gray {
    left: 66.55%;
  }
}

.area05 {
  overflow: hidden;
}
.area05 .title {
  top: 3%;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area05 .title {
    max-width: 1310px;
    width: 68.23%;
    top: 8%;
  }
}
.area05 .video {
  width: 67%;
  height: 10%;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (min-width: 1221px) {
  .area05 .video {
    width: 19.85%;
    height: 19.6%;
    left: 60.4%;
    right: auto;
  }
}
.area05 .video.v1 {
  top: 16.3%;
}
@media screen and (min-width: 1221px) {
  .area05 .video.v1 {
    top: 44%;
  }
}
.area05 .video.v2 {
  top: 30.4%;
}
@media screen and (min-width: 1221px) {
  .area05 .video.v2 {
    top: 73.5%;
  }
}

/* layout */
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  src: url("./fonts/slick.eot");
  src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal;
}
/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}
.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}
[dir=rtl] .slick-prev {
  left: auto;
  right: -25px;
}
.slick-prev:before {
  content: "←";
}
[dir=rtl] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}
[dir=rtl] .slick-next {
  left: -25px;
  right: auto;
}
.slick-next:before {
  content: "→";
}
[dir=rtl] .slick-next:before {
  content: "←";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}