aside b .fa{transform:rotate(0);-webkit-transform:rotate(0);transition:all .3s ease-in-out;-webkit-transition:all .3s ease-in-out}
aside>ul>li .subUL{transform:translate(0,30px);-webkit-transform:translate(0,30px)}
aside>ul>li[data-type="2"] h4 b .fa{transform:rotate(180deg);-webkit-transform:rotate(180deg)}
aside>ul>li[data-type="2"] .subUL{transform:translate(0,0);-webkit-transform:translate(0,0)}
#faq_list li .title i{transform:rotate(0);-webkit-transform:rotate(0);transition:all .3s ease-in-out;-webkit-transition:all .3s ease-in-out}
#faq_list li.current .title i{transform:rotate(180deg);-webkit-transform:rotate(180deg)}
#book_list li .img_box:after,#book_list li .img_box:before{transform:scaleY(0);-webkit-transform:scaleY(0)}
#book_list li .img_box:after{transform-origin:center bottom;-webkit-transform-origin:center bottom}
@media (min-width:1281px){#book_list li:hover .img_box:after,#book_list li:hover .img_box:before{transform:scaleY(0);-webkit-transform:scaleY(0)}
#book_list li:hover .teinfo font{ransform:translateY(-22px);-webkit-transform:translateY(-22px)}
}
[data-action=loader] .loader_circle{width:50px;height:50px;border-radius:50%}
[data-action=loader]#lodbg .loader_circle{-webkit-animation:circle infinite .75s linear;animation:circle infinite .75s linear}
@keyframes circle{0%{transform:rotate(0);-webkit-transform:rotate(0)}
100%{transform:rotate(360deg);-webkit-transform:rotate(360deg)}
}
@-webkit-keyframes circle{0%{transform:rotate(0);-webkit-transform:rotate(0)}
100%{transform:rotate(360deg);-webkit-transform:rotate(360deg)}
}
#wrap{z-index:6}
#wrap .page_area{margin:auto;width:100%;z-index:2;position:relative}
#wrap aside{display: none;}
#category_nav{margin-top:0;background:#f0f0f0;padding-top:10px;padding-bottom:0}
#wrap .shadow{box-shadow:0 0 20px rgba(var(--black-rgb),.2)}
#sub_banner{top:0;left:0}
#page_title,#sub_banner a{padding-top:0;height:400px}
#sub_banner a img{height:100%}
#sub_banner a:after{position:absolute;width:100%;height:100%;background:rgba(var(--black-rgb),.4);top:0;left:0;z-index:2;content:""}
#page_title>div{margin:auto}
#page_title .pag_tit{line-height:1.3em;letter-spacing:.15em;font-size:2em}
.waylink ol{padding-top:5px}
.waylink ol li,.waylink ol li a{letter-spacing:1.5px;font-weight:300;font-size:13px;vertical-align:bottom}
.waylink ol li:after{margin:0 10px;display:inline-block;font-weight:100;font-size:12px;color:var(--white);content:"/"}
.waylink ol li:last-child:after{margin:0;content:""}
aside>ul{margin-top:2vw}
aside ul li b{padding:5px 10px}
aside ul li b .fa:before{content:"\f107"}
aside>ul>li{position:relative;display:inline-block}
aside>ul>li h4{padding:0 15px}
aside>ul>li h4 a{padding:10px 5px 10px 10px;font-weight:300;font-size:18px}
aside>ul>li.action h4 a,aside>ul>li.action h4 i{color:var(--primary)}
aside>ul>li .subUL{position:absolute;margin-top:10px;width:180px;background:var(--white);left:calc((100% - 180px)/ 2)}
aside>ul>li .subUL>li{border-bottom:1px rgba(var(--gray-rgb),.1) solid}
aside>ul>li .subUL>li a{padding:3px 15px;display:block;line-height:140%;font-weight:300}
aside>ul>li .subUL>li .subULHead a{padding:10px 15px;color:var(--primary)}
aside>ul>li .subUL>li b{display:none}
aside>ul>li .sub2UL{margin:0 10px 10px}
aside>ul>li[data-type="1"]{overflow:hidden}
aside>ul>li[data-type="1"] .subUL{box-shadow:0 0 15px rgba(var(--black-rgb),0);opacity:0;z-index:-1}
aside>ul>li[data-type="2"]{overflow:visible}
aside>ul>li[data-type="2"] .subUL{box-shadow:0 0 15px rgba(var(--black-rgb),.15);opacity:1;z-index:1}
.list_box li{margin:0 15px 50px;border-radius:20px 20px 2px 2px}
.list_box li img{background:rgba(var(--primary-rgb),.05)}
#product_list .img_scale img{background-size:cover;background-position:50%}
#product_list .right_box{display:none}
#article_list li h3{padding:10px 20px;width:calc(90% - 0px);height:51px;background:rgba(var(--white-rgb),.9);line-height:37px;font-weight:400;font-size:18px;bottom:20px;left:5%;color:#364243}
#article_list li img{height:35vw}
#article_list li .info_box{padding:30px;width:calc(100% - 100px);background:rgba(var(--white-rgb),.9);bottom:-100%;left:20px;opacity:0}
#article_list li .info_box p{height:34px;font-size:20px}
#article_list li .info_box .cate{z-index:2}
#article_list li .info_box article{margin:15px 0 40px;height:90px;line-height:220%;font-weight:300;font-size:14px;-webkit-line-clamp:3}
#news_list{display:flex;flex-direction:column;margin-top:20px}
#news_list li{width:100%;padding:3px 10px;margin:0 0 20px;border-radius:10px;background:#f5f5f5}
#news_list li:hover{-moz-transform:translateY(-.25em);-webkit-transform:translateY(-.25em);-o-transform:translateY(-.25em);-ms-transform:translateY(-.25em);transform:translateY(-.25em);background:#f8f8f8}
#news_list li img{height:320px}
#news_list li .info_box{padding:15px 30px}
#news_list li .info_box p a{margin-right:10px;max-width:calc(100% - 100px);font-weight:400;z-index:2}
#news_list li .info_box p .time{width:auto;font-weight:300}
#news_list li .info_box h3{height:34px;font-size:20px}
#faq_list{margin-top:30px}
#faq_list li{margin-bottom:30px}
#faq_list li .title font{padding:15px 65px 15px 25px;background:var(--white);font-size:max(1.4*(1vw + 1vh) / 2,16px);box-shadow:0 0 15px rgba(var(--black-rgb),.2)}
#faq_list li .title i{font-size:26px;top:calc((100% - 26px)/ 2);right:25px}
#faq_list li .info{padding:25px;font-size:14px;-webkit-transition:none;-moz-transition:none;-ms-transition:none;-o-transition:none;transition:none}
#faq_list li.current{box-shadow:0 0 15px rgba(var(--black-rgb),.2)}
#faq_list li.current .title font{background:var(--secondary);box-shadow:none;color:var(--white)}
#faq_list li.current .title i{color:var(--white)}
#book_list img{height:250px}
#book_list .img_box{border:var(--white) solid;border-width:0 1px 1px 0}
#book_list .img_box:after,#book_list .img_box:before{position:absolute;width:100%;height:100%;background:var(--white);z-index:9;opacity:.4;content:""}
#book_list .img_box:after{right:0;bottom:0}
#book_list .atag_item{z-index:10}
#book_list .badge{margin:auto;max-width:calc(80% - 40px);height:44px;line-height:36px;width:100%;font-size:max(1.4*(1vw + 1vh) / 2,16px);background:unset;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;white-space:pre-wrap}
#album_list{flex-wrap:wrap}
#album_list>div{margin: 0 5px 5px 0;height:300px;flex-grow:1}
#album_list>div img{width:auto;min-width:100%;height:300px}
#book_list{width:min(90%,1440px);margin:0 auto}
#content_wrap{position:relative;padding: 60px 0 30px;z-index:1;background:#fff;border-bottom:#ededed 1px solid}
#content_wrap h1{margin-bottom:5px;padding:30px 20px 10px;border-bottom:1px rgba(var(--black-rgb),.1) solid;line-height:130%;font-size:max(2.2*(1vw + 1vh) / 2,26px)}
#content_wrap .top_box{padding:0 20px}
#content_wrap .quote_box{margin-right:30px}
#pagenav{padding-top:50px}
#pagenav a,#pagenav strong{margin:0 2px;width:35px;height:35px;background:rgba(var(--black-rgb),.1);border-radius:5px;display:inline-block;text-align:center;line-height:35px;font-weight:400}
#pagenav strong{background:var(--secondary);color:var(--white)}
#pagenav a:first-child,#pagenav a:last-child{line-height:30px}
#pagenav p a{margin:0;padding:0 20px;width:auto;border-radius:20px}
#pagenav p a i{margin:0 5px 0 0}
#pagenav p a font{-webkit-transition:none;-moz-transition:none;-ms-transition:none;-o-transition:none;transition:none}
#pagenav p:last-child a i{margin:0 0 0 5px}
#describe{margin:2em 0 2vw}
.outlinkJJface{display:flex;margin-bottom:20px}
.outlinkJJface a{background:#395597;padding:20px 40px;color:#ffffff;border-radius:50px}
.outlinkJJface a:hover{background:#427ead}
.outlinkJJface a svg{width:30px;aspect-ratio:1/1;fill:#ffffff}
.cenifame{display:flex;flex-direction:column;align-items:center}
.antext{display:flex;flex-direction:column;align-items:center;padding:20px 0 0}
.antext p{text-align:center}
.cenifame iframe{width:min(100%,1000px);aspect-ratio:5/3;height:auto}
.cninfotext{padding:50px;background:#fff;box-shadow:0 0 21px rgb(208 208 208 / 30%)}
.cninfotext div{margin-bottom:30px}
.cninfotext h3{font-size:max(1.6*(1vw + 1vh) / 2,18px);color:#a3c9cb;font-weight:500}
.cninfotext p{font-size:max(1.2*(1vw + 1vh) / 2,16px)}
.cenifame .titlevent{display:flex;flex-direction:column;align-items:center;padding:30px 0}
.cenifame .titlevent h2{margin-top:20px}
.cenifame .titlevent:before{content:"";position:relative;display:flex;width:1px;height:50px;background:#a1a1a1}
#describe *{vertical-align:bottom;box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box}
.form_box{display: block;   /* 不要 grid */
  max-width: 800px;
  margin: 0 auto;
  padding: 30px;
  background: #f9f9f9;
  border-radius: 10px;
  font-family: "Noto Sans TC", sans-serif;
  color: #333;}
.form_box p.large{grid-column:1/3}
.form_box p.note{margin-bottom:20px}
.form_box p #btnOK{width:150px}
[data-action=loader]{width:100vw;height:100vh;background:rgba(var(--black-rgb),.3);line-height:100vh;top:0;left:0;opacity:0;z-index:-1}
[data-action=loader] .loader_circle{border:2px rgba(var(--black-rgb),.6) solid;border-left-color:rgba(var(--white-rgb),.4)}
#lodbg{opacity:1;z-index:99999}

.brand-story {
  background: #fafafa;
  padding: 60px 20px;
  font-family: "Noto Sans TC", sans-serif;
  line-height: 1.8;
}

.brand-story .container {
  max-width: 900px;
  margin: 0 auto;
}

.story-title {
  font-size: 2rem;
  font-weight: 700;
  color: #333;
  text-align: center;
  margin-bottom: 40px;
  border-bottom: 3px solid #d39947;
  display: inline-block;
  padding-bottom: 10px;
}

.story-block {
  margin-bottom: 50px;
}

.story-block h2 {
  font-size: 1.5rem;
  color: #d39947;
  margin-bottom: 15px;
  position: relative;
}

.story-block h2::before {
  content: "◆";
  color: #bead9d;
  margin-right: 8px;
}

.story-block p {
  margin-bottom: 15px;
  color: #444;
}

.story-block ul {
  list-style: disc;
  padding-left: 30px;
  margin-bottom: 20px;
}

.story-block blockquote {
  font-style: italic;
  background: #efddc7;
  padding: 15px 20px;
  border-left: 5px solid #d39947;
  margin: 20px 0;
  color: #333;
}

/* 表單外框 */
.form_box {
  max-width: 800px;
  margin: 0 auto;
  padding: 30px;
  background: #f9f9f9;
  border-radius: 10px;
  font-family: "Noto Sans TC", sans-serif;
  color: #333;
}

/* 標示必填欄位說明 */
.form_box .note {
  font-size: 14px;
  margin-bottom: 20px;
  color: #888;
}

/* 單行輸入框 */
.form_box input[type="text"],
.form_box input[type="email"],
.form_box select,
.form_box textarea {
  width: 100%;
  padding: 12px 14px;
  font-size: 15px;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #fff;
  transition: all 0.3s ease;
  box-sizing: border-box;
  margin-bottom: 20px;
}
#Name::placeholder{color: #4f4949;opacity: 1;}
#Phone::placeholder{color: #4f4949;opacity: 1;}
#Email::placeholder{color: #4f4949;opacity: 1;}
#Address::placeholder{color: #4f4949;opacity: 1;}
#Title::placeholder{color: #4f4949;opacity: 1;}
#Content::placeholder{color: #4f4949;opacity: 1;}
#Checknum::placeholder{color: #4f4949;opacity: 1;}

.nobreak {
  white-space: nowrap;
}
.contact-note {
  font-size: 1rem;           /* 比 pt 更適合 RWD */
  line-height: 1.7;          /* 調整行高避免擠壓 */
  white-space: normal;       /* 手機可換行 */
  overflow-wrap: anywhere;   /* 避免超出容器 */
  word-break: break-word;    /* 中文/英文都能斷行 */
  margin: 0 0 12px;
  text-align: left;          /* 可依需求改成 center */
}

/* hover / focus 效果 */
.form_box input[type="text"]:focus,
.form_box input[type="email"]:focus,
.form_box select:focus,
.form_box textarea:focus {
  border-color: #d39947;
  box-shadow: 0 0 5px rgba(211, 153, 71, 0.4);
  outline: none;
}

/* placeholder 顏色 */
.form_box input::placeholder,
.form_box textarea::placeholder {
  color: #bbb;
}

/* 下拉選單 */
.form_box select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: #fff url("data:image/svg+xml;utf8,<svg fill='%23999' height='20' viewBox='0 0 24 24' width='20' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/></svg>") no-repeat right 10px center;
  background-size: 16px;
}

/* 驗證碼區塊 */
.form_box .checknum {
  display: flex;
  align-items: center;
  gap: 10px;
}

.form_box .checknum input {
  flex: 1;            /* 改成佔滿剩餘寬度 */
  min-width: 150px;   /* 最小寬度限制，避免太窄 */
  text-transform: uppercase;
  text-align: center;
  font-weight: bold;
}

/* 驗證碼圖片 */
.form_box .checknum img {
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 2px;
  cursor: pointer;
}

/* 備註文字框 */
.form_box textarea {
  resize: vertical;
  min-height: 120px;
}

/* 送出按鈕 */
.form_box .more_btn {
  display: inline-block;
  width: 160px;
  padding: 14px 0;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 2px;
  background: #000;
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.form_box .more_btn:hover {
  background: #d39947;
  color: #fff;
}

/* 容器 */
.proj-yearly{
  --primary: var(--primary, #d39947);
  --ink:#333;
  --muted:#6b7280;
  background:#fafafa;
  padding:40px 20px;
  border-radius:12px;
  box-shadow:0 6px 24px rgba(0,0,0,.04);
  font-family: "Noto Sans TC", sans-serif;
}

/* 每個年度群組 */
.proj-yearly .year{
  background:#fff;
  border-radius:14px;
  margin:14px auto;
  padding:0;
  border:1px solid #eee;
  overflow:hidden;
}

.proj-yearly .year[open]{ box-shadow:0 10px 24px rgba(0,0,0,.06); }

/* 年度列 */
.proj-yearly .year > summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 20px;
  position:relative;
  user-select:none;
}

.proj-yearly .year > summary::-webkit-details-marker{ display:none; }

.proj-yearly .year > summary .y{
  font-size:1.4rem;
  font-weight:700;
  color:var(--ink);
  letter-spacing:.05em;
}

/* 計數圓點 */
.proj-yearly .year > summary .cnt{
  font-size:.9rem;
  color:#fff;
  background:var(--primary);
  border-radius:999px;
  padding:.25em .6em;
}

/* 展開箭頭（用 :after 畫） */
.proj-yearly .year > summary::after{
  content:"";
  width:10px; height:10px;
  border:2px solid var(--muted);
  border-left-color:transparent;
  border-top-color:transparent;
  transform: rotate(45deg);
  transition:transform .2s ease;
  margin-left:8px;
}
.proj-yearly .year[open] > summary::after{ transform: rotate(225deg); }

/* 條列 */
.proj-yearly ul{
  padding: 4px 22px 18px 30px;
  margin:0 0 12px;
  border-top:1px dashed #eee;
}
.proj-yearly li{
  position:relative;
  padding:10px 8px 10px 18px;
  line-height:1.7;
  color:#444;
  border-radius:8px;
}
.proj-yearly li + li{ margin-top:2px; }

.proj-yearly li::before{
  content:"";
  width:8px; height:8px;
  border-radius:50%;
  background:var(--primary);
  position:absolute;
  left:0; top:1.1em;
  transform:translate(-50%,-50%);
  opacity:.9;
}

/* hover 微互動 */
@media (hover:hover){
  .proj-yearly li:hover{
    background:#fff7ed; /* 淡橘 */
  }
}

/* RWD 調整 */
@media (max-width: 640px){
  .proj-yearly{ padding:24px 14px; }
  .proj-yearly .year > summary .y{ font-size:1.2rem; }
  .proj-yearly ul{ padding:4px 16px 14px 24px; }
}


/* 頁首標題列 */
.proj-header {
  max-width: 900px;                  /* 與 .proj-yearly 寬度接近 */
  margin: 20px auto 10px;            /* 上下留白，置中 */
  padding: 12px 20px;
  background: #fff7ed;               /* 淡橘背景呼應主色 */
  color: #d39947;                    /* 主色字體 */
  font-weight: 700;
  font-size: 1.2rem;
  text-align: center;
  border: 1px solid #f3e2c5;         /* 邊框柔和 */
  border-radius: 8px;
  letter-spacing: 0.05em;
  box-shadow: 0 4px 10px rgba(0,0,0,.04);
}

.procure-steps {
  padding: 40px 20px;
  background: #f8fafc;
}

.steps-header {
  text-align: center;
  margin-bottom: 32px;
}
.steps-header h2 {
  font-size: 28px;
  color: #FFFFFF;
  margin-bottom: 12px;
}
.steps-header p {
  color: #FFFFFF;
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.8;
}

.steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 28px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.step-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.25s, box-shadow 0.25s;
}
.step-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 26px rgba(0,0,0,0.12);
}

.step-img {
  aspect-ratio: 16/9;          /* 保持比例 */
  overflow: hidden;
}
.step-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;           /* 照片裁切填滿 */
  display: block;
}

.step-body {
  padding: 18px 20px;
}
.step-body h3 {
  font-size: 18px;
  display: flex;
  align-items: center;
  margin-bottom: 8px;
  color: #222;
}
.step-body p {
  color: #555;
  line-height: 1.7;
  font-size: 15px;
}

/* 編號圓點 */
.step-no {
  background: #d39947;
  color: #fff;
  border-radius: 50%;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 8px;
  font-weight: bold;
  font-size: 14px;
  flex-shrink: 0;
}


/* RWD：手機縮小字體 */
@media (max-width: 640px){
  .proj-header {
    font-size: 1rem;
    padding: 10px 14px;
  }
}

.waylink {
  display: none !important;
}

.outlinkJJface{display: none;}
#community .d_inblock #twitter-widget-0 {display: none;}
{display: none;}

@media screen and (min-width: 1281px) {
#page_title,#sub_banner a{padding-top:0;height:400px}
aside>ul>li.action h4 a,aside>ul>li:hover h4 a,aside>ul>li:hover h4 i{color:var(--secondary)}
#article_list li:hover h3{opacity:0}
aside>ul>li.action h4 a{border-bottom:var(--secondary) 2px solid;font-weight:600}
#article_list li img{height:500px}
#article_list li:hover .info_box{bottom:20px;opacity:1}
#book_list li{padding:10px}
#book_list li:hover .badge{background:var(--secondary);color:var(--white)}
#pagenav a:hover{background:var(--primary);color:var(--white)}
#pagenav a:hover font,#pagenav a:hover i,#pagenav a:hover i:before{color:var(--white)}

}

@media screen and (max-width: 1024px) {
	.form_box {grid-template-columns: 1fr;}
	.form_box p.large {grid-column: inherit;}
}

@media screen and (max-width: 768px) {
	#article_list li img {height: 50vw;}
	#news_list li .info_box {padding: 15px 0;}
}

@media screen and (max-width: 640px) {
	#article_list li img{height:320px}
	#book_list{margin:0 5%}
	#book_list li{margin-bottom:20px}
	#book_list .img_box{border:0}
	#album_list>div,#album_list>div img{height:40vw}
}

@media screen and (max-width: 550px) {
	#community{margin-top:10px}
	#pagenav p a i,#pagenav p:last-child a i{margin:0}
	#content_wrap{padding:30px 0}
	#content_wrap h1{padding-left:1px;font-size:max(2.2*(1vw + 1vh) / 2,24px)}
	#page_title,#sub_banner a{height:280px}
	#page_title>div{margin-top:135px}
	aside>ul>li h4{padding:0 0;display:flex}
	aside>ul>li h4 a{color:#fff;padding:0 0;width:100%;padding:2px 16px}
	aside>ul>li{padding:0 4px;background:var(--complement);margin:7px 3px;border-radius:55px}
	#category_nav{text-align:left;padding:30px 21px 30px}
	aside>ul>li.action h4 a{color:#fff}
	aside>ul>li.action{background:#3d686a}
	#wrap aside.page_area{display:none}
	.list_box li{margin:10px 10px 40px;border-radius:20px}
	#article_list li h3{width:95%;left:2.5%}
	#book_list .badge{max-width:100%}
}

@media screen and (max-width: 450px) {
	#album_list>div,#album_list>div img{height:50vw}
	#pagenav a,#pagenav strong{margin:0;width:24px;height:24px;line-height:24px;font-size:14px}
	#pagenav a:first-child,#pagenav a:last-child{line-height:20px}
	#pagenav p a i,#pagenav p:last-child a i{font-size:20px}
}