@charset "UTF-8";
.quad-width {
  display: inline-block;
  padding: 10px;
  margin: 0px;
  width: calc(100% - 20px);
  -webkit-transition: height 0.5s ease;
  transition: height 0.5s ease;
  -webkit-transition: width 0.5s ease;
  transition: width 0.5s ease; }
  @media only screen and (min-width: 360px) {
    .quad-width {
      width: calc(100% - 20px); } }
  @media only screen and (min-width: 600px) {
    .quad-width {
      width: calc(50% - 20px); } }
  @media only screen and (min-width: 1366px) {
    .quad-width {
      width: calc(25% - 20px); } }

.half-width {
  display: inline-block;
  padding: 10px;
  margin: 0px;
  width: calc(100% - 20px);
  -webkit-transition: height 0.5s ease;
  transition: height 0.5s ease;
  -webkit-transition: width 0.5s ease;
  transition: width 0.5s ease; }
  @media only screen and (min-width: 360px) {
    .half-width {
      width: calc(100% - 20px); } }
  @media only screen and (min-width: 600px) {
    .half-width {
      width: calc(50% - 20px); } }
  @media only screen and (min-width: 1366px) {
    .half-width {
      width: calc(50% - 20px); } }

.one-third-width {
  display: inline-block;
  padding: 10px;
  margin: 0px;
  width: calc(100% - 20px);
  -webkit-transition: height 0.5s ease;
  transition: height 0.5s ease; }
  @media only screen and (min-width: 360px) {
    .one-third-width {
      width: calc(100% - 20px); } }
  @media only screen and (min-width: 600px) {
    .one-third-width {
      width: calc(50% - 20px); } }
  @media only screen and (min-width: 1366px) {
    .one-third-width {
      width: calc(33% - 20px); } }

* {
  box-sizing: border-box;
  font-family: "微軟正黑體", "Microsoft JhengHei"; }

body {
  font-size: 1em;
  margin: 0px;
  overflow-x: hidden;
  max-width: 100%; }

.main-title {
  margin: 60px auto 30px auto;
  font-size: 2.5em; }
  @media only screen and (min-width: 600px) {
    .main-title {
      font-size: 3em; } }

.sub-title {
  padding: 20px; }

.discript-title {
  padding-top: 10px;
  padding-left: 10px;
  padding-bottom: 10px;
  margin: 0px;
  font-size: 1.3em;
  line-height: 1em; }

.center {
  display: block;
  margin: auto;
  clear: both;
  text-align: center; }

.img-icon {
  position: relative;
  top: 8px;
  display: inline-block;
  width: 30px;
  height: 30px; }

.top-align {
  vertical-align: top; }

.text-enhance {
  font-weight: bold;
  text-decoration: underline; }

.text-highlight {
    font-size: 1.2em;
    color: red;
    text-decoration: underline; }

.strong-warning {
  color: red;
  font-size: 1.5em; }

.bound-center-1024 {
  width: 1024px;
  max-width: 100%;
  display: block;
  margin: auto; }

.inline-block {
  display: inline-block; }

.picture {
  width: 100%;
  max-width: 350px;
  object-fit: contain;
  margin: 20px auto 20px auto; }

.picture-mid {
  width: 100%;
  max-width: 800px;
  object-fit: contain;
  margin: 20px auto 20px auto; }

.bold {
  font-weight: bold; }

.top-title {
  padding: 10px;
  display: none;
  font-size: 1.2em;
  color: white;
  text-decoration: none; }
  @media only screen and (min-width: 360px) {
    .top-title {
      display: inline-block; } }
  @media only screen and (min-width: 1366px) {
    .top-title {
      display: inline-block; } }

.bar-padding {
  height: 50px; }

.fixbar {
  z-index: 4;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  display: block;
  background-color: rgba(50, 50, 50, 0.7); }
  .fixbar p {
    margin: 5px; }
  .fixbar ul {
    float: right;
    list-style-type: none;
    margin-top: 11px;
    padding: 0px; }
    @media only screen and (min-width: 360px) {
      .fixbar ul {
        display: inline-block; } }
    .fixbar ul li {
      padding: 0px 7px;
      display: inline-block; }
      .fixbar ul li a {
        font-weight: bold;
        text-decoration: none;
        color: white;
        font-size: 1.1em; }
        .fixbar ul li a:hover {
          cursor: pointer;
          color: #c89664; }

.inline-block {
  display: inline-block; }

.theme {
  position: relative;
  overflow: hidden;
  background-color: #222751;
  display: flex;
  flex-direction: column;
  justify-content: center; }
  .theme .theme-image {
    margin: 50px auto 0px auto;
    height: auto;
    max-height: 500px;
    max-width: 100%;
    object-fit: contain;
    z-index: 1; }
  .theme .theme-bg {
    position: absolute;
    top: 0px;
    left: 0px;
    margin: 50px auto 0px auto;
    height: auto;
    max-height: 500px;
    width: 100%;
    object-fit: cover;
    z-index: 0; }
  .theme .title-container {
    position: absolute;
    top: 110px;
    left: 0px;
    width: 100%;
    height: 100%; }
    @media only screen and (min-width: 600px) {
      .theme .title-container {
        top: 150px; } }
    .theme .title-container .title {
      font-size: 2.5em;
      margin: auto 10px;
      max-width: calc(100% - 20px);
      padding: 20px;
      line-height: 1.1em;
      font-weight: bold;
      background-color: #222751;
      color: #0b5394; }
      @media only screen and (min-width: 600px) {
        .theme .title-container .title {
          font-size: 3em;
          margin: auto;
          max-width: 600px; } }
    .theme .title-container .sub-title {
      font-size: 1.2em;
      margin: auto 10px;
      max-width: calc(100% - 20px);
      padding: 10px;
      background-color: #222751;
      color: #0b5394; }
      @media only screen and (min-width: 600px) {
        .theme .title-container .sub-title {
          margin: auto;
          max-width: 300px; } }
    .theme .title-container .bold-title {
      font-size: 1.5em;
      padding-bottom: 3px;
      margin: 0px;
      font-weight: bold; }
    .theme .title-container .wide-space {
      font-size: 1em;
      padding: 0px;
      letter-spacing: 12px;
      margin: 0px; }

.content-container {
  max-width: 75em;
  margin: auto;
  padding: 10px 0px;
  clear: both; }

.segment {
  padding: 30px 0px; }
  .segment:nth-child(even) {
    background-color: #b2dff6; }
    .segment:nth-child(even).enhance {
      background-color: #407E67;
      color: white; }
    .segment:nth-child(even) .button {
      display: inline-block;
      margin: 10px;
      padding: 20px;
      background-color: #CB6243; }
      .segment:nth-child(even) .button a {
        text-decoration: none;
        color: white; }
      .segment:nth-child(even) .button:hover {
        background-color: #FB9273; }
  .segment:nth-child(odd) {
    background-color: #dbe7ed; }
    .segment:nth-child(odd).enhance {
      background-color: #407E67;
      color: white; }
    .segment:nth-child(odd) .button {
      display: inline-block;
      margin: 10px;
      padding: 20px;
      background-color: #67AA8D; }
      .segment:nth-child(odd) .button a {
        text-decoration: none;
        color: white; }
      .segment:nth-child(odd) .button:hover {
        background-color: #97DABD; }
  .segment .toggle-bt {
    cursor: pointer; }
    .segment .toggle-bt .expand-icon {
      position: relative;
      top: 2px;
      width: 20px;
      height: 20px; }
  .segment .toggle-content {
    display: none; }
  .segment p {
    margin: auto;
    padding: 10px;
    line-height: 1.7em; }
  .segment h2 {
    padding: 15px; }
  .segment h3 {
    padding: 15px 15px 5px 15px;
    line-height: 1.7em; }
  .segment li {
    line-height: 1.7em; }
  .segment .center-p {
    margin: auto;
    max-width: 600px; }
  .segment a {
    color: #c86432;
    text-decoration: none; }
    .segment a:hover {
      cursor: pointer;
      color: #646464; }
  .segment iframe {
    width: 100%; }

.showreel {
  width: 960px;
  max-width: 100%;
  margin: auto;
  text-align: center; }
  .showreel .flex-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: flex-start;
    align-content: flex-start; }
    @media only screen and (min-width: 600px) {
      .showreel .flex-container {
        justify-content: space-between; } }
  .showreel .showreel-title {
    font-size: 2.5em;
    margin: 45px auto 0px auto;
    color: #526d68; }
    @media only screen and (min-width: 600px) {
      .showreel .showreel-title {
        font-size: 4em;
        margin: 40px; } }
  .showreel .showreel-desc {
    font-size: 1.25em;
    line-height: 1.5em;
    margin: 30px auto;
    text-align: left;
    color: #4d4d4d; }
    .showreel .showreel-desc:first-letter {
      font-size: 1.5em; }
    @media only screen and (min-width: 600px) {
      .showreel .showreel-desc {
        font-size: 1.25em;
        border-left: 10px solid #1a5d9e;
        margin: 20px 0px 20px 30px;
        padding: 20px 0px 20px 30px; } }
  .showreel .w-520 {
    display: inline-block;
    width: 350px;
    max-width: 100%;
    margin: 0px 10px; }
    @media only screen and (min-width: 600px) {
      .showreel .w-520 {
        width: 520px;
        max-width: calc(56.5% - 20px); } }
  .showreel .w-400 {
    display: inline-block;
    width: 350px;
    max-width: 100%;
    margin: 0px 10px; }
    @media only screen and (min-width: 600px) {
      .showreel .w-400 {
        width: 400px;
        max-width: calc(43.5% - 20px); } }
  .showreel .w-460 {
    display: inline-block;
    width: 350px;
    max-width: 100%;
    margin: 0px 10px; }
    @media only screen and (min-width: 600px) {
      .showreel .w-460 {
        width: 460px;
        max-width: calc(50% - 20px); } }
  .showreel .project-box {
    width: 100%; }
    .showreel .project-box .thumb-280 {
      cursor: pointer;
      display: block;
      width: 100%;
      height: 155px;
      object-fit: cover; }
      @media only screen and (min-width: 600px) {
        .showreel .project-box .thumb-280 {
          height: 280px; } }
    .showreel .project-box .thumb-170 {
      cursor: pointer;
      display: block;
      width: 100%;
      height: 155px;
      object-fit: cover; }
      @media only screen and (min-width: 600px) {
        .showreel .project-box .thumb-170 {
          height: 170px; } }
    .showreel .project-box .thumb-200 {
      cursor: pointer;
      display: block;
      width: 100%;
      height: 155px;
      object-fit: cover; }
      @media only screen and (min-width: 600px) {
        .showreel .project-box .thumb-200 {
          height: 200px; } }
    .showreel .project-box .desc-box {
      width: 100%;
      margin: auto;
      height: auto;
      padding: 0px;
      overflow: hidden;
      margin-bottom: 30px; }
      @media only screen and (min-width: 600px) {
        .showreel .project-box .desc-box {
          margin-bottom: 25px;
          height: 150px; } }
  .showreel .first-title {
    font-size: 2em; }
  .showreel h1 {
    font-size: 2em;
    margin: 30px auto 15px auto; }
    @media only screen and (min-width: 600px) {
      .showreel h1 {
        font-size: 1.5em;
        margin: 20px auto; } }
  .showreel h2 {
    font-size: 1.5em;
    margin: 0px; }
  .showreel p {
    font-size: 1em;
    line-height: 1.5em;
    margin: 0px;
    padding: 0px; }
  .showreel .more-bt {
    display: block;
    width: 144px;
    margin: auto;
    border-radius: 5px;
    box-shadow: 0px 10px 12.1px 0.9px rgba(6, 0, 1, 0.15);
    border: solid 3px #407E67;
    color: #407E67;
    padding: 10px;
    text-align: center;
    cursor: pointer; }
    @media only screen and (min-width: 600px) {
      .showreel .more-bt {
        display: none; } }
  .showreel .load-more {
    display: none; }
    @media only screen and (min-width: 600px) {
      .showreel .load-more {
        display: block; } }

.project-pic-pc {
  display: none;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  padding: 20px 0px;
  overflow: auto;
  z-index: 5; }
  .project-pic-pc .pic-bg {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0px;
    top: 0px;
    background-color: rgba(0, 0, 0, 0.9); }
  .project-pic-pc .main-pic {
    position: relative;
    width: 820px;
    max-width: calc(100% - 20px);
    margin: 50px auto 30px auto;
    background-color: black;
    height: 546px; }
    .project-pic-pc .main-pic .main-img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .project-pic-pc .main-pic .main-mask {
      position: absolute;
      left: 0px;
      top: 0px;
      width: 100%;
      height: 100%;
      object-position: 50% 100%;
      object-fit: cover; }
    .project-pic-pc .main-pic .left-arrow {
      cursor: pointer;
      position: absolute;
      left: 15px;
      top: 50%;
      height: 35px;
      width: 25px; }
    .project-pic-pc .main-pic .right-arrow {
      cursor: pointer;
      position: absolute;
      right: 15px;
      top: 50%;
      height: 35px;
      width: 25px; }
    .project-pic-pc .main-pic .pic-info {
      position: absolute;
      bottom: 0px;
      left: 0px;
      width: 100%;
      color: white;
      text-align: center; }
    .project-pic-pc .main-pic .pic-desc {
      width: 690px;
      margin: auto;
      padding-bottom: 20px;
      max-width: 100%; }
  .project-pic-pc .pic-list {
    position: relative;
    width: 820px;
    max-width: 100%;
    margin: auto; }
    .project-pic-pc .pic-list .pic-container {
      width: calc(100% - 80px);
      margin: auto;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-around;
      align-items: flex-start;
      align-content: flex-start; }
    .project-pic-pc .pic-list .pic-item {
      cursor: pointer;
      width: 160px;
      height: 105px;
      margin: 10px; }
      .project-pic-pc .pic-list .pic-item.select {
        -webkit-filter: brightness(30%);
        filter: brightness(50%); }
    .project-pic-pc .pic-list .left-arrow {
      cursor: pointer;
      position: absolute;
      left: 15px;
      top: 50%;
      height: 26px;
      width: 18px; }
    .project-pic-pc .pic-list .right-arrow {
      cursor: pointer;
      position: absolute;
      right: 15px;
      top: 50%;
      height: 26px;
      width: 18px; }

.project-pic-mobile {
  display: none;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  padding: 20px 0px;
  overflow: auto;
  z-index: 5; }
  .project-pic-mobile .pic-bg {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0px;
    top: 0px;
    background-color: #1f1f1f; }
  .project-pic-mobile .pic-carousel {
    margin-top: 50px; }
    .project-pic-mobile .pic-carousel .carousel-item {
      padding: 12px;
      color: white;
      text-align: center; }
      .project-pic-mobile .pic-carousel .carousel-item .pic-container {
        margin: auto;
        position: relative;
        width: 350px;
        max-width: 100%;
        height: 237px; }
        .project-pic-mobile .pic-carousel .carousel-item .pic-container .pic-image {
          width: 100%;
          height: 100%;
          object-fit: cover; }
        .project-pic-mobile .pic-carousel .carousel-item .pic-container .pic-mask {
          position: absolute;
          top: 0px;
          left: 0px;
          width: 100%;
          height: 100%;
          object-fit: cover;
          object-position: 50% 100%; }
        .project-pic-mobile .pic-carousel .carousel-item .pic-container .pic-title {
          position: absolute;
          left: 0px;
          bottom: 0px;
          width: 100%; }
      .project-pic-mobile .pic-carousel .carousel-item .pic-desc {
        margin: auto;
        margin-top: 27px;
        position: relative;
        width: 350px;
        max-width: 100%; }
    .project-pic-mobile .pic-carousel .slick-dots {
      bottom: auto;
      top: 250px; }
    .project-pic-mobile .pic-carousel .slick-dots li button:before {
      color: white; }

.slide, .slide-4col, .slide-full {
  position: relative;
  width: 100%;
  margin: auto; }
  .slide img, .slide-4col img, .slide-full img {
    width: 100%;
    height: 200px;
    object-fit: cover; }

.slide-3col {
  position: relative;
  width: 100%;
  margin: auto; }
  .slide-3col img {
    width: 100%;
    object-fit: cover; }
  .slide-3col img {
    height: 100%;
    max-height: 200px;
    object-fit: contain; }
  .slide-3col .item {
    margin: 0px 20px; }
  .slide-3col .course-title {
    font-size: 1.6em;
    font-weight: bold;
    margin-top: 10px; }
  .slide-3col .course-info {
    font-size: 1em; }
  .slide-3col .underline {
    text-decoration: underline; }
  .slide-3col .original-price {
    font-size: 1em;
    font-weight: normal;
    text-decoration: line-through; }
  .slide-3col .discount-price {
    font-size: 1.2em;
    color: red;
    text-decoration: underline; }
  .slide-3col ul {
    margin: 0px; }
    .slide-3col ul li {
      color: black; }

  .slide-3col-a4case {
    position: relative;
    width: 100%;
    margin: auto; }
    .slide-3col-a4case img {
      width: 100%;
      object-fit: cover; }
    .slide-3col-a4case img {
      height: 100%;
      max-height: 400px;
      object-fit: contain; }


.arrow-icon {
  width: 20px;
  height: 20px; }

.item-list .item {
  vertical-align: top;
  display: inline-block;
  padding: 10px; }
  .item-list .item .circular {
    width: auto;
    height: auto;
    margin: auto;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%; }
  .item-list .item img {
    width: 100%;
    object-fit: cover; }
  .item-list .item p {
    text-align: left; }

.schedule {
  margin: 10px;
  overflow-x: auto; }
  .schedule table {
    border-collapse: collapse;
    vertical-align: top;
    width: 100%; }
    .schedule table caption {
      padding: 5px; }
    .schedule table th {
      padding: 10px;
      background-color: #7EBCA4;
      border: 1px solid #9E9E9E; }
    .schedule table td {
      min-width: 120px;
      padding: 10px;
      line-height: 1.7em;
      border: 1px solid #9E9E9E;
      background-color: white;
      color: black;
      text-align: left; }
    .schedule table .enlarge {
      min-width: 200px; }
    .schedule table td[colspan="4"] {
      text-align: center; }


.logo-fixbar {
  margin-top: 9px;
  display: inline-block;
  height: 35px;
  max-width: calc(100% - 20px);
  object-fit: contain; }

.logo-long {
  margin: 10px;
  display: inline-block;
  height: 50px;
  max-width: calc(100% - 20px);
  object-fit: contain; }

.logo-mid {
  margin: 10px;
  display: inline-block;
  height: 80px;
  max-width: calc(100% - 20px);
  object-fit: contain; }

.logo {
  margin: 10px;
  display: inline-block;
  height: 120px;
  max-width: calc(100% - 20px);
  object-fit: contain; }

.logo-collection {
  width: 100%;
  padding: 10px;
  object-fit: contain; }

.sponsorship-container {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap; }
  .sponsorship-container .sponsorship {
    flex-grow: 1;
    margin: 10px;
    height: 200px;
    object-fit: cover; }

.footer {
  position: relative;
  margin-top: 0px;
  padding: 0px 10px;
  width: 100%;
  background-color: #1a5d9e;
  color: #ffffff; }
  @media only screen and (min-width: 600px) {
    .footer {
      height: 60px; } }
  @media only screen and (min-width: 1366px) {
    .footer {
      height: 60px; } }
  .footer .contact-info {
    display: block;
    margin: auto;
    padding: 0px 30px 20px 30px;
    font-size: 0.9em; }
    @media only screen and (min-width: 600px) {
      .footer .contact-info {
        position: absolute;
        left: 20px;
        display: inline-block;
        text-align: left;
        padding: 10px; } }
    @media only screen and (min-width: 1366px) {
      .footer .contact-info {
        position: absolute;
        left: 20px;
        display: inline-block;
        text-align: left;
        padding: 10px; } }
  .footer ul {
    padding: 20px;
    display: block;
    margin: auto;
    list-style-type: none; }
    @media only screen and (min-width: 600px) {
      .footer ul {
        position: absolute;
        right: 20px;
        padding: 0px; } }
    @media only screen and (min-width: 1366px) {
      .footer ul {
        position: absolute;
        right: 20px;
        padding: 0px; } }
    .footer ul li {
      cursor: pointer;
      display: inline-block;
      margin: 10px 10px 0px 10px; }
      @media only screen and (min-width: 600px) {
        .footer ul li {
          margin: 10px 20px; } }
      @media only screen and (min-width: 1366px) {
        .footer ul li {
          margin: 10px 20px; } }
      .footer ul li a {
        color: #ffffff;
        text-decoration: none; }
        .footer ul li a:hover {
          color: #f5a623; }
    .footer ul img {
      position: relative;
      top: 10px;
      width: 30px;
      height: 30px;
      -webkit-filter: invert(100%);
      filter: invert(100%); }
