@charset "UTF-8";
@import url(notosanstc.css);
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap");
* {
  margin: 0;
  padding: 0; }

a {
  text-decoration: none;
  color: inherit; }

.fullimg {
  display: block;
  width: 100%; }

.fullimgHeight {
  display: block;
  height: 100%;
  margin: auto; }

.hoverImg {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

.clear {
  clear: both; }

*::placeholder,
select:invalid {
  color: #838383; }

select:valid {
  color: #333333; }

input,
textarea {
  -webkit-appearance: none; }

input,
textarea {
  background: none;
  border: 0;
  font-size: 1rem;
  color: #333333;
  border: 1px solid #999999;
  border-radius: 5px;
  -ms-border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  padding: 0.75rem 1.25rem;
  line-height: 125%;
  font-family: "Roboto", "Noto Sans TC"; }
  input:focus,
  textarea:focus {
    outline: none; }

label {
  cursor: pointer; }

input[type="radio"] {
  display: none !important; }

input[type="radio"] + label span {
  position: relative;
  display: inline-block;
  top: -0.15rem;
  width: 1.25rem;
  height: 1.25rem;
  padding: 0;
  margin-right: 0.5rem;
  border: 1px solid #999999;
  vertical-align: middle;
  border-radius: 50%;
  -ms-border-radius: 50%;
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
  -o-border-radius: 50%; }

input[type="radio"]:checked + label span {
  background: #07B53B;
  border-color: #07B53B; }

input[type="checkbox"] + label span {
  position: relative;
  display: inline-block;
  top: -0.15rem;
  width: 1.5rem;
  height: 1.5rem;
  background: none;
  cursor: pointer;
  border: 1px solid #000;
  box-sizing: border-box;
  border-radius: 5px;
  -ms-border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  margin-right: 0.5rem;
  vertical-align: middle; }

input[type="checkbox"]:checked + label span {
  background: url("../img/icon/icon-check.png") no-repeat center center;
  background-size: contain; }

input[type="checkbox"] {
  display: none !important; }

.swiper-pagination-bullet {
  border-radius: 50% !important; }
  .swiper-pagination-bullet:focus {
    outline: none; }

html {
  font-size: 16px; }

.wrap-all {
  width: 100%; }

.wrap-m {
  width: 1350px;
  margin: 0 auto; }

.wrap-s {
  width: 1100px;
  margin: 0 auto; }

.text-hide {
  display: none; }

select {
  font-size: 1rem;
  padding: 0.5rem 1rem;
  color: #838383;
  box-sizing: border-box;
  font-family: "Roboto", "Noto Sans TC";
  background: none;
  border: 1px solid #999999;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  line-height: 125%;
  border-radius: 5px;
  -ms-border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px; }
  select:focus {
    outline: none; }

.select-wrap {
  display: inline-block;
  position: relative; }

.select-block {
  position: relative;
  border: 1px solid transparent;
  padding: 0;
  line-height: 150%;
  box-sizing: border-box;
  border-radius: 5px;
  -ms-border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  text-align: left;
  transition: background 0.5s, color 0.5s, border 0.5s; }
  .select-block:hover {
    cursor: pointer; }
  .select-block p {
    position: relative;
    width: 100%;
    padding: 0.5rem 2rem 0.5rem 1rem !important;
    box-sizing: border-box; }
    .select-block p::after {
      z-index: 0;
      position: absolute;
      display: block;
      content: "";
      right: -1rem;
      width: 0.35rem;
      height: 0.35rem;
      border: 0.1rem solid transparent;
      border-left: 0;
      border-bottom: 0;
      top: 50%;
      transform: translateY(-50%) rotate(45deg);
      transition: transform 0.5s, border 0.5s;
      right: 1rem;
      transform: translateY(-75%) rotate(135deg); }
  .select-block ul {
    z-index: 1;
    display: none;
    position: absolute;
    padding: 0.5rem 0 !important;
    max-height: 15rem;
    left: -1px;
    width: calc(100% + 2px);
    overflow-y: auto;
    margin: 0 !important;
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box; }
    .select-block ul::-webkit-scrollbar {
      width: 3px; }
    .select-block ul::-webkit-scrollbar-track {
      border-radius: 5px;
      -ms-border-radius: 5px;
      -moz-border-radius: 5px;
      -webkit-border-radius: 5px;
      -o-border-radius: 5px; }
    .select-block ul::-webkit-scrollbar-thumb {
      border-radius: 5px;
      -ms-border-radius: 5px;
      -moz-border-radius: 5px;
      -webkit-border-radius: 5px;
      -o-border-radius: 5px; }
    .select-block ul li {
      list-style: none;
      display: block;
      padding: 0.5rem 1rem;
      color: #FFF;
      white-space: nowrap;
      transition: color 0.25s, background 0.25s; }
      .select-block ul li:hover {
        cursor: pointer;
        background: rgba(255, 255, 255, 0.25); }
      .select-block ul li.active {
        background: rgba(255, 255, 255, 0.25); }
  .select-block.down ul {
    border-radius: 0 0 5px 5px;
    top: 100%; }
  .select-block.down p::before {
    bottom: 0; }
  .select-block.up ul {
    border-radius: 5px 5px 0 0;
    bottom: 100%; }
  .select-block.up p::before {
    top: 0; }
  .select-block.show {
    color: #FFF; }
    .select-block.show.down {
      border-radius: 5px 5px 0 0; }
    .select-block.show.up {
      border-radius: 0 0 5px 5px; }
    .select-block.show p {
      z-index: 0;
      position: relative; }
      .select-block.show p::before {
        display: block; }
      .select-block.show p::after {
        transform: translateY(-25%) rotate(-45deg); }
    .select-block.show ul {
      display: block; }
  .select-block.dark {
    border-color: #999999;
    background: none;
    color: #999999; }
    .select-block.dark p::after {
      border-color: #999999; }
    .select-block.dark ul {
      background: #333333; }
      .select-block.dark ul::-webkit-scrollbar-track {
        background-color: #333333; }
      .select-block.dark ul::-webkit-scrollbar-thumb {
        background-color: rgba(0, 0, 0, 0.75); }
    .select-block.dark li:hover {
      color: #07B53B; }
    .select-block.dark.show, .select-block.dark:hover {
      background: #333333;
      border-color: #333333; }
      .select-block.dark.show p, .select-block.dark:hover p {
        color: #999999; }
      .select-block.dark.show.up p, .select-block.dark.show.down p, .select-block.dark:hover.up p, .select-block.dark:hover.down p {
        border-color: #999999; }
  .select-block.bright {
    color: #333333;
    border-color: #333333;
    background: #FFF; }
    .select-block.bright p::after {
      border-color: #333333; }
    .select-block.bright ul {
      background: #07B53B; }
      .select-block.bright ul::-webkit-scrollbar-track {
        background-color: #07B53B; }
      .select-block.bright ul::-webkit-scrollbar-thumb {
        background-color: rgba(255, 255, 255, 0.5); }
    .select-block.bright li:hover {
      color: #FFF; }
    .select-block.bright.show, .select-block.bright.active, .select-block.bright:hover {
      background: #07B53B;
      border-color: #07B53B; }
      .select-block.bright.show p, .select-block.bright.active p, .select-block.bright:hover p {
        color: #FFF; }
        .select-block.bright.show p::after, .select-block.bright.active p::after, .select-block.bright:hover p::after {
          border-color: #FFF; }
  .select-block.showArrow {
    padding: 0;
    border: 0; }
    .select-block.showArrow::after {
      position: absolute;
      display: block;
      content: "";
      right: -1rem;
      width: 0.35rem;
      height: 0.35rem;
      border: 0.1rem solid #999999;
      border-left: 0;
      border-bottom: 0;
      top: 50%;
      transform: translateY(-50%) rotate(45deg);
      transition: transform 0.5s, border 0.5s;
      right: 1rem;
      transform: translateY(-50%) rotate(135deg); }

table {
  width: 100%;
  border: 0 !important; }
  table th, table td {
    padding: 1rem;
    box-sizing: border-box; }
  table th {
    color: #FFF;
    background: #07B53B;
    font-weight: 500;
    text-align: center; }
  table td:first-child {
    background: #ececec; }
  table td {
    text-align: left; }
  table tr {
    background: #f5f5f5; }

ol {
  list-style: decimal;
  margin-left: 1rem; }
  ol ol {
    list-style: lower-roman; }

ul {
  list-style: none;
  margin-left: 1rem; }
  ul ol {
    list-style: lower-roman; }
  ul > li {
    position: relative; }
    ul > li::before {
      position: absolute;
      content: "・";
      left: -1rem;
      color: #07B53B; }

.imageBtn.active [data-hover] {
  display: none !important; }
.imageBtn.active .hoverImg {
  display: block !important; }

.wrap-back {
  margin: 2rem auto; }
  .wrap-back a {
    position: relative;
    margin-left: 1.25rem;
    transition: color 0.5s; }
    .wrap-back a::before {
      position: absolute;
      display: block;
      content: "";
      left: -1rem;
      width: 0.35rem;
      height: 0.35rem;
      border: 0.1rem solid #333333;
      border-left: 0;
      border-bottom: 0;
      top: 50%;
      transform: translateY(-50%) rotate(-135deg);
      transition: transform 0.5s, border 0.5s;
      transition: transform 0.5s, color 0.5s; }

@media only screen and (min-width: 1025px) {
  .for-m {
    display: none !important; }

  .wrap-back a:hover {
    color: #07B53B; }
    .wrap-back a:hover::before {
      border-color: #07B53B;
      transform: translateX(-0.5rem) translateY(-50%) rotate(-135deg); } }
@media only screen and (max-width: 1440px) {
  html {
    font-size: 15px; }

  .wrap-m {
    width: 1024px; }

  .wrap-s {
    width: 900px; } }
@media only screen and (max-width: 1024px) {
  .for-pc {
    display: none !important; }

  html {
    font-size: 18px; }

  body {
    margin-top: 50px; }

  .wrap-m {
    width: 768px; }

  .wrap-s {
    width: 640px; }

  .wrap-back {
    margin: 1rem auto; }

  select {
    line-height: 125%;
    padding: 0.75rem 1.5rem;
    border-radius: 50px;
    -ms-border-radius: 50px;
    -moz-border-radius: 50px;
    -webkit-border-radius: 50px;
    -o-border-radius: 50px; }

  .select-block {
    padding: 0; }
    .select-block::after {
      position: absolute;
      display: block;
      content: "";
      right: -1rem;
      width: 0.35rem;
      height: 0.35rem;
      border: 0.1rem solid #999999;
      border-left: 0;
      border-bottom: 0;
      top: 50%;
      transform: translateY(-50%) rotate(45deg);
      transition: transform 0.5s, border 0.5s;
      right: 1rem;
      transform: translateY(-50%) rotate(135deg); }
    .select-block.dark::after {
      border-color: #999999; }
    .select-block.bright::after {
      border-color: #333333; }

  .select-wrap.bright {
    float: left;
    margin: 1.5% 0;
    width: 49%; }
    .select-wrap.bright:nth-child(2n) {
      margin-left: 2%; }
    .select-wrap.bright .select-block::after {
      border-color: #333333; }
    .select-wrap.bright select {
      width: 100%;
      min-width: auto;
      border-width: 2px;
      border-color: #333333;
      color: #333333;
      margin: 0;
      border-radius: 5px;
      -ms-border-radius: 5px;
      -moz-border-radius: 5px;
      -webkit-border-radius: 5px;
      -o-border-radius: 5px; } }
@media only screen and (max-width: 768px) {
  html {
    font-size: 16px; }

  .wrap-m {
    width: 640px; }

  .wrap-s {
    width: 500px; } }
@media only screen and (max-width: 640px) {
  html {
    font-size: 15px; }

  .wrap-m {
    width: 480px; }

  .wrap-s {
    width: 425px; } }
@media only screen and (max-width: 480px) {
  .wrap-m {
    width: 375px; }

  .wrap-s {
    width: 345px; } }
@media only screen and (max-width: 375px) {
  html {
    font-size: 14px; }

  .wrap-m {
    width: 320px; }

  .wrap-s {
    width: 300px; } }
@media only screen and (max-width: 320px) {
  html {
    font-size: 13px; }

  .wrap-m {
    width: 300px; }

  .wrap-s {
    width: 280px; } }
.banner {
  height: calc(80vh - 6rem);
  min-height: 32rem;
  max-height: 50rem; }
  .banner h1.title,
  .banner h2.title,
  .banner p.title {
    font-size: 3rem;
    font-weight: 500;
    line-height: 150%; }
  .banner h1.title p {
    font-size: 2rem;
    line-height: 120%;
    margin-bottom: 1rem; }
  .banner h1.title,
  .banner h2.title,
  .banner p.title {
    line-height: 125%; }
  .banner p.des {
    display: block;
    font-size: 1.375rem;
    margin-top: 0.75rem; }
  .banner span.des {
    margin-top: 0.5rem;
    letter-spacing: 0.05rem; }
  .banner .bread {
    z-index: 3;
    position: absolute;
    top: 1.5rem;
    padding: 0;
    left: 0;
    right: 0;
    margin: auto;
    text-align: left; }
    .banner .bread a {
      transition: color 0.5s; }

.banner-case,
.banner-column,
.banner-contact,
.banner-seminar,
.banner-product-main,
.banner-product-module,
.banner-account,
.banner-login,
.banner-news,
.banner-learn-intro,
.banner-manual,
.banner-faq,
.banner-download,
.banner-404,
.banner-family,
.banner-purchase,
.banner-sheet-sticker,
.banner-sheet-cony,
.banner-partner-info,
.banner-partner-awards,
.banner-partner-awards-detail {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  height: 40vh;
  min-height: 20rem;
  max-height: 50rem;
  color: #FFF; }

.banner-product-module {
  height: 50vh;
  min-height: 30rem;
  max-height: 70rem; }

.banner-case {
  background: url("../img/case/banner-case.jpg") no-repeat center center;
  background-size: cover; }

.banner-column {
  background: url("../img/column/banner-column.jpg") no-repeat center center;
  background-size: cover; }

.banner-contact {
  background: url("../img/contact/banner-contact.jpg") no-repeat center center;
  background-size: cover; }

.banner-seminar {
  background: url("../img/seminar/banner-seminar.jpg") no-repeat center center;
  background-size: cover; }

.banner-product-main {
  background: url("../img/product/banner-product-main.jpg") no-repeat center center;
  background-size: cover; }

.banner-product-module {
  background: url("../img/product/banner-product-module.jpg") no-repeat center center;
  background-size: cover; }

.banner-account {
  background: url("../img/account/banner-account.jpg") no-repeat center center;
  background-size: cover; }

.banner-login {
  background: url("../img/login/banner-login.jpg") no-repeat center center;
  background-size: cover; }

.banner-news {
  background: url("../img/news/banner-news.jpg") no-repeat center center;
  background-size: cover; }

.banner-learn-intro {
  background: url("../img/learn/banner-learn-intro.jpg") no-repeat center center;
  background-size: cover; }

.banner-manual {
  background: url("../img/manual/banner-manual.jpg") no-repeat center center;
  background-size: cover; }

.banner-faq {
  background: url("../img/faq/banner-faq.jpg") no-repeat center center;
  background-size: cover; }

.banner-download {
  background: url("../img/download/banner-download.jpg") no-repeat center center;
  background-size: cover; }

.banner-404 {
  background: url("../img/404/banner-404.jpg") no-repeat center center;
  background-size: cover; }

.banner-family {
  background: url("../img/family/banner-family.jpg") no-repeat center center;
  background-size: cover; }

.banner-purchase {
  background: url("../img/purchase/banner-purchase.jpg") no-repeat center center;
  background-size: cover; }

.banner-sheet-sticker {
  text-align: center;
  background: url("../img/sheet/banner-sheet-sticker.jpg") no-repeat center center;
  background-size: cover; }

.banner-sheet-cony {
  text-align: center;
  background: url("../img/sheet/banner-sheet-cony.jpg") no-repeat center center;
  background-size: cover; }

.banner-partner-info {
  background: url("../img/partner/banner-partner-info.jpg") no-repeat center center;
  background-size: cover; }

.banner-partner-awards {
  background: url("../img/partner/banner-partner-info.jpg") no-repeat center center;
  background-size: cover; }

.banner-partner-awards-detail {
  background: url("../img/partner/banner-partner-info.jpg") no-repeat center center;
  background-size: cover; }

.bread {
  position: static;
  padding: 1.5rem 0; }
  .bread a {
    transition: color 0.5s; }
  .bread p {
    position: relative;
    display: inline-block;
    width: 0.35rem;
    height: 0.35rem;
    border: 0.1rem solid transparent;
    border-left: 0;
    border-bottom: 0;
    top: -0.1rem;
    margin: 0 0.5rem;
    transform: rotate(45deg); }
  .bread p.title {
    font-size: 3rem;
    letter-spacing: 0.25rem; }
  .bread span.des {
    display: block;
    font-size: 1.375rem; }
  .bread.white {
    color: #FFF; }
    .bread.white p {
      border-color: #FFF; }
  .bread.black {
    color: #333333; }
    .bread.black p {
      border-color: #333333; }

@media only screen and (min-width: 1025px) {
  .bread a:hover {
    color: #07B53B; } }
@media only screen and (max-width: 1024px) {
  .banner {
    height: 60vh;
    min-height: 500px; }

  .banner h1.title,
  .banner h2.title,
  .banner p.title {
    font-size: 2rem; }

  .banner h1.title p {
    font-size: 1.375rem; }

  .banner-case,
  .banner-column,
  .banner-contact,
  .banner-seminar,
  .banner-product-main,
  .banner-account,
  .banner-login,
  .banner-news,
  .banner-learn-intro,
  .banner-manual,
  .banner-faq,
  .banner-download,
  .banner-404,
  .banner-family,
  .banner-purchase,
  .banner-sheet-sticker,
  .banner-sheet-cony,
  .banner-partner-info,
  .banner-partner-awards,
  .banner-partner-awards-detail {
    min-height: 200px;
    max-height: none;
    height: 30vh; }

  .banner-product-module {
    height: auto !important;
    min-height: auto !important;
    max-height: none !important; }

  .banner-sheet-sticker {
    background: url("../img/sheet/banner-sheet-sticker-m.jpg") no-repeat center center;
    background-size: cover; }

  .banner-sheet-cony {
    background: url("../img/sheet/banner-sheet-cony-m.jpg") no-repeat center center;
    background-size: cover; } }
@media only screen and (max-width: 768px) {
  .banner {
    min-height: 400px; } }
@media only screen and (max-width: 640px) {
  .banner {
    min-height: 300px; }

  .banner-case,
  .banner-column,
  .banner-contact,
  .banner-seminar,
  .banner-product-main,
  .banner-account,
  .banner-login,
  .banner-news,
  .banner-learn-intro,
  .banner-manual,
  .banner-faq,
  .banner-download,
  .banner-family,
  .banner-purchase,
  .banner-sheet-sticker,
  .banner-sheet-cony,
  .banner-partner-info,
  .banner-partner-awards,
  .banner-partner-awards-detail {
    min-height: 150px; } }
@media only screen and (max-width: 480px) {
  .banner h1.title,
  .banner h2.title,
  .banner p.title {
    font-size: 1.75rem; }

  .banner p.des {
    font-size: 1rem; } }

/*# sourceMappingURL=banner.css.map */
