﻿@import url("icomoon/style.min.css");


.m-t50{margin-top:50px;}
.m-t60{margin-top:60px;}

.m-b50{margin-bottom:50px;}
.m-b60{margin-bottom:60px;}

button#ihavecookiesBtn {
    margin-left: 0px !important
}

#gdpr-cookie-message {
    position: fixed;
    right: 30px;
    bottom: 30px;
    max-width: 375px;
    background-color: #4d4d4d;
    padding: 20px;
    border-radius: 5px;
    box-shadow: 0 6px 6px rgba(0, 0, 0, 0.25);
    margin-left: 30px;
    z-index: 3
}

#gdpr-cookie-message::before {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: fixed;
    width: 100%;
    height: 100vh;
    content: " ";
    background-color: rgba(0, 0, 0, 0.25);
    z-index: -1
}

#gdpr-cookie-message h4 {
    color: #fff;
    font-size: 18px;
    margin-bottom: 10px;
    font-weight: bolder;
    letter-spacing: 1px
}

#gdpr-cookie-message h5 {
    color: #fff;
    font-size: 15px;
    margin-bottom: 10px;
    letter-spacing: 1px
}

#gdpr-cookie-message p,
#gdpr-cookie-message ul {
    color: white;
    font-size: 15px;
    line-height: 1.5em
}

#gdpr-cookie-message p:last-child {
    margin-bottom: 0;
    text-align: right
}

#gdpr-cookie-message li {
    width: 49%;
    display: inline-block
}

#gdpr-cookie-message a {
    color: #f5c88c;
    text-decoration: none;
    font-size: 16px;
    padding-bottom: 2px;
    border-bottom: 1px dotted #f1b15d;
    transition: all 0.3s ease-in;
    margin-top: 0 !important
}

#gdpr-cookie-message a:hover {
    color: white;
    border-bottom-color: #495057;
    transition: all 0.3s ease-in
}

#gdpr-cookie-message button,
button#ihavecookiesBtn {
    border: none;
    background-color: #495057;
    color: #fff;
    font-size: 15px;
    padding: 7px;
    border-radius: 3px;
    margin-left: 15px;
    cursor: pointer;
    transition: all 0.3s ease-in;
    margin-top: 10px;
    font-weight: normal
}

#gdpr-cookie-message button:hover {
    background-color: darkenen(#427AA1, 30%);
    color: white;
    transition: all 0.3s ease-in
}

button#gdpr-cookie-advanced {
    background: #1a274e;
    color: white
}

#gdpr-cookie-message button:disabled {
    opacity: 0.3
}

#gdpr-cookie-message input[type="checkbox"] {
    float: none;
    margin-top: 0;
    margin-right: 5px
}

form.inquiry-form ::-webkit-input-placeholder,
form.contact ::-webkit-input-placeholder {
    color: #aaa;
    font-size: 15px
}

form.inquiry-form ::-moz-placeholder,
form.contact ::-moz-placeholder {
    color: #aaa;
    font-size: 15px
}

form.inquiry-form :-ms-input-placeholder,
form.contact :-ms-input-placeholder {
    color: #aaa;
    font-size: 15px
}

form.inquiry-form :-moz-placeholder,
form.contact :-moz-placeholder {
    color: #aaa;
    font-size: 15px
}

.mask {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    content: " ";
    opacity: .65;
    display: block;
    float: left
}

.mask~ :not(.pos-ab) {
    position: relative
}

.mask.gradient {
    opacity: .8;
    background: linear-gradient(to right, #050b1f, #196dbe)
}

.logo {
    width: 200px;
    height: 45.5px;
    background-size: auto 100%;
    display: inline-block;
    background-position: 0% 50%;
    background-image: url("../images/logo-text.svg")
}

.logo.text {
    /* width: 160px;
    height: 60px; */
    width: 200px;
    height: 45.5px;
    background-image: url("../images/logo-text.svg");
    background-size: 100% 60px
}

.breadcrumb .container {
    overflow-x: auto;
    overflow-y: hidden;
    height: 30px;
    white-space: nowrap
}

.breadcrumb .breadcrumb-item {
    display: inline-block;
    /* max-width: 130px; */
    font-size: 15px;
    padding-top: 7.5px;
    padding-bottom: 7.5px;
    line-height: 15px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis
}

.viewer [class*="abimg"] img {
    transition: all ease-out .3s;
    filter: brightness(1.05)
}

.viewer [class*="abimg"]::after {
    width: 60px;
    height: 60px;
    font-family: 'icomoon';
    content: "\e943";
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -30px 0 0 -30px;
    line-height: 60px;
    text-align: center;
    font-size: 40px;
    color: #fff;
    transition: .3s all ease-out .2s;
    opacity: 0;
    transform: scale(0.3);
    pointer-events: none
}

.viewer [class*="abimg"]:hover img {
    filter: brightness(0.6);
    height: 120%
}

.viewer [class*="abimg"]:hover::after {
    transform: scale(1.1);
    opacity: 1
}

#top {
    width: 40px;
    height: 40px;
    background-color: #b28247;
    line-height: 40px;
    position: fixed;
    bottom: 8vh;
    right: .35rem;
    z-index: 0;
    color: #fff;
    font-size: 17px;
    font-weight: bold;
    text-align: center;
    display: none;
    border-radius: 10px;
}

.shuffle-ctrl>.btn {
    padding: 10px 1.5rem;
    letter-spacing: 1px
}

.shuffle-ctrl>.btn::after {
    margin-left: 15px;
    margin-right: -6px
}

.dropdown-menu {
    padding: 0
}

.dropdown-menu .dropdown-item {
    display: block
}

.table-wrap,
.table-responsive-md {
    width: 100%;
    display: block;
    float: left;
    overflow-x: auto
}

.table-wrap>table,
.table-responsive-md>table {
    min-width: 1000px
}

.table-wrap>table img,
.table-responsive-md>table img {
    max-width: 80px
}

.table-wrap>table thead th,
.table-responsive-md>table thead th {
    text-transform: uppercase;
    font-size: .9rem;
    vertical-align: middle
}

.table-wrap>table tbody th,
.table-wrap>table tbody td,
.table-responsive-md>table tbody th,
.table-responsive-md>table tbody td {
    vertical-align: middle
}

.table-wrap+.gw,
.table-responsive-md+.gw {
    display: none
}

@media screen and (max-width: 1060px) {

    .table-wrap+.gw,
    .table-responsive-md+.gw {
        display: none
    }
}

@media screen and (max-width: 629px) {

    .table-wrap::after,
    .table-responsive-md::after {
        display: block;
        content: "<- 請左右滑動 ->";
        font-size: .85rem;
        text-align: center;
        color: #cf164d;
        margin-bottom: .5rem
    }
}

.has-table .table-wrap {
    overflow-x: auto;
    width: 100%;
    white-space: normal
}

.has-table .table-wrap>table {
    min-width: 600px;
    white-space: normal
}

.has-table .table-wrap>table tr>th {
    vertical-align: top;
    font-size: .9rem
}

.has-table .table-wrap>table tr>td {
    white-space: pre-line;
    line-height: 1.6
}

@media screen and (max-width: 1260px) {
    .has-table .table-wrap::after {
        display: block;
        content: "<- TOUCH MOVE ->";
        font-size: .85rem;
        text-align: center;
        color: #cf164d;
        margin-bottom: .5rem
    }
}

.has-table.small-text table {
    min-width: 860px
}

.has-table.small-text caption {
    caption-side: top;
    margin-bottom: .5rem;
    padding-top: 0rem;
    padding-bottom: .25rem;
    font-size: 1.15rem;
    line-height: 1
}

.has-table.small-text thead {
    background-color: #1a274e
}

.has-table.small-text th {
    font-size: .9rem;
    text-align: center;
    padding-top: .45rem;
    padding-bottom: .45rem;
    color: #fff;
    line-height: 1.15
}

.has-table.small-text [rowspan] {
    vertical-align: middle
}

.has-table.small-text [colspan] {
    border-bottom: 0
}

.has-table.small-text tbody td {
    font-size: .9rem;
    padding-top: .35rem;
    padding-bottom: .35rem;
    line-height: 1.15;
    text-align: center
}

.smalls {
    font-size: 0.9375rem
}

.pagination-wrap {
    display: block;
    max-width: 100%;
    text-align: center
}

.pagination-wrap>.prev,
.pagination-wrap>.next,
.pagination-wrap>.pagi-content a {
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    display: inline-block;
    background-color: #f0f0f0;
    box-shadow: inset 0 0 0 1px #dbdbdb;
    margin: 1px
}

.pagination-wrap .pagi-content {
    max-width: 204px;
    display: inline-block;
    overflow: hidden;
    height: 32px;
    white-space: nowrap;
    margin-top: 0;
    margin-bottom: 0;
    counter-reset: section
}

@media screen and (max-width: 800px) {
    .pagination-wrap .pagi-content {
        max-width: 204px
    }
}

.pagination-wrap .pagi-content>div {
    max-width: 100%;
    display: flex;
    flex-flow: row nowrap;
    transition: all ease .35s
}

.pagination-wrap .pagi-content a {
    color: #777;
    font-size: .9rem;
    min-width: 30px;
    margin-left: 2px;
    margin-right: 2px
}

.pagination-wrap .pagi-content a::before {
    counter-increment: section;
    content: counter(section)
}

.pagination-wrap .pagi-content a.active {
    background-color: #888;
    color: #fff;
    pointer-events: none
}

.pagination-wrap .pagi-content a:nth-child(50)~* {
    display: none
}

.pagination-wrap .prev::before,
.pagination-wrap .next::before {
    width: 16px;
    height: 16px;
    display: block;
    border: 8px solid transparent;
    content: " ";
    margin-top: 7px;
    transform: scaleY(0.8)
}

.pagination-wrap .prev::before {
    border-right-color: #888;
    margin-left: 2px
}

.pagination-wrap .next::before {
    border-left-color: #888;
    margin-left: 12px
}

.pagination-wrap>.prev.active,
.pagination-wrap>.next.active {
    pointer-events: none
}

.pagination-wrap>.prev.active::before,
.pagination-wrap>.next.active::before {
    opacity: .35
}

main {
    min-height: 60vmin;
}

main.bg-cover {
    padding-top: 15vh
}

@media screen and (max-width: 800px) {
    main.bg-cover {
        padding-top: 8vh
    }
}

.limit-item .after-line:nth-of-type(3)~* {
    display: none
}

article h2 {
    font-weight: lighter
}

article h2 span {
    display: block;
    font-size: 18px;
    text-transform: uppercase;
    color: #9A879D;
    margin-top: 18px
}

.img-wrap>a {
    display: block
}

.img-wrap>a * {
    transition: all ease-in .3s
}

.img-wrap>a>img {
    margin-bottom: 1rem;
    filter: brightness(1);
    opacity: 1
}

.img-wrap>a>img+* {
    color: #9A879D;
    font-weight: 600;
    margin-bottom: 0
}

.img-wrap>a>img+*+* {
    margin-top: -18px;
    color: #666
}

.img-wrap>a:hover img {
    filter: brightness(1.1);
    opacity: .8
}

.corporation {
    position: relative
}

.corporation .bnr-content {
    min-height: 420px;
    overflow: visible;
    background-clip: content-box;
    padding-left: 3rem;
    padding-right: 15px
}

.corporation .bnr-content::after {
    position: absolute;
    height: 1px;
    display: block;
    background-color: #ccc;
    content: " ";
    bottom: -50px;
    left: 3rem;
    right: 15px;
    z-index: 0
}

@media screen and (max-width: 640px) {
    .corporation .bnr-content {
        min-height: 320px
    }
}

.corporation .locate {
    position: absolute;
    top: 0;
    left: 0;
    width: 3rem;
    text-align: left;
    font-size: 18px;
    letter-spacing: 1px;
    padding: 0px 20px 0 10px;
    line-height: 30px;
    font-weight: 600;
    color: #000
}

.corporation .locate::after,
.corporation .locate::before {
    width: 1px;
    height: 85px;
    background-color: #000;
    content: " ";
    display: block;
    margin: 20px auto
}

@media screen and (max-width: 640px) {
    .corporation .locate {
        line-height: 20px
    }

    .corporation .locate::after {
        display: none
    }

    .corporation .locate::before {
        height: 50px
    }
}

.corporation .locate+* {
    margin-top: -80px;
    background-clip: content-box
}

.corporation .dd>* {
    font-size: 0.9375rem;
    white-space: pre-line;
    line-height: 1.8;
    letter-spacing: 1px
}

@media screen and (max-width: 640px) {
    .corporation .dd>* {
        font-size: 14px
    }
}

.accordion .card-header {
    padding-top: 3px;
    padding-bottom: 3px;
    margin-bottom: 0;
    width: 100%;
    background-color: #1a274e;
}

.accordion .card-header button {
    display: block;
    width: 100%;
    text-align: left;
    font-size: 18px;
    font-weight: bold;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding-right: 30px;
    position: relative;
    color: #fff
}

.accordion .card-header button::after {
    font-family: 'icomoon';
    content: "\e92d";
    position: absolute;
    top: 50%;
    right: 6px;
    height: 20px;
    font-size: 14px;
    margin-top: -9px;
    line-height: 20px;
    display: inline-block;
    transition: all ease .3s;
    transform: rotate(180deg)
}

.accordion .card-header button.collapsed::after {
    transform: rotate(0deg)
}

.accordion .card+.card {
    margin-top: -1px
}

.accordion .card {
    margin-bottom: 0
}

.accordion .card:only-child {
    border-bottom: 1px solid #dbdbdb
}

.accordion .card-link {
    padding: 0;
    width: 100%
}

.accordion .card-link>a {
    display: block;
    width: 100%;
    padding: 10px 15px;
    background-color: #fff;
    color: #555;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding-left: 50px;
    position: relative;
    margin: 1px 0 1px 0;
    border-bottom: 1px solid #dfdfdf;
    font-weight: 600
}

.accordion .card-link>a:last-of-type {
    margin-bottom: -1px
}

.accordion .card-link>a:hover,
.accordion .card-link>a.active {
    background-color: #fff;
    color: #1a274e
}

.accordion .card-link>a:hover::before {
    color: #fff;
    background-color: #1a274e
}

.accordion .card-link>a.active::before {
    background-color: #1a274e;
    color: #fff
}

.accordion .card-link>a::before {
    position: absolute;
    width: 20px;
    height: 20px;
    top: 50%;
    left: 20px;
    background-color: #666;
    line-height: 20px;
    content: " ";
    margin-top: -10px;
    border-radius: 50%;
    text-align: center;
    font-family: 'icomoon';
    content: "\e92f";
    font-size: 12px;
    color: #fff;
    transform: scale(0.75);
    transform-origin: 0 50%
}

.img-link>a {
    position: relative;
    user-select: block;
    padding-bottom: 37.5%;
    overflow: hidden;
    width: 100%;
    overflow: hidden;
    float: left
}

.img-link>a img {
    position: absolute;
    width: 100%;
    max-width: 100%;
    top: 0;
    left: 0;
    display: block
}

.list-style {
    padding-bottom: 1rem;
    margin-bottom: 2rem;
    position: relative
}

.list-style::after {
    width: calc(100% - 30px);
    height: 1px;
    content: " ";
    display: block;
    position: absolute;
    bottom: 1px;
    border-bottom: 1px dotted #ccc;
    left: 15px
}

.list-style dt {
    font-size: 21px;
    padding-left: 25px;
    color: #1a274e;
    margin-bottom: 15px
}

.list-style dt::before {
    font-family: 'icomoon';
    content: "\e91b";
    width: 20px;
    display: inline-block;
    vertical-align: middle;
    font-size: 16px;
    color: inherit;
    margin-top: -4px;
    margin-left: -20px;
    margin-right: 5px
}

.list-style dd {
    display: block;
    counter-reset: section
}

.list-style dd>* {
    display: block;
    padding-left: 30px;
    font-size: 1rem !important;
    line-height: 1.7;
    letter-spacing: .5px;
    font-weight: 500;
    white-space: pre-line
}

.list-style dd>*::before {
    width: 20px;
    margin-left: -25px;
    margin-right: 5px;
    display: inline-block;
    vertical-align: middle;
    color: #aaa;
    font-weight: bold;
    counter-increment: section;
    content: counter(section) ". "
}

.list-style:last-of-type::after {
    display: none
}

/* header {
    margin-bottom: 50px;
} */

header .bnr-header {
    height: calc((100vh / 16) * 8);
    min-height: 600px;
    content: " ";
    background-color: #f2f2f2;
    transition: all ease-out .25s
}

header .bnr-header .row {
    min-height: 450px;
    position: relative
}

@media screen and (max-width: 800px) {
    header .bnr-header {
        height: calc((100vh / 16) * 8.5);
        min-height: 420px
    }

    header .bnr-header .row {
        min-height: 370px;
        position: relative
    }
}

@media screen and (max-width: 640px) {
    header .bnr-header {
        height: calc((100vh / 16) * 6);
        min-height: 320px
    }

    header .bnr-header .row {
        min-height: 300px;
        position: relative
    }

    header .bnr-header .row .font-vmin {
        font-size: 4.5vmin;
        transform: translateY(50%)
    }
}

@media screen and (min-width: 1440.02px) {
    header .__center .bnr-header {
        min-width: 1360px
    }
}

@media screen and (max-width: 1440px) {
    header .__center .bnr-header {
        min-width: 1120px
    }
}

@media screen and (max-width: 1360.02px) {
    header .__center .bnr-header {
        min-width: auto;
        width: 100%
    }
}

header .bnr-content {
    min-height: 180px;
    background-size: cover !important;
    background-repeat: no-repeat
}

@media scren and (max-width: 640px) {
    header .bnr-content {
        min-height: 120px
    }
}

.header-slides .slick-slide .bnr-header {
    opacity: .8;
    filter: brightness(0.5);
    transition: all ease-in .3s
}

.header-slides .slick-slide.slick-active.slick-current .bnr-header {
    opacity: 1;
    filter: brightness(1);
    transition: all ease-in .3s
}

.pager a {
    display: inline-block;
    vertical-align: middle
}

.pager a span {
    line-height: 30px;
    padding: 0;
    margin-bottom: -3px
}

.bnr-content {
    min-height: 360px
}

.bnr-content .match-h {
    height: 320px;
    margin-top: 30px
}

@media screen and (max-width: 800px) {
    .bnr-content {
        min-height: 300px
    }
}

.bnr-page {
    min-height: 70vmin;
    content: " "
}

.title-wave {
    text-align: center
}

.title-wave>*:first-child {
    position: relative;
    font-size: 1.5em;
    font-weight: 600;
    letter-spacing: 1px
}

.title-wave>*:first-child::before,
.title-wave>*:first-child::after {
    display: inline-block;
    vertical-align: middle;
    width: 50px;
    height: 10px;
    background-image: url("../images/dec/title-wave.svg");
    content: " ";
    background-repeat: repeat-x;
    background-position: 0 50%;
    margin-top: -2px
}

.title-wave>*:first-child::before {
    margin-right: 10px
}

.title-wave>*:first-child::after {
    margin-left: 10px
}

.inquiry-form input[disabled] {
    background-color: transparent
}

.inquiry-form input[disabled].form-control {
    border: 0
}

.inquiry-form .update-wrap .btn.sprite {
    font-size: 18px;
    color: #fff
}

.inquiry-form .update-wrap .btn-primary {
    color: #fff
}

.inquiry-form [data-item] {
    border: 1px solid #dbdbdb;
    padding: 0;
    border-left: 0;
    border-bottom: 0;
    text-align: center
}

.inquiry-form [data-item]>* {
    padding-left: 15px;
    padding-right: 15px;
    text-align: center;
    font-size: 15px
}

.inquiry-form [data-item]::before {
    display: block;
    letter-spacing: 3px;
    font-weight: bold;
    font-size: 15px;
    width: 100%;
    content: attr(data-item);
    padding: 6px 15px;
    border-bottom: 1px solid #dbdbdb;
    background-color: #ebebeb
}

.inquiry-form [data-item] input[type="number"].form-control {
    border: 0 !important;
    box-shadow: none !important
}

.inquiry-form [data-item] input[type="number"].form-control:focus {
    border: 0 !important;
    box-shadow: none !important
}

.inquiry-form .row.prod-detail {
    border: 1px solid #dbdbdb;
    overflow: hidden;
    border-top: none;
    border-right: none
}

.inquiry-form .row.prod-detail>*>* {
    margin: 8px 0
}

.inquiry-form .row.prod-detail:not(:first-of-type) [data-item]::before {
    display: none
}

@media screen and (max-width: 800px) {
    .inquiry-form .row.prod-detail:not(:first-of-type) [data-item]::before {
        display: block
    }
}

.inquiry-form .row.prod-detail+.row.prod-detail {
    margin-top: -1px
}

@media screen and (max-width: 800px) {
    .inquiry-form .row.prod-detail+.row.prod-detail {
        margin-top: 1rem
    }
}

.inquiry-form textarea {
    resize: none;
    font-size: 15px !important;
    border-radius: 0 !important;
    border: 0;
    background-color: #f8f8f8;
    white-space: pre-line;
    transition: all ease .3s;
    overflow-y: auto;
    color: #5a8d97
}

.inquiry-form textarea::-webkit-input-placeholder {
    color: #cfcfcf
}

.inquiry-form textarea::-moz-placeholder {
    color: #cfcfcf
}

.inquiry-form textarea:-ms-input-placeholder {
    color: #cfcfcf
}

.inquiry-form textarea:-moz-placeholder {
    color: #cfcfcf
}

.inquiry-form textarea:focus {
    box-shadow: none;
    background-color: #f5f5f5;
    height: auto;
    color: #5a8d97
}

.inquiry-form textarea:focus::-webkit-input-placeholder {
    color: #5a8d97
}

.inquiry-form textarea:focus::-moz-placeholder {
    color: #5a8d97
}

.inquiry-form textarea:focus:-ms-input-placeholder {
    color: #5a8d97
}

.inquiry-form textarea:focus:-moz-placeholder {
    color: #5a8d97
}

.inquiry-form textarea[disabled] {
    background-color: #f7f7f5
}

.inquiry-form [name="members"],
.inquiry-form input[type="radio"][name="pay-style"] {
    position: absolute;
    top: 30px;
    left: 20px;
    opacity: 0;
    z-index: 0
}

.inquiry-form [name="members"]+label,
.inquiry-form input[type="radio"][name="pay-style"]+label {
    z-index: 1;
    position: relative
}

.inquiry-form [name="members"]~* input,
.inquiry-form [name="members"]~* label,
.inquiry-form input[type="radio"][name="pay-style"]~* input,
.inquiry-form input[type="radio"][name="pay-style"]~* label {
    pointer-events: none;
    opacity: .5
}

.inquiry-form [name="members"]:checked~label::before,
.inquiry-form input[type="radio"][name="pay-style"]:checked~label::before {
    content: "\e931";
    color: #cf164d
}

.inquiry-form [name="members"]:checked~* input,
.inquiry-form [name="members"]:checked~* label,
.inquiry-form input[type="radio"][name="pay-style"]:checked~* input,
.inquiry-form input[type="radio"][name="pay-style"]:checked~* label {
    pointer-events: painted;
    opacity: 1
}

.inquiry-form [name="members"][disabled]~.member-data .form-control,
.inquiry-form input[type="radio"][name="pay-style"][disabled]~.member-data .form-control {
    background-color: #eee;
    border: 1px solid #dbdbdb
}

.inquiry-form .checkeds::before {
    transition: all ease .3s;
    font-size: 16px;
    text-align: center;
    width: 20px;
    height: 20px;
    border: 1px solid #dbdbdb;
    line-height: 18px;
    content: " ";
    display: inline-block;
    vertical-align: middle;
    margin-top: -3px;
    margin-right: 7px;
    font-family: 'icomoon';
    background-color: #fff;
    pointer-events: none
}

.inquiry-form .form-control {
    transition: all ease .3s;
    font-size: 16px
}

.inquiry-form .form-control+.input-group-text {
    border-right: 0;
    margin-right: -1px;
    transition: all ease .3s
}

.inquiry-form select.form-control {
    font-size: 16px
}

.inquiry-form ul,
.inquiry-form ol {
    margin-left: 0;
    margin-right: 0;
    padding-left: 50px;
    list-style-position: outside;
    padding-top: 10px
}

.inquiry-form ul li,
.inquiry-form ol li {
    padding-left: 8px
}

.inquiry-form ul li:only-child,
.inquiry-form ol li:only-child {
    list-style-type: none;
    padding-left: 0;
    margin-left: -50px
}

@media screen and (max-width: 1023.98px) {

    .inquiry-form ul,
    .inquiry-form ol {
        margin-left: .35rem
    }
}

.inquiry-form ul li,
.inquiry-form ol li {
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 6px
}

@media screen and (max-width: 639.98px) {

    .inquiry-form ul,
    .inquiry-form ol {
        margin-left: 0;
        margin-right: 0;
        padding-left: 26px;
        list-style-position: outside;
        padding-right: 15px
    }

    .inquiry-form ul li,
    .inquiry-form ol li {
        padding-left: 8px
    }

    .inquiry-form ul li:only-child,
    .inquiry-form ol li:only-child {
        list-style-type: none;
        padding-left: 0;
        margin-left: -26px
    }
}

@media screen and (max-width: 639.98px) and (max-width: 1023.98px) {

    .inquiry-form ul,
    .inquiry-form ol {
        margin-left: .35rem
    }
}

.inquiry-form #amounts {
    font-size: 15px
}

.inquiry-form *>dl:last-of-type::after {
    display: none
}

.inquiry-form dl {
    margin-bottom: .5rem;
    position: relative
}

.inquiry-form dl::after {
    height: 1px;
    border-bottom: 1px dotted #dbdbdb;
    content: " ";
    position: absolute;
    bottom: 0;
    left: 20px;
    right: 20px
}

.inquiry-form dl dt,
.inquiry-form dl dd {
    padding-left: .65rem;
    padding-right: .65rem;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis
}

.inquiry-form dl dt {
    font-size: 15px;
    font-weight: bold;
    line-height: 1.7;
    letter-spacing: 2px;
    color: #777
}

.inquiry-form dl dd {
    font-size: 1rem;
    color: #000;
    line-height: 1.7
}

.inquiry-form .border-left.border-right+* {
    margin-left: -1px
}

@media screen and (max-width: 640px) {
    .inquiry-form .border-left.border-right+* {
        margin-left: 0px
    }
}

form.contact input[type="checkbox"],
form.contact input[type="radio"] {
    display: inline-block;
    width: 20px;
    height: 20px;
    vertical-align: middle;
    left: 5px
}

form.contact .input-group {
    position: relative
}

form.contact span.input-state {
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center
}

form.contact input,
form.contact .form-control:not(textarea) {
    padding-left: 40px !important;
    z-index: 0 !important;
    font-size: 16px;
    height: calc(1.5em + 1rem + 4px);
    border-radius: 0
}

form.contact input~label[class*="icon"],
form.contact input~span.input-state,
form.contact .form-control:not(textarea)~label[class*="icon"],
form.contact .form-control:not(textarea)~span.input-state {
    border: 0;
    background-color: transparent;
    position: absolute;
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    display: inline-block;
    padding: 0;
    left: 10px;
    top: 50%;
    margin-top: -15px;
    margin-bottom: 0;
    font-size: 17px;
    transition: all ease .25s;
    margin-left: -5px;
    z-index: 1;
    color: #aaa;
    align-self: center
}

form.contact input~label[class*="icon"]::before,
form.contact input~span.input-state::before,
form.contact .form-control:not(textarea)~label[class*="icon"]::before,
form.contact .form-control:not(textarea)~span.input-state::before {
    display: block;
    line-height: inherit
}

form.contact input:focus~*,
form.contact .form-control:not(textarea):focus~* {
    z-index: 1
}

form.contact input:focus:required:invalid~label[class*="icon"],
form.contact .form-control:not(textarea):focus:required:invalid~label[class*="icon"] {
    color: #d23737
}

form.contact input:focus:required:invalid~label[class*="icon"]::before,
form.contact .form-control:not(textarea):focus:required:invalid~label[class*="icon"]::before {
    content: "\e937"
}

form.contact input:required:valid~label[class*="icon"],
form.contact .form-control:not(textarea):required:valid~label[class*="icon"] {
    color: #1fbef9
}

form.contact input:required:valid~label[class*="icon"]::before,
form.contact .form-control:not(textarea):required:valid~label[class*="icon"]::before {
    content: "\e931"
}

form.contact textarea {
    resize: none;
    overflow-y: auto;
    white-space: pre-line
}

.custom-list {
    margin-left: 0;
    margin-right: 0;
    padding-left: 18px;
    list-style-position: outside;
    padding-top: 10px
}

.custom-list li {
    padding-left: 8px
}

.custom-list li:only-child {
    list-style-type: none;
    padding-left: 0;
    margin-left: -18px
}

@media screen and (max-width: 1023.98px) {
    .custom-list {
        margin-left: .35rem
    }
}

.custom-list li {
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 6px
}

.custom-list li>* {
    font-size: inherit;
    line-height: inherit
}

.custom-list li>*.textarea {
    font-weight: normal
}

@media screen and (max-width: 639.98px) {
    .custom-list {
        margin-left: 0;
        margin-right: 0;
        padding-left: 26px;
        list-style-position: outside;
        padding-right: 15px
    }

    .custom-list li {
        padding-left: 8px
    }

    .custom-list li:only-child {
        list-style-type: none;
        padding-left: 0;
        margin-left: -26px
    }
}

@media screen and (max-width: 639.98px) and (max-width: 1023.98px) {
    .custom-list {
        margin-left: .35rem
    }
}

.overscroll {
    width: 100%;
    float: left;
    height: 250px;
    overflow-x: hidden;
    overflow-y: auto;
    background-color: #f9f9f9;
    padding: 0rem 1rem 1rem 1rem;
    font-size: 15px;
    line-height: 1.7;
    letter-spacing: 1px;
    white-space: pre-line;
    margin-top: 4px;
    margin-bottom: 1rem
}

.small-link {
    display: inline-block;
    vertical-align: middle;
    font-size: 15px;
    margin-right: 5px;
    margin-left: 5px
}

.small-link::before {
    display: inline-block;
    margin-right: 6px
}

.ph-link>a {
    display: block;
    float: left;
    width: 100%
}

.ph-link>a * {
    transition: all linear .3s
}

.ph-link>a:hover img {
    transform: scale(1.08)
}

.short-line {
    position: relative;
    padding-bottom: 2rem
}

.short-line::after {
    width: 180px;
    height: 44px;
    background-image: url("../images/png-icon/leaf.png");
    background-size: auto 100%;
    background-size: 100%;
    content: " ";
    position: absolute;
    right: 0;
    bottom: -20px
}

.short-line:last-of-type::after {
    display: none
}

.vertical-line {
    width: 2px;
    height: 40px;
    content: " "
}

.fake-line {
    height: 2px;
    content: " ";
    background-color: #dbdbdb
}

.ab-squite {
    margin-top: -80px;
    margin-left: 20px;
    opacity: .5;
    z-index: 1
}

.z-0 {
    z-index: 0
}

.z-1 {
    z-index: 1
}

.mb-less {
    margin-bottom: -40px
}

@media screen and (max-width: 0) {
    .mb-less.mb-zo-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 320px) {
    .mb-less.mb-xx-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 480px) {
    .mb-less.mb-xs-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 640px) {
    .mb-less.mb-sm-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 800px) {
    .mb-less.mb-md-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 1024px) {
    .mb-less.mb-lg-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 1440px) {
    .mb-less.mb-xl-less {
        margin-bottom: 0px !important
    }
}

@media screen and (max-width: 1921px) {
    .mb-less.mb-1k-less {
        margin-bottom: 0px !important
    }
}

.pogress {
    position: relative;
    z-index: 0
}

.pogress::before {
    left: 15px;
    height: 15px;
    content: " ";
    position: absolute;
    top: 15px;
    left: 15px;
    background-color: rgba(139, 197, 63, 0.8);
    background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.3) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.3) 50%, rgba(255, 255, 255, 0.3) 75%, transparent 75%, transparent);
    background-size: 35px 35px;
    box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.25);
    z-index: 0;
    border-radius: 20px 20px
}

@media screen and (max-width: 551px) {
    .pogress::before {
        display: none
    }
}

.pogress::after {
    left: 15px;
    height: 15px;
    right: 15px;
    content: " ";
    position: absolute;
    top: 15px;
    left: 15px;
    border-radius: 20px 20px;
    z-index: -1;
    box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.25);
    background-color: #ebebeb;
    background-size: 35px 35px;
    background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.3) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.3) 50%, rgba(255, 255, 255, 0.3) 75%, transparent 75%, transparent)
}

@media screen and (max-width: 551px) {
    .pogress::after {
        display: none
    }
}

.pogress>* {
    flex: 1 1 20%;
    text-align: center;
    position: relative;
    z-index: 1;
    padding: 0 15px
}

.pogress>*>.sprite {
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    border-radius: 50%;
    font-family: sans-serif;
    box-shadow: 0 0 0 3px #fff, inset 2px 2px 2px 0 rgba(0, 0, 0, 0.24);
    position: relative;
    z-index: 2;
    margin-bottom: 10px;
    background-color: #1ba5d1
}

@media screen and (max-width: 419px) {
    .pogress>*>.sprite {
        width: 50px;
        height: 50px;
        line-height: 50px;
        font-size: 18px
    }
}

.pogress>*>.sprite+* {
    display: block;
    font-weight: bold;
    letter-spacing: 1px;
    color: #1ba5d1
}

@media screen and (max-width: 551px) {
    .pogress>* {
        flex: 2 1 50%;
        width: 50%;
        text-align: left;
        padding-bottom: 1rem
    }

    .pogress>*>.sprite {
        display: inline-block;
        vertical-align: middle;
        margin-right: 6px
    }

    .pogress>*>.sprite+* {
        display: inline-block;
        vertical-align: middle
    }
}

@media screen and (max-width: 420px) {
    .pogress>* {
        flex: 1 1 100%;
        width: 100%;
        text-align: left;
        padding-bottom: 1rem
    }

    .pogress>*>.sprite {
        display: inline-block;
        vertical-align: middle;
        margin-right: 12px
    }

    .pogress>*>.sprite+* {
        display: inline-block;
        vertical-align: middle;
        font-size: 18px
    }
}

.pogress.step-1::before {
    width: 17.85%;
    transition: all ease-in-out .5s
}

.pogress.step-1>.current>.sprite {
    background-color: #8bc53f
}

.pogress.step-1>.current>.sprite+* {
    color: #8bc53f
}

.pogress.step-2::before {
    width: 37.85%;
    transition: all ease-in-out .5s
}

.pogress.step-2>.current>.sprite {
    background-color: #8bc53f
}

.pogress.step-2>.current>.sprite+* {
    color: #8bc53f
}

.pogress.step-3::before {
    width: 57.85%;
    transition: all ease-in-out .5s
}

.pogress.step-3>.current>.sprite {
    background-color: #8bc53f
}

.pogress.step-3>.current>.sprite+* {
    color: #8bc53f
}

.pogress.step-4::before {
    width: 77.85%;
    transition: all ease-in-out .5s
}

.pogress.step-4>.current>.sprite {
    background-color: #8bc53f
}

.pogress.step-4>.current>.sprite+* {
    color: #8bc53f
}

.pogress.step-5::before {
    width: 97.85%;
    transition: all ease-in-out .5s
}

.pogress.step-5>.current>.sprite {
    background-color: #8bc53f
}

.pogress.step-5>.current>.sprite+* {
    color: #8bc53f
}

.over-lr {
    width: calc(100% + 30px);
    margin-left: -15px;
    margin-right: -15px;
    display: block;
    float: left
}

.after-pattern {
    position: relative;
    padding-top: 60px;
    padding-bottom: 60px;
    margin-top: 60px
}

.after-pattern::before {
    width: 120%;
    height: 100%;
    content: " ";
    display: block;
    top: 0px;
    left: -20%;
    position: absolute;
    background-color: #f0f0f0;
    z-index: -1
}

@media screen and (max-width: 800px) {
    .after-pattern {
        padding-top: 30px;
        margin-top: 0
    }

    .after-pattern::before {
        height: 130%;
        top: -30%;
        width: calc(100% + 30px);
        left: -15px
    }
}

.after-line {
    position: relative;
    background-clip: content-box;
    border-radius: 6px;
    background-color: #f9f9f9
}

.after-line::after {
    border-radius: 6px;
    position: absolute;
    top: 0;
    left: 15px;
    right: 15px;
    bottom: 0px;
    content: " ";
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.05), 0 0 8px 0 rgba(0, 0, 0, 0.1);
    pointer-events: none;
    transition: all ease .25s
}

.small-size {
    font-size: 0.9375rem
}

@media screen and (max-width: 640px) {
    .small-size {
        font-size: 15px !important
    }
}

.icon-wrap {
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.1);
    padding: 10px
}

.icon-wrap .size--60 {
    font-size: 30px;
    border-right: 1px solid rgba(0, 0, 0, 0.1);
    transition: all ease .25s;
    color: #98af00
}

.icon-wrap .size--60+.media-body {
    width: calc(100% - 60px)
}

.icon-wrap .size--60+.media-body dl {
    margin-bottom: 0
}

.icon-wrap .size--60.icon-paper-airplane+.media-body dd {
    font-size: 16px
}

.icon-wrap .media-body {
    padding-left: 15px;
    margin-bottom: 0
}

.icon-wrap .media-body dd,
.icon-wrap .media-body dt {
    margin-bottom: 0
}

.icon-wrap .media-body dt {
    font-size: 20px;
    color: #98af00;
    letter-spacing: 1px;
    line-height: 1.5;
    font-weight: 500;
    margin-bottom: 0px
}

.icon-wrap .media-body dd {
    font-size: 20px;
    line-height: 1.4;
    font-weight: bold;
    font-weight: bold;
    font-family: sans-serif;
    color: #777;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: 1px
}

.icon-wrap .media-body:hover dd {
    color: #000
}

.ico-btn {
    display: inline-block;
    background-color: #cd4432;
    padding: 0px 15px 0px 40px;
    line-height: 36px;
    color: #fff;
    overflow: hidden;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.5)
}

.ico-btn::before {
    width: 36px;
    height: 36px;
    background-color: #fff;
    line-height: 36px;
    text-align: center;
    display: inline-block;
    margin-left: -40px;
    margin-right: 15px;
    color: #cd4432;
    font-size: 18px;
    margin-top: -2px;
    vertical-align: middle;
    transform: scale(1.2)
}

.ico-btn:hover {
    background-color: #ac392a;
    color: #fff
}

.btn[class*="primary"]:hover {
    color: #fff
}

.yt-control>a {
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding-left: 10px;
    padding-right: 10px
}

.prod-list ul {
    border-left: 1px solid #dfdfdf;
    border-right: 1px solid #dfdfdf;
    border-bottom: 1px solid #dfdfdf;
    flex-flow: row wrap !important
}

.prod-list .nav-item {
    border-bottom: 1px solid rgba(0, 0, 0, 0.11);
    box-shadow: inset 0 -1px 0 0 rgba(255, 255, 255, 0.35);
    transition: all ease-out .25s;
    position: relative !important;
    font-weight: 600;
    margin-bottom: -1px
}

.prod-list .nav-item:last-of-type {
    border-bottom: 0;
    box-shadow: none
}

.prod-list .nav-item:hover {
    background-color: #f7fafd
}

.prod-list .nav-item.active {
    background-color: #ebebeb
}

.prod-list .nav-item.active>a {
    color: #A5BE00
}

.prod-list .nav-item.active>a::after {
    color: #A5BE00
}

.prod-list .nav-item a {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #000;
    padding: .65rem 25px .65rem 0rem;
    position: relative;
    font-weight: 600;
    font-size: 16px
}

.prod-list .nav-item a::after {
    content: "\000BB";
    display: inline-block;
    width: 20px;
    height: 20px;
    line-height: 20px;
    vertical-align: middle;
    margin-left: -20px;
    transform: scale(1.2);
    margin-right: 5px;
    margin-top: -2px;
    position: absolute;
    right: -10px;
    top: 15px;
    color: #ccc
}

.news-list {
    min-height: 60vmin;
    align-content: flex-start
}

.news-list dl {
    position: relative;
    padding: 20px 15px 0 15px;
    margin-bottom: 0;
    flex-wrap: wrap
}

.news-list dl::after {
    width: calc(100% - 30px);
    display: block;
    content: " ";
    height: 1px;
    border-bottom: 1px dotted #dbdbdb;
    margin: 20px auto 0 auto
}

.news-list dl:last-of-type::after {
    display: none
}

.news-list dd,
.news-list dt {
    margin-bottom: 0
}

.news-list dt {
    display: flex;
    flex-flow: row wrap;
    margin-bottom: 12px;
    width: 255px;
    padding-right: 10px;
    align-items: center
}

.news-list dt>* {
    display: inline-block
}

.news-list dt .img {
    width: 130px;
    margin-left: 20px;
    padding-bottom: 35%;
    position: relative;
    overflow: hidden
}

.news-list dt .img img {
    position: absolute;
    width: 100%;
    display: block;
    top: 0;
    left: 50%;
    transform: translateX(-50.25%)
}

.news-list dt .date {
    font-size: 13px;
    color: #9EA3B0
}



@media screen and (max-width: 640px) {
    .news-list dt {
        width: 100%;
        padding-right: 0;
        margin-bottom: 15px
    }

    .news-list dt .img {
        width: 100%;
        order: -1;
        margin-left: 0;
        margin-bottom: 10px;
        padding-bottom: 56.26%
    }

    .news-list dt .date {
        font-size: 16px;
        color: #9EA3B0;
        order: 2;
        width: 100%
    }
}

.news-list dd {
    width: calc(100% - 255px);
    display: inline-block;
    padding-left: 40px !important
}

.news-list dd::before {
    font-family: 'icomoon';
    content: "\e92f";
    width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
    display: inline-block;
    margin-left: -30px;
    background-color: #0D1F2D;
    border-radius: 50%;
    margin-right: 4px;
    color: #FAE1DF;
    font-size: 12px;
    transform: scale(0.7);
    transform-origin: 0 0;
    box-shadow: inset 0 0 0 1px #0D1F2D;
    vertical-align: middle;
    margin-bottom: -3px
}

.news-list dd a {
    display: block;
    width: 100%;
    font-size: 16px;
    color: #0D1F2D;
    float: right;
    overflow: hidden
}

.news-list dd a>*:first-child {
    font-size: 18px;
    font-weight: 600
}

.news-list dd a>*:first-child+* {
    display: block;
    float: left;
    letter-spacing: 1px;
    text-align: justify;
    /* color: #9EA3B0; */
    color: #b28247;
    margin-bottom: .35rem;
    width: calc(100% + 0.6rem);

    position: relative;
    margin-right: -.4375rem;
    padding-right: 0.6rem;
    font-size: .9375rem !important;
    line-height: 1.59375rem !important;
    background-color: inherit
}

.news-list dd a>*:first-child+*::before,
.news-list dd a>*:first-child+*::after {
    position: absolute;
    right: 0
}

.news-list dd a>*:first-child+*::before {
    content: "...";
    bottom: 0;
    padding-right: .62rem;
    padding-left: .2rem;
    display: inline-block;
    vertical-align: middle;
    background-color: white;
    margin-left: 2px
}

.news-list dd a>*:first-child+*::after {
    content: " ";
    width: 1.45313rem;
    height: 28.33333px;
    margin-top: .9375rem;
    background-color: white
}

.news-list dd a:hover {
    color: #546A7B;
}



@media screen and (max-width: 640px) {
    .news-list dd {
        width: 100%;
        padding-left: 30px
    }

    .news-list dd:before {
        margin-left: -36px;
        margin-right: 14px
    }

    .news-list dd .img {
        transform: scale(1);
        margin-bottom: 0
    }

    .news-list dd a {
        font-size: 18px;
        font-weight: bold;
        line-height: 1.5
    }

}

.news-list.idx {
    min-height: auto
}

.news-list.idx dt {
    display: flex;
    flex-flow: row wrap;
    margin-bottom: 12px;
    width: 130px;
    padding-right: 30px;
    align-items: center
}

@media screen and (max-width: 480px) {
    .news-list.idx dt {
        width: 100%;
        padding-right: 0
    }
}

.news-list.idx dt>* {
    display: inline-block
}

.news-list.idx dt .img {
    display: none
}

.news-list.idx dt .date {
    font-size: 13px;
    color: #909a93
}

.news-list.idx dd {
    width: calc(100% - 130px);
    display: inline-block
}

.news-list.idx dd a>*:first-child {
    font-size: 16px
}

.news-list.idx dd a>*:first-child~* {
    display: none
}

.news-list.idx.caselist dl{padding: 0 15px;}

.news-list.idx.caselist dl dt{
    display: none;
    width: 0;
}

.news-list.idx.caselist dl dd{width: 100%; margin: 10px 0;}

.news-list.caselist dl::after{margin: 0;}

@media screen and (max-width: 480px) {
    .news-list.idx dd {
        width: 100%;
        padding-left: 30px
    }

    .news-list.idx dd:before {
        margin-left: -36px;
        margin-right: 14px
    }

    .news-list.idx dd a>*:first-child {
        font-size: 16px
    }

    .news-list.idx dd a>*:first-child~* {
        display: none
    }
}

.news-list.img-only dt .date {
    display: none
}

.news-list.img-only dt .img {
    width: 100%;
    padding-bottom: 56.25%;
    margin-left: 0;
    transform: scale(0.9);
    margin-bottom: -10px;
    transform-origin: 0 0
}



/* no-dt */
.news-list.no-dt dt{
    display: none;
}

.news-list.no-dt dd{
    width:  100%;
}

.news-list.no-dt dd::before{margin-bottom: -15px;}


.news-list.no-dt dd >a h5{margin: 5px 0;}
.news-list.no-dt dd >a p{display:  none;}

.news-list.no-dt dl{padding: 0 10px;}
.news-list.no-dt dl::after{margin:  0;}


.news-list.no-date dt {width: 130px; margin: 5px 0;}
.news-list.no-date dt .date{display: none;}
.news-list.no-date dt .img{
    width:  130px;
    /* margin-left: 0; */
    margin: 10px 0 !important;
    padding-bottom: 0 !important;
    padding-left: 15px;
    position:static;
    transform: none !important;
}

.news-list.no-date dt .img img{
    position:static;
    transform: none;
}

.news-list.no-date dd{width: calc(100% - 130px);}
.news-list.no-date dd::before{margin-bottom: -15px;}
.news-list.no-date dd >a h5{margin: 5px 0;}

.news-list.no-date dl{padding: 0 15px; align-items: center;}
.news-list.no-date dl::after{margin:  0;}


.news-list.no-pic dl{ 
    padding: 10px 15px;
    align-items: flex-start;
    border-bottom: 1px dotted lightgrey;}
.news-list.no-pic dl::after{margin: 0; display: none;}
.news-list.no-pic dt{ width:  130px; margin: 0;}
.news-list.no-pic dt .date{color:#b28349; font-size:14px;}
.news-list.no-pic dd{ width: calc(100% - 130px);}
.news-list.no-pic dd >a h5{margin: 0;}
.news-list.no-pic dd >a p {margin: 0;}


@media screen and (max-width: 840px) {
    .news-list.no-date dd{padding-left: 20px !important;}
    .news-list.no-date dd:before{display: none;}
    .news-list.no-date dd a > :first-child{font-size: 16px;}
}

@media screen and (max-width: 680px) {
    .news-list.no-date dl{align-items: flex-start;}
    .news-list.no-pic dl{padding: 15px;}
    .news-list.no-pic dt{ width:  100%; margin-bottom: 5px; padding: 0;}
    .news-list.no-pic dt .date{
        font-size: 14px; 
        color: #b28349; 
        background:#1a274e; 
        padding: 0 10px; 
        border-radius: 25px;
        width:  auto;
    }

    .news-list.no-pic dd{padding-left: 0 !important; width: 100%;}
    .news-list.no-pic dd::before{display: none;}


}

@media screen and (max-width: 640px) {
    .news-list.img-only dt .img {
        transform: scale(1);
        margin-bottom: 0px;
        transform-origin: 0 0
    }
}

iframe[allow] {
    width: 100%;
    height: 100%;
    display: block
}

.news-page {
    /* white-space: pre-line; */
    font-size: .9375rem;
    letter-spacing: 0.5px;
    line-height: 1.7;
    margin-bottom: 1rem;
    color: #000;
    user-select: auto !important;
}

.news-page img {
    display: block;
    max-width: 100%;
    margin-bottom: 1rem
}

.news-page h1,
.news-page h2,
.news-page h3 {
    font-weight: 600
}

.news-page h1 {
    font-size: 1.8rem;
    margin-bottom: -.8rem
}

.news-page h2 {
    font-size: 1.6rem;
    margin-bottom: -.8rem
}

.news-page h3 {
    font-size: 1.5rem;
    margin-bottom: -.8rem
}

.news-page h4 {
    font-size: 1.3rem;
    margin-bottom: -.8rem
}

.news-page h5 {
    font-size: 1.2rem;
    margin-bottom: -.8rem
}

.news-page .news-vid {
    position: relative;
    display: block;
    width: 80%;
    max-width: 640px;
    padding-bottom: 38%
}

@media screen and (max-width: 640px) {
    .news-page .news-vid {
        padding-bottom: 56.25%;
        width: 100%
    }
}

.news-page .news-vid iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.news-wrap * {
    transition: all ease-out .3s
}

.news-wrap .slide,
.news-wrap>[class|="col"] {
    position: relative;
    background-clip: content-box;
    background-color: #f1fbf7;
    transition: all ease-in-out .3s;
    position: relative;
    outline: 0;
    border: 0;
    box-shadow: none
}

.news-wrap .slide::after,
.news-wrap>[class|="col"]::after {
    content: " ";
    display: block;
    position: absolute;
    top: 0px;
    bottom: 0px;
    right: 15.5px;
    left: 15.5px;
    border: 1px solid #e5e5e5;
    pointer-events: none;
    transition: all ease-out .3s;
    border-radius: 4px
}

.news-wrap .slide [class*="abimg"],
.news-wrap>[class|="col"] [class*="abimg"] {
    margin-bottom: .8rem
}

.news-wrap .slide [class*="abimg"] img,
.news-wrap>[class|="col"] [class*="abimg"] img {
    filter: brightness(0.9);
    transition: all ease-out .3s
}

.news-wrap .slide [class*="abimg"]+*,
.news-wrap>[class|="col"] [class*="abimg"]+* {
    position: relative;
    color: inherit;
    z-index: 1;
    margin-bottom: 1rem;
    padding-left: 1rem;
    padding-right: 1rem
}

.news-wrap .slide [class*="abimg"]+*>*:first-child,
.news-wrap>[class|="col"] [class*="abimg"]+*>*:first-child {
    display: block;
    font-size: 15px;
    font-weight: bold;
    margin-bottom: 0;
    transition: all ease-out .3s;
    font-weight: 600;
    padding-left: 25px;
    margin-bottom: 0;
    color: #949892
}

.news-wrap .slide [class*="abimg"]+*>*:first-child::before,
.news-wrap>[class|="col"] [class*="abimg"]+*>*:first-child::before {
    font-family: 'icomoon';
    content: "\e906";
    display: inline-block;
    font-weight: normal;
    vertical-align: middle;
    margin-right: 10px;
    margin-left: -25px
}

.news-wrap .slide [class*="abimg"]+*>*:first-child+*,
.news-wrap>[class|="col"] [class*="abimg"]+*>*:first-child+* {
    display: block;
    font-size: .9375rem;
    color: #333;
    text-align: left;
    margin-top: .5rem;
    margin-bottom: 10px;
    font-weight: bold;
    line-height: 1.6;
    height: 48px;
    overflow: hidden;
    font-weight: 500
}

.news-wrap .slide a,
.news-wrap>[class|="col"] a {
    display: inline-block;
    position: relative;
    line-height: 36px;
    margin-bottom: 15px;
    font-size: .9rem;
    letter-spacing: .5px;
    position: relative;
    transition: all ease-out .3s;
    border-radius: 3px;
    overflow: hidden;
    border: 0;
    outline: 0
}

.news-wrap .slide a:hover img,
.news-wrap>[class|="col"] a:hover img {
    transform: scale(1.1);
    filter: brightness(1.1)
}

.news-wrap .slide:hover,
.news-wrap>[class|="col"]:hover {
    background-color: #fff
}

.limit-imaged>* {
    padding: 1px;
    background-color: #EBF2FA;
    background-clip: content-box
}

.limit-imaged>*:nth-child(6)~* {
    display: none
}

.textarea {
    white-space: pre-line;
    font-size: 1rem;
    line-height: 1.8;
    max-width: 100%;
    display: block;
    float: left;
    font-weight: 400;
    margin-top: -1rem;
    letter-spacing: .5px
}

.textarea>* {
    font-size: inherit;
    line-height: inherit;
    margin-top: -2rem;
    margin-bottom: 0
}

.textarea img {
    display: block;
    margin: 1rem 0 0 0;
    max-width: 100%
}

.textarea img+img {
    margin-top: -1rem
}

.textarea.small-size {
    font-size: 0.9375rem
}

.share-wrap .dropdown-toggle {
    width: 40px;
    height: 40px;
    display: inline-block;
    line-height: 40px;
    border: 0;
    outline: 0;
    border-radius: 4px;
    transform: scale(0.75)
}

.share-wrap .dropdown-toggle::after {
    display: none
}

.share-wrap .dropdown-toggle+.dropdown-menu {
    width: 220px;
    padding-left: 6px;
    padding-right: 6px
}

.share-wrap .dropdown-toggle+.dropdown-menu a {
    display: inline-block;
    vertical-align: middle;
    margin: 3px 2.4px 5px 2.4px
}

.tab-pane .textarea {
    margin-top: -25px
}

.prod-detail img {
    max-width: 100%;
    display: block
}

.prod-detail .media dt {
    max-width: 90px;
    margin-right: 1rem
}

.prod-detail .textarea {
    white-space: pre-line;
    font-size: 1.0625rem;
    line-height: 1.8;
    max-width: 100%;
    display: block;
    float: left
}

.prod-detail .textarea>* {
    font-size: inherit;
    line-height: inherit;
    margin-top: -2rem;
    margin-bottom: 0
}

.prod-detail .btn-lg {
    font-size: 1.0625rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem
}

.prod-detail .type {
    padding-left: 90px;
    margin-bottom: 30px
}

.prod-detail .type>span {
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    position: relative;
    margin-left: -90px;
    width: 90px;
    color: #595959
}

.less-mr {
    float: left;
    width: calc(100% + 30px);
    margin-left: -15px;
    margin-right: -15px;
    min-height: 70vh
}

.shuffle-ctrl button {
    padding: 6px 1.5rem;
    font-size: 17px;
    font-weight: bold;
    letter-spacing: 1px
}

.shuffle-ctrl button:focus {
    box-shadow: none !important
}

.shuffle-ctrl .dropdown-menu {
    max-width: 240px;
    padding: 0px !important;
    width: 100%
}

.shuffle-ctrl .dropdown-item {
    display: block;
    padding: 8px 15px;
    margin: 0
}

.shuffle-ctrl .dropdown-item.active {
    background-color: #1a274e;
    color: #fff
}

.prod-wrap {
    justify-content: flex-start;
    align-content: flex-start
}

.prod-wrap .prod-type {
    display: none
}

.prod-wrap>* {
    padding-bottom: 30px;
    position: relative
}

.prod-wrap>*::after {
    position: absolute;
    pointer-events: none;
    top: 0;
    bottom: 30px;
    left: 15px;
    right: 15px;
    border: 1px solid #eee;
    border-radius: 4px;
    content: " "
}

.prod-wrap>*>a {
    display: block;
    width: 100%;
    padding: 20px
}

.prod-wrap>*>a+* {
    position: absolute;
    top: 30px;
    display: block;
    width: 100%;
    margin-top: -50px;
    text-align: right;
    padding: 20px 30px
}

.prod-wrap>*>a+* label,
.prod-wrap>*>a+* button {
    width: 34px;
    height: 34px;
    margin-bottom: 0;
    margin: 5px;
    display: inline-block;
    line-height: 34px;
    background-color: #1a274e;
    text-align: center;
    color: #fff;
    border-radius: 3px;
    transition: all ease-out .3s;
    transform-origin: 100% 0%;
    position: relative;
    z-index: 1;
    border: 0;
    outline: 0
}

.prod-wrap>*>a+* label::before,
.prod-wrap>*>a+* button::before {
    font-family: 'icomoon';
    content: "\e90e"
}

.prod-wrap>*>a+* label::after,
.prod-wrap>*>a+* button::after {
    position: absolute;
    content: attr(data-title);
    background-color: #242424;
    display: block;
    white-space: nowrap;
    font-size: 13px;
    padding: 6px 8px;
    line-height: 13px;
    top: 5px;
    right: calc(100% + 5px);
    border-radius: 3px;
    transition: all ease-in-out .2s;
    transform-origin: 100% 50%;
    transform: scaleX(0);
    opacity: 0
}

.prod-wrap>*>a+* label.push-cart,
.prod-wrap>*>a+* button.push-cart {
    background-color: #242424;
    pointer-events: none
}

.prod-wrap>*>a+* label.push-cart::before,
.prod-wrap>*>a+* button.push-cart::before {
    content: "\e90a"
}

.prod-wrap>*>a+* label.push-cart::after,
.prod-wrap>*>a+* button.push-cart::after {
    transform: scaleX(1);
    opacity: 1
}

.prod-wrap>*>a+* label:hover::after,
.prod-wrap>*>a+* button:hover::after {
    transform: scaleX(1.1);
    opacity: 1
}

.prod-wrap>*>a * {
    transition: all ease-out .3s
}

.prod-wrap>*>a:hover [class*="abimg"]::after {
    transform: scale(1);
    opacity: 1
}

.prod-wrap>*>a:hover img {
    transform: scale(1.1) translateY(-10px);
    filter: brightness(0.6)
}

.prod-wrap>* [class*="abimg"] {
    transition: all ease-out .3s;
    margin-bottom: 12px
}

.prod-wrap>* [class*="abimg"]::after {
    width: 60px;
    height: 60px;
    line-height: 60px;
    text-align: center;
    font-size: 50px;
    color: #fff;
    font-family: 'icomoon';
    content: "\e943";
    display: block;
    top: 50%;
    left: 50%;
    position: absolute;
    margin-top: -30px;
    margin-left: -30px;
    transition: all ease .3s;
    transform: scale(0.5);
    opacity: 0
}

.prod-wrap>* [class*="abimg"]+*>*:first-child {
    font-size: 1rem;
    letter-spacing: 1px;
    text-align: left;
    width: 100%;
    display: block;
    color: #000;
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis
}

@media screen and (max-width: 479px) {
    .prod-wrap>* [class*="abimg"]+*>*:first-child {
        white-space: normal;
        text-overflow: auto
    }
}

.prod-wrap>* [class*="abimg"]+* .w-100 {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    width: 100%
}

.prod-wrap>* [class*="abimg"]+* .w-100>* {
    width: 50%;
    font-size: 15px;
    padding-right: 10px
}

.prod-wrap>* [class*="abimg"]+* .w-100>*::before {
    display: block;
    content: attr(data-title);
    font-size: 14px;
    letter-spacing: 2px
}

.prod-wrap>* [class*="abimg"]+* .w-100>*:last-child {
    color: #1a274e
}

.prod-wrap>* [class*="abimg"]+* .w-100>*:first-child {
    color: #cf164d
}

@media screen and (max-width: 639.98px) {
    .prod-wrap>* [class*="abimg"]+* .w-100>* {
        width: 100%;
        padding-left: 0;
        margin-bottom: 0px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap
    }

    .prod-wrap>* [class*="abimg"]+* .w-100>*::before {
        display: inline-block;
        vertical-align: middle;
        margin-right: 10px;
        font-size: 13px
    }

    .prod-wrap>* [class*="abimg"]+* .w-100>*+* {
        margin-bottom: 20px
    }
}

.prod-wrap>*:hover button:not(.push-cart) {
    transform: scale(0.9);
    background-color: #8fa500;
    font-size: 18px
}

.prod-wrap.filtr-container {
    opacity: 0;
    margin: 0;
    width: 100%;
    transition: all ease .3s;
    align-items: stretch
}

.prices {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.prices>*:last-child::before,
.prices>*:last-child::after {
    display: inline-block;
    vertical-align: middle
}

.prices>*:last-child::before {
    content: "$NT.";
    margin-right: 3px
}

.prices>*:last-child::after {
    content: "元";
    margin-top: -3px
}

.projects>* {
    padding: 0px .8rem;
    align-items: center
}

.projects>*>* {
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 0
}

.projects>* label {
    padding: 6px 0px;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    text-overflow: ellipsis
}

.projects>* input[type="checkbox"],
.projects>* input[type="radio"] {
    width: 16px;
    height: 16px;
    vertical-align: middle;
    margin-right: 10px;
    margin-top: -5px
}

.projects>* span {
    font-size: 0px;
    opacity: 0
}

.project-text {
    width: 100%;
    text-align: left;
    min-width: 150px;
    position: relative;
    padding-right: 25px;
    font-size: 16px
}

.project-text::after {
    position: absolute;
    top: 50%;
    right: 7px;
    margin-top: -3px
}

.prod-alert.toast {
    position: fixed;
    top: 50%;
    right: 1rem;
    z-index: 0;
    transform: translateY(-50%);
    box-shadow: 0px 0px 0 1px rgba(0, 0, 0, 0.02) 0 0 20px 0 rgba(0, 0, 0, 0.4)
}

.toggle-state {
    min-height: 60px
}

.toggle-state a {
    order: -1;
    display: none
}

.toggle-state button .spinner-border {
    display: inline-block;
    vertical-align: middle;
    opacity: 0;
    width: 0;
    height: 0;
    border-width: 0;
    transition: all ease .25s;
    margin-top: -4px
}

.toggle-state button.add-cart .spinner-border {
    opacity: 1;
    width: 1rem;
    height: 1rem;
    border-width: 0.2em;
    transition: all ease .25s;
    margin-right: 6px
}

.logo-icon {
    position: relative;
    background-color: #EBF2FA;
    color: #424242;
    padding-right: 50px
}

.logo-icon::after {
    position: absolute;
    width: 40px;
    height: 50px;
    margin-top: -10px;
    top: 0;
    right: 0;
    content: " ";
    background-image: url("../images/logo-icon.png");
    background-size: contain;
    background-repeat: no-repeat
}

.shopping-pogress [class*="abimg"] {
    background-image: url("../images/shopping-pogress.jpg");
    background-size: 100% 500%
}

.shopping-pogress [data-slick-index="1"] [class*="abimg"] {
    background-position: 50% 25%
}

.shopping-pogress [data-slick-index="2"] [class*="abimg"] {
    background-position: 50% 50%
}

.shopping-pogress [data-slick-index="3"] [class*="abimg"] {
    background-position: 50% 75%
}

.shopping-pogress [data-slick-index="4"] [class*="abimg"] {
    background-position: 50% 100%
}

.shopping-pogress [data-slick-index="5"] [class*="abimg"] {
    background-position: 50% 125%
}

.text-gy {
    color: #69777a
}

.bg-ef {
    background-color: #efefef
}

footer {
    background-color: #efefef
}

footer .logo.text {
    width: 100% !important;
    height: auto;
    content: " ";
    padding-bottom: calc((100% / 16) * 6);
    background-size: 96% 96%;
    background-repeat: no-repeat
}

footer .logo+p {
    font-size: .9rem;
    text-align: justify
}

footer .media,
footer ul {
    list-style-type: none;
    padding-left: 0;
    margin-left: 0;
    margin-right: 0;
    padding-right: 0
}

footer .media>*,
footer ul>* {
    display: inline-block;
    padding-left: 30px;
    padding-right: 0px
}

footer .media>*>i,
footer ul>*>i {
    width: 20px;
    height: 20px;
    line-height: 20px;
    vertical-align: top;
    margin-left: -30px;
    display: inline-block;
    margin-right: 0px;
    margin-top: 4px;
    align-self: flex-start;
    color: #777
}

footer .media>*>p,
footer ul>*>p {
    display: inline-block;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 10px;
    color: #494949;
    font-size: .9375rem
}

footer .media>*>p a,
footer ul>*>p a {
    color: inherit;
    padding: 0;
    font-size: inherit
}

footer .media>*>p a:hover,
footer ul>*>p a:hover {
    color: #0D1F2D;
}

footer ul a {
    font-size: 0.9375rem;
    color: #444;
    font-weight: 500
}

footer ul a:hover {
    color: #0D1F2D;
}

footer .privacy>a {
    display: inline-block
}

footer .privacy>a+a::before {
    width: 1px;
    height: 10px;
    vertical-align: middle;
    content: " ";
    background-color: #ccc;
    display: inline-block;
    margin-left: 8px;
    margin-right: 8px;
    margin-top: -3px
}

footer .menu_btm a {
    margin-bottom: 6px;
    display: block;
    color: #434343
}

footer>.gw:last-child {
    background-color: #0D1F2D;
}

footer>.gw:last-child p {
    font-size: 14px;
    color: #fff
}

footer>.gw:last-child a {
    color: #bfbfbf
}

footer>.gw:last-child a:hover {
    color: #e3ecee
}

.member-icon {
    background-image: url("../images/member-sets.png");
    background-repeat: no-repeat;
    background-size: 100% 300%
}

.member-icon.member-edit {
    background-position: 50% 0%
}

.member-icon.member-logout {
    background-position: 50% 50%
}

.member-icon.shopping-list {
    background-position: 50% 100%
}

/*# sourceMappingURL=layout.min.css.map */