@charset "UTF-8";
html {
  font-size: 16px;
}

body {
  font-family: "Noto Sans TC", "Microsoft Jhenghei", "微軟正黑", sans-serif;
}

a {
  color: inherit;
}

.fix_aside {
  position: fixed;
  z-index: 99;
  right: 1rem;
  bottom: 1rem;
  transform: translateX(150%);
  transition: transform 600ms;
}
.fix_aside.is_active {
  transform: translateX(0%);
}
.fix_aside .fx_item {
  position: relative;
  display: block;
  border-radius: 0.5em;
  margin: 0.5em 0;
  width: 4em;
  height: 4em;
  background: #fff linear-gradient(120deg, #fff, #ddd);
  font-size: 0.95rem;
  cursor: pointer;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.19);
  transition: transform 240ms, box-shadow 240ms;
}
.fix_aside .fx_item.is_primary {
  background: linear-gradient(135deg, #0d274d, #27a5df);
  color: #fff;
}
.fix_aside .fx_item:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.19);
}
.fix_aside .fx_item .in_wrap {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.fix_aside .fx_item .in_wrap.txt {
  text-align: center;
  line-height: 1.3;
}
.fix_aside .fx_item .in_wrap.ic {
  width: 100%;
  height: 100%;
  padding: 0.6em;
}
.fix_aside .fx_item .in_wrap .ic_top {
  width: 100%;
  padding-top: 100%;
  background: url("img/ui/arrow_top.png") center/contain no-repeat;
}

.cta {
  margin-top: 2rem;
}
.cta .bttn {
  display: block;
  margin: 0 auto;
  width: 320px;
  border-radius: 4px;
  background: linear-gradient(120deg, #0d274d, #27a5df);
  padding: 1px;
  transition: transform 300ms;
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.5);
}
.cta .bttn .wrp {
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2rem;
  transition: background 300ms;
  background-color: #0d274d;
}
.cta .bttn .t {
  flex: 0 1 100%;
  padding-left: 1rem;
  padding-right: 0.5rem;
  font-size: 2rem;
  line-height: 1;
  color: #fff;
}
.cta .bttn .i {
  flex: 0 0 50px;
}
.cta .bttn:hover {
  transform: scale(1.1);
  text-decoration: none;
  box-shadow: 0 5px 12px 0 rgba(0, 0, 0, 0.5);
}
.cta .bttn:hover .wrp {
  background-color: rgba(13, 39, 77, 0);
}

.sc_title {
  position: relative;
  z-index: 2;
  line-height: 1;
  margin-bottom: 2em;
}
.sc_title .tit {
  position: relative;
  border-radius: 4px;
  padding: 0.5rem 1rem 0.6rem;
  background: linear-gradient(90deg, #27a5df, rgba(39, 165, 223, 0));
  font-size: 1.5rem;
  color: #fff;
}

@keyframes scalee {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(1.03);
    opacity: 0.67;
  }
}
.g_kv .desktop {
  position: relative;
}
.g_kv .desktop img {
  max-width: 100%;
}
.g_kv .desktop .img {
  padding-top: 56.25%;
  background: url("img/kv_bg.jpg") 0 0/contain no-repeat;
}
.g_kv .desktop .logo,
.g_kv .desktop .tit {
  position: absolute;
  right: 4.1666666667%;
}
.g_kv .desktop .logo {
  top: 4.1666666667vw;
  width: 18.2291666667%;
}
.g_kv .desktop .tit {
  top: 22.2222222222%;
  width: 46.875%;
  text-align: right;
}
.g_kv .desktop .tit .p1 {
  width: 100%;
}
.g_kv .desktop .tit .p2 {
  width: 87.7777777778%;
}
.g_kv .desktop .tit .p3 {
  width: 47.7777777778%;
}

.g_main {
  position: relative;
  z-index: 2;
  background: linear-gradient(rgba(13, 39, 77, 0.99), rgba(13, 39, 77, 0.9)), url("img/kv_bg.jpg") center/cover fixed no-repeat;
  color: #fff;
}

.sc_intro {
  padding: 3rem 0;
}
.sc_intro p {
  max-width: calc(800px + 2rem);
  margin: 0 auto 1em;
  padding: 0 1rem;
  font-size: 1.25rem;
}
.sc_intro p:last-child {
  margin-bottom: 0;
}

.sc_agenda {
  padding: 2rem 0;
}

.agenda_cnt .ag_wrap {
  padding: 0;
}
.agenda_cnt .ag_row {
  display: flex;
  margin-bottom: 1rem;
}
.agenda_cnt .ag_row.td_one .td {
  flex: 0 0 100%;
}
.agenda_cnt .ag_row.td_split {
  justify-content: space-between;
}
.agenda_cnt .ag_row.td_split .td,
.agenda_cnt .ag_row.td_split .ag_date {
  flex: 0 0 50%;
  max-width: calc(50% - .5rem);
}
.agenda_cnt .ag_date {
  text-align: center;
  line-height: 1;
}
.agenda_cnt .ag_date .date,
.agenda_cnt .ag_date .time {
  display: inline-block;
}
.agenda_cnt .ag_date .date {
  font-size: 2rem;
  font-weight: 700;
}
.agenda_cnt .ag_date .time {
  padding-left: 1rem;
  font-size: 1.5rem;
  font-weight: 400;
}
.agenda_cnt .td {
  padding-bottom: 1.5rem;
  text-align: center;
  border-radius: 10px;
  background: linear-gradient(#fff 67%, #a8b1bf);
  color: #0d274d;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.19);
}
.agenda_cnt .td .time {
  display: inline-block;
  padding: 0.25rem 1rem 0.33rem;
  border-radius: 0 0 10px 10px;
  max-width: 12rem;
  background: linear-gradient(120deg, rgba(13, 39, 77, 0.9) 67%, #27a5df);
  color: #fff;
  font-size: 1.25rem;
}
.agenda_cnt .td .title {
  margin-top: 1rem;
  padding-left: 2rem;
  padding-right: 2rem;
  font-size: 1.5rem;
  line-height: 1.2;
}
.agenda_cnt .td .speaker {
  margin-top: 1rem;
  font-size: 1.125rem;
  color: rgba(0, 0, 0, 0.75);
}
.agenda_cnt .td .speaker .name {
  font-size: 1.25rem;
  font-weight: 700;
  color: #000;
}
.sc_speaker {
  padding: 3rem 0;
}

.spk_cnt .items {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-left: -5px;
  margin-right: -5px;
}
.spk_cnt .item_wrap {
  flex: 0 0 25%;
  padding: 0 5px;
  margin-bottom: 10px;
}
.spk_cnt .item {
  border-radius: 4px;
  height: 100%;
  background-color: #fff;
  overflow: hidden;
  color: #000;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.19);
}
.spk_cnt .item .img {
  background-color: rgba(13, 39, 77, 0.5);
  background: linear-gradient(0deg, rgba(39, 165, 223, 0.5), rgba(39, 165, 223, 0.2));
}
.spk_cnt .item img {
  max-width: 100%;
  display: block;
}
.spk_cnt .item .speaker {
  padding: 1rem;
  line-height: 1.1;
  font-size: 0.875rem;
}
.spk_cnt .item .name {
  font-size: 1.25rem;
  font-weight: 700;
  color: #0d274d;
}
.spk_cnt .item .com {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.sc_gift {
  padding: 3rem 0;
}

.gift_cnt .gift_intro {
  margin: 0 auto 2rem;
  padding: 0 1em;
  max-width: 50em;
  font-size: 1.25rem;
}
.gift_cnt .gift_intro p {
  margin-bottom: 0;
}
.gift_cnt .items {
  display: flex;
  justify-content: space-between;
}
.gift_cnt .item {
  position: relative;
  flex: 0 1 24%;
}
.gift_cnt .item .type {
  border-radius: 2px 10px 0 0;
  display: inline-block;
  background-color: #27a5df;
  padding: 0.5rem 2rem 0.5rem 1rem;
  line-height: 1;
  color: #fff;
}
.gift_cnt .item .img {
  border-radius: 0 4px 4px 4px;
  overflow: hidden;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.19);
}
.gift_cnt .item .txt {
  margin-top: 1rem;
  padding: 0.5em 2rem 2rem;
  text-align: center;
  line-height: 1;
}
.gift_cnt .item .att {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5em;
  font-size: 1.25em;
}
.gift_cnt .item .att .t {
  flex: 0 0 auto;
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}
.gift_cnt .item .att .l {
  margin-top: 3px;
  flex: 0 0 3rem;
  height: 1px;
  background-color: #fff;
}
.gift_cnt .item .name {
  margin-top: 0.5rem;
  font-size: 1.5em;
  font-weight: 700;
  line-height: 1.3;
}
.gift_cnt .item .count {
  margin: 1rem 0;
}
.gift_cnt .item .price {
  border: 1px solid #27a5df;
  padding: 0.5rem 1rem;
  border-radius: 40px;
  font-size: 1.125em;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  color: #fff;
}
.gift_cnt .more {
  margin-top: 1rem;
  text-align: center;
}
.gift_cnt .more_inner {
  display: inline-block;
  border-radius: 3rem;
  padding: 1rem 2rem;
  font-size: 1.25rem;
}

.g_footer {
  padding: 3rem 0;
}
.g_footer .foo_logo {
  margin: 0 auto;
  max-width: 200px;
}

@media (max-width: 767px) {
  .sc_intro p {
    font-size: 1.125rem;
  }

  .ag_table {
    margin-bottom: 2rem;
  }
  .ag_table .td {
    margin-top: 1rem;
  }

  .spk_cnt .items,
.gift_cnt .items {
    display: block;
  }

  .spk_cnt .item {
    width: 100%;
    margin-bottom: 1rem;
  }
}