/* ==========================================================================
   1. 動畫關鍵影格 (Keyframes)
   ========================================================================== */
@-webkit-keyframes bg {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes bg {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@-webkit-keyframes scale {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
  }

  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@keyframes scale {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
  }

  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@-webkit-keyframes train {
  0% {
    margin-left: 100%;
  }

  100% {
    margin-left: -466px;
  }
}

@keyframes train {
  0% {
    margin-left: 100%;
  }

  100% {
    margin-left: -466px;
  }
}

@-webkit-keyframes car-left {
  0% {
    margin-left: -5%;
  }

  100% {
    margin-left: 100%;
  }
}

@keyframes car-left {
  0% {
    margin-left: -5%;
  }

  100% {
    margin-left: 100%;
  }
}

@-webkit-keyframes car-right {
  0% {
    margin-left: 100%;
  }

  100% {
    margin-left: -5%;
  }
}

@keyframes car-right {
  0% {
    margin-left: 100%;
  }

  100% {
    margin-left: -5%;
  }
}

@-webkit-keyframes airplane {
  0% {
    margin-left: 0%;
    margin-top: 40%;
  }

  100% {
    margin-left: 100%;
    margin-top: 0%;
  }
}

@keyframes airplane {
  0% {
    margin-left: 0%;
    margin-top: 40%;
  }

  100% {
    margin-left: 100%;
    margin-top: 0%;
  }
}

@-webkit-keyframes camera {
  0% {
    margin-left: 100%;
    margin-top: 0%;
  }

  8% {
    margin-left: 80%;
    margin-top: 5%;
  }

  16% {
    margin-left: 65%;
    margin-top: 3%;
  }

  24% {
    margin-left: 50%;
    margin-top: 7%;
  }

  36% {
    margin-left: 38%;
    margin-top: 5%;
  }

  42% {
    margin-left: 23%;
    margin-top: 2%;
  }

  46% {
    margin-left: 13%;
    margin-top: 5%;
  }

  50% {
    margin-left: 0%;
    margin-top: 8%;
  }

  58% {
    margin-left: 18%;
    margin-top: 7%;
  }

  62% {
    margin-left: 35%;
    margin-top: 4%;
  }

  72% {
    margin-left: 50%;
    margin-top: 2%;
  }

  80% {
    margin-left: 62%;
    margin-top: 5%;
  }

  88% {
    margin-left: 75%;
    margin-top: 2%;
  }

  94% {
    margin-left: 88%;
    margin-top: 4%;
  }

  100% {
    margin-left: 100%;
    margin-top: 0%;
  }
}

@keyframes camera {
  0% {
    margin-left: 100%;
    margin-top: 0%;
  }

  8% {
    margin-left: 80%;
    margin-top: 5%;
  }

  16% {
    margin-left: 65%;
    margin-top: 3%;
  }

  24% {
    margin-left: 50%;
    margin-top: 7%;
  }

  36% {
    margin-left: 38%;
    margin-top: 5%;
  }

  42% {
    margin-left: 23%;
    margin-top: 2%;
  }

  46% {
    margin-left: 13%;
    margin-top: 5%;
  }

  50% {
    margin-left: 0%;
    margin-top: 8%;
  }

  58% {
    margin-left: 18%;
    margin-top: 7%;
  }

  62% {
    margin-left: 35%;
    margin-top: 4%;
  }

  72% {
    margin-left: 50%;
    margin-top: 2%;
  }

  80% {
    margin-left: 62%;
    margin-top: 5%;
  }

  88% {
    margin-left: 75%;
    margin-top: 2%;
  }

  94% {
    margin-left: 88%;
    margin-top: 4%;
  }

  100% {
    margin-left: 100%;
    margin-top: 0%;
  }
}

@-webkit-keyframes cloud {
  0% {
    left: 1%;
  }

  50% {
    left: 2%;
  }

  100% {
    left: 1%;
  }
}

@keyframes cloud {
  0% {
    left: 1%;
  }

  50% {
    left: 2%;
  }

  100% {
    left: 1%;
  }
}

@-webkit-keyframes car {
  0% {
    margin-left: -443px;
  }

  100% {
    margin-left: 100%;
  }
}

@keyframes car {
  0% {
    margin-left: -443px;
  }

  100% {
    margin-left: 100%;
  }
}

@-webkit-keyframes iconshake {
  0% {
    margin-top: 40px;
  }

  33% {
    margin-top: 30px;
  }

  66% {
    margin-top: 40px;
  }

  100% {
    margin-top: 30px;
  }
}

@keyframes iconshake {
  0% {
    margin-top: 40px;
  }

  33% {
    margin-top: 30px;
  }

  66% {
    margin-top: 40px;
  }

  100% {
    margin-top: 30px;
  }
}

@-webkit-keyframes earth {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@keyframes earth {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@-webkit-keyframes goon {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes goon {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@-webkit-keyframes jump {
  0% {
    -webkit-transform: translateY(-12px);
    transform: translateY(-12px);
  }

  50% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  100% {
    -webkit-transform: translateY(-12px);
    transform: translateY(-12px);
  }
}

@keyframes jump {
  0% {
    -webkit-transform: translateY(-12px);
    transform: translateY(-12px);
  }

  50% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  100% {
    -webkit-transform: translateY(-12px);
    transform: translateY(-12px);
  }
}

@-webkit-keyframes click01 {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
  }

  20% {
    opacity: 1;
  }

  30% {
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }

  99% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@keyframes click01 {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
  }

  20% {
    opacity: 1;
  }

  30% {
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }

  99% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@-webkit-keyframes click02 {
  0% {
    opacity: 0;
  }

  20% {
    opacity: 1;
  }

  99% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@keyframes click02 {
  0% {
    opacity: 0;
  }

  20% {
    opacity: 1;
  }

  99% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@-webkit-keyframes click03 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0%);
    transform: scale(0%);
  }

  10% {
    opacity: 1;
  }

  80% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  99% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@keyframes click03 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0%);
    transform: scale(0%);
  }

  10% {
    opacity: 1;
  }

  80% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  99% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@-webkit-keyframes bounceInDown {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-2000px);
    transform: translateY(-2000px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }

  80% {
    -webkit-transform: translateY(-10px);
    transform: translateY(-10px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes bounceInDown {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-2000px);
    transform: translateY(-2000px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }

  80% {
    -webkit-transform: translateY(-10px);
    transform: translateY(-10px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@-webkit-keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
    transform: translateY(20px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
    transform: translateY(20px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@-webkit-keyframes slideInLeft {
  0% {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  100% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInLeft {
  0% {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  100% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@-webkit-keyframes slideInRight {
  0% {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  100% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInRight {
  0% {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  100% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

/* 背景滑入動畫 */
@-webkit-keyframes slideFadeInTop {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-50px);
    transform: translateY(-50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes slideFadeInTop {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-50px);
    transform: translateY(-50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@-webkit-keyframes slideFadeInBottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes slideFadeInBottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@-webkit-keyframes slideFadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes slideFadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@-webkit-keyframes slideFadeInRight {
  0% {
    opacity: 0;
    -webkit-transform: translateX(50px);
    transform: translateX(50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes slideFadeInRight {
  0% {
    opacity: 0;
    -webkit-transform: translateX(50px);
    transform: translateX(50px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

/* 背景旋轉淡入動畫 */
@-webkit-keyframes rotateFadeIn {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.2) rotate(-10deg);
    transform: scale(1.2) rotate(-10deg);
  }

  100% {
    opacity: 1;
    -webkit-transform: scale(1) rotate(0deg);
    transform: scale(1) rotate(0deg);
  }
}

@keyframes rotateFadeIn {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.2) rotate(-10deg);
    transform: scale(1.2) rotate(-10deg);
  }

  100% {
    opacity: 1;
    -webkit-transform: scale(1) rotate(0deg);
    transform: scale(1) rotate(0deg);
  }
}

/* ==========================================================================
   2. 共用元件與設定 (Global & Components)
   ========================================================================== */
.bg-m {
  display: none;
}

.anisec .animate {
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  opacity: 0;
}

.anisec .animate.show {
  opacity: 1;
}

.anisec .animate.show.inifite {
  -webkit-transition: all 1s;
  transition: all 1s;
  -webkit-animation: goon 1.5s infinite;
  animation: goon 1.5s infinite;
}

.anisec .animate.fadeInUp.show {
  -webkit-animation: fadeInUp 0.5s;
  animation: fadeInUp 0.5s;
}

.train {
  opacity: 0;
  overflow: hidden;
  width: 100%;
  height: 65px;
  position: absolute;
  bottom: 21px;
}

.train figure {
  display: block;
  width: 466px;
  height: 65px;
  background: url(../images/train.png) center center no-repeat;
}

.train.show {
  opacity: 1;
}

.train.show figure {
  -webkit-animation: train 8s linear infinite;
  animation: train 8s linear infinite;
}

.iconshake {
  position: absolute;
  display: block;
  left: 0;
  right: 0;
  margin: 0 auto 1rem;
  bottom: 80px;
  width: 60px;
  margin-bottom: 1.5rem;
}

.iconshake a {
  width: 60px;
  height: 80px;
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/scroll.svg);
  background-position: bottom center;
}

@media (max-width: 1024px) {
  .iconshake a {
    background-image: url(../images/scroll_xs.svg);
    width: 45px;
  }
}

ul.boxlist > li {
  position: relative;
  font-size: 20px;
  line-height: 32px;
  padding-left: 30px;
  margin-top: 10px;
  margin-bottom: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

ul.boxlist > li + li {
  margin-top: 10px;
}

ul.boxlist > li:before {
  display: inline-block;
  vertical-align: top;
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  position: absolute;
  left: 8px;
  top: 9px;
  background: #666666;
}

ul.boxlist > li * {
  font-size: 18px;
  line-height: 1.6em;
  color: #666666;
}

ul.boxlist > li b {
  font-weight: bold;
}

ul.boxlist > li span {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

ul.boxlist table {
  width: 95%;
  margin: 10px 0;
}

ul.boxlist table caption {
  font-size: 20px;
  line-height: 32px;
  margin-bottom: 5px;
}

ul.boxlist table th,
ul.boxlist table td {
  font-size: 18px;
  padding: 3px 10px;
  border: 1px solid #ccc;
  text-align: center;
}

ul.boxlist table thead th {
  border: 1px solid #fff;
  background-color: #dfdfdf;
}

ul.boxlist table thead th.th2 {
  background: #fadaba;
}

ul.boxlist table thead th.th3 {
  background: #b7e7df;
}

ul.boxlist table tbody tr.point td {
  background-color: #1cbbc5;
  color: #fff;
}

ul.boxlist img {
  max-width: 100%;
  margin: auto;
}

.icon-list li {
  padding-left: 80px;
  position: relative;
  margin: 25px 60px;
}

.icon-list li * {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.6em;
  color: #666666;
}

.icon-list li span {
  color: #a07729;
}

.icon-list li:before {
  display: inline-block;
  vertical-align: top;
  content: "";
  width: 52px;
  height: 48px;
  position: absolute;
  left: 8px;
  top: 0;
  background-image: url(../images/requestItem-icon.svg);
  background-size: cover;
}

.icon-list li:nth-child(1):before {
  background-position: 0 0;
}

.icon-list li:nth-child(2):before {
  background-position: 0 -72px;
}

.icon-list li:nth-child(3):before {
  background-position: 0px -148px;
}

.icon-list li:nth-child(4):before {
  background-position: 0px -220px;
}

.icon-list li:nth-child(5):before {
  background-position: 0px -284px;
}

.icon-list.flex li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 15px 60px;
}

.icon-list.flex li * {
  font-size: 24px;
  line-height: 48px;
  color: #666666;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.icon-list .download {
  background: url(../images/download.svg) center center no-repeat;
  width: 32px;
  height: 48px;
  display: block;
  margin: 0 8px;
}

/* Global RWD */
@media (max-width: 768px) {
  .icon-list li {
    margin: 25px auto;
  }
}

@media (max-width: 700px) and (max-width: 550px) {
  ul.boxlist > li {
    padding-left: 20px;
  }

  ul.boxlist > li:before {
    left: 0px;
  }

  ul.boxlist > li * {
    font-size: 18px;
    line-height: 1.6em;
    color: #666666;
  }

  ul.boxlist > li b {
    padding-left: 15px;
  }

  ul.boxlist table {
    width: 100%;
  }

  ul.boxlist table th,
  ul.boxlist table td {
    padding: 3px;
    word-break: break-all;
  }
}

@media (max-width: 480px) {
  .icon-list li {
    padding-left: 52px;
  }

  .icon-list li:before {
    width: 40px;
    height: 35px;
  }

  .icon-list li:nth-child(2):before {
    background-position: 0 -52px;
  }

  .icon-list li:nth-child(3):before {
    background-position: 0px -114px;
  }

  .icon-list li:nth-child(4):before {
    background-position: 0px -170px;
  }

  .icon-list li:nth-child(5):before {
    background-position: 0px -219px;
  }

  .icon-list.flex li {
    padding-left: 52px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 15px 0;
  }

  .icon-list.flex li * {
    line-height: 35px;
    font-size: 18px;
  }

  .icon-list .download {
    width: 24px;
    background-size: contain;
    height: 35px;
    margin: 0 4px;
  }
}

/* ==========================================================================
   3. 各區塊設定 (Sections) & 各區塊獨立 RWD
   ========================================================================== */

/* --- #index --- */
#index {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  padding-top: 0;
  overflow: hidden;
  min-height: auto !important;
}

#index .bg {
  background: url(../images/index-bg-m.svg) center top no-repeat;
  background-size: cover;
  background-color: #a22e4e;
}

#index .title {
  margin: -1.5rem auto 0;
  width: 85%;
  max-width: 720px;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-top: 1rem;
}

#index .bg.animate.show {
  opacity: 1;
}

#index .index-bg-m {
  display: none;
}

#index .streetlamp {
  background: url(../images/rail.png) center bottom no-repeat;
  z-index: 2;
  position: absolute;
  width: 100%;
  height: 70px;
  bottom: 0;
  background-size: 100% 100%;
}

#index .streetlamp.animate {
  opacity: 0;
}

#index .streetlamp.animate.show {
  opacity: 1;
  -webkit-animation: bg 1s ease-in;
  animation: bg 1s ease-in;
}

#index .map {
  z-index: 2;
  position: absolute;
  opacity: 0;
  bottom: 10.5%;
  width: 47%;
  left: 21%;
}

#index .map.animate {
  opacity: 0;
  -webkit-transition: 0.5s all 0.8s;
  transition: 0.5s all 0.8s;
}

#index .map.animate.show {
  opacity: 1;
}

#index .word {
  z-index: 0;
  position: absolute;
  opacity: 0;
  top: 75px;
  left: 12%;
  height: 86%;
}

#index .word.animate {
  opacity: 0;
  -webkit-transition: 0.5s all 0.8s;
  transition: 0.5s all 0.8s;
}

#index .word.animate.show {
  opacity: 1;
}

#index .illustration {
  z-index: -1;
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
}

#index .illustration .animate {
  opacity: 0;
  bottom: 25%;
  position: absolute;
  left: 40.5%;
}

#index .illustration .animate.show {
  opacity: 1;
  -webkit-transition: 1s all;
  transition: 1s all;
}

#index .thing {
  z-index: -1;
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 100%;
}

#index .thing .house {
  position: absolute;
  bottom: 95px;
  width: 100%;
  height: 388px;
  -webkit-transition: 2s all;
  transition: 2s all;
  opacity: 0;
  background: url(../images/house.png) center bottom no-repeat;
}

#index .thing .house.show {
  opacity: 1;
  -webkit-animation: bounceInDown 2s linear;
  animation: bounceInDown 2s linear;
}

#index .thing .phone {
  bottom: 36px;
  opacity: 0;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 165px;
}

#index .thing .phone > div {
  height: 100%;
  position: relative;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

#index .thing .phone > div:after {
  content: " ";
  display: block;
  clear: both;
}

#index .thing .phone > div img {
  position: absolute;
  right: 0;
  bottom: 0;
}

#index .thing .phone.show {
  opacity: 1;
  -webkit-animation: bounceInDown 2s linear;
  animation: bounceInDown 2s linear;
}

#index .car-left {
  position: absolute;
  width: 80%;
  height: 388px;
  bottom: 0;
  margin: 0 auto;
  left: 10%;
  overflow: hidden;
  z-index: 10;
}

#index .car-left .animate {
  position: absolute;
  opacity: 0;
  bottom: 132px;
}

#index .car-left .animate.show {
  opacity: 1;
  -webkit-animation: car-left 10s linear infinite;
  animation: car-left 10s linear infinite;
}

#index .car-right {
  position: absolute;
  bottom: 100px;
  width: 845px;
  height: 388px;
  bottom: 0;
  margin: 0 auto;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  left: 49.5%;
  overflow: hidden;
}

#index .car-right .animate {
  position: absolute;
  opacity: 0;
  bottom: 100px;
}

#index .car-right .animate.show {
  opacity: 1;
  -webkit-animation: car-right 10s linear infinite;
  animation: car-right 10s linear infinite;
}

#index .airplane {
  position: absolute;
  width: 100vw;
  height: 388px;
  top: 0;
  margin: 0 auto;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  left: 49.5%;
  overflow: hidden;
  z-index: -1;
}

#index .airplane .animate {
  position: absolute;
  opacity: 0;
}

#index .airplane .animate.show {
  opacity: 1;
  -webkit-animation: camera 15s linear infinite;
  animation: camera 15s linear infinite;
}

#index .index-obj {
  width: 100%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}

#index .index-obj-1.animate {
  -webkit-transition: 0.5s all 0.5s;
  transition: 0.5s all 0.5s;
  left: 20%;
}

#index .index-obj-2.animate {
  -webkit-transition: 0.5s all 0.8s;
  transition: 0.5s all 0.8s;
  left: 46.5%;
  bottom: 14.5% !important;
}

#index .index-obj-3.animate {
  -webkit-transition: 0.5s all 0.4s;
  transition: 0.5s all 0.4s;
  left: 58%;
  bottom: 14.5% !important;
}

#index .index-obj-4.animate {
  -webkit-transition: 0.5s all 0.8s;
  transition: 0.5s all 0.8s;
}

#index .index-obj-5.animate {
  -webkit-transition: 0.5s all 0.5s;
  transition: 0.5s all 0.5s;
}

#index .index-obj-6.animate {
  -webkit-transition: 0.5s all 0.8s;
  transition: 0.5s all 0.8s;
}

#index .index-obj-5g {
  left: 0;
  bottom: 20%;
}

#index .index-obj-5g.animate {
  -webkit-transition: 1s all;
  transition: 1s all;
}

#index .index-obj .animate {
  position: absolute;
  opacity: 0;
  bottom: 15%;
}

#index .index-obj .animate.show {
  opacity: 1;
  -webkit-animation: scale 0.5s ease-in;
  animation: scale 0.5s ease-in;
}

#index .tree {
  width: 100%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}

#index .tree-1.animate {
  -webkit-transform-origin: 50% 100%;
  transform-origin: 50% 100%;
  left: -119px;
}

#index .tree-2.animate {
  -webkit-transform-origin: 50% 100%;
  transform-origin: 50% 100%;
  left: 10%;
}

#index .tree-3.animate {
  -webkit-transform-origin: 50% 100%;
  transform-origin: 50% 100%;
  left: 30%;
}

#index .tree .animate {
  position: absolute;
  opacity: 0;
  bottom: -15px;
}

#index .tree .animate.show {
  opacity: 1;
  -webkit-animation: scale 1s ease-in;
  animation: scale 1s ease-in;
}

#index .cloud {
  position: absolute;
  width: 100%;
  height: 100%;
}

#index .cloud .animate {
  position: absolute;
}

#index .cloud-left {
  opacity: 0;
  bottom: 27%;
  margin-left: 36%;
}

#index .cloud-left-b {
  margin-left: 5%;
  margin-top: 15%;
}

#index .cloud-left.animate.show {
  opacity: 1;
  -webkit-animation:
    goon 1s ease-in,
    cloud 3s linear infinite;
  animation:
    goon 1s ease-in,
    cloud 3s linear infinite;
}

#index .cloud-right {
  margin-left: 86%;
  opacity: 0;
  bottom: 39%;
  margin-left: 69%;
}

#index .cloud-right-w {
  margin-left: 82%;
  margin-top: 15%;
}

#index .cloud-right.animate.show {
  opacity: 1;
  -webkit-animation:
    goon 1s ease-in,
    cloud 3s linear infinite;
  animation:
    goon 1s ease-in,
    cloud 3s linear infinite;
}

#index .mtitle {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  text-align: center;
}

#index .mtitle.show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

#index .mtitle-m {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  display: none;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
}

#index .mtitle-m.show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

#index .type .mt {
  text-align: center;
  height: 112px;
  display: inline-block;
}

#index .type .mt.left {
  margin-right: 61px;
}

#index .type .mt.left li {
  -webkit-transform: translateX(60px);
  transform: translateX(60px);
}

#index .type .mt.left li.show {
  -webkit-transform: translateX(0px);
  transform: translateX(0px);
}

#index .type .mt.right {
  margin-left: 61px;
}

#index .type .mt.right li {
  -webkit-transform: translateX(-60px);
  transform: translateX(-60px);
}

#index .type .mt.right li.show {
  -webkit-transform: translateX(0px);
  transform: translateX(0px);
}

#index .type .mt li {
  display: inline-block;
  width: 124px;
  height: 112px;
  -webkit-transition: 1s all;
  transition: 1s all;
  opacity: 0;
}

#index .type .mt li.show {
  opacity: 1;
}

#index .type .mt li.h03 {
  position: absolute;
  left: 50%;
  margin-left: -63px;
}

#index .type .mt li.h01 {
  background: url(../images/h101.png) center center no-repeat;
}

#index .type .mt li.h02 {
  background: url(../images/h102.png) center center no-repeat;
}

#index .type .mt li.h03 {
  background: url(../images/h103.png) center center no-repeat;
}

#index .type .mt li.h04 {
  background: url(../images/h104.png) center center no-repeat;
}

#index .type .mt li.h05 {
  background: url(../images/h105.png) center center no-repeat;
}

#index .mh1 {
  display: none;
}

#index .index-title {
  max-width: 1280px;
  width: 90%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#index .title {
  margin: 0 auto;
  position: relative;
  width: 100%;
  z-index: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  align-content: center;
  flex-wrap: wrap;
  text-align: center;
}

#index .maintitle {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 100%;
}

#index .maintitle.mainsub {
  margin: 0 auto;
  width: 30%;
}

#index .mainsub {
  margin-bottom: -4rem;
  margin: 0 auto;
  width: 95%;
  max-width: 880px;
  opacity: 0;
  transition: 1s all 0.5s;
  transform: translateX(-50%);
}

#index.active .maintitle.show {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

#index .maintitle-m {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  margin: 1rem 0 0;
  display: none;
}

#index .maintitle-m.show {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

#index .subtitle {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  -webkit-transform: translateX(50%);
  transform: translateX(50%);
  margin: 0.75rem auto;
}

#index .subtitle.show {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

#index .subtitle-m {
  display: none;
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  -webkit-transform: translateX(50%);
  transform: translateX(50%);
  margin: 0.75rem auto;
}

#index .subtitle-m.show {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

#index .content-title {
  opacity: 0;
  -webkit-transition: 1s all 1.5s;
  transition: 1s all 1.5s;
}

#index .content-title.show {
  opacity: 1;
}

#index .info {
  opacity: 0;
  -webkit-transition: 1s all 1s;
  transition: 1s all 1s;
  max-width: 65%;
  margin: 0 auto;
  z-index: 5;
}

#index .info.show {
  opacity: 1;
}

#index .portrait {
  width: 100%;
  max-width: 600px;
  height: clamp(300px, 80vh, 960px);
  position: absolute;
  bottom: 0;
  left: 2rem;
}
#index .portrait>img{
  height: 100%;

}

#index .portrait-pc {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
}

#index .portrait-pc.show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

#index .portrait-m {
  opacity: 0;
  -webkit-transition: 1s all 0.5s;
  transition: 1s all 0.5s;
  display: none;
  position: absolute;
  bottom: 0;
  right: 0;
  width: 65%;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
}

#index .portrait-m.show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

#index p {
  text-align: center;
  position: relative;
  padding: 3px 0;
  font-size: 20px;
  line-height: 35px;
  text-align: left;
  color: #000000;
  font-size: 14px;
  width: 100%;
}

#index p span {
  display: inline-block;
  font-size: 30px;
  color: #fff;
  border-bottom: 1px solid #fff;
}

#index ul.link {
  margin: 10px auto;
}

#index ul.link li {
  display: inline-block;
  margin: 0 10px;
}

#index ul.link li:first-child {
  margin-left: -6px;
}

#index ul.link li img {
  height: 45px;
}

#index .btns {
  display: table;
  margin: 20px auto;
}

#index .btns a {
  background: #9e7830;
  color: #000;
}

#index .btns a:hover {
  background: #cf33b4;
  color: #fff;
}

/* #index RWD */
@media (min-width: 768px) {
  #index {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #ffffff;
    height: clamp(680px, 98vh, 1280px);
  }

  #index .bg {
    background: url(../images/index-bg-pc.jpg) center center no-repeat;
    background-size: cover;
    z-index: -1;
    position: absolute;
    width: 100%;
    height: 100%;
    bottom: 0;
    opacity: 0;
    -webkit-animation: rotateFadeIn 1.5s ease-out forwards;
    animation: rotateFadeIn 1.5s ease-out forwards;
  }

  #index .index-title {
    margin-top: 8%;
  }
}

@media (min-width: 980px) {
  #index {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  #index .bg {
    background: url(../images/index-bg-pc.jpg) center center no-repeat;
    background-size: cover;
    z-index: -1;
    position: absolute;
    width: 100%;
    height: 100%;
    bottom: 0;
  }

  #index .index-title {
    margin-top: 8%;
  }
}

@media (min-width: 1280px) {
  #index p {
    font-size: clamp(0.85rem, 2.5vw, 18px);
  }
}

@media (max-width: 1700px) {
  #index .map {
    bottom: 11%;
  }

  #index .car-left .animate {
    bottom: 137px;
  }

  #index .index-obj-1.animate {
    left: 16%;
  }

  #index .index-obj-2.animate {
    left: 46.5%;
  }

  #index .index-obj-3.animate {
    left: 60%;
  }

  #index .index-obj .animate {
    bottom: 15.5% !important;
  }
}

@media (max-width: 1600px) {
  #index .thing .phone > div img {
    right: 0;
    width: 100%;
  }
}

@media (max-width: 1500px) {
  #index .map {
    left: 14%;
    bottom: 10%;
  }

  #index .word {
    left: 5%;
  }

  #index .car-left .animate {
    bottom: 92px;
  }

  #index .index-obj-1.animate {
    bottom: 13% !important;
    left: 11%;
  }

  #index .index-obj-3.animate {
    left: 62%;
  }

  #index .cloud-left {
    margin-left: 30%;
  }

  #index .cloud-right {
    margin-left: 76%;
  }
}

@media (max-width: 1440px) {
  #index .index-obj-5g {
    width: 90%;
    left: 4%;
    bottom: -8% !important;
  }
}

@media (max-width: 1280px) {
  #index .word {
    max-width: 40%;
  }
}

@media (max-width: 1024px) {
  #index {
    padding-top: 0;
    background-size: cover;
  }

  #index .streetlamp {
    background-size: auto 100%;
  }

  #index .word,
  #index .map,
  #index .illustration,
  #index .car-left,
  #index .index-obj,
  #index .cloud {
    display: none;
  }

  #index .index-obj {
    width: 170%;
    position: absolute;
    height: 100%;
    bottom: 10%;
    left: -26%;
    top: auto;
  }

  #index .index-obj-5g {
    bottom: -15% !important;
  }

  #index .tree-1.animate,
  #index .tree-2.animate {
    display: none;
  }

  #index .tree-3.animate {
    left: 0;
  }

  #index .tree {
    position: absolute;
    height: 100%;
    bottom: 0;
  }

  #index .mtitle-m {
    display: block;
    margin: 24px auto 0;
    font-size: 16px;
    line-height: 1.5;
  }

  #index .maintitle-m {
    max-width: 80%;
    display: block;
  }

  #index .subtitle {
    display: none;
  }

  #index .subtitle-m {
    display: block;
  }

  #index .portrait-m {
    display: block;
    text-align: center;
    margin: 24px auto 0;
    font-size: 16px;
    line-height: 1.5;
  }
}



@media (max-width: 768px) {
  #index .content-title {
    font-size: 14px;
    max-width: 85%;
  }
}

@media (max-width: 767px) {

  #index .bg,
  #index .title,
  #index .portrait {
    display: none;
  }

  #index .index-bg-m {
    display: block;
  }

  #index .thing,
  #index .h1,
  #index .car-right,
  #index .mtitle,
  #index .cloud,
  #index .maintitle,
  #index .portrait-pc {
    display: none;
  }

  #index .mh1 {
    display: table;
    margin: 10px auto;
  }

  #index .info {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
  }

  #index p span {
    font-size: 24px;
    border-bottom: none;
  }
}

@media (max-width: 480px) {
  #index .bg::after {
    top: 16px;
    left: 28px;
  }

  #index .streetlamp,
  #index .map,
  #index .word,
  #index .car-left,
  #index .index-obj,
  #index .airplane {
    display: none;
  }

  #index .content-title {
    -webkit-transition: none;
    transition: none;
  }

  #index .info {
    opacity: 1 !important;
    display: none;
  }

  #index .portrait {
    max-width: 100%;
  }

  #index ul.link li img {
    height: 30px;
  }
}

@media (max-height: 700px) {
  #index .title {
    padding-top: 0;
  }
}

/* Tablet 橫式（含 iPad） */
@media (min-width: 1024px) and (max-width: 1366px) {
  #index .portrait {
    height: clamp(220px, 40vh, 960px);
}

}


@media (min-width: 768px) and (max-width: 960px) {
  #index {
    display: flex !important;
    align-items: center;
    overflow: hidden;
    padding-top: 60px;
  }

  #index .index-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
  }

  #index .index-bg-m {
    display: none !important;
  }

  #index .bg,
  #index .portrait,
  #index .portrait-pc {
    display: block !important;
  }

  #index .title {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    z-index: 5;
    width: 80%;
    height: calc(100% - 90px);
    margin: 0;
  }

  #index .maintitle {
    display: block !important;
    max-width: 100%;
    margin-bottom: 1rem;
  }

  #index .subtitle {
    display: block !important;
    max-width: 90%;
    margin: 0;
  }

  #index .portrait {
    height: clamp(300px, 48vh, 960px);
}

  #index .cloud,
  #index .car-left,
  #index .index-obj,
  #index .tree {
    display: block !important;
  }

  #index .car-left {
    transform: scale(0.65);
    transform-origin: left bottom;
    bottom: -20px;
    left: 0;
  }

  #index .index-obj {
    transform: scale(0.7);
    transform-origin: left bottom;
    bottom: 5% !important;
    left: -10%;
  }

  #index .tree {
    transform: scale(0.75);
    transform-origin: center bottom;
    bottom: 0;
  }

  #index .airplane,
  #index .car-right,
  #index .maintitle-m,
  #index .subtitle-m,
  #index .portrait-m {
    display: none !important;
  }
}

/* --- #forum --- */
#forum {
    background: linear-gradient(180deg, #f3f1f8 0%, #dddcf0 100%);
    padding-top: 60px;
    padding-bottom: 60px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    
  height: clamp(500px, 80vh, 1280px);
  min-height: auto !important;

}

#forum p {
  color: #2d2d2d;
  font-size: 20px;
  text-align: center;
  margin-bottom: 10px;
}

#forum p span {
  color: #2d2d2d;
  font-size: 20px;
}

#forum ul.info {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 3%;
}

#forum ul.info .info-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

#forum ul.info li {
  display: flex;
  gap: 10px;
  font-size: 26px;
  margin: 12px auto;
  color: #2d2d2d;
  align-items: flex-start;
  width: 100%;
}

@media (min-width: 1024px) {
  #forum ul.info li span.info-wrap-title {
    font-size: 22px;
    padding: 7px 35px;
  }
}

#forum ul.info li p.info-add-s {
  text-align: left;
  color: #2d2d2d;
  font-size: 0.85em;
}

#forum ul.info li:first-child {
  margin-right: 30px;
}

#forum ul.info li span.info-wrap-title {
  border: 3px solid #332c69;
  border-radius: 20rem;
  display: inline-block;
  background-color: #332c69;
  color: #ffffff;
  font-size: 16px;
  font-weight: 600;
  line-height: 30px;
  padding: 1px 10px;
}

#forum ul.info li .info-wrap-map {
  display: flex;
  flex-wrap: wrap;
}

#forum ul.info li span {
  font-size: 18px;
  color: #2d2d2d;
}

#forum ul.info li > img {
  display: inline-block;
  vertical-align: middle;
  margin-top: -3px;
  margin-right: 3px;
  width: 51px;
}

#forum ul.info li a.map {
  display: inline-block;
  vertical-align: middle;
  margin-top: 5px;
  position: relative;
  width: 25px;
  height: 25px;
  margin-left: 8px;
}

#forum ul.info li a.map img {
  -webkit-animation: jump 0.8s infinite;
  animation: jump 0.8s infinite;
}

#forum .btns {
  margin-top: 1.5rem;
}

#forum .forum-bottom {
  position: absolute;
  bottom: -100%;
  z-index: -1;
  -webkit-transition: 1s all;
  transition: 1s all;
}

#forum .forum-left,
#forum .forum-left-m {
  position: absolute;
  left: -100%;
  top: 0;
  z-index: -1;
  -webkit-transition: 1s all;
  transition: 1s all;
}

#forum .forum-right,
#forum .forum-right-m {
  position: absolute;
  right: -50%;
  bottom: 0;
  z-index: -1;
  height: 100%;
  -webkit-transition: 1s all;
  transition: 1s all;
}

#forum.active .forum-left {
  left: 0%;
}

#forum.active .forum-right {
  right: 0%;
}

#forum.active .forum-bottom {
  bottom: 0%;
}

/* #forum RWD */
@media (min-width: 768px) {
  #forum ul.info li {
    letter-spacing: 2px;
  }

  #forum ul.info li span.info-wrap-title {
    width: 6rem;
    font-size: 22px;
  }

  #forum ul.info li span,
  #forum ul.info li p {
    font-size: 26px;
  }

  #forum > div.con {
    background-position:
      -6px 25px,
      40px bottom;
  }

  #forum ul.info li a.map {
    width: 30px;
    height: 30px;
  }
}

@media (min-width: 1080px) {
  #forum > div.con {
    max-width: 1280px;
  }
}


@media (max-width: 980px) {
  #forum {
    min-height: auto !important;
    padding-top: 60px;
    padding-bottom: 120px;
  }

  #forum.active .forum-left,
  #forum.active .forum-right {
    display: none;
  }
}

@media (max-width: 768px) {
  #forum ul.info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

@media (max-width: 767px) {
  #forum.active .forum-left,
  #forum.active .forum-right {
    display: none;
  }
}

@media (max-width: 480px) {
  #forum p {
    font-size: 18px;
    margin-bottom: 0;
  }

  #forum p span {
    font-size: 18px;
    display: block;
  }

  #forum p br {
    display: none;
  }

  #forum ul.info li > img {
    width: 40px;
  }
}

/* ==========================================================================
   Forum 背景與分開滑入動畫 (.forum-bk)
   ========================================================================== */

/* 1. 背景容器設為絕對定位，鋪滿 #forum */
#forum .forum-bk {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  /* 確保墊在內容最底層 */
  overflow: hidden;
  opacity: 1 !important;
}

/* 2. 共用偽元素設定 */
#forum .forum-bk::before,
#forum .forum-bk::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  opacity: 0;
  /* 預設全透明 */
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

/* --- 3. 手機版預設：上下圖片、上下滑入 --- */
#forum .forum-bk::before {
  background-image: url("../images/forum-bg-left.png");
  /* 請替換為實際圖檔名 */
  background-position: left top;
  background-size: contain;
  top: 0;
  left: 0;
  width: 30%;
  height: 30%;
}

#forum .forum-bk::after {
  background-image: url("../images/forum-bg-right.png");
  /* 請替換為實際圖檔名 */
  background-position: right bottom;
  background-size: contain;
  bottom: 0;
  right: 0;
  width: 40%;
  height: 40%;
}

/* 加上 active 觸發手機版動畫 */
#forum.active .forum-bk::before {
  -webkit-animation: slideFadeInTop 0.8s ease-out forwards;
  animation: slideFadeInTop 0.8s ease-out forwards;
}

#forum.active .forum-bk::after {
  -webkit-animation: slideFadeInBottom 0.8s ease-out forwards;
  animation: slideFadeInBottom 0.8s ease-out forwards;
  -webkit-animation-delay: 0.2s;
  /* 下半圖晚 0.2 秒出現，增加層次感 */
  animation-delay: 0.2s;
}

/* --- 4. 桌機版 (768px 以上)：左右圖片、左右滑入 --- */
@media (min-width: 768px) {
  #forum .forum-bk::before,
  #forum .forum-bk::after {
    width: 60%;
    height: 60%;
    background-size: contain;
    /* 或者依據你的視覺圖改成 20% / 30% 等特定比例 */
  }
}

/* --- 4. 桌機版 (1280px 以上)：左右圖片、左右滑入 --- */
@media (min-width: 1280px) {
  /* 左邊背景圖 */
  #forum .forum-bk::before {
    background-image: url("../images/forum-bg-left.png");
    /* 請替換為實際圖檔名 */
    background-position: left top;
    left: 0;
  }

  /* 右邊背景圖 */
  #forum .forum-bk::after {
    background-image: url("../images/forum-bg-right.png");
    /* 請替換為實際圖檔名 */
    background-position: right bottom;
    right: 0;
    left: auto;
  }

  /* 觸發桌機版動畫 (覆寫手機版的上下動畫，改為左右滑入) */
  #forum.active .forum-bk::before {
    -webkit-animation: slideFadeInLeft 0.8s ease-out forwards;
    animation: slideFadeInLeft 0.8s ease-out forwards;
  }

  #forum.active .forum-bk::after {
    -webkit-animation: slideFadeInRight 0.8s ease-out forwards;
    animation: slideFadeInRight 0.8s ease-out forwards;
    -webkit-animation-delay: 0.2s;
    animation-delay: 0.2s;
  }
}

@media (min-width: 1680px) {
  #forum .forum-bk::before,
  #forum .forum-bk::after {
    width: 80%;
    height: 80%;
  }
}

@media (min-width: 1920px) {
  #forum .forum-bk::before,
  #forum .forum-bk::after {
    width: 90%;
    height: 90%;
  }
}

/* ==========================================================================
   5. 區塊：Speaker (#speaker) 主容器與背景
   ========================================================================== */
#speaker {
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
  z-index: 1;
  overflow: hidden; /* 防止背景動畫超出版面產生卷軸 */
  min-height: auto !important;
}

/* 獨立的旋轉淡入背景層 (.speaker-bg) */
#speaker .speaker-bg {
  /* 替換成你實際的世界地圖背景 */
  background: url("../images/speaker-xs.jpg") center center no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

#speaker .tag-name {
  display: none;
}
/* ==========================================================================
   講者列表排版與樣式
   ========================================================================== */
#speaker .people {
  max-width: 1200px; /* 稍微加大寬度以容納 3 人 */
  margin: 3rem auto;
  padding: 0 20px;
}

#speaker ul.speaker {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  /* 手機與平板預設使用 Flexbox 彈性排版 */
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px;
}

#speaker ul.speaker li {
  width: 100%;
  max-width: 380px; /* 控制單一講者的最大寬度 */
  position: relative;
  opacity: 0;
  top: 3rem; /* 準備滑入的起始位置 */
}

/* 加上 .active 觸發階層式滑入動畫 */
#speaker.active .speaker li {
  opacity: 1;
  top: 0;
}

/* --- 講者圖片與文字樣式 --- */
#speaker ul.speaker figure {
  margin: 0;
  text-align: center;
}

#speaker ul.speaker figure img {
  width: 100%;
  height: auto;
  display: block;
}

#speaker ul.speaker figcaption.lecturerBox {
  text-align: center;
  margin-top: 15px;
}

#speaker ul.speaker figcaption p {
  font-family: "Noto Sans TC", sans-serif;
  margin: 0;
  padding: 4px 0;
  color: var(--color-black, #333333); /* 加入備用色防止變數失效 */
  letter-spacing: 1px;
}

/* 職稱 */
#speaker ul.speaker figcaption p.title {
  font-size: 15px;
  font-weight: 500;
  color: #555555;
}

/* 姓名 */
#speaker ul.speaker figcaption p.name {
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 5px;
}

/* 平板尺寸 (768px ~ 1023px)：一行 2 個 */
@media (min-width: 768px) and (max-width: 1023px) {
  #speaker ul.speaker li {
    width: calc(50% - 20px);
  }
}

@media (min-width: 1024px) {
  #speaker ul.speaker {
    display: flex; /* 改回 flex 能夠更完美地處理這種不規則數量的置中 */
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px; /* 直接在這裡調整上下左右的間距 (原本太寬的話，可以把 40px 改小) */
    margin: 0 auto;
  }

  #speaker ul.speaker li {
    width: calc(33.333% - 40px); /* 一排 3 個，減去 gap 的空間 */
    max-width: 500px;
    margin-bottom: 20px;
  }

  #speaker .speaker-bg {
  /* 替換成你實際的世界地圖背景 */
  background: url("../images/speaker-pc.jpg") center center no-repeat;

  -webkit-animation: rotateFadeIn 1.5s ease-out forwards;
  animation: rotateFadeIn 1.5s ease-out forwards;
}
}

/* 手機版微調 */
@media (max-width: 520px) {
  #speaker {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  #speaker ul.speaker li {
    max-width: 80%;
  }
}

/* --- #agenda --- */
#agenda {
  display: flex;
  justify-content: center;
  align-items: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-top: 60px;
  padding-bottom: 120px;
  position: relative;
  background: linear-gradient(180deg, #f3f1f8 0%, #dddcf0 100%);
  min-height: auto !important;
}

#agenda .con {
  max-width: 950px;
}

#agenda .title {
  margin-bottom: 60px;
}

#agenda .agenda-list li {
  display: flex;
  margin: 12px 0;
}

#agenda .agenda-list li * {
  color: #151515;
  font-size: 18px;
  font-weight: 600;
}

#agenda .agenda-list li .title-sup {
  color: #151515;
}

#agenda .agenda-list li i {
  position: relative;
  flex: 0 0 auto;
  width: 160px;
}

#agenda .agenda-list li i.time {
  color: #151515;
}

#agenda .agenda-list li i:before {
  content: "";
  position: absolute;
  width: 2px;
  height: 100%;
  background-color: #be8383;
  right: -51px;
  top: 18px;
}

#agenda .agenda-list li:last-child i:before {
  display: none;
}

#agenda .agenda-list .agenda-list-box {
  margin-left: 100px;
  position: relative;
}

#agenda .agenda-list .agenda-list-box.agenda-list-box-flex {
  display: flex;
  flex-wrap: wrap;
}

#agenda .agenda-list .agenda-list-box > h4 {
  display: flex;
  margin: 8px 0 10px;
  gap: 8px;
}

#agenda .agenda-list .agenda-list-box > h4 > .agenda-list-name {
  width: 100%;
  align-items: center;
}

#agenda .agenda-list .agenda-list-box > h4 > .agenda-list-name .con-person {
  width: 100%;
}

#agenda .agenda-list .agenda-list-box > h4 > .agenda-list-name .s-name {
  font-size: 18px;
}

#agenda .agenda-list .agenda-list-box::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  background: #b81c22;
  border-radius: 50%;
  left: -58.5px;
  top: 3.25px;
  border: 3px solid #b81c22;
}

#agenda .agenda-list .agenda-list-box b {
  font-size: clamp(15px, 3vw, 18px);
  padding: 2px 10px;
  border: 1px solid #332c69;
  background-color: transparent;
  color: #332c69;
  border-radius: 4px;
  width: 60px;
  height: 25px;
  line-height: 25px;
  text-align: center;
}

#agenda .agenda-list .agenda-list-box span.s-text {
  padding-right: 4px;
}

#agenda .agenda-list .agenda-list-box span.s-text,
#agenda .agenda-list .agenda-list-box span.s-name {
  color: #151515;
  font-size: clamp(15px, 3vw, 18px);
}

#agenda .agenda-list .agenda-list-box .without-title {
  padding-left: 92px;
}

#agenda .agenda-bk {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: linear-gradient(180deg, #f3f1f8 0%, #dddcf0 100%);
  overflow: hidden;
  opacity: 1 !important;
}

#agenda .agenda-bk::before,
#agenda .agenda-bk::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  opacity: 0;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

#agenda .agenda-bk::before {
  background-image: url("../images/agenda-bg-top.png");
  background-position: left top;
  background-size: 100%;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
}

#agenda .agenda-bk::after {
  background-image: url("../images/agenda-bg-bottom.png");
  background-position: right bottom;
  background-size: 100%;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 50%;
}

#agenda.active .agenda-bk::before {
  -webkit-animation: slideFadeInTop 0.8s ease-out forwards;
  animation: slideFadeInTop 0.8s ease-out forwards;
}

#agenda.active .agenda-bk::after {
  -webkit-animation: slideFadeInBottom 0.8s ease-out forwards;
  animation: slideFadeInBottom 0.8s ease-out forwards;
  -webkit-animation-delay: 0.2s;
  animation-delay: 0.2s;
}

/* #agenda RWD */
@media (min-width: 768px) {
  #agenda {
    padding-top: 100px;
    padding-bottom: 330px;
  }

  #agenda .agenda-list li i {
    width: 160px;
  }

  #agenda .agenda-list .agenda-list-box.agenda-list-box-flex {
    align-items: center;
  }

  #agenda .agenda-list .agenda-list-box > h4 > .agenda-list-name {
    width: 100%;
  }

  #agenda .agenda-list .agenda-list-box b {
    width: 80px;
  }

  #agenda .agenda-bk::before,
  #agenda .agenda-bk::after {
    background-size: 60%;
  }
}

@media (min-width: 768px) and (max-width: 960px) {
  #agenda .agenda-list .agenda-list-box {
    margin-left: 65px;
  }

  #agenda .agenda-list li i:before {
    right: -16.5px;
    top: 20px;
  }

  #agenda .agenda-list .agenda-list-box::after {
    top: 3px;
  }

  #agenda .agenda-list .agenda-list-box span.s-name,
  #agenda .agenda-list .agenda-list-box span.s-text {
    font-size: 18px;
  }
}

@media (min-width: 1280px) {
  #agenda {
    padding-bottom: 100px;
  }

  #agenda .agenda-list li * {
    font-size: 20px;
  }

  #agenda .agenda-list li i:before {
    right: -50px;
  }

  #agenda .agenda-left {
    left: 0%;
    bottom: 0;
    top: auto;
  }

  #agenda .agenda-right {
    right: 0%;
    top: 0;
    bottom: auto;
  }

  #agenda.active .agenda-left {
    height: auto;
    top: 0%;
    left: -10%;
  }

  #agenda.active .agenda-right {
    height: auto;
    top: 0%;
    right: 0%;
  }

  #agenda .agenda-bk::before,
  #agenda .agenda-bk::after {
    width: 100%;
    height: 100%;
    background-size: 20%;
    top: 0;
  }

  #agenda .agenda-bk::before {
    background-image: url("../images/agenda-bg-left.png");
    background-position: left bottom;
  }

  #agenda .agenda-bk::after {
    background-image: url("../images/agenda-bg-right.png");
    background-position: right top;
  }

  #agenda.active .agenda-bk::before {
    -webkit-animation: slideFadeInLeft 0.8s ease-out forwards;
    animation: slideFadeInLeft 0.8s ease-out forwards;
  }

  #agenda.active .agenda-bk::after {
    -webkit-animation: slideFadeInRight 0.8s ease-out forwards;
    animation: slideFadeInRight 0.8s ease-out forwards;
    -webkit-animation-delay: 0.2s;
    animation-delay: 0.2s;
  }
}

@media (min-width: 1680px) {
  #agenda.active .agenda-left {
    left: 0%;
  }


  #agenda.active .agenda-right {
    right: 0%;
  }
}

@media (min-width: 1750px) {

  #agenda .agenda-bk::before,
  #agenda .agenda-bk::after {
    background-size: contain;
  }

}
@media (max-width: 1750px) {
  #agenda.active .agenda-left {
    left: -10%;
  }

  #agenda.active .agenda-right {
    right: -10%;
  }
}

@media (max-width: 1600px) {
  #agenda.active .agenda-left-bottom-m {
    left: -25%;
  }
}

@media (max-width: 1470px) {
  #agenda.active .agenda-left {
    left: -15%;
  }

  #agenda.active .agenda-right {
    right: -15%;
  }
}

@media (max-width: 1260px) {
  #agenda.active .agenda-left {
    left: -50%;
  }

  #agenda.active .agenda-right {
    right: -15%;
  }
}

@media (max-width: 1024px) {
  #agenda.active .agenda-left-bottom-m {
    left: -25%;
    bottom: -37%;
    width: 69%;
  }
}

@media (max-width: 980px) {
  #agenda .agenda-left,
  #agenda .agenda-right {
    display: none;
  }
}

@media (max-width: 680px) {
  #agenda .agenda-list li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 30px;
  }

  #agenda .agenda-list li i:before {
    height: 1124%;
    left: -28px;
  }

  #agenda .agenda-list .agenda-list-box {
    margin-left: 0;
  }

  #agenda .agenda-list .agenda-list-box:before {
    left: -40px;
    top: -22px;
  }
}

@media (max-width: 680px) {
  #agenda .agenda-list li i {
    width: 200px;
  }

  #agenda .agenda-list .agenda-list-box::after {
    left: -35px;
    top: -22px;
  }
}

@media (max-width: 480px) {
  #agenda.active .agenda-left-bottom-m {
    bottom: -17%;
    left: -70%;
  }
}

@media (max-width: 360px) {
  #agenda .agenda-list li i:before {
    height: 1050%;
  }
}

/* --- #survey & #surveyresult & #surveyyear --- */
#survey {
  background: url(../images/survey_bg.png) center center no-repeat;
  background-size: cover;
  padding-top: 140px;
  padding-bottom: 90px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#survey .title span,
#survey .title b {
  color: #ffffff;
}

#survey h2.title::after {
  background: #1e6674;
}

#survey h3 {
  font-size: 30px;
  font-weight: bold;
  color: #1e6674;
  text-align: center;
  margin-top: 20px;
}

#survey .btns {
  margin-top: 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

#survey .btns li {
  display: block;
}

#survey .btns a {
  background: #1e6674;
  color: #fff;
}

#survey .btns a:hover {
  background: #9e7830;
  color: #fff;
}

#surveyresult .tab_container,
#surveyyear .tab_container {
  max-width: 830px;
  margin: auto;
}

#surveyresult h3,
#surveyyear h3 {
  font-size: 40px;
  font-weight: bold;
  padding: 10px;
}

#surveyresult h5,
#surveyyear h5 {
  font-size: 18px;
  color: #fff;
  text-align: center;
  padding: 10px;
  margin: 20px 0;
  clear: both;
}

#surveyresult h5.green,
#surveyyear h5.green {
  background-color: #f6ab36;
}

#surveyresult h5.blue,
#surveyyear h5.blue {
  background-color: #03c9a8;
}

#surveyresult .tab_content#leading,
#surveyresult .tab_content#leading_lastyear,
#surveyyear .tab_content#leading,
#surveyyear .tab_content#leading_lastyear {
  text-align: left;
  max-width: 1000px;
}

#surveyresult .tab_content#leading p,
#surveyresult .tab_content#leading_lastyear p,
#surveyyear .tab_content#leading p,
#surveyyear .tab_content#leading_lastyear p {
  font-size: 18px;
}

#surveyresult .tab_content#leading ul li,
#surveyresult .tab_content#leading_lastyear ul li,
#surveyyear .tab_content#leading ul li,
#surveyyear .tab_content#leading_lastyear ul li {
  margin: 25px 0;
}

#surveyresult .tab_content#leading ul li b,
#surveyresult .tab_content#leading_lastyear ul li b,
#surveyyear .tab_content#leading ul li b,
#surveyyear .tab_content#leading_lastyear ul li b {
  font-size: 22px;
  margin-bottom: 5px;
  display: block;
  font-weight: bold;
}

#surveyresult .tab_content#leading ul li b img,
#surveyresult .tab_content#leading_lastyear ul li b img,
#surveyyear .tab_content#leading ul li b img,
#surveyyear .tab_content#leading_lastyear ul li b img {
  display: inline-block;
  vertical-align: middle;
  margin-right: 5px;
}

#surveyresult .tab_content#government ul,
#surveyresult .tab_content#government_lastyear ul,
#surveyresult .tab_content#people ul,
#surveyresult .tab_content#people_lastyear ul,
#surveyresult .tab_content#people_2_lastyear ul,
#surveyyear .tab_content#government ul,
#surveyyear .tab_content#government_lastyear ul,
#surveyyear .tab_content#people ul,
#surveyyear .tab_content#people_lastyear ul,
#surveyyear .tab_content#people_2_lastyear ul {
  display: inline-block;
  width: 100%;
  margin-top: 30px;
}

#surveyresult .tab_content#government ul li,
#surveyresult .tab_content#government_lastyear ul li,
#surveyresult .tab_content#people ul li,
#surveyresult .tab_content#people_lastyear ul li,
#surveyresult .tab_content#people_2_lastyear ul li,
#surveyyear .tab_content#government ul li,
#surveyyear .tab_content#government_lastyear ul li,
#surveyyear .tab_content#people ul li,
#surveyyear .tab_content#people_lastyear ul li,
#surveyyear .tab_content#people_2_lastyear ul li {
  width: 47.91667%;
  float: left;
  margin-left: 1.04167%;
  margin-right: 1.04167%;
  margin-bottom: 20px;
}

#surveyresult .tab_content#government ul li img,
#surveyresult .tab_content#government_lastyear ul li img,
#surveyresult .tab_content#people ul li img,
#surveyresult .tab_content#people_lastyear ul li img,
#surveyresult .tab_content#people_2_lastyear ul li img,
#surveyyear .tab_content#government ul li img,
#surveyyear .tab_content#government_lastyear ul li img,
#surveyyear .tab_content#people ul li img,
#surveyyear .tab_content#people_lastyear ul img,
#surveyyear .tab_content#people_2_lastyear ul li img {
  margin: auto;
}

#surveyresult .tab_content#government ul.boxlist,
#surveyresult .tab_content#government_lastyear ul.boxlist,
#surveyresult .tab_content#people ul.boxlist,
#surveyresult .tab_content#people_lastyear ul.boxlist,
#surveyresult .tab_content#people_2_lastyear ul.boxlist,
#surveyyear .tab_content#government ul.boxlist,
#surveyyear .tab_content#government_lastyear ul.boxlist,
#surveyyear .tab_content#people ul.boxlist,
#surveyyear .tab_content#people_lastyear ul.boxlist,
#surveyyear .tab_content#people_2_lastyear ul.boxlist {
  margin-top: 0;
}

#surveyresult .tab_content#government ul.boxlist li,
#surveyresult .tab_content#government_lastyear ul.boxlist li,
#surveyresult .tab_content#people ul.boxlist li,
#surveyresult .tab_content#people_lastyear ul.boxlist li,
#surveyresult .tab_content#people_2_lastyear ul.boxlist li,
#surveyyear .tab_content#government ul.boxlist li,
#surveyyear .tab_content#government_lastyear ul.boxlist li,
#surveyyear .tab_content#people ul.boxlist li,
#surveyyear .tab_content#people_lastyear ul.boxlist li,
#surveyyear .tab_content#people_2_lastyear ul.boxlist li {
  margin: 0;
}

#surveyresult .tab_content#government p,
#surveyresult .tab_content#government_lastyear p,
#surveyresult .tab_content#people p,
#surveyresult .tab_content#people_lastyear p,
#surveyresult .tab_content#people_2_lastyear p,
#surveyyear .tab_content#government p,
#surveyyear .tab_content#government_lastyear p,
#surveyyear .tab_content#people p,
#surveyyear .tab_content#people_lastyear p,
#surveyyear .tab_content#people_2_lastyear p {
  font-size: 13px;
  font-weight: bold;
  margin: 10px auto;
  max-width: 356px;
  width: 100%;
  display: table;
}

#surveyresult .tab_content#people ul li,
#surveyresult .tab_content#people_lastyear ul li,
#surveyresult .tab_content#people_2_lastyear ul li,
#surveyyear .tab_content#people ul li,
#surveyyear .tab_content#people_lastyear ul li,
#surveyyear .tab_content#people_2_lastyear ul li {
  width: 97.91667%;
  float: left;
  margin-left: 1.04167%;
  margin-right: 1.04167%;
  font-size: 20px;
}

#surveyresult .tab_content table,
#surveyyear .tab_content table {
  max-width: 356px;
  width: 100%;
  border-collapse: inherit;
  border-spacing: 1px;
  margin: auto;
}

#surveyresult .tab_content table th,
#surveyresult .tab_content table td,
#surveyyear .tab_content table th,
#surveyyear .tab_content table td {
  padding: 6px 15px;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
}

#surveyresult .tab_content table thead th,
#surveyyear .tab_content table thead th {
  background: #ffedde;
}

#surveyresult .tab_content table tbody th,
#surveyyear .tab_content table tbody th {
  background: #ffdfc3;
}

#surveyresult .tab_content table tbody td,
#surveyyear .tab_content table tbody td {
  background: #eaeaea;
}

#surveyi03 ul,
.surveyi03 ul {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

#surveyi03 ul li,
.surveyi03 ul li {
  width: 32%;
  display: inline-block;
  vertical-align: top;
  margin: 10px 0;
}

#surveyi03 ul:after,
.surveyi03 ul:after {
  content: "";
  -webkit-box-flex: 1;
  -ms-flex: auto;
  flex: auto;
}

#surveyi03 figure img,
.surveyi03 figure img {
  margin: auto;
}

#surveyi03 figcaption b,
.surveyi03 figcaption b {
  font-size: 22px;
  display: block;
}

#surveyi03 figcaption span,
.surveyi03 figcaption span {
  display: inline-block;
}

/* #survey RWD */
@media (min-width: 480px) {
  #survey h3 br {
    display: none;
  }
}

@media (max-width: 880px) {
  #surveyresult .tab_content#government ul li,
  #surveyresult .tab_content#people ul li,
  #surveyyear .tab_content#government ul li,
  #surveyyear .tab_content#people ul li {
    width: 97.91667%;
    float: left;
    margin-left: 1.04167%;
    margin-right: 1.04167%;
  }
}

@media (max-width: 768px) {
  #survey .btns a {
    width: 190px;
  }
}

@media (max-width: 700px) {
  #survey {
    padding-top: 40%;
    padding-bottom: 40%;
  }

  #survey .btns {
    margin-top: 40px;
  }

  #survey.active .survey-left {
    left: -12%;
    top: 12px;
    width: 46%;
  }

  #survey.active .survey-right {
    right: 0;
    bottom: 0;
    width: 47%;
  }

  #surveyi03 ul li,
  .surveyi03 ul li {
    width: 48%;
  }
}

@media (max-width: 480px) {
  #survey .btns {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  #survey .btns a {
    width: 250px;
  }
}

/* --- #vote & #voteway & #award --- */
#vote {
  background-color: #1e6674;
  position: relative;
  padding-top: 120px;
  padding-bottom: 90px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#vote .btns {
  margin-top: 70px;
  margin-left: -10px;
}

#vote:before {
  display: block;
  width: 45%;
  height: 100%;
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0;
  -webkit-transition: all 1s;
  transition: all 1s;
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 80% auto;
}

#vote h3 {
  font-size: 30px;
  font-weight: bold;
  color: #ffffff;
  text-align: center;
  margin-top: 20px;
}

#voteway ul.way1 {
  max-width: 580px;
  margin: auto;
}

#voteway ul.way1 li i {
  display: inline-block;
  vertical-align: middle;
  width: 140px;
  height: 140px;
  background: #f6ab36;
  text-align: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 30px;
  line-height: 33px;
  padding: 35px;
  color: #fff;
  font-weight: bold;
  border-radius: 50%;
}

#voteway ul.way1 li i.big {
  padding: 35px 24px;
}

#voteway ul.way1 li p {
  display: inline-block;
  vertical-align: middle;
  width: calc(100% - 160px);
  margin-left: 10px;
  font-size: 20px;
}

#voteway ul.way1 li p span {
  display: block;
  font-size: 20px;
}

#voteway ul.way1 li + li {
  margin-top: 20px;
}

#voteway ul.way1 li + li i {
  background: #03c9a8;
}

#voteway ul.way2 {
  margin: 20px 0;
  text-align: center;
}

#voteway ul.way2 li {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  padding: 10px 20px;
}

#voteway ul.way2 li > div {
  display: inline-block;
  vertical-align: middle;
  width: 180px;
  height: 180px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 3px solid #1cbbc5;
  text-align: center;
  border-radius: 50%;
  padding: 20px;
}

#voteway ul.way2 li > div i {
  display: table;
  margin: 0 auto 5px auto;
}

#voteway ul.way2 li > div p {
  font-size: 22px;
}

#voteway ul.way2 li > div p span {
  font-size: 22px;
  display: block;
}

#voteway ul.way2 li + li:before {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  left: -11px;
  top: 50%;
  margin-top: -11px;
  background: url(../images/way2icon.png) center center no-repeat;
}

#voteway .way3 {
  margin: 20px 0;
  text-align: center;
}

#voteway .way3 .percent {
  display: inline-block;
  vertical-align: middle;
}

#voteway .way3 .percent li {
  width: 100%;
}

#voteway .way3 .percent li div {
  display: inline-block;
  vertical-align: middle;
}

#voteway .way3 .percent li span {
  display: inline-block;
  vertical-align: middle;
  font-size: 35px;
  margin: 0 10px;
}

#voteway .way3 .percent li > div.tt {
  font-size: 22px;
  width: 140px;
  min-width: 350px;
  background: #f6ab36;
  text-align: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 35px;
  color: #fff;
  font-weight: bold;
  border-radius: 10px;
}

#voteway .way3 .percent li + li {
  margin-top: 15px;
}

#voteway .way3 .percent li + li > div.tt {
  background: #03c9a8;
}

#voteway .way3 .total {
  display: inline-block;
  vertical-align: middle;
}

#voteway .way3 .total div {
  display: inline-block;
  vertical-align: middle;
}

#voteway .way3 .total div.score {
  font-size: 36px;
  width: 120px;
  height: 120px;
  color: #fff;
  background: #f54746;
  border-radius: 50%;
  text-align: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 35px 0;
}

#voteway ul.award {
  width: 90%;
  margin: auto;
  max-width: 900px;
}

#voteway ul.award li {
  background: #f0f0f0;
  padding: 15px;
  position: relative;
}

#voteway ul.award li + li {
  margin-top: 15px;
}

#voteway ul.award figure {
  display: inline-block;
  vertical-align: top;
  width: 250px;
}

#voteway ul.award figcaption {
  padding-bottom: 30px;
  display: inline-block;
  vertical-align: top;
  width: calc(100% - 280px);
  margin-left: 20px;
}

#voteway ul.award figcaption b {
  font-size: 26px;
  font-weight: bold;
  margin: 15px 0;
  display: block;
}

#voteway ul.award figcaption p {
  font-size: 18px;
}

#voteway ul.award figcaption span {
  color: #4c78be;
  position: absolute;
  left: 290px;
  bottom: 12px;
}

#voteway ul.award figcaption span b {
  display: inline;
  color: #4c78be;
  font-size: 14px;
}

#award {
  position: relative;
  background: url(../images/award_bg.png) center bottom no-repeat;
  background-size: 100% 100%;
  z-index: 1;
}

#award.active:before {
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
}

#award .car {
  width: 100%;
  height: 58px;
  position: absolute;
  bottom: 7px;
}

#award .car figure {
  display: block;
  width: 443px;
  height: 50px;
  background: url(../images/train.png) center center no-repeat;
  -webkit-animation: car 12s linear infinite;
  animation: car 12s linear infinite;
}

#award .btns {
  margin-top: 70px;
}

#award .btns a {
  background: #9e7830;
}

#award .btns a:hover {
  background: #27a038;
}

#award.active:before,
#award.active:after {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
}

#awardway {
  max-width: 1000px;
}

#awardname ul.list {
  max-width: 1000px;
  text-align: center;
}

#awardname ul.list li {
  display: inline-block;
  vertical-align: top;
  width: 30%;
  padding: 10px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin-bottom: 20px;
}

#awardname ul.list li figcaption {
  text-align: left;
}

#awardname ul.list li figcaption i {
  margin: 5px 0;
  display: block;
  font-size: 22px;
}

#awardname ul.list li figcaption i img {
  display: inline-block;
  vertical-align: middle;
  margin-top: -3px;
  margin-right: 5px;
}

#awardname ul.list li figcaption b {
  display: block;
  font-size: 26px;
  font-weight: bold;
  margin: 10px 0;
  min-height: 85px;
}

#awardname ul.list li figcaption b span {
  display: block;
  font-size: 18px;
  font-weight: normal;
}

#awardname ul.list li figcaption p {
  font-size: 16px;
}

#awardname ul.list li.a1 i {
  color: #e65b5d;
}

#awardname ul.list li.a2 i {
  color: #5f6fb2;
}

#awardname ul.list li.a3 i {
  color: #125caa;
}

#awardname ul.list li.a4 i {
  color: #e45a7f;
}

#awardname ul.list li.a5 i {
  color: #62b54d;
}

#awardname ul.list li.a6 i {
  color: #f29d0b;
}

#awardname ul.list li.a7 i {
  color: #ec8622;
}

#awardname ul.list li.a8 i {
  color: #388d38;
}

#awardname ul.list li.a9 i {
  color: #2bb6fb;
}

/* #vote & #award RWD */
@media (min-width: 480px) {
  #vote h3 br {
    display: none;
  }
}

@media (max-width: 1024px) {
  #award {
    padding: 5% 0 16%;
  }

  #award:before {
    background-size: 46%;
    background-position: 0% 90%;
  }

  #award:after {
    background-position: 100% 8%;
    background-size: 40%;
  }
}

@media (max-width: 980px) {
  #awardname ul.list li {
    width: 47%;
  }
}

@media (max-width: 880px) {
  #voteway .way3 .percent li > div.tt {
    min-width: 250px;
  }

  #voteway .way3 .percent li + li:before {
    content: "+";
    font-size: 50px;
    display: table;
    margin: auto;
  }

  #voteway .way3 .total {
    display: block;
  }

  #voteway .way3 .total div {
    display: table;
    margin: auto;
  }

  #voteway .way3 .total div img {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
  }
}

@media (max-width: 768px) {
  #award:before {
    background-size: 62%;
    background-position: -24% 95%;
  }

  #award:after {
    background-position: 130% 6%;
    background-size: 50%;
  }
}

@media (max-width: 700px) {
  #voteway ul.award figure {
    width: 100%;
  }

  #voteway ul.award figure img {
    margin: auto;
  }

  #voteway ul.award figcaption {
    width: 100%;
    margin-left: 0px;
  }

  #voteway ul.award figcaption span {
    left: 12px;
  }
}

@media (max-width: 560px) {
  #vote {
    padding-bottom: 120px;
  }

  #vote:before {
    left: -20%;
  }
}

@media (max-width: 700px) and (max-width: 550px) {
  #voteway ul.way2 {
    max-width: 500px;
    margin: auto;
  }

  #voteway ul.way2 li {
    max-width: 240px;
    margin-bottom: 10px;
  }

  #voteway ul.way2 li + li:before {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    top: -4px;
    left: 50%;
    margin-left: -11px;
  }

  #voteway ul.way2 li + li:nth-child(3):before {
    display: block;
  }

  #voteway .way3 .percent li > div.tt {
    min-width: 100%;
    padding: 10px;
    margin-bottom: 5px;
  }

  #voteway .way3 .total {
    display: block;
  }

  #voteway .way3 .total div {
    display: table;
    margin: auto;
  }

  #voteway .way3 .total div img {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
  }
}

@media (max-width: 700px) and (max-width: 400px) {
  #voteway ul.way1 li i {
    display: table;
    margin: auto;
  }

  #voteway ul.way1 li p {
    display: table;
    margin: auto;
    width: 100%;
    text-align: center;
  }
}

/* --- #book --- */
.book-nav {
  position: fixed;
  bottom: 150px;
  right: 10px;
  z-index: 1;
  width: 60px;
}

#book {
  padding-top: 100px;
  padding-bottom: 80px;
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 1;
  background: linear-gradient(180deg, #f3f1f8 0%, #dddcf0 100%);
}

#book .title span {
}

#book .book-film {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 40px;
  border: 11px solid #9e006d;
  position: relative;
  z-index: 2;
}

#book .book-bk {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  overflow: hidden;
  opacity: 1 !important;
}

#book .book-bk::before,
#book .book-bk::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  opacity: 0;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

#book .book-bk::before {
  background-image: url("../images/book-bg-top.png");
  background-position: center top;
  background-size: 100%;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
}

#book .book-bk::after {
  background-image: url("../images/book-bg-bottom.png");
  background-position: center bottom;
  background-size: 100%;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50%;
}

#book.active .book-bk::before {
  -webkit-animation: slideFadeInTop 0.8s ease-out forwards;
  animation: slideFadeInTop 0.8s ease-out forwards;
}

#book.active .book-bk::after {
  -webkit-animation: slideFadeInBottom 0.8s ease-out forwards;
  animation: slideFadeInBottom 0.8s ease-out forwards;
  -webkit-animation-delay: 0.3s;
  animation-delay: 0.3s;
}

#book .book-container {
  max-width: 1100px;
  width: 90%;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 5;
}

#book .title-decoration {
  position: absolute;
  width: 340px;
  height: 90px;
  background: radial-gradient(ellipse at center, rgba(171, 35, 126, 0.9) 0%, rgba(85, 17, 63, 0) 70%);
  border-radius: 50%;
  z-index: 1;
}

#book .book-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  gap: 60px;
  margin-top: 5rem;
}

#book .book-visual {
  text-align: right;
  margin: 0;
}

#book .book-visual img {
  max-width: 100%;
  height: auto;
  -webkit-filter: drop-shadow(10px 20px 25px rgba(0, 0, 0, 0.5));
  filter: drop-shadow(10px 20px 25px rgba(0, 0, 0, 0.5));
}

#book .book-info {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 55%;
  flex: 0 0 55%;
  text-align: left;
}

#book .pre-title {
  font-size: 20px;
  color: #e59ad8;
  margin-bottom: 5px;
  letter-spacing: 2px;
}

#book .main-title {
  font-size: clamp(36px, 5vw, 50px);
  font-weight: bold;
  color: #f39800;
  margin-bottom: 20px;
  margin-left: -10px;
}

#book .divider {
  border: none;
  height: 2px;
  background-color: #f39800;
  width: 100%;
  margin-bottom: 25px;
}

#book .desc-text {
  margin-bottom: 40px;
}

#book .desc-text p {
  font-size: clamp(16px, 3vw, 16.8px);
  line-height: 1.8;
  color: #ffffff;
  margin-bottom: 10px;
  text-align: justify;
}

/* #book RWD */
@media (min-width: 768px) {
  .book-nav {
    bottom: 260px;
    width: 120px;
    right: 20px;
  }
}

@media (min-width: 1280px) {
  #book {
    padding-top: 100px;
    padding-bottom: 100px;
  }

  #book .book-bk::before,
  #book .book-bk::after {
    width: 100%;
    height: 100%;
    background-size: contain;
    top: 0;
    bottom: auto;
  }

  #book .book-bk::before {
    background-image: url("../images/book-bg-left.png");
    background-position: left center;
    left: 0;
  }

  #book .book-bk::after {
    background-image: url("../images/book-bg-right.png");
    background-position: right center;
    right: 0;
    left: auto;
  }

  #book.active .book-bk::before {
    -webkit-animation: slideFadeInLeft 0.8s ease-out forwards;
    animation: slideFadeInLeft 0.8s ease-out forwards;
  }

  #book.active .book-bk::after {
    -webkit-animation: slideFadeInRight 0.8s ease-out forwards;
    animation: slideFadeInRight 0.8s ease-out forwards;
    -webkit-animation-delay: 0.3s;
    animation-delay: 0.3s;
  }
}

@media (max-width: 980px) {
  #book .book-content {
    gap: 30px;
  }

  #book .section-title h2 {
    font-size: 32px;
  }

  #book .title-decoration {
    width: 280px;
  }
}

@media (max-width: 768px) {
  #book .book-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    text-align: center;
  }

  #book .book-visual {
    text-align: center;
    margin-bottom: 30px;
  }

  #book .book-content .book-visual > img {
    width: 50%;
    margin: 0 auto;
    max-width: 500px;
  }

  #book .book-info {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  #book .main-title {
    margin-left: 0;
  }
}

/* --- #video --- */
#video {
  background-color: #622435;
  position: relative;
  padding-top: 90px;
  padding-bottom: 140px;
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  min-height: auto !important;
}

#video .title span {
}

#video .video-film {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 40px;
  border: 11px solid #B81C22;
}

#video .list {
  display: inline-block;
  width: 100%;
  text-align: center;
  margin-top: 40px;
}

#video .list li {
  margin-bottom: 10px;
  display: inline-block;
  vertical-align: top;
  width: 24%;
  padding: 5px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

#video .list li figcaption {
  padding-top: 10px;
  text-align: left;
  font-size: 18px;
}

#video .list li figcaption b {
  display: block;
  font-size: 20px;
  font-weight: bold;
}

#video .list li figcaption b div {
  font-size: 18px;
}

#video .btns {
  margin-top: 20px;
}

#video .btns a {
  background: #9e7830;
}

#video .btns a:hover {
  background: #27a038;
}

#video .video-bk {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: linear-gradient(180deg, #f3f1f8 0%, #dddcf0 100%);
  overflow: hidden;
  opacity: 1 !important;
}

#video .video-bk::before,
#video .video-bk::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  opacity: 0;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

#video .video-bk::before {
  background-image: url("../images/video-bg-top.png");
  background-position: left top;
  background-size: 100%;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
}

#video .video-bk::after {
  background-image: url("../images/video-bg-bottom.png");
  background-position: right bottom;
  background-size: 100%;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 50%;
}

#video.active .video-bk::before {
  -webkit-animation: slideFadeInTop 0.8s ease-out forwards;
  animation: slideFadeInTop 0.8s ease-out forwards;
}

#video.active .video-bk::after {
  -webkit-animation: slideFadeInBottom 0.8s ease-out forwards;
  animation: slideFadeInBottom 0.8s ease-out forwards;
  -webkit-animation-delay: 0.2s;
  animation-delay: 0.2s;
}

/* #video RWD */
@media (min-width: 1280px) {
  #video .video-bk::before,
  #video .video-bk::after {
    width: 100%;
    height: 100%;
    background-size: contain;
    top: 0;
  }

  #video .video-bk::before {
    background-image: url("../images/video-bg-left.png");
    background-position: left bottom;
  }

  #video .video-bk::after {
    background-image: url("../images/video-bg-right.png");
    background-position: right top;
  }

  #video.active .video-bk::before {
    -webkit-animation: slideFadeInLeft 0.8s ease-out forwards;
    animation: slideFadeInLeft 0.8s ease-out forwards;
  }

  #video.active .video-bk::after {
    -webkit-animation: slideFadeInRight 0.8s ease-out forwards;
    animation: slideFadeInRight 0.8s ease-out forwards;
    -webkit-animation-delay: 0.2s;
    animation-delay: 0.2s;
  }
}

@media (max-width: 980px) {
  #video {
    min-height: auto !important;
  }

  #video .video-left {
    left: -50%;
    top: -50%;
  }

  #video .video-film {
    margin-bottom: 40px;
  }

  #video:before,
  #video:after {
    background-size: 120% auto;
  }

  #video ul.list li {
    width: 48%;
  }
}

@media (max-width: 767px) {
  #video {
    min-height: auto !important;
  }
}

@media (max-width: 480px) {
  #video {
    padding-top: 40px;
    padding-bottom: 60px;
  }

  #video.active .video-left,
  #video.active .video-right {
    display: none;
  }
}



/* ==========================================================================
   區塊：Note (#note) 主容器
   ========================================================================== */
#note {
  background: linear-gradient(180deg, #f3f1f8 0%, #dddcf0 100%);
  padding-top: 60px;
  padding-bottom: 180px;
  min-height: auto !important;

  position: relative; /* 確保內部的 .note-bk 可以絕對定位滿版 */
  z-index: 1;
  overflow: hidden; /* 防止滑入動畫產生卷軸 */
}

#note h3 {
    color: #B81C22;
    font-size: clamp(16px, 3vw, 18px);
    font-weight:bold;
}

#note .sp-text > p {
  text-decoration: underline;
  text-underline-offset: 3px;
}

#note .sp-text > p,
#note .sp-text > i {
  color: #ffbd60 !important;
}

#note .title {
  margin-bottom: 60px;
}

#note .title span {
}

#note .list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 16px 0;
}

#note .list li i {
  width: 20px;
}

#note .list * {
  color: #000000;
  font-size: 16px;
}

/* ==========================================================================
   Note 背景與分開滑入動畫 (.note-bk)
   ========================================================================== */

/* 1. 背景容器設為絕對定位，鋪滿 #note */
#note .note-bk {
 
}

/* 2. 共用偽元素設定 (負責兩側滑入的裝飾圖) */
#note .note-bk::before,
#note .note-bk::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  opacity: 0; /* 預設全透明 */
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

/* --- 3. 手機版預設：上下圖片、上下滑入 --- */
#note .note-bk::before {
  background-image: url("../images/note-xs-top.png"); /* 請替換為實際圖檔名 */
  background-position: left top;
  background-size: 100%;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
}

#note .note-bk::after {
  background-image: url("../images/note-xs-bottom.png"); /* 請替換為實際圖檔名 */
  background-position: right bottom;
  background-size: 100%;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 50%;
}

/* 加上 active 觸發手機版動畫 */
#note.active .note-bk::before {
  -webkit-animation: slideFadeInTop 0.8s ease-out forwards;
  animation: slideFadeInTop 0.8s ease-out forwards;
}

#note.active .note-bk::after {
  -webkit-animation: slideFadeInBottom 0.8s ease-out forwards;
  animation: slideFadeInBottom 0.8s ease-out forwards;
  -webkit-animation-delay: 0.2s; /* 下半圖晚 0.2 秒出現 */
  animation-delay: 0.2s;
}

/* --- 4. 桌機版 (1280px 以上)：左右圖片、左右滑入 --- */
@media (min-width: 1280px) {
  #note .note-bk::before,
  #note .note-bk::after {
    width: 100%;
    height: 100%;
    background-size: contain; /* 依據你的視覺圖改成適當比例 */
    top: 0;
    bottom: auto;
  }

  /* 左邊背景圖 */
  #note .note-bk::before {
    background-image: url("../images/note-xs-top.png"); /* 請替換為實際圖檔名 */
    background-position: left center;
    left: 0;
  }

  /* 右邊背景圖 */
  #note .note-bk::after {
    background-image: url("../images/note-xs-bottom.png"); /* 請替換為實際圖檔名 */
    background-position: right center;
    right: 0;
    left: auto;
  }

  /* 觸發桌機版動畫 (覆寫手機版的動畫，改為左右滑入) */
  #note.active .note-bk::before {
    -webkit-animation: slideFadeInLeft 0.8s ease-out forwards;
    animation: slideFadeInLeft 0.8s ease-out forwards;
  }

  #note.active .note-bk::after {
    -webkit-animation: slideFadeInRight 0.8s ease-out forwards;
    animation: slideFadeInRight 0.8s ease-out forwards;
    -webkit-animation-delay: 0.2s;
    animation-delay: 0.2s;
  }
}


/* --- #unit --- */
#unit {
  background: url(../images/unit-bg.png) center center no-repeat;
  background-size: cover;
  padding-top: 80px;
  padding-bottom: 150px;
  position: relative;
}

#unit .title {
  margin: 0 auto 3rem;
}

#unit .title::after {
  background: #27a038;
}

#unit ul {
  text-align: center;
  width: auto;
  display: table;
  margin: auto;
}

#unit ul li {
  margin: 10px;
  width: 31.25%;
  float: left;
  margin-left: 1.04167%;
  margin-right: 1.04167%;
}

#unit ul li img {
  margin: auto;
  border: 1px solid #ccc;
}

#unit ul.one li {
  width: 100%;
}

#unit ul.two li {
  width: 47.91667%;
  float: left;
  margin-left: 1.04167%;
  margin-right: 1.04167%;
}

#unit ul.four li {
  width: 22.91666%;
}

#unit ul.five li {
  width: 17.91666%;
}

#unit .airplane {
  position: absolute;
  right: 10%;
  top: 5%;
}

/* #unit RWD */
@media (max-width: 768px) {
  #unit ul.five li {
    width: 47.91667%;
  }

  #unit .airplane {
    display: none;
  }
}

@media (max-width: 480px) {
  #unit ul.one li img {
    width: 186px;
  }
}

/* --- #report --- */
#report {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  background-color: #b18739;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

#report .con {
  -webkit-box-flex: 1;
  -ms-flex: 1 0 auto;
  flex: 1 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#report h4 {
  margin-bottom: 40px;
}

#report ul.list {
  display: inline-block;
  width: 100%;
  vertical-align: top;
  margin: 15px 0;
}

#report ul.list li {
  float: left;
  width: 25%;
  margin-bottom: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 2px;
}

#report ul.list li a {
  display: block;
  text-align: center;
}

#report ul.list li a figure {
  overflow: hidden;
}

#report ul.list li a figure img {
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
  -webkit-transform: scale(1);
  transform: scale(1);
}

#report ul.list li a figcaption {
  margin: 10px 0;
  font-size: 20px;
}

#report ul.list li a:hover figure img {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}

#report ul.list li a:hover figcaption {
  color: #1cbbc5;
}

/* #report RWD */
@media (max-width: 980px) {
  #report .con {
    margin: 100px 0 40px;
  }

  #report ul.list li {
    width: 50%;
  }
}

@media (max-width: 480px) {
  #report ul.list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
