#wrap { z-index: 5; }
/* section */
section { padding: 5vw 0; }
section >* { z-index: 3; }
section .title_box { padding-bottom: 0vw; font-size: 35px; font-weight: 500; }
section .entitle_box { font-family: "DM Sans",sans-serif; padding-bottom: 5px; display: block; line-height: 1.5; font-size: 24px; font-weight: 700; }
section .clip { margin: auto; width: 100%; }
section .clip img { height: 100%; }
section .clip iframe { width: 100%; height: 100%; top: 0; left: 0; }
section .clip video { width: auto; height: 100%; top: 50%; left: 50%; transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); }
/* about_area */
#about_area { z-index: 5; position: relative; background-image: url(/images/44/aboutBg.jpg); background-repeat: no-repeat; background-position: 50% 50%; background-size: cover; }
#about_area .bg { position: absolute; left: -70px; top: -100px; }
#fakeNumber { position: absolute; top: 100px; left: 10%; z-index: 7; }
#fakeNumber >div { display: flex; align-items: center; justify-content: center; }
#fakeNumber >div:after { content: ''; position: absolute; background-image: url(/images/44/munBg.png); background-repeat: no-repeat; background-position: 50% 50%; background-size: cover; width: 250px; aspect-ratio: 25/32; z-index: -1; box-shadow: 0 0 30px rgb(0 0 0/10%); }
#fakeNumber .eva { display: flex; flex-direction: column; align-items: center; justify-content: center; }
#fakeNumber .eva b { color: white; font-family: "Arimo",sans-serif; font-size: 135px; text-shadow: 0 0 30px rgb(0 0 0/10%); line-height: 1; }
#fakeNumber .eva p { color: white; font-size: 20px; }
#about_area .titbox { margin-bottom: 0; }
#about_area .title_box { padding-bottom: 50px; word-break: keep-all; display: block; line-height: 1.5; font-size: 35px; font-weight: 500; }
#about_area .workframe { width: 87%; margin: auto 0 auto auto; display: grid; grid-template-columns: 30% 68%; justify-content: space-between; align-items: end; }
#about_area article p { margin-bottom: 60px; line-height: 2.3; letter-spacing: 2px; font-weight: 400; width: 65%; text-align: justify; }
#about_area .clip { -webkit-clip-path: url(#clip_about); clip-path: url(#clip_about); }
#about_area .clip img { aspect-ratio: 5/2; }
#about_area .about_sub_1 { width: 350px; top: -10vw; left: -3vw; }
#about_area .about_sub_1 .clip { -webkit-clip-path: url(#clip_about_sub_1); clip-path: url(#clip_about_sub_1); }
#about_area .about_sub_2 { width: 470px; top: -26vw; right: 14vw; }
#about_area .about_sub_2 .clip { -webkit-clip-path: url(#clip_about_sub_2); clip-path: url(#clip_about_sub_2); }
#about_area .about_sub_3 { width: 300px; bottom: -11vw; left: 35vw; }
#about_area .about_sub_3 .clip { -webkit-clip-path: url(#clip_about_sub_3); clip-path: url(#clip_about_sub_3); }
#about_area #about_img { right: -110px; }
/* process */
#process { display: flex; width: 85%; justify-content: flex-end; position: relative; margin-top: 40px; }
#process .imgbox { position: absolute; left: 0; top: 0; display: flex; gap: 30px; }
#process .imgbox p { writing-mode: vertical-lr; display: flex; align-items: center; gap: 20px; font-size: 14px; margin-top: 15px; letter-spacing: 10px; }
#process .imgbox p b { font-family: "DM Sans",sans-serif; font-size: 15px; letter-spacing: 0; }
#process .list { width: 63%; display: grid; grid-template-columns: repeat(3,1fr); margin-top: 40px; }
#process .list >div { border-right: 1px solid #d5d5d5; padding: 15px 50px; }
#process .list >div:not(:last-child):after { content: ''; width: 1px; position: absolute; top: 0; right: -1px; height: 60px; background: #8c7860; }
#process .list >div:last-child { border: 0 }
#process .list >div .top { display: flex; align-items: center; justify-content: space-between; }
#process .list >div .top p { display: flex; align-items: baseline; font-family: "DM Sans",sans-serif; font-size: 37px; gap: 10px; font-weight: 600; }
#process .list >div .top p b { font-family: "DM Sans",sans-serif; font-size: 18px; font-weight: 600; }
#process .list >div .top .img { height: 60px; aspect-ratio: 1/1; border-radius: 50px; border: 1px solid #cbcbcb; display: flex; align-items: center; justify-content: center; }
#process .list >div .h3 { font-size: 18px; margin-bottom: 10px; margin-top: 30px; }
#process .list >div .h3:after { content: ''; background: #8c7860; width: 30px; height: 1px; display: block; margin: 20px 0 15px; }
#process .list >div article { height: auto; -webkit-line-clamp: 2; }
/* custom_area */
#custom_area { background-image: url(/images/44/customBg.jpg); background-repeat: no-repeat; background-position: 50% 50%; background-size: cover; }
#custom_area .workframe { width: 90%; }
#custom_area .slick-list { padding: 34px 20px; margin: 0 -15px; }
#custom_area .slick-slide { outline: none; padding: 0 8px; }
#custom_area li > .pos_rel { background: #ffffff; border-radius: 20px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,0.06); transition: transform 0.4s cubic-bezier(0.175,0.885,0.32,1.275),box-shadow 0.4s ease; display: flex; flex-direction: column; cursor: pointer; height: 100%; border: 1px solid rgba(0,0,0,0.03); }
#custom_area li > .pos_rel:hover { transform: translateY(-12px); box-shadow: 0 20px 40px rgba(0,0,0,0.15); border-color: rgba(217,119,6,0.2); }
#custom_area .clip { width: 100%; aspect-ratio: 9/14; position: relative; overflow: hidden; background-color: #1e293b; border-radius: 20px 20px 0 0; }
#custom_area .clip::before { content: ''; position: absolute; top: 15px; right: 15px; width: 34px; height: 34px; background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23FF0000" d="M16.4 10.1l-1.4-.6 1.4-.6c1.6-.7 2.4-2.5 1.7-4.1-.7-1.6-2.5-2.4-4.1-1.7l-8.6 3.8c-1.6.7-2.4 2.5-1.7 4.1.4.9 1 1.5 1.9 1.7l1.4.6-1.4.6c-1.6.7-2.4 2.5-1.7 4.1.7 1.6 2.5 2.4 4.1 1.7l8.6-3.8c1.6-.7 2.4-2.5 1.7-4.1-.4-.9-1-1.5-1.9-1.7z"/><path fill="%23FFF" d="M10 8l6 4-6 4V8z"/></svg>'); background-size: contain; background-position: center; background-repeat: no-repeat; z-index: 3; transition: all 0.4s ease; filter: drop-shadow(0 2px 6px rgba(0,0,0,0.5)); }
#custom_area li > .pos_rel:hover .clip::before { opacity: 0; transform: translateY(-10px); }
#custom_area .clip::after { content: ''; position: absolute; inset: 0; background-color: rgba(0,0,0,0.2); background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23FF0000" d="M21.582 6.186a2.665 2.665 0 00-1.875-1.881C18.053 3.864 12 3.864 12 3.864s-6.053 0-7.707.441a2.665 2.665 0 00-1.875 1.881C1.977 7.85 1.977 12 1.977 12s0 4.15.441 5.814a2.665 2.665 0 001.875 1.881c1.654.441 7.707.441 7.707.441s6.053 0 7.707-.441a2.665 2.665 0 001.875-1.881c.441-1.664.441-5.814.441-5.814s0-4.15-.441-5.814z"/><path fill="%23FFF" d="M10 15.464V8.536L16 12l-6 3.464z"/></svg>'); background-size: 64px; background-position: center; background-repeat: no-repeat; opacity: 0; transition: all 0.4s cubic-bezier(0.175,0.885,0.32,1.275); z-index: 2; pointer-events: none; transform: scale(0.5); backdrop-filter: blur(2px); }
#custom_area li > .pos_rel:hover .clip::after { opacity: 1; transform: scale(1); background-color: rgba(0,0,0,0.4); }
#custom_area .img_cover { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s ease; display: block; }
#custom_area li > .pos_rel:hover .img_cover { transform: scale(1.08); }
#custom_area li > .pos_rel .tit { padding: 22px 20px 8px 20px; margin: 0; text-align: left; }
#custom_area li > .pos_rel .tit .h3 { font-size: 1.15rem; font-weight: 800; color: var(--secondary); display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; line-height: 1.5; height: 1.5em; transition: color 0.3s ease; }
#custom_area li > .pos_rel:hover .tit .h3 { color: var(--primary); }
#custom_area .Contentbox { font-size: 0.8rem; color: var(--info); padding: 0 20px 24px 20px; font-weight: 400; display: flex; align-items: center; }
#custom_area .Contentbox::before { content: ''; display: inline-block; width: 16px; height: 16px; margin-right: 6px; background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%2364748b" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><path d="M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z"></path><circle cx="12" cy="12" r="3"></circle></svg>'); background-size: contain; background-repeat: no-repeat; }
#custom_area .atag_item { inset: 0; z-index: 10; cursor: pointer; }
section#custom_area .title_box { padding-bottom: 0; }
/* --- 自訂輪播控制按鈕 --- */
#custom_area .nav-arrows { display: flex; gap: 12px; margin-bottom: 8px; }
#custom_area .custom-arrow { width: 48px; height: 48px; border-radius: 50%; background-color: #ffffff; border: 1px solid rgba(0,0,0,0.08); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s ease; box-shadow: 0 4px 10px rgba(0,0,0,0.05); }
#custom_area .custom-arrow:hover { background-color: var(--primary); border-color: var(--primary); color: #ffffff; transform: translateY(-2px); box-shadow: 0 8px 15px rgb(194 194 194/30%); }
#custom_area .custom-arrow svg { width: 20px; height: 20px; stroke: currentColor; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; fill: none; transition: stroke 0.3s ease; }
#custom_area .custom-arrow:hover svg { stroke: #ffffff; }
#custom_area .title_bar { display: flex; align-items: center; gap: 7vw; margin-left: 20vw; margin-bottom: 20px; }
/* --- 3D 地圖區塊樣式 (ID 作用域限制) --- */
#map_3d_area { padding: 80px 0 120px 0; background-color: #f9f8f6; position: relative; }
section#map_3d_area .title_box { padding-bottom: 0; }
#map_3d_area .tit { display: flex; flex-direction: column; align-items: center; margin-bottom: 4vw; }
#map_3d_area .map_3d_box { border-radius: 24px; overflow: hidden; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.15); border: 1px solid rgba(255,255,255,0.5); background: rgba(255,255,255,0.8); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); padding: 10px; transform: translateY(0); transition: transform 0.5s ease,box-shadow 0.5s ease; }
#map_3d_area .map_3d_box:hover { transform: translateY(-8px); box-shadow: 0 30px 60px -15px rgba(0,0,0,0.2); }
#map_3d_area .map_3d_box iframe { width: 100%; border-radius: 16px; display: block; border: none; background-color: #e2e8f0; }
#map_3d_area .note_text { font-size: 0.85rem; color: #a38f77; text-align: center; margin-top: 1.5rem; letter-spacing: 0.5px; }
#map_3d_area .tit div { text-align: center; }
/* --- 產品輪播區塊樣式 (ID 作用域限制，嚴格遵守單行模式) --- */
#product_area { background-color: #f9f8f6; position: relative; }
#product_area .cotoptitlebox { display: flex; flex-direction: column; align-items: center; padding-bottom: 2vw; }
#product_area:before { content: ""; position: absolute; background: url(/images/44/about-numbg.png); width: 5vw; aspect-ratio: 22/35; right: 0; top: -4vw; z-index: 5; background-size: cover; }
#product_area .bg_box { top: 0; left: 0; width: 100%; height: 60%; background: linear-gradient(180deg,#e7e0d0 0%,#f9f8f6 100%); z-index: 0; opacity: 0.5; }
/* 列表與卡片樣式 */
#product_list { margin: 0 -15px; }
#product_list .nowrap_box { list-style: none; padding: 0; margin: 0; }
#product_list .slick-list { padding: 20px 0; }
#product_list .slick-slide { outline: none; }
#product_list li { margin: 0 15px; background: #ffffff; border-radius: 20px; box-shadow: 0 10px 30px rgba(0,0,0,0.06); transition: all 0.4s cubic-bezier(0.175,0.885,0.32,1.275); border: 1px solid rgba(0,0,0,0.03); padding-bottom: 25px; height: 100%; }
#product_list li:hover { transform: translateY(-12px); box-shadow: 0 20px 40px rgba(0,0,0,0.12); border-color: rgba(217,119,6,0.15); }
/* 圖片比例與動態 */
#product_list li .clip { border-radius: 20px 20px 0 0; background-color: #e2e8f0; }
#product_list li .clip img { width: 100%; aspect-ratio: 1000/767; object-fit: cover; transition: transform 0.8s ease; display: block; }
#product_list li:hover .clip img { transform: scale(1.08); }
/* 資訊排版 */
#product_list .info_box { position: relative; padding: 25px 25px 15px 25px; display: flex; flex-direction: column; margin-bottom: 10px; }
#product_list .info_box:before { content: ""; width: calc(100% - 50px); background: #ededed; height: 1px; bottom: 0; position: absolute; }
#product_list .info_box p { font-size: 0.85rem; color: var(--primary); font-weight: 800; margin: 0 0 8px 0; letter-spacing: 2px; text-transform: uppercase; }
#product_list .info_box .h3 { font-size: 1.35rem; font-weight: 800; color: var(--secondary); margin: 0 0 0px 0; line-height: 1.4; transition: color 0.3s ease; }
#product_list li:hover .info_box .h3 { color: var(--primary); }
#product_list .txt_clamp { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
/* 按鈕與小標籤 */
#product_list .more_btn { display: inline-flex; align-items: center; font-size: 0.9rem; font-weight: 800; color: #0f172a; text-decoration: none; transition: color 0.3s ease; z-index: 11; position: relative; padding-top: 25px; }
#product_list .more_btn:hover { color: #b45309; }
#product_list .more_btn img { transition: transform 0.3s ease; }
#product_list .more_btn:hover img { transform: translateX(6px); }
#product_list .pinfoo { padding: 0 25px; font-size: 0.95rem; color: #575046; font-weight: 500; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; line-height: 1.6; }
#product_list li > span { position: absolute; top: 15px; left: 15px; background: rgba(15,23,42,0.7); color: #ffffff; padding: 6px 14px; border-radius: 50px; font-size: 0.85rem; font-weight: 700; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); z-index: 2; letter-spacing: 1px; }
#product_list .atag_item { top: 0; left: 0; width: 100%; height: 100%; z-index: 10; cursor: pointer; }
/* 導航控制列 */
#product_list .btn { display: flex; align-items: center; justify-content: flex-end; margin-top: 20px; gap: 15px; padding-right: 15px; }
#product_list .slick-arrow { width: 48px; height: 48px; border-radius: 50%; border: 2px solid #e2e8f0; display: flex; align-items: center; justify-content: center; text-decoration: none; transition: all 0.3s ease; background: #ffffff; z-index: 12; cursor: pointer; }
#product_list .slick-arrow:hover { background: var(--primary); border-color: var(--primary); transform: translateY(-2px); box-shadow: 0 5px 15px #8c78605e; }
#product_list .slick-arrow img { width: 20px; transition: filter 0.3s ease; filter: grayscale(100%) opacity(0.6); }
#product_list .slick-arrow:hover img { filter: brightness(0) invert(1); }
#product_prev img { transform: rotate(180deg); }
#product_list .btn font { display: flex; align-items: center; font-size: 1.2rem; font-weight: 800; color: #0f172a; letter-spacing: 2px; }
#product_list .btn font span:nth-child(2) { color: #cbd5e1; margin: 0 6px; font-weight: 400; font-size: 1rem; }
.moreu2_box { display: flex; align-items: center; justify-content: space-between; padding: 30px 20px; }
.moreu1_box { display: flex; align-items: center; justify-content: center; padding: 30px 20px; }
/* news_area */
#news_area li .img_box,#book_area li .img_box { border-radius: 15px; background-color: #f9f9f9; }
#news_area li .info_box { margin: 10px 15px 0; }
#news_area li .time { width: 65px; font-weight: 400; font-size: 13px; }
#news_area li .more_btn { margin-left: 10px; padding: 2px 15px; max-width: calc(100% - 105px); height: 22px; font-weight: 100; font-size: 13px; z-index: 6; }
#news_area li h3 { margin-top: 10px; height: 60px; line-height: 150%; font-size: 20px; -webkit-line-clamp: 2; }
/* book_area */
#book_area li .h3 { margin-top: 10px; height: 30px; font-size: 18px; }
#book_area .cotoptitlebox { display: flex; flex-direction: column; align-items: center; padding-bottom: 2vw; }
#book_area .slick-list li { margin: 0 10px; }
#book_area .slick-list .img_box {aspect-ratio: 9/14;}
/* photo_area */
#photo_area .item { width: 260px; height: 200px; }
#photo_area .item img { height: 100%; object-fit: cover; }
@media screen and (max-width:1470px) {
  #process .list { width: 65%; }
  #process .imgbox { width: 30%; }
  #about_area .title_box,section .title_box { font-size: 30px; }
  section .entitle_box { font-size: 20px; padding-bottom: 0; }
  #process { width: 95%; }
  #about_area .workframe { width: 90%; }
  #about_area .titbox { margin-bottom: 30px; }
  #about_area .bg { width: 320px; }
}
@media screen and (max-width:1280px) {
  #process .list { width: 65%; }
  #process { width: 100%; }
}
@media screen and (max-width:1024px) {
  #process .list { width: 100%; }
  #process .list >div { padding: 15px 30px; }
  #process { width: 90%; margin: 30px auto 0; flex-wrap: wrap; }
  #process .imgbox { width: auto; position: relative; width: 95%; }
  #process .imgbox p { writing-mode: unset }
  #process .imgbox img { display: none; }
  #about_area article p { width: 90% }
  #about_area .titbox { margin-left: 40%; margin-bottom: 7%; }
  #about_area .workframe { grid-template-columns: 1fr; margin-top: 5%; }
  #fakeNumber { top: 130px; }
  #about_area .bg { top: -20px; }
  #news_area li h3 { height: 30px; -webkit-line-clamp: 1; }
}
@media screen and (max-width:980px) {
  #about_area .title_box { font-size: 30px; }
  #fakeNumber { left: 5%; }
  section { padding: 12vw 0; }
  #about_area #about_info { margin-bottom: 8vw; }
  #about_area .about_sub_2 { top: auto; bottom: 35vw; width: 35vw; }
  #about_area .about_sub_3 { width: 29vw; left: 10vw; }
}
@media screen and (max-width:760px) {
  #custom_area .tit p,#custom_area .tit .title_box { text-align: center; width: 100%; }
  #custom_area li .tit p { text-align: left; }
  section .title_box { font-size: 26px; }
  #about_area .entitle_box,#custom_area .entitle_box { font-size: 20px; }
  #map_3d_area { padding: 60px 0 80px 0; }
  #map_3d_area .map_3d_box { padding: 6px; border-radius: 16px; }
  #map_3d_area .map_3d_box iframe { height: 350px; border-radius: 12px; }
  #map_3d_area .note_text { font-size: 0.75rem; margin-top: 2rem; }
  #product_list li { margin: 0 10px; }
  #product_list .info_box { padding: 20px 20px 10px 20px; }
  #product_list .info_box .h3 { font-size: 1.2rem; margin-bottom: 15px; }
  #product_list .pinfoo { padding: 0 20px; font-size: 0.85rem; }
  #product_list .btn { justify-content: center; padding-right: 0; margin-top: 0; }
  #product_list .slick-arrow { width: 35px; height: 35px; }
  #product_list .slick-arrow img { width: 15px; }
  #process .list >div:not(:last-child):after { height: 1px; width: 60px; right: 0; bottom: -1px; top: unset; }
  #process .list { grid-template-columns: 1fr }
  #process .list >div { border: 0; border-bottom: 1px solid #d5d5d5; padding: 30px 30px; }
  #about_area article p { width: 100%; margin-bottom: 10px; }
  #about_area #about_info { width: 85%; margin: 0 auto; }
  #about_area .title_box { margin-bottom: 0; padding-bottom: 50px; }
  #about_area .titbox { width: 85%; margin: 35px auto; }
  #fakeNumber { top: 90px; left: 10%; display: none; }
  #about_area .workframe { width: 100%; margin-top: 0px; }
  #fakeNumber >div:after { zoom: 65%; }
  #about_area .bg { width: 170px; height: 109px; overflow: hidden; right: 0; left: auto; }
  #fakeNumber .eva b { font-size: 85px; }
  section .clip img { height: auto; }
  #product_sub_list li { margin: 10px; width: 35vw; }
  #product_sub_list li .clip { height: 35vw; }
  #about_area #about_img { width: 80vw; }
  #about_area .about_sub_2 { bottom: 60vw; }
  #news_area li .row { margin: auto; width: 280px; }
}
@media screen and (max-width:640px) {
  #custom_area .title_bar { margin-left: 0vw; gap: 2vw; }
  #custom_area .title_bar .tit { display: flex; flex-direction: column; align-items: flex-start; }
  #custom_area .nav-arrows { display: none; }
  #map_3d_area .tit { margin-bottom: 40px; }
  #book_area .cotoptitlebox,#product_area .cotoptitlebox { margin-bottom: 20px; }
}
@media screen and (max-width:480px) {
  #about_area .workframe { display: block; }
  #book_area li.row { margin: auto; width: 250px; }
}
