@charset "UTF-8";
*, *::before, *::after { box-sizing: border-box; }

html { height: 100%; }

body { position: relative; width: 100%; height: 100%; font-size: 16px; line-height: 1.5; color: #000000; font-weight: normal; font-family: "微軟正黑體", "Microsoft JhengHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 16px; font-style: normal; background-color: #ffffff; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }

.container:after { content: ''; display: block; clear: both; }

.isList ul { list-style-type: disc; list-style-position: inside; }

.isList ul > li { list-style-type: disc; }

.noList ul { list-style-type: none; }

a { text-decoration: none; }

ul { margin: 0; padding: 0; list-style: none; }

img { max-width: 100%; height: auto; }

header.header { background: #fff; padding: 1.5em 0 0; border-bottom: 1px solid #cccccc; box-shadow: 0 4px 5px -2px #cccccc; display: none; }

@media all and (min-width: 64.0625em) { header.header { display: block; } }

.row { display: flex; flex-direction: row; flex-wrap: wrap; width: 100%; }

.menu, .lang { display: flex; flex-direction: column; }

.menu { display: none; font-weight: bold; }

@media all and (min-width: 64.0625em) { .menu { display: block; } }

.menu > ul { display: flex; flex-direction: row; justify-content: flex-start; }

.menu > ul > li { cursor: pointer; padding: 0 0 1em; margin: 0 1em; border-bottom: 2px solid transparent; transition: all .3s ease; }

.menu > ul > li:hover { border-bottom: 2px solid #00489d; }

.menu > ul > li:hover .sub-menu { display: block; }

.menu > ul > li a { display: block; padding: 20px 15px 0; color: #333; }

.menu > ul > li a.active, .menu > ul > li a:hover { color: #00489d; }

.sub-menu { display: none; z-index: 2; position: absolute; width: 100%; top: 87px; left: 0; background: #fff; box-shadow: 0 4px 5px -2px #cccccc; padding: 1em 0; text-align: center; }

.sub-menu ul { display: flex; flex-direction: row; justify-content: center; }

.sub-menu ul .sub-item { margin-bottom: .5em; }

.sub-menu ul a { font-size: 16px; color: #333; }

.lang ul { display: flex; flex-direction: row; justify-content: flex-start; }

.lang li { position: relative; cursor: pointer; }

.lang li::after { content: '/'; position: absolute; display: block; padding: 0 10px; top: 20px; right: -12px; color: #999999; }

.lang li:last-child::after { display: none; }

.lang li:hover a { color: #333; }

.lang li a { display: block; font-size: 13px; padding: 24px 5px 0; color: #999999; }

.mobile-lang { position: absolute; top: 60px; width: 100%; background: #00489d; display: block; }

@media all and (min-width: 64.0625em) { .mobile-lang { display: none; } }

.mobile-lang ul { display: flex; flex-direction: row; justify-content: center; align-items: center; padding: 5px; }

.mobile-lang li { position: relative; cursor: pointer; }

.mobile-lang li::after { content: '/'; position: absolute; display: block; padding: 0 10px; top: -2px; right: -12px; color: #FFFFFF; }

.mobile-lang li:last-child::after { display: none; }

.mobile-lang li:hover a { color: #FFFFFF; text-decoration: underline; }

.mobile-lang li a { display: block; font-size: 13px; padding: 0 16px; color: #FFFFFF; }

.logo { margin: 0 auto 0 0; line-height: 1; padding: 1em 0; display: none; }

@media all and (min-width: 64.0625em) { .logo { display: block; padding: 0; } }

.logo img { max-width: 70%; }

@media all and (min-width: 45em) { .logo .logo img { max-width: 100%; } }

.mobile_head { position: fixed; display: block; width: 100%; height: 60px; background-color: rgba(255, 255, 255, 0.85); z-index: 20; }

@media all and (min-width: 64.0625em) { .mobile_head { display: none; } }

.mobile_head .m_logo { position: relative; text-align: center; margin: 6px 0; z-index: 11; float: left; }

.mobile_head .m_logo a { display: block; width: 214px; height: 48px; margin: 0 auto 0 5.4298642534%; background-repeat: no-repeat; background-position: left center; background-size: 60%; background-image: url(../images/logo.png); }

#m-menu { display: block; position: fixed; top: 0; right: 5.4298642534%; z-index: 10; }

#m-menu .hamburger.is-active { padding: 22px 0 20px; }

#m-menu .hamburger.is-active .hamburger-inner::before { top: 0; }

#m-menu .hamburger.is-active .hamburger-inner::after { top: 0; }

#m-menu .hamburger-inner, #m-menu .hamburger-inner::before, #m-menu .hamburger-inner::after { background-color: #00489d; border-radius: 1px; }

@media all and (min-width: 48em) { #m-menu .hamburger-inner, #m-menu .hamburger-inner::before, #m-menu .hamburger-inner::after { width: 26px; height: 2px; } }

@media all and (max-width: 47.9375em) { #m-menu .hamburger-inner, #m-menu .hamburger-inner::before, #m-menu .hamburger-inner::after { width: 18px; height: 2px; } }

#m-menu .hamburger-inner::before { top: -6px; }

#m-menu .hamburger-inner::after { top: -12px; }

@media all and (min-width: 48em) { #m-menu .hamburger-box { width: 26px; height: 15px; } }

@media all and (max-width: 47.9375em) { #m-menu .hamburger-box { width: 18px; height: 15px; } }

#m-menu .hamburger { position: relative; z-index: 2; padding: 18px 0; background: transparent; }

#m-menu .hamburger:hover { opacity: 1; }

@media all and (min-width: 64.0625em) { #m-menu { display: none; } }

.sidebar { position: fixed; top: 0; bottom: 0; right: 0; width: 100%; background-color: white; -webkit-transition: transform 0.3s ease-out; -webkit-transition: -webkit-transform 0.3s ease-out; transition: -webkit-transform 0.3s ease-out; transition: transform 0.3s ease-out; transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out; height: 100%; overflow: auto; }

.sidebar > ul { height: 100%; padding: 0; margin-top: 60px; }

.sidebar a { display: block; font-weight: 600; padding: 15px; color: #00489d; text-transform: uppercase; letter-spacing: 0.1em; font-size: 16px; }

.sidebar a img { display: inline-block; vertical-align: middle; margin-right: 10px; }

.sidebar.is-hidden { -webkit-transform: translateX(190%); transform: translateX(190%); }

.m_sub { position: relative; width: 100%; display: block; display: none; }

.m_sub_list { position: relative; }

.m_sub_list::after { position: absolute; top: 15px; right: 1em; display: block; content: '\f123'; font-family: 'Ionicons'; font-size: 18px; color: #00489d; }

.m_sub_menu { overflow: hidden; }

.m_sub_menu:after { content: ''; display: block; clear: both; }

.m_sub_menu.support li { width: 32.2033898305%; float: left; margin-right: 1.6949152542%; }

.m_sub_menu.support li:nth-of-type(3n) { width: 32.2033898305%; float: right; margin-right: 0; }

.m_sub_menu.product li { width: 100%; float: left; margin-left: 0; margin-right: 0; /* border-bottom: 1px solid rgba(255, 255, 255, 0.8); */ }

.m_sub_menu .title { width: 100%; float: left; margin-left: 0; margin-right: 0; padding: 15px 15px 0; color: #fff; }

.m_sub_menu .title h3 { margin: 0; font-size: 18px; font-weight: 900; }

.m_sub_menu li a { display: block; padding: 15px; color: #00489d; text-transform: uppercase; font-weight: 400; }

.m_sub_menu li a::after { content: ''; display: block; clear: both; }

.m_sub_menu figure { margin: 0; text-align: center; }

.m_sub_menu li h4 { font-size: 16px; font-weight: 600; text-align: center; margin: .5em 0; }

.m_sub_menu.support figure { width: 100%; float: left; margin-left: 0; margin-right: 0; text-align: center; margin-bottom: 8px; }

.m_sub_menu.support figure img { max-height: 30px; }

.m_sub_menu.support h4 { width: 100%; float: left; margin-left: 0; margin-right: 0; height: 24px; line-height: 1.2; }

.overlay { position: fixed; width: 100%; height: 100%; top: 0; left: 0; z-index: 4; background: rgba(0, 0, 0, 0.7); display: none; }

.overlay.is-active { display: block; }

.hidden { border: 0; clip: rect(1px 1px 1px 1px); clip: rect(1px, 1px, 1px, 1px); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }

.container { max-width: 1200px; margin-left: auto; margin-right: auto; }

.container:after { content: " "; display: block; clear: both; }

.container-compact { position: relative; max-width: 960px; margin-left: auto; margin-right: auto; }

.container-compact:after { content: " "; display: block; clear: both; }

img { display: block; max-width: 100%; height: auto; }

a { cursor: pointer; }

button { outline: none; }

.inner-block { padding-top: 60px; }

@media all and (min-width: 64.0625em) { .inner-block { padding-top: 0; } }

.index-slider { display: none !important; }

@media all and (min-width: 45em) { .index-slider { display: block !important; } }

.index-slider.mobile { display: block !important; }

@media all and (min-width: 45em) { .index-slider.mobile { display: none !important; } }

.index-slider .slider-item { position: relative; display: block; padding-top: 40.1041667%; padding-bottom: 40.1041667%; width: 100%; background-repeat: no-repeat; background-size: cover; background-position: center center; }

@media all and (min-width: 64.0625em) { .index-slider .slider-item { padding-top: 0; padding-bottom: 40.1041667%; } }

.index-slider .slider-item span { display: block; position: absolute; width: 30%; height: 30%; top: 50%; left: 50%; transform: translate(-50%, -50%); background-image: url(../images/index/icon-play.png); background-repeat: no-repeat; background-size: contain; background-position: center center; }

.index-slider.owl-theme .owl-nav.disabled + .owl-dots { margin-top: -40px; position: relative; z-index: 2; }

.index-slider.owl-theme .owl-dots .owl-dot span { width: 15px; height: 15px; margin: 5px 2em; }

.index-slider.owl-theme .owl-dots .owl-dot.active span, .index-slider.owl-theme .owl-dots .owl-dot:hover span { background: #e94820; }

.index-block { display: flex; flex-direction: row; flex-wrap: wrap; width: 100%; }

.index-block:after { content: ''; display: block; clear: both; }

.index-block .index-item { position: relative; margin-bottom: 1.6949152542%; width: 100%; float: left; margin-left: 0; margin-right: 0; }

@media all and (min-width: 45em) { .index-block .index-item { width: 32.2033898305%; float: left; margin-right: 1.6949152542%; } .index-block .index-item:nth-last-child(-n + 3) { margin-bottom: 0; } .index-block .index-item:nth-child(3n) { width: 32.2033898305%; float: right; margin-right: 0; } }

.index-block .index-item.index-video { background-size: cover; background-repeat: no-repeat; background-position: center center; padding-bottom: 21.472%; }

@media all and (max-width: 44.9375em) { .index-block .index-item.index-video { padding-bottom: 66.675%; } }

.index-block .index-item.index-video span { display: block; position: absolute; width: 50%; height: 50%; top: 50%; left: 50%; transform: translate(-50%, -50%); background-image: url(../images/index/icon-play.png); background-repeat: no-repeat; background-size: contain; background-position: center center; }

.index-block .index-title { position: absolute; color: #fff; text-shadow: 2.796px 4.145px 10px rgba(0, 0, 0, 0.8); font-size: 3em; line-height: 1.2; font-weight: 700; text-align: center; top: 50%; left: 50%; transform: translate(-50%, -50%); }

.footer { position: relative; background-color: #00489d; padding: 3em 0 0 0; }

.footer:after { content: ''; display: block; clear: both; }

.footer::after { content: ''; display: block; background: url(../images/footer/footer-pattern.png) repeat-x left top; width: 100%; height: 37px; margin: 3em 0 0 0; }

.footer-info { width: 100%; float: left; margin-left: 0; margin-right: 0; }

@media all and (min-width: 45em) { .footer-info { width: 32.2033898305%; float: left; margin-right: 1.6949152542%; } }

.footer-logo { display: block; background: url(../images/footer/footer-logo.png) no-repeat left top; width: 174px; height: 97px; margin: 0 auto; }

@media all and (min-width: 45em) { .footer-logo { margin: 0; } }

.footer .site-map { width: 100%; float: left; margin-left: 0; margin-right: 0; padding: 1em; }

@media all and (min-width: 45em) { .footer .site-map { width: 66.1016949153%; float: right; margin-right: 0; padding: 0; } }

.site-map a, .site-map h2 { color: #ffffff; }

.site-map h2 { font-size: 1em; }

.site-map li > ul li a { font-size: 0.8125em; }

.site-map li > ul li a:hover { text-decoration: underline; }

.site-map li > ul li { margin-bottom: .5em; }

.site-map li > ul li:last-child { margin-bottom: 0; }

@media all and (max-width: 44.9375em) { .site-map > ul { display: flex; flex-wrap: wrap; justify-content: center; } }

@media all and (max-width: 44.9375em) { .site-map > ul li.column { flex: 1 0 100%; text-align: center; margin-bottom: 1.3em; } .site-map > ul li.column:last-child { margin-bottom: 0; } }

@media all and (min-width: 45em) { .site-map > ul li.column { width: 23.7288135593%; float: left; margin-right: 1.6949152542%; } .site-map > ul li.column:nth-child(4n) { width: 23.7288135593%; float: right; margin-right: 0; } }

.copy { background-color: #00489d; }

.copy .design-by { text-align: center; color: #ffffff; text-decoration: underline; font-size: 0.8125em; padding: 1.5em 0; }

.banner { position: relative; display: flex; align-items: center; justify-content: center; background-position: 0 0; background-repeat: no-repeat; background-size: cover; }

@media all and (min-width: 45em) { .banner.mobile { display: none; } }

@media all and (max-width: 44.9375em) { .banner:not(.mobile) { display: none; }}

.banner span { display: block; color: #ffffff; text-shadow: 3px 4px 10px rgba(0, 0, 0, 0.8); font-size: 1.3em; text-align: center; line-height: 1.15; }

.banner span:last-child { font-size: 1em; font-weight: 400; }

@media all and (max-width: 44.9375em) { .banner { height: 300px; } }

@media all and (min-width: 45em) { .banner { padding: 6.2% 0; background-position: center; } .banner span { display: block; color: #ffffff; text-shadow: 3px 4px 10px rgba(0, 0, 0, 0.8); text-align: center; line-height: 1.15; font-size: 1.7em; } .banner span:last-child { font-size: 1.3em; font-weight: 400; } }

.banner-about { background-image: url(../images/about/m-banner-about.jpg); }

@media all and (min-width: 45em) { .banner-about { background-image: url(../images/about/banner-about.jpg); } }

.banner-innovate { background-image: url(../images/about/m-banner-innovate.jpg); }

@media all and (min-width: 45em) { .banner-innovate { background-image: url(../images/about/banner-innovate.jpg); } }

.row { display: flex; flex-direction: row; flex-wrap: wrap; width: 100%; }

.row.reverse { flex-direction: row-reverse; }

.row .column { display: flex; flex-direction: column-reverse; align-items: center; justify-content: center; }

@media all and (min-width: 45em) { .row .column { flex: 1; flex-basis: 50%; height: 70vh; padding: 0; } }

.column-content { max-width: 100%; text-align: center; padding: 1.5em 1em; }

@media all and (min-width: 45em) { .column-content { text-align: left; max-width: 60%; padding: 0; } }

.column-content .title { font-weight: 700; font-size: 1.3em; margin-bottom: 1rem; }

@media all and (min-width: 45em) { .column-content .title { font-size: 2em; } }

.column-content .info { font-weight: 400; font-size: 1em; line-height: 2; }

@media all and (min-width: 45em) { .column-content .info { font-size: 1.25em; line-height: 2.4; } }

.column-bg { position: relative; background-repeat: no-repeat; background-size: cover; background-position: center center; padding-bottom: 69.89%; }

@media all and (min-width: 45em) { .column-bg { padding-bottom: 0; } }

.column-text-bg { background: #eeeeee; }

.text { position: relative; text-align: center; color: #333333; }

.text-inner { padding: 1.5em 1em; }

.text h2 { font-size: 1.3em; font-weight: normal; letter-spacing: .4em; }

.text p { font-size: 1em; line-height: 2; }

.text.bg { background-size: cover; background-repeat: no-repeat; background-position: 0 0; padding: 16.66665% 0; }

@media all and (min-width: 45em) { .text { padding: 15em 0; } .text.no-bg { padding: 5em 0; } .text-inner { max-width: 960px; margin-left: auto; margin-right: auto; } .text-inner:after { content: " "; display: block; clear: both; } .text h2 { font-size: 1.5625em; } .text p { font-size: 1.25em; } }

.bg-inn-1 { background-image: url(../images/about/inn-01.jpg); }

.bg-inn-2 { background-image: url(../images/about/inn-02.jpg); }

.bg-inn-3 { background-image: url(../images/about/inn-03.jpg); }

.dealer { color: #333333; }

.dealer h2 { font-weight: 400; margin-top: 0; }

@media all and (max-width: 44.9375em) { .dealer h2 { font-size: 1.4em; } }

.dealer-info { padding: 1em; word-break: break-all; }

.dealer-info a { color: #333; text-decoration: underline; transition: all .3s ease; }

.dealer-info a:hover { color: #222; }

.dealer .meta { font-size: 1em; }

.dealer .meta li { margin-bottom: .5em; }

@media all and (min-width: 45em) { .dealer .meta li { margin-bottom: 1em; font-size: 1.15em; } }

.dealer .meta li:last-child { margin-bottom: 0; }

.dealer .container { display: block; }

@media all and (min-width: 45em) { .dealer .container { display: flex; } }

.dealer .row { background: #eeeeee; }

.dealer .row:nth-child(even) { background: #ffffff; }

.dealer .row .column { flex-direction: row; justify-content: left; }

@media all and (min-width: 45em) { .dealer .row .column { flex-direction: column; justify-content: center; } }

.contact { position: relative; margin: 0 auto; }

@media all and (min-width: 64.0625em) { .contact { margin: 2em auto; } }

.contact-info { width: 100%; float: left; margin-left: 0; margin-right: 0; max-height: 960px; padding: 1em; background-image: url(../images/contact/contact-info.jpg); background-repeat: no-repeat; background-position: 0 bottom; height: 100%; }

@media all and (min-width: 45em) { .contact-info { width: 32.2033898305%; float: left; margin-right: 1.6949152542%; height: 100vh; } }

.contact-form { padding: 1em; width: 100%; float: left; margin-left: 0; margin-right: 0; background: url(../images/contact/contact-form.jpg); background-repeat: no-repeat; background-position: 0 0; height: 100%; max-height: 960px; }

@media all and (min-width: 45em) { .contact-form { width: 66.1016949153%; float: right; margin-right: 0; height: 100vh; } }

.contact-block { color: #fff; margin-bottom: 1em; border-bottom: 1px solid #fff; padding: 1.5em 1em; }

.contact-block:last-child { border-bottom: none; }

.contact-meta li { margin-bottom: .5em; }

.contact-form-inner { color: #fff; max-width: 100%; padding: 0; }

@media all and (min-width: 45em) { .contact-form-inner { max-width: 85%; margin: 0 auto; padding: 1.5em 1em; } }

.field { display: block; margin-bottom: 1em; }

.field:after { content: ''; display: block; clear: both; }

.field.full { width: 100%; }

.field label { display: inline-block; padding: 1em; color: #666666; background: #fff; border-top-left-radius: 30px; border-bottom-left-radius: 30px; width: 33.3333333333%; float: left; }

@media all and (min-width: 45em) { .field label { width: 16.6666666667%; float: left; } }

.field input { padding: 1em; color: #333333; background: #fff; border-top-right-radius: 30px; border-bottom-right-radius: 30px; border-top-left-radius: 0; border-bottom-left-radius: 0; border: none; line-height: 1.5; width: 66.6666666667%; float: right; }

@media all and (min-width: 45em) { .field input { width: 83.3333333333%; float: right; } }

.field input:focus { outline: none; }

.field textarea { border-radius: 30px; padding: 1em; border: none; width: 100%; resize: none; height: 200px; }

.field textarea:focus { outline: none; }

.field button { padding: 1em 2em; min-width: 200px; color: #fff; background: #66ccff; border: none; border-radius: 30px; cursor: pointer; }

.field button:hover { background: #1ba7de; }

.field button:active { background: #00489d; }

.half { width: 100%; float: left; margin-right: 0; }

@media all and (min-width: 45em) { .half { width: 49.1525423729%; } .half:nth-child(2n) { margin-right: 1.6949152542%; } }

.half label { width: 25%; float: left; }

@media all and (min-width: 45em) { .half label { width: 41.6666666667%; float: left; } }

.half input { width: 75%; float: right; }

@media all and (min-width: 45em) { .half input { width: 58.3333333333%; float: right; } }

.dark { color: #fff; }

.bg-base { position: relative; overflow: hidden; background-repeat: no-repeat; background-size: cover; background-position: center center; }

#bg1 { background-image: url(../images/about/bg-about.jpg); padding: 10% 0; }

#bg2 { background-image: url(../images/about/bg-about-2.jpg); padding: 20% 0; margin-bottom: 5em; }

.lity { background: rgba(102, 102, 102, 0.65) !important; }

button.lity-close { display: none; }

.news { position: relative; text-align: center; }

.news h2 { font-size: 1.7em; padding: 1em 0; border-bottom: 1px solid #cccccc; color: #00489d; letter-spacing: .4em; margin: 0; }

.news-block { position: relative; overflow: hidden; margin: 1.3em 0; }

.news-date { color: #00489d; }

.news-item { padding: 1.5em 0; transition: all .3s ease; cursor: pointer; }

.news-item a { color: #666666; }

.news-item:hover { background: linear-gradient(to left top, #318fe9, #0057b7); }

.news-item:hover a { color: #fff; }

.news-item:hover .news-date { color: #fff; }

.news-content { max-height: 300px; overflow: auto; }

.news-content-modal { position: relative; background: #fff; padding: 1em; overflow: scroll; }

@media all and (min-width: 45em) { .news-content-modal { width: 1200px !important; margin-left: auto; margin-right: auto; padding: 3em 5em; } }

.news-content-modal .left { width: 100%; float: left; margin-left: 0; margin-right: 0; margin-bottom: 1.6949152542%; }

@media all and (min-width: 45em) { .news-content-modal .left { width: 49.1525423729%; float: left; margin-right: 1.6949152542%; margin-bottom: 0; } }

.news-content-modal .left .news-slider img { margin: 0 auto; }

.news-content-modal .right { color: #666; width: 100%; float: left; margin-left: 0; margin-right: 0; margin-bottom: 1.6949152542%; }

@media all and (min-width: 45em) { .news-content-modal .right { width: 49.1525423729%; float: right; margin-right: 0; margin-bottom: 0; } }

.news-content-modal .right .news-title { font-size: 24px; margin-top: 0.3em; margin-bottom: 1em; }

.news-content-modal .close-modal { position: absolute; right: 0; top: 0; width: 35px; height: 35px; background: #e94820; }

@media all and (min-width: 45em) { .news-content-modal .close-modal { width: 70px; height: 70px; } }

.news-content-modal .close-modal:hover { background: #e94820; opacity: 0.9; }

.news-content-modal .close-modal::before, .news-content-modal .close-modal::after { position: absolute; left: 50%; transform: translateX(-50%); content: ' '; height: 30px; width: 2px; background-color: #fff; }

@media all and (min-width: 45em) { .news-content-modal .close-modal::before, .news-content-modal .close-modal::after { height: 65px; } }

.news-content-modal .close-modal::before { transform: rotate(45deg); }

.news-content-modal .close-modal::after { transform: rotate(-45deg); }

.news-pagination { margin: 3em 0; }

.news-pagination:after { content: ''; display: block; clear: both; }

.news-pagination ul { text-align: center; }

.news-pagination li { display: inline-block; margin: 0 1.5em 0 0; }

.news-pagination li a { display: block; width: 18px; height: 18px; background: #cccccc; }

.news-pagination li a.active { background: #00489d; }

.news-pagination .pagin-basic { font-size: 14px; text-decoration: underline; color: #666; background: transparent; width: auto; }

.news-pagination .pagin-basic:hover { color: #00489d; }

.news-more { display: block; letter-spacing: 5px; color: #00489d; margin-bottom: 3em; }

.news-more:hover { text-decoration: underline; }

.service { position: relative; text-align: center; }

@media all and (min-width: 64.0625em) { .service { min-height: calc(100vh - 272px); } }

.service > .container { padding: 2em 0; }

.service h2 { color: #00489d; letter-spacing: .2em; }

.service-block { margin: 1em 0 2em; }

.service-list { display: flex; flex-wrap: wrap; justify-content: center; }

.service-list > * { flex: 1 0 100%; }

@media all and (min-width: 45em) { .service-list > * { flex: 0 0 32.2033898305%; } }

.service-item { margin-bottom: 1em; overflow: hidden; }

@media all and (min-width: 64.0625em) { .service-item { margin-right: 1.6949152542%; margin-bottom: 1.6949152542%; } }

.service-item:nth-child(3n) { margin-right: 0; }

.service-item .sub-item { font-weight: 700; color: #333; margin-bottom: 0.5em; }

.service-item img { display: block; overflow: hidden; transition: all .3s ease; margin: 0 auto; }

.service-title { margin-bottom: .5em; font-weight: 700; color: #333; }

.bg-prod-1 { background-image: url(../images/prod/bg-prod-1.jpg); }

.prod .column-text { background: #eeeeee; color: #333; }

.prod .column-content .modal, .prod .column-content .modal-name { font-size: 1.3em; font-weight: bold; }

.prod .column-content .modal-name { margin-bottom: 1.5em; }

.prod .column-content p { margin: 0; line-height: 2.4; }

.prod-feature { background-image: url(../images/prod/bg-feature.jpg); }

.prod-feature .column-text-bg { background: transparent; }

.prod-view { position: relative; background: #FFFFFF; max-width: 1000px; margin-left: auto; margin-right: auto; }

.prod-view:after { content: " "; display: block; clear: both; }

.prod-view-tip { max-width: 800px; margin: 2.5em auto 5em; }

.prod-view-tip img { display: block; margin: 0 auto; }

.prod-title, .prod-content { color: #fff; font-size: 1.2em; }

@media all and (min-width: 45em) { .prod-title, .prod-content { font-size: 2em; } }

.prod-mode-block { margin-top: 2em; max-width: 90%; margin-left: auto; margin-right: auto; }

@media all and (min-width: 45em) { .prod-mode-block { max-width: 960px; margin-left: auto; margin-right: auto; } .prod-mode-block:after { content: " "; display: block; clear: both; } }

.prod-mode-block .prod-file-name { text-align: center; width: 100%; margin-top: 2em; font-size: 1.3em; font-weight: 600; color: #333; }

.prod-mode-block .prod-file-item { margin: 1em auto 2em; }

.prod-mode { border: 1px solid #eeeeee; }

.prod-cover-m { position: relative; display: flex; align-items: center; justify-content: center; background-position: 0 0; background-repeat: no-repeat; background-size: cover; padding: 40% 0; background-position: center center; }

@media all and (min-width: 45em) { .prod-cover-m { display: none; } }

.prod-cover { position: relative; display: flex; align-items: center; justify-content: center; background-position: 0 0; background-repeat: no-repeat; background-size: cover; padding: 17.5% 0; }

@media all and (max-width: 44.9375em) { .prod-cover { display: none; } }

.prod-mode:last-child { margin-bottom: 2em; }

@media all and (min-width: 45em) { .prod-mode { padding: 0; } }

.prod-mode-title { font-size: 1.5em; margin-bottom: 1em; font-weight: bold; }

.prod-mode-meta li { margin-bottom: 0.5em; }

.prod-mode-meta li:last-child { margin-bottom: 0; }

.prod-mode-meta li span { font-weight: bold; }

.prod-mode .column-cover { position: relative; padding: 2em !important; }

.prod-mode .column-cover i.fas { position: absolute; bottom: 3%; right: 3%; font-size: 1.4em; }

.prod-mode .column-info { width: 100%; }

.prod-mode .columns { display: inline-flex; flex: 1; flex-basis: 100%; padding: 1em; align-items: center; }

@media all and (min-width: 45em) { .prod-mode .columns { padding: 2em; flex-basis: 50%; } }

.prod-feat-block .prod-feat.sp { background: #a20089 !important; }

.prod-feat-block .prod-feat:nth-child(odd) { background: #003c6a; }

.prod-feat-block .prod-feat:nth-child(even) { background: #005ca2; }

.prod-file { text-align: center; margin: 0 0 2em; }

.prod-file:after { content: ''; display: block; clear: both; }

.prod-file-btn { font-size: 1.3em; color: #fff; border-radius: 30px; padding: .5em 3em; display: inline-block; background: #e94820; min-width: 230px; }

.prod-file-btn.contact { margin: 0; background: #66ccff; }

.prod-file-btn:hover { opacity: 0.9; }

.bg-feat-1 { background-size: contain; background-image: url(../images/prod/feature-cover-2.png); background-position: bottom center; }

.view-inner { background-repeat: no-repeat; background-position: center center; background-size: contain; max-width: 1000px !important; margin: 0 auto; cursor: pointer; }

.rotate { position: absolute; top: 50%; background-repeat: no-repeat; background-position: 0 0; background-size: contain; transform: translateY(-50%); display: block; cursor: pointer; opacity: 1; transition: all .3s ease; }

.rotate:hover { opacity: 0.9; }

.view-btn { font-size: 5em; color: rgba(0, 72, 157, 0.8); transition: all .3s ease; }

.view-btn:hover { color: #00489d; }

.view-left { position: absolute; left: 1rem; }

@media all and (min-width: 64.0625em) { .view-left { left: 0%; } }

.view-right { position: absolute; right: 1rem; }

@media all and (min-width: 64.0625em) { .view-right { right: 0; } }

.prod-spec { position: relative; }

.prod-spec-wrap { position: relative; background: #cccccc; }

.prod-spec-meta { background: #666666; }

img[data-action="zoom"] { cursor: pointer; cursor: -webkit-zoom-in; cursor: -moz-zoom-in; }

.zoom-img, .zoom-img-wrap { position: relative; z-index: 666; -webkit-transition: all 300ms; -o-transition: all 300ms; transition: all 300ms; }

img.zoom-img { cursor: pointer; cursor: -webkit-zoom-out; cursor: -moz-zoom-out; }

.zoom-overlay { z-index: 420; background: #fff; position: fixed; top: 0; left: 0; right: 0; bottom: 0; pointer-events: none; filter: "alpha(opacity=0)"; opacity: 0; -webkit-transition: opacity 300ms; -o-transition: opacity 300ms; transition: opacity 300ms; }

.zoom-overlay-open .zoom-overlay { filter: "alpha(opacity=100)"; opacity: 1; }

.zoom-overlay-open, .zoom-overlay-transitioning { cursor: default; }

.threesixty-wrapper { position: relative; overflow: hidden; max-width: 800px; margin: 10px auto; }

.threesixty-wrapper .threesixty { cursor: grab; }

.angle-view { overflow: hidden; max-width: 800px; margin: 10px auto; border: 5px solid transparent; }

.angle-view ul, #angle-view li { margin: 0; padding: 0; }

.angle-view li { list-style: none; }

.angle-view ul { max-width: 800px; height: 620px; }

.angle-view img { width: 100%; display: block; }

.lity-inline .lity-container .lity-content::after { box-shadow: none; }

@media all and (max-width: 44.9375em) { video { display: block; width: 90%; margin: 0 auto; } }

.transition { -webkit-transition: all 0.5s ease; -moz-transition: all 0.5s ease; -o-transition: all 0.5s ease; transition: all 0.5s ease; }

.fx5 .item { margin: 10px 0; }

/* active on focus for accessibility tab navigation */
.fx5 .item { position: relative; padding: 0; overflow: hidden; }

.fx5 .item img { padding: 0 !important; display: block; max-width: 100%; height: auto; }

.fx5 a:hover .item img, .fx5 a:focus .item img { opacity: 0.8; }

.fx5 h4, .fx5 p { -webkit-transition: all 0.5s ease-out; -moz-transition: all 0.5s ease-out; -o-transition: all 0.5s ease-out; transition: all 0.5s ease-out; }

.fx5 a .item h4 { font-size: 16px; position: absolute; color: #fff; text-transform: uppercase; letter-spacing: 2px; background-color: #00489d; padding: 5px 10px; position: absolute; bottom: 0%; left: 0%; opacity: 0; }

.fx5 a:hover .item h4, .fx5 a:focus .item h4 { opacity: 1; left: 10%; }

.fx5 a .item p { font-size: 8px; position: absolute; color: #fff; text-transform: uppercase; letter-spacing: 2px; background-color: #00489d; padding: 5px 10px; position: absolute; bottom: 3%; left: 0%; opacity: 0; }

.fx5 a:hover .item p, .fx5 a:focus .item p { opacity: 1; left: 10%; }

@media screen and (max-width: 991px) { .fx5 a .item h4 { font-size: 13px; } }

.index-container { max-width: 1200px; margin-left: auto; margin-right: auto; padding-top: 3.4482758621%; padding-bottom: 3.4482758621%; }

.index-container:after { content: " "; display: block; clear: both; }

.index-mobile-block { display: flex; }

@media all and (min-width: 64.0625em) { .index-mobile-block { display: none; } }

@media all and (min-width: 64.0625em) { .index-video-block { display: flex; } }

.video-overlay { pointer-events: none !important; position: absolute; z-index: 2; top: 0; left: 0; height: 100%; right: 0; bottom: 0; margin: 0 !important; padding: 0 !important; }

.video-bg { position: relative; z-index: 1; object-fit: cover; object-position: 50% 50%; width: 100%; height: 100%; }

figure.snip0017 { font-family: 'Raleway', Arial, sans-serif; color: #fff; position: relative; overflow: hidden; margin: 10px; min-width: 220px; max-width: 310px; max-height: 220px; width: 100%; background: #000000; text-align: right; }

figure.snip0017 * { -webkit-box-sizing: border-box; box-sizing: border-box; }

figure.snip0017 img { opacity: 1; width: 100%; -webkit-transition: opacity 0.35s; transition: opacity 0.35s; }

figure.snip0017 figcaption { position: absolute; bottom: 0; left: 0; padding: 30px 3em; width: 100%; height: 100%; }

figure.snip0017 figcaption::before { position: absolute; top: 30px; right: 100%; bottom: 30px; left: 30px; border-right: 4px solid rgba(255, 255, 255, 0.8); content: ''; opacity: 0; background-color: rgba(255, 255, 255, 0.5); -webkit-transition: all 0.5s; transition: all 0.5s; -webkit-transition-delay: 0.6s; transition-delay: 0.6s; }

figure.snip0017 h2, figure.snip0017 p { margin: 0 0 5px; opacity: 0; -webkit-transition: opacity 0.35s, -webkit-transform 0.35s; transition: opacity 0.35s,-webkit-transform 0.35s,-moz-transform 0.35s,-o-transform 0.35s,transform 0.35s; }

figure.snip0017 h2 { word-spacing: -0.15em; font-weight: 300; text-transform: uppercase; -webkit-transform: translate3d(-30%, 0%, 0); transform: translate3d(-30%, 0%, 0); -webkit-transition-delay: 0.3s; transition-delay: 0.3s; }

figure.snip0017 h2 span { font-weight: 800; }

figure.snip0017 p { font-weight: 200; -webkit-transform: translate3d(0%, -30%, 0); transform: translate3d(0%, -30%, 0); -webkit-transition-delay: 0s; transition-delay: 0s; }

figure.snip0017 a { left: 0; right: 0; top: 0; bottom: 0; position: absolute; color: #ffffff; }

figure.snip0017:hover img { opacity: 0.3; }

figure.snip0017:hover figcaption h2, figure.snip0017:hover figcaption p { visibility: visible; }

figure.snip0017:hover figcaption h2 { opacity: 1; -webkit-transform: translate3d(0%, 0%, 0); transform: translate3d(0%, 0%, 0); -webkit-transition-delay: 0.4s; transition-delay: 0.4s; }

figure.snip0017:hover figcaption p { opacity: 0.9; -webkit-transform: translate3d(0%, 0%, 0); transform: translate3d(0%, 0%, 0); -webkit-transition-delay: 0.6s; transition-delay: 0.6s; }

figure.snip0017:hover figcaption::before { background: rgba(255, 255, 255, 0); right: 30px; opacity: 1; -webkit-transition-delay: 0s; transition-delay: 0s; }

.go-top { display: block; text-align: center; position: fixed; bottom: 50px; right: 50px; cursor: pointer; opacity: 0; z-index: 998; -moz-transform: translateY(100%); -ms-transform: translateY(100%); -webkit-transform: translateY(100%); transform: translateY(100%); -moz-transition: opacity 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275), -moz-transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); -o-transition: opacity 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275), -o-transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); -webkit-transition: opacity 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275), -webkit-transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); transition: opacity 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275), transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.go-top img { display: inline-block; max-width: 80%; }

.go-top.scroll-view.show { opacity: 1; visibility: visible; }

.go-top.scroll-view { -moz-transform: translateY(0%); -ms-transform: translateY(0%); -webkit-transform: translateY(0%); transform: translateY(0%); }

@media only screen and (max-width: 990px) { .go-top { bottom: 3%; right: 3%; } .go-top img { max-width: 50%; } }

.ad-img { position: relative; overflow: hidden; transition: all .3s ease; }

.ad-img span { text-align: center; opacity: 0; position: absolute; top: 50%; left: 50%; transform: translate(0%, 0%); z-index: 3; color: #fff; transition: all .2s ease; font-size: 18px; font-weight: bold; }

.ad-img:hover img { filter: blur(5px); transition: all .6s ease; }

.ad-img:hover span { opacity: 1; transform: translate(-50%, -50%); transition: all .5s ease; }
