/*根元素*/
:root{
--bg:#ffffff; /* 背景(白) var(--bg)*/
--p:#000000; /* 段落文字 var(--p)*/
--card:#f1f1f1; /* 卡片底(淺灰) var(--card)*/
--text:#004da3; /* 主要文字(主色系藍) var(--text)*/
--text2:#1070db; /* h3次要文字(藍) var(--text2)*/
--text3:#90daff; /* h4次要文字(天藍) var(--text3)*/
--text4:#012f5d; /* h4次要文字(黑藍) var(--text4)*/
--shadow: 0 5px 10px rgba(0,0,0,.25); /* 陰影 var(--shadow)*/
--gradient: linear-gradient(120deg, var(--text4) 0%, var(--text) 100%); /* 漸層 var(--gradient)*/
}

.topnavbar {
    background-color: #fff;/*頁籤底圖顏色;background-color: rgba(255,255,255,0);透明Transparent*/
    position: relative;/*relative 頁籤&banner分開不重疊;頂置 fixed;*/
    line-height: 0;
    padding: 0;/*頁籤間距*/
}

body[data-type="fullpage"] .topnavbar .container {
    text-align: justify;
    padding: 0;
    width: 100%;
}

.topnavbar .container::after {
  display: inline-block;
  width: 100%;
}

/*頁籤底拉寬*/
#header .topnavbar .container {
  padding-left: clamp(30px, 4vw, 50px);
  padding-right: clamp(30px, 8vw, 100px);
  width: 100%;
}

body {
    background-color: #fff;/*背景底色*/
    font-family: 'Noto Sans TC', sans-serif;/*套用google font字型Noto Sans TC黑體*/
}

#logo h1 { text-align: center; }

/*動到表格手機不會破版*/
table {
  table-layout: fixed;
  word-wrap:break-word;
} 

hr {
  border-top: 1px solid #ddd;
  border-bottom: 0;
  margin: 2em 0;
}

/*編輯欄設定*/
#main-wrap .container {
  font-size: clamp(14px, 2vw, 16px);
  color: var(--p);
}/*編輯欄文字*/

body[data-type="fullpage"]:not(#managehome) #wrap>*:not(:last-child) { margin-bottom: 0px; }
body[data-type="fullpage"] #product-header.main { min-height: auto;}/*產品-編輯框不設定高*/

.fcol p { line-height: 2; }

.fcol h1 { 
  color: var(--text);
  font-size: clamp(32px, 3vw, 36px);/*最小值 首選值 最大值 限制屬性值區間*/
  font-weight: 700;
}

.fcol h2 { 
  color: var(--text2);
  font-size: clamp(26px, 3vw, 28px);/*最小值 首選值 最大值 限制屬性值區間*/
  line-height:2;
}

.fcol h3 { 
  color: var(--text3);
  font-size: clamp(24px, 3vw, 26px);/*最小值 首選值 最大值 限制屬性值區間*/
}

.fcol h4 { 
  color: var(--text4);
  font-size: clamp(20px, 3vw, 24px);/*最小值 首選值 最大值 限制屬性值區間*/
}

/*nav*/
#nav {
    vertical-align: bottom;
}
#nav ul li a {
    white-space: normal; /*自動換行*/
    font-size: 15px;/*頁籤文字大小*/
    color: #000;/*頁籤文字顏色*/
    padding: 10px 20px;/*頁籤文字間隔;padding:2px 16px 2px 16px;*/
    line-height: 1.3;
    transition: .3s;
}

#nav ul li a:hover  {
    color: var(--text);/*頁籤滑過文字顏色*/
}
#nav ul li.current a {
    color: var(--text);/*頁籤按下後文字顏色*/
    font-weight: 500;
}

#nav .subnav {
    background-color: #fff;/*次頁籤底色*/
    max-width: 400px;/*次頁籤背景最大寬度*/
    width: max-content;/*最大內容*/
    text-align: left;
}

#nav .subnav .has-subnav span{
    max-width: 400px;/*次頁籤文字背景最大寬度*/
}

#nav li.has-subnav ul li.has-subnav>div a::after, #nav>ul>li.has-subnav>a::after {
    padding-left: 2px;/*下拉選單箭頭距離*/
}

/*產品頁*/
#side h3 {
  /*background-color: var(--card);*/
  background-image: var(--gradient);
  border-radius: 10px 10px 0 0;
  font-size: 1.4em;
  font-weight: 700;
  color: var(--bg);
}
#side ul li a {
  font-size: 16px;
  color: #333;
  border-bottom: 1px dashed #ddd;
}
#side ul li a:hover { color: var(--text);}
#side ul li.current>div a { color: var(--text2); }

ul.product-list li a {
    color: var(--text);/*產品格文字顏色*/
    background-color: #eee;/*產品格底色*/
}
ul.product-list li a:hover {
    color: var(--text2);/*產品格滑過文字顏色*/
}
.productdetail .detail-spec h2 p{
    color: #333;
    font-size: 30px;
}/*產品內頁標題文字*/


/*title文字顏色*/
.fcol.fcol-header { background-image: var(--gradient); margin-bottom: 1em; }
.h1title h1{
  color: var(--bg);
  line-height: 1;
  text-align: center;
}

a {
    color: var(--text);/*連結顏色*/
    text-decoration: none;
}

.swiper-container {
  height: auto !important; /* 將容器預設的高拿掉 */
}
.swiper-wrapper, .swiper-slide {
  height: 0 !important;
}
.swiper-slide {
  width: 100% !important; /* 強制圖片寬度隨容器變更 */
}
/* 首頁 */
#bodyinhome .swiper-wrapper, #bodyinhome .swiper-slide {
  padding-bottom: calc(750 / 1920 * 100%); /* 首頁 banner 大小 */
}
/* 內頁 */
#bodyinpage .swiper-wrapper, #bodyinpage .swiper-slide {
  padding-bottom: calc(0 / 1920 * 100%); /* 內頁 banner 大小 */
}

#bodyinhome .fcol.fcol-1 .container { padding: 3em 0; }/*拉寬編輯欄設定*/
#bodyinhome .fcol.fcol-2 { background-color: var(--text2); padding: 3em 0; }
@media only screen and (min-width: 768px){
  #bodyinhome .fcol.fcol-2 .container { width: 90% ;}
}

#bodyinhome .fcol.fcol-5 { background-image: var(--gradient); padding: 3em 0; }

/*footer*/
#foot-nav {
  border-bottom: 1px solid var(--card);
  margin-bottom: 2em;
  display: flex;
  justify-content: center;
}
#foot-nav ul li a {
    display: block;
    color: var(--text4);
    font-size: 14px;
    margin-right: 15px;
    padding: 3px 10px;
    background-color: var(--card);
  /*  border-radius: 10px;*/
}
#foot-nav ul li a:hover { background-color: var(--text); color: var(--bg);}
#foot-nav ul li.current a { color: var(--text4); }

#footer {
  color: var(--p);
  width: 100%;
  background-color: var(--bg);
}
#footer a { color: var(--text2); }
#footer a:hover { color: var(--text3); }

#footer p{
  color: var(--p);/*footer文字顏色*/
  font-size: 14px;
  line-height: 1.6;
}
#contact-info ul li span {color: var(--p);}
#footer h1,h2,h3,h4,h5,h6 {color: var(--text4);}

/*go_top 回最上層按鈕*/
#gotop {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: fixed;
    right: 1%;
    bottom: 5%;
    padding: 10px 10px 15px;
    font-size: 16px;
    line-height: 1;
    border-radius: 50px;
    width: 65px;
    height: 65px;
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
    text-align: center;
    cursor: pointer;
}
/*手機版-側欄浮動按鈕-縮小*/
@media (max-width: 430px){ 
  #gotop { transform: scale(0.8); right:0; }
}

/*標題偽元素樣式*/
.t-line {
  position: relative;
  margin: 1.5em auto;
  border-bottom: 1px solid var(--text3);
  width: 80px;
}

.t-line:before {  
  content: '';
  position: absolute;
  width: 10px;
  height: 5px;
  bottom: -3px;
  left: 45%;
  right: 0;
  background: var(--text3);
}

/*按鈕-文字底色變化特效*/
.custom-btn {
    padding: 5px 25px;
    outline: none !important;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    display: inline-block;
}

.btn-more1 {
    border-radius: 0px;
    border: 1px solid var(--card);
    color: var(--text2);
    font-size: clamp(13px, 2vw, 15px);
    background-color: var(--bg);
    font-weight: 400;
  letter-spacing: 3px;
}
.btn-more1:hover{
    background-color: var(--text); /* 當滑鼠經過時按鈕表格底色變化 */
    color: var(--bg);/* 當滑鼠經過時按鈕表格文字變化 */
}

/*文字按鈕特效*/
.snip1562 {
  background-color: var(--text2);
  border: none;
  color: var(--bg);
  cursor: pointer;
  display: inline-block;
  font-family: 'BenchNine', Arial, sans-serif;
  font-size: clamp(18px, 3vw, 20px);
  line-height: 1.2;
  margin: 0 auto;
  outline: none;
  padding: 10px 15px;
  position: relative;
  text-transform: uppercase;
  font-weight: 500;
  width: 100%;
  height: 100%;
}

.snip1562:before,
.snip1562:after {
  border-color: transparent;
  -webkit-transition: all 0.25s;
  transition: all 0.25s;
  border-style: solid;
  border-width: 0;
  content: "";
  height: 24px;
  position: absolute;
  width: 24px;
}

.snip1562:before {
  border-color: var(--text2);
  border-left-width: 1px;
  border-top-width: 1px;
  left: -5px;
  top: -5px;
}

.snip1562:after {
  border-bottom-width: 1px;
  border-color: var(--text2);
  border-right-width: 1px;
  bottom: -5px;
  right: -5px;
}

.snip1562:hover,
.snip1562.hover {
  background-color: var(--text2);
}

.snip1562:hover:before,
.snip1562.hover:before,
.snip1562:hover:after,
.snip1562.hover:after {
  height: 100%;
  width: 100%;
}

/*服務項目*/
.pic-1 img {filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2)); transition: all 0.5s ease;}
.pic-1 img:hover { transform: translateY(-7px);  }

/*owl 輪播圖語法*/
#bodyinhome .fcol.fcol-5 .container{
  max-width:100%;
  width:85%;
}
.owl-carousel.owl-theme {
  padding: 0 20px 35px;/*內距:上 左右 下;*/
}
.owl-carousel.owl-theme .owl-nav {
  position: absolute;
  margin: 0;
  top:40%;
  left: 0;
  right: 0;
  transform: translateY(0%);
  color: var(--text3);
}
.owl-carousel.owl-theme .owl-dots {
  position: relative;
  left: 0;
  right: 0;
  bottom: 0;
}
.owl-carousel.owl-theme button:focus {
  outline: none;
}
.owl-carousel.owl-theme .owl-nav .owl-prev {
  float: left;
  transform: translateX(-100%);
}
.owl-carousel.owl-theme .owl-nav .owl-next {
  float: right;
  transform: translateX(100%);
}
.owl-carousel.owl-theme .owl-nav .owl-prev:hover,
.owl-carousel.owl-theme .owl-nav .owl-next:hover{
  background: none;
  color: inherit;
}
.owl-carousel.owl-theme .owl-nav .fa{
  font-size: 3em; /*箭頭大小*/
}

.editmode .owl-carousel.owl-loaded {
  display: flex;
  flex-wrap: wrap;
}
.editmode .owl-carousel > div {
  flex: 0 0 25%;
  max-width: 25%;
}

.owl-carousel .owl-item img {
  object-fit: cover;  /*cover圖片剪裁不拉伸壓縮 ; contain不拉伸壓縮.等比縮放)*/
  display: block;
  width: 100%;
  height: auto; 
  aspect-ratio: 1 / 1;  /*比例*/
  border: 2px solid #fff;
  box-shadow: 0 6px 5px rgba(44,44,44,0.25);
}
.owl-carousel .row-no-gutters {
    margin-right: 5px;
    margin-left: 2px;
}

/*聯絡我們*/
#contact-icon {
  font-size: 4em;
    color: var(--text2);
    padding: 20px;
    border: 3px dotted #ddd;
    border-radius: 100%;
    aspect-ratio: 1 / 1;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 10px auto;
}

/*麵包屑*/
#breadcrumb li { color: var(--text3); }
#breadcrumb li a { color: var(--text3); }
#breadcrumb li a:hover { color: var(--text2); }

/*FAQ*/
.faq {
	 background-color: #fff;
	 margin-bottom: 30px;
	 padding: 5px 35px;
	 box-shadow: var(--shadow);
}
 .faq dt, .faq dd {
	 padding: 25px 25px;
}
 .faq dt {
	 display: flex;
	 align-items: center;
	 border-bottom: 1px dashed var(--text4);
	 position: relative;
}
 .faq dt:before, .faq dt:after {
	 content: "";
	 position: absolute;
	 width: 5px;
	 height: 5px;
	 background-color: var(--text4);
	 border-radius: 50%;
	 bottom: -3px;
}
 .faq dt:before {
	 left: 0;
}
 .faq dt:after {
	 right: 0;
}
 .faq dd {
	 display: flex;
	 align-items: center;
}
 .faq .faq_q, .faq .faq_a {
	 width: 45px;
	 height: 45px;
	 color: #fff;
	 line-height: 1;
	 margin-right: 25px;
	 border: 1px solid var(--text);
	 font-size: 2.2rem;
	 position: relative;
	 flex: 0 0 auto;
	 display: flex;
	 align-items: center;
	 justify-content: center;
	 background: var(--text);
}
 .faq .faq_a {
	 background: #fff;
	 color: var(--text);
}
 