/*!********************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-1.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-1.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-1.use[3]!./resources/src/css/home/article_content.scss ***!
  \********************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  /* === Songshan brand palette === */
  --bg: #ffffff;
  --bg-warm: #f5f5f3;
  --bg-warm-2: #ebebe7;
  --line: #dbdcdc;
  --line-soft: #e8e8e6;
  --ink: #2a2a28;
  --ink-2: #595757;
  --muted: #88908d;
  --muted-2: #b8bcb9;
  /* category accents */
  --moss: rgb(49, 79, 63);
  --moss-soft: rgb(94, 121, 106);
  --moss-tint: #e8f0ec;
  --indigo: #005787;
  --indigo-soft: #c9e1ee;
  --indigo-tint: #e6f0f7;
  --terracotta: #bd8145;
  --terracotta-soft: #dfbc8b;
  --terracotta-tint: #f4e8d4;
  --sun: #f8dd00;
  /* fonts */
  --serif-tc: "Noto Serif TC", "Songti TC", serif;
  --serif-en: "Cormorant Garamond", "Noto Serif TC", serif;
  --sans: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  /* === legacy fluid sizes (kept) === */
  --fs-xs: 0.875rem;
  --fs-s: 1rem;
  --fs-r: 1.125rem;
  --fs-m: 1.25rem;
  --fs-ml: 1.8125rem;
  --fs-l: 2.3125rem;
  --fs-xl: 2.6875rem;
  --fs-xxl: 3.3125rem;
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss: color(display-p3 0.22014 0.30800 0.25261);
}
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss-soft: color(display-p3 0.38885 0.47177 0.41797);
}
}

@media screen and (max-width: 480px) {
  :root {
    --fs-ml: 1.6875rem;
  }
}
/* news_content 頁面所有版型都由共用元件提供：
   - _breadcrumb.scss
   - _article_layout.scss   （article_intro / meta / title / lead / footer / back_link）
   - _article_toolbar.scss  （字級 + 社群分享）
   - _ckeditor_content.scss （CKEditor 富文本內容）
   皆於 news_content.js 中 import。本檔保留頁面層級覆寫位置。 */
@media (orientation: portrait) {
  .main {
    padding-top: 6.5rem;
  }
}
/*!****************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-1.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-1.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-1.use[3]!./resources/src/css/share/components/_breadcrumb.scss ***!
  \****************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  /* === Songshan brand palette === */
  --bg: #ffffff;
  --bg-warm: #f5f5f3;
  --bg-warm-2: #ebebe7;
  --line: #dbdcdc;
  --line-soft: #e8e8e6;
  --ink: #2a2a28;
  --ink-2: #595757;
  --muted: #88908d;
  --muted-2: #b8bcb9;
  /* category accents */
  --moss: rgb(49, 79, 63);
  --moss-soft: rgb(94, 121, 106);
  --moss-tint: #e8f0ec;
  --indigo: #005787;
  --indigo-soft: #c9e1ee;
  --indigo-tint: #e6f0f7;
  --terracotta: #bd8145;
  --terracotta-soft: #dfbc8b;
  --terracotta-tint: #f4e8d4;
  --sun: #f8dd00;
  /* fonts */
  --serif-tc: "Noto Serif TC", "Songti TC", serif;
  --serif-en: "Cormorant Garamond", "Noto Serif TC", serif;
  --sans: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  /* === legacy fluid sizes (kept) === */
  --fs-xs: 0.875rem;
  --fs-s: 1rem;
  --fs-r: 1.125rem;
  --fs-m: 1.25rem;
  --fs-ml: 1.8125rem;
  --fs-l: 2.3125rem;
  --fs-xl: 2.6875rem;
  --fs-xxl: 3.3125rem;
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss: color(display-p3 0.22014 0.30800 0.25261);
}
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss-soft: color(display-p3 0.38885 0.47177 0.41797);
}
}

@media screen and (max-width: 480px) {
  :root {
    --fs-ml: 1.6875rem;
  }
}
/* ============================================================
   共用麵包屑 breadcrumb
   配置：
     <nav class="breadcrumb" aria-label="麵包屑">
       <a class="breadcrumb_link" href="...">首頁</a>
       <span class="breadcrumb_sep" aria-hidden="true">／</span>
       <a class="breadcrumb_link" href="...">最新資訊</a>
       <span class="breadcrumb_sep" aria-hidden="true">／</span>
       <span class="breadcrumb_current" aria-current="page">當前頁面</span>
     </nav>
   .breadcrumb_current 含長標題 ellipsis 截斷；短標題不受影響。
   ============================================================ */
.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.625rem 0.5rem;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  color: #88908d;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 2.5rem;
}
@media (orientation: portrait) {
  .breadcrumb {
    margin-bottom: 1.75rem;
  }
}

.breadcrumb_link {
  color: #88908d;
  color: var(--muted);
  transition: color 0.2s;
}
.breadcrumb_link:hover {
  color: rgb(49, 79, 63);
  color: color(display-p3 0.22014 0.30800 0.25261);
  color: var(--moss);
}

.breadcrumb_sep {
  color: #b8bcb9;
  color: var(--muted-2);
}

.breadcrumb_current {
  color: #2a2a28;
  color: var(--ink);
  font-weight: 500;
  max-width: 23.75rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (orientation: portrait) {
  .breadcrumb_current {
    max-width: 13.75rem;
  }
}
@media screen and (max-width: 480px) {
  .breadcrumb_current {
    max-width: 10rem;
  }
}
/*!********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-1.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-1.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-1.use[3]!./resources/src/css/share/components/_article_layout.scss ***!
  \********************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  /* === Songshan brand palette === */
  --bg: #ffffff;
  --bg-warm: #f5f5f3;
  --bg-warm-2: #ebebe7;
  --line: #dbdcdc;
  --line-soft: #e8e8e6;
  --ink: #2a2a28;
  --ink-2: #595757;
  --muted: #88908d;
  --muted-2: #b8bcb9;
  /* category accents */
  --moss: rgb(49, 79, 63);
  --moss-soft: rgb(94, 121, 106);
  --moss-tint: #e8f0ec;
  --indigo: #005787;
  --indigo-soft: #c9e1ee;
  --indigo-tint: #e6f0f7;
  --terracotta: #bd8145;
  --terracotta-soft: #dfbc8b;
  --terracotta-tint: #f4e8d4;
  --sun: #f8dd00;
  /* fonts */
  --serif-tc: "Noto Serif TC", "Songti TC", serif;
  --serif-en: "Cormorant Garamond", "Noto Serif TC", serif;
  --sans: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  /* === legacy fluid sizes (kept) === */
  --fs-xs: 0.875rem;
  --fs-s: 1rem;
  --fs-r: 1.125rem;
  --fs-m: 1.25rem;
  --fs-ml: 1.8125rem;
  --fs-l: 2.3125rem;
  --fs-xl: 2.6875rem;
  --fs-xxl: 3.3125rem;
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss: color(display-p3 0.22014 0.30800 0.25261);
}
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss-soft: color(display-p3 0.38885 0.47177 0.41797);
}
}

@media screen and (max-width: 480px) {
  :root {
    --fs-ml: 1.6875rem;
  }
}
/* ============================================================
   共用文章內頁版型 article layout
   配置：
     <main class="main">
       <section class="article_intro">
         <div class="container">
           <div class="article_inner">
             <nav class="breadcrumb">...</nav>           ← _breadcrumb.scss
             <div class="article_meta">
               <span class="tag">類別</span>             ← 支援 .warn / .gray 變體
               <time class="article_date">...</time>
               <span class="article_views">...</span>
             </div>
             <h1 class="article_title">標題</h1>
             <p class="article_lead">前言摘要</p>
           </div>
         </div>
       </section>

       <section class="article_section">
         <div class="container">
           <div class="article_inner">
             <div class="article_toolbar">...</div>      ← _article_toolbar.scss
             <article class="ckeditor_content">...</article>  ← _ckeditor_content.scss
             <footer class="article_footer">
               <nav class="article_nav">                 ← prev/next 兩欄
                 <a class="article_nav_link prev">...</a>
                 <a class="article_nav_link next">...</a>
               </nav>
               <a class="back_link">← 返回列表</a>
             </footer>
           </div>
         </div>
       </section>
     </main>
   .article_inner 為窄版容器（max-width: rem(880)）提升閱讀舒適度。
   ============================================================ */
/* ---- intro ---- */
.article_intro {
  padding: 3.5rem 0 3rem;
  border-bottom: 0.0625rem solid #dbdcdc;
  border-bottom: 0.0625rem solid var(--line);
}
@media (orientation: portrait) {
  .article_intro {
    padding: 2.5rem 0 2rem;
  }
}
@media screen and (max-width: 480px) {
  .article_intro {
    padding: 1.75rem 0 1.5rem;
  }
}

.article_inner {
  max-width: 62.5rem;
  margin: 0 auto;
}

/* ---- meta（tag + date + views）---- */
.article_meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}

.article_meta .tag {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.65625rem;
  letter-spacing: 0.16em;
  color: rgb(49, 79, 63);
  color: color(display-p3 0.22014 0.30800 0.25261);
  color: var(--moss);
  text-transform: uppercase;
  width: -moz-fit-content;
  width: fit-content;
}
.article_meta .tag::before {
  content: "";
  width: 0.3125rem;
  height: 0.3125rem;
  background: rgb(49, 79, 63);
  background: color(display-p3 0.22014 0.30800 0.25261);
  background: var(--moss);
  border-radius: 50%;
}
.article_meta .tag.warn {
  color: #bd8145;
  color: var(--terracotta);
}
.article_meta .tag.warn::before {
  background: #bd8145;
  background: var(--terracotta);
}
.article_meta .tag.gray {
  color: #88908d;
  color: var(--muted);
}
.article_meta .tag.gray::before {
  background: #88908d;
  background: var(--muted);
}

.article_date,
.article_views {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.6875rem;
  letter-spacing: 0.12em;
  color: #88908d;
  color: var(--muted);
}
.article_date svg,
.article_views svg {
  width: 0.8125rem;
  height: 0.8125rem;
  opacity: 0.85;
  flex-shrink: 0;
}

/* ---- title + lead ---- */
.article_title {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-weight: 500;
  font-size: 2.75rem;
  line-height: 1.35;
  color: #2a2a28;
  color: var(--ink);
  margin: 0 0 1.5rem;
  letter-spacing: 0.02em;
  max-width: 62.5rem;
}
@media (orientation: portrait) {
  .article_title {
    font-size: 2rem;
    margin-bottom: 1.25rem;
  }
}
@media screen and (max-width: 480px) {
  .article_title {
    font-size: 1.5rem;
    line-height: 1.45;
  }
}

.article_lead {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-size: 1.0625rem;
  line-height: 1.9;
  color: #595757;
  color: var(--ink-2);
  max-width: 56.25rem;
}
@media screen and (max-width: 480px) {
  .article_lead {
    font-size: 0.9375rem;
  }
}

/* ---- section wrapper ---- */
.article_section {
  padding: 0 0 6rem;
}
@media (orientation: portrait) {
  .article_section {
    padding: 0 0 4rem;
  }
}
@media screen and (max-width: 480px) {
  .article_section {
    padding: 0 0 3rem;
  }
}

/* ---- footer：article_nav + back_link ---- */
.article_footer {
  margin-top: 5rem;
  padding-top: 2.5rem;
  border-top: 0.0625rem solid #dbdcdc;
  border-top: 0.0625rem solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 3rem;
}
@media (orientation: portrait) {
  .article_footer {
    margin-top: 3.5rem;
    gap: 2rem;
  }
}

.article_nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 1rem;
  gap: 1rem;
}
@media (orientation: portrait) {
  .article_nav {
    grid-template-columns: 1fr;
  }
}

.article_nav_link {
  display: block;
  padding: 1.375rem 1.5rem;
  background: #f5f5f3;
  background: var(--bg-warm);
  border-radius: 0.125rem;
  transition: background 0.2s;
}
.article_nav_link .dir {
  display: block;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.65625rem;
  letter-spacing: 0.18em;
  color: #88908d;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}
.article_nav_link .t {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #2a2a28;
  color: var(--ink);
  transition: color 0.2s;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.article_nav_link:hover {
  background: #ebebe7;
  background: var(--bg-warm-2);
}
.article_nav_link:hover .t {
  color: rgb(49, 79, 63);
  color: color(display-p3 0.22014 0.30800 0.25261);
  color: var(--moss);
}
.article_nav_link.next {
  text-align: right;
}
@media (orientation: portrait) {
  .article_nav_link.next {
    text-align: left;
  }
}

.back_link {
  align-self: center;
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.875rem 2rem;
  border: 0.0625rem solid #2a2a28;
  border: 0.0625rem solid var(--ink);
  border-radius: 62.4375rem;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: #2a2a28;
  color: var(--ink);
  text-transform: uppercase;
  transition: background 0.2s, color 0.2s;
}
.back_link svg {
  width: 0.875rem;
  height: 0.875rem;
  transition: transform 0.25s;
}
.back_link:hover {
  background: #2a2a28;
  background: var(--ink);
  color: #fff;
}
.back_link:hover svg {
  transform: translateX(-0.25rem);
}

.article_bottom_note {
  text-align: center;
  border-top: 0.0625rem solid #dbdcdc;
  border-top: 0.0625rem solid var(--line);
  padding-top: 5rem;
  margin-top: 3.125rem;
}
@media (orientation: portrait) {
  .article_bottom_note {
    padding-top: 3.5rem;
  }
}
/*!*********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-1.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-1.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-1.use[3]!./resources/src/css/share/components/_article_toolbar.scss ***!
  \*********************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  /* === Songshan brand palette === */
  --bg: #ffffff;
  --bg-warm: #f5f5f3;
  --bg-warm-2: #ebebe7;
  --line: #dbdcdc;
  --line-soft: #e8e8e6;
  --ink: #2a2a28;
  --ink-2: #595757;
  --muted: #88908d;
  --muted-2: #b8bcb9;
  /* category accents */
  --moss: rgb(49, 79, 63);
  --moss-soft: rgb(94, 121, 106);
  --moss-tint: #e8f0ec;
  --indigo: #005787;
  --indigo-soft: #c9e1ee;
  --indigo-tint: #e6f0f7;
  --terracotta: #bd8145;
  --terracotta-soft: #dfbc8b;
  --terracotta-tint: #f4e8d4;
  --sun: #f8dd00;
  /* fonts */
  --serif-tc: "Noto Serif TC", "Songti TC", serif;
  --serif-en: "Cormorant Garamond", "Noto Serif TC", serif;
  --sans: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  /* === legacy fluid sizes (kept) === */
  --fs-xs: 0.875rem;
  --fs-s: 1rem;
  --fs-r: 1.125rem;
  --fs-m: 1.25rem;
  --fs-ml: 1.8125rem;
  --fs-l: 2.3125rem;
  --fs-xl: 2.6875rem;
  --fs-xxl: 3.3125rem;
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss: color(display-p3 0.22014 0.30800 0.25261);
}
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss-soft: color(display-p3 0.38885 0.47177 0.41797);
}
}

@media screen and (max-width: 480px) {
  :root {
    --fs-ml: 1.6875rem;
  }
}
/* ============================================================
   共用文章工具列 article toolbar
   配置：
     <div class="article_toolbar">
       <div class="font_control" role="group" aria-label="文字大小">
         <span class="font_label">字級</span>
         <button class="font_btn active"><span class="font_btn_inner">A</span></button>
         ...
       </div>
       <div class="share_control" role="group" aria-label="社群分享">
         <span class="share_label">分享</span>
         <a class="share_btn share_btn_fb">...</a>
         <a class="share_btn share_btn_line">...</a>
         <a class="share_btn share_btn_x">...</a>
         <button class="share_btn share_btn_copy">
           <svg>...</svg>
           <transition name="fade">
             <span v-if="copied" class="share_tip">已複製連結</span>
           </transition>
         </button>
       </div>
     </div>
   sticky 吸附在 header 下方（top: rem(84) / portrait rem(64)）
   ============================================================ */
.article_toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  padding: 1.125rem 0;
  border-bottom: 0.0625rem solid #dbdcdc;
  border-bottom: 0.0625rem solid var(--line);
  margin-bottom: 3.5rem;
  position: sticky;
  top: 5.25rem;
  background: rgba(253, 253, 252, 0.92);
  backdrop-filter: blur(0.5rem);
  -webkit-backdrop-filter: blur(0.5rem);
  z-index: 30;
}
@media (orientation: portrait) {
  .article_toolbar {
    top: 4rem;
    flex-direction: column;
    align-items: stretch;
    gap: 0.875rem;
    padding: 0.875rem 0;
    margin-bottom: 2.5rem;
  }
}

.font_control,
.share_control {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.font_label,
.share_label {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.65625rem;
  letter-spacing: 0.18em;
  color: #88908d;
  color: var(--muted);
  text-transform: uppercase;
  margin-right: 0.375rem;
}

.font_btn {
  width: 2.125rem;
  height: 2.125rem;
  border-radius: 50%;
  border: 0.0625rem solid #dbdcdc;
  border: 0.0625rem solid var(--line);
  color: #595757;
  color: var(--ink-2);
  display: grid;
  align-items: center;
  justify-items: center;
  place-items: center;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.font_btn .font_btn_inner {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-weight: 500;
  line-height: 1;
  color: inherit;
  position: relative;
  top: -0.125rem;
}
.font_btn:hover {
  border-color: rgb(49, 79, 63);
  border-color: color(display-p3 0.22014 0.30800 0.25261);
  border-color: var(--moss);
  color: rgb(49, 79, 63);
  color: color(display-p3 0.22014 0.30800 0.25261);
  color: var(--moss);
}
.font_btn.active {
  background: #2a2a28;
  background: var(--ink);
  color: #fff;
  border-color: #2a2a28;
  border-color: var(--ink);
}

.share_btn {
  width: 2.125rem;
  height: 2.125rem;
  border-radius: 50%;
  border: 0.0625rem solid #dbdcdc;
  border: 0.0625rem solid var(--line);
  color: #595757;
  color: var(--ink-2);
  display: grid;
  align-items: center;
  justify-items: center;
  place-items: center;
  position: relative;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.share_btn svg {
  width: 0.875rem;
  height: 0.875rem;
}
.share_btn:hover {
  background: #2a2a28;
  background: var(--ink);
  color: #fff;
  border-color: #2a2a28;
  border-color: var(--ink);
}
.share_btn.share_btn_fb:hover {
  background: #1877f2;
  border-color: #1877f2;
}
.share_btn.share_btn_line:hover {
  background: #06c755;
  border-color: #06c755;
}
.share_btn.share_btn_x:hover {
  background: #000;
  border-color: #000;
}

.share_tip {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 50%;
  transform: translateX(-50%);
  background: #2a2a28;
  background: var(--ink);
  color: #fff;
  padding: 0.3125rem 0.75rem;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  font-size: 0.625rem;
  letter-spacing: 0.12em;
  white-space: nowrap;
  pointer-events: none;
  border-radius: 0.125rem;
}
.share_tip::before {
  content: "";
  position: absolute;
  top: -0.25rem;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 0.5rem;
  height: 0.5rem;
  background: #2a2a28;
  background: var(--ink);
}

/* Vue <transition name="fade"> ─ 給 share_tip 顯示動畫 */
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.2s ease;
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}
/*!**********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-1.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-1.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-1.use[3]!./resources/src/css/share/components/_ckeditor_content.scss ***!
  \**********************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  /* === Songshan brand palette === */
  --bg: #ffffff;
  --bg-warm: #f5f5f3;
  --bg-warm-2: #ebebe7;
  --line: #dbdcdc;
  --line-soft: #e8e8e6;
  --ink: #2a2a28;
  --ink-2: #595757;
  --muted: #88908d;
  --muted-2: #b8bcb9;
  /* category accents */
  --moss: rgb(49, 79, 63);
  --moss-soft: rgb(94, 121, 106);
  --moss-tint: #e8f0ec;
  --indigo: #005787;
  --indigo-soft: #c9e1ee;
  --indigo-tint: #e6f0f7;
  --terracotta: #bd8145;
  --terracotta-soft: #dfbc8b;
  --terracotta-tint: #f4e8d4;
  --sun: #f8dd00;
  /* fonts */
  --serif-tc: "Noto Serif TC", "Songti TC", serif;
  --serif-en: "Cormorant Garamond", "Noto Serif TC", serif;
  --sans: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  /* === legacy fluid sizes (kept) === */
  --fs-xs: 0.875rem;
  --fs-s: 1rem;
  --fs-r: 1.125rem;
  --fs-m: 1.25rem;
  --fs-ml: 1.8125rem;
  --fs-l: 2.3125rem;
  --fs-xl: 2.6875rem;
  --fs-xxl: 3.3125rem;
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss: color(display-p3 0.22014 0.30800 0.25261);
}
}
@supports (color: color(display-p3 0 0 0)){
:root {
  --moss-soft: color(display-p3 0.38885 0.47177 0.41797);
}
}

@media screen and (max-width: 480px) {
  :root {
    --fs-ml: 1.6875rem;
  }
}
/* ============================================================
   共用 CKEditor 文章排版 ckeditor content
   配置：
     <article class="ckeditor_content" :style="{ '--font-scale': fontScale }">
       ... CKEditor 後台輸出的 HTML 直接貼入 ...
     </article>
   涵蓋元素：p / h2~h4 / ul / ol / blockquote / a / strong / em /
            figure / figcaption / img / table / hr / pre / code
   CKEditor 5 變體：
     - 圖片：.image / .image-style-side / .image-style-align-left
             / .image-style-block-align-center
     - 對齊：.text-align-left / -center / -right / -justify
   字級可由外部 inline style 變數 --font-scale 控制（0.92 / 1 / 1.18）。
   .ckeditor_content { overflow: hidden } 為浮動圖片建立 BFC。
   ============================================================ */
.ckeditor_content {
  --font-scale: 1;
  font-family: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  font-family: var(--sans);
  color: #2a2a28;
  color: var(--ink);
  line-height: 1.95;
  font-size: calc(1rem * var(--font-scale));
  overflow: hidden;
}
.ckeditor_content p {
  margin: 0 0 1.625rem;
  font-size: inherit;
}
.ckeditor_content h2 {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-weight: 500;
  font-size: calc(1.75rem * var(--font-scale));
  line-height: 1.4;
  margin: 3.5rem 0 1.375rem;
  color: #2a2a28;
  color: var(--ink);
  padding-left: 1.125rem;
  border-left: 0.1875rem solid rgb(49, 79, 63);
  border-left: 0.1875rem solid color(display-p3 0.22014 0.30800 0.25261);
  border-left: 0.1875rem solid var(--moss);
  letter-spacing: 0.02em;
}
.ckeditor_content h3 {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-weight: 500;
  font-size: calc(1.375rem * var(--font-scale));
  line-height: 1.5;
  margin: 2.5rem 0 0.875rem;
  color: #2a2a28;
  color: var(--ink);
  letter-spacing: 0.02em;
}
.ckeditor_content h4 {
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-weight: 500;
  font-size: calc(1.125rem * var(--font-scale));
  line-height: 1.55;
  margin: 1.75rem 0 0.625rem;
  color: #2a2a28;
  color: var(--ink);
}
.ckeditor_content ul,
.ckeditor_content ol {
  margin: 0 0 1.75rem;
  padding-left: 1.75rem;
}
.ckeditor_content ul li,
.ckeditor_content ol li {
  margin-bottom: 0.5rem;
}
.ckeditor_content ul li {
  list-style: disc;
}
.ckeditor_content ol li {
  list-style: decimal;
}
.ckeditor_content blockquote {
  margin: 2.5rem 0;
  padding: 1.375rem 1.75rem;
  border-left: 0.1875rem solid rgb(49, 79, 63);
  border-left: 0.1875rem solid color(display-p3 0.22014 0.30800 0.25261);
  border-left: 0.1875rem solid var(--moss);
  background: #f5f5f3;
  background: var(--bg-warm);
  color: #595757;
  color: var(--ink-2);
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-size: calc(0.9375rem * var(--font-scale));
}
.ckeditor_content blockquote p {
  margin-bottom: 0.625rem;
}
.ckeditor_content blockquote p:last-child {
  margin-bottom: 0;
}
.ckeditor_content a:not(.share_btn):not(.back_link):not(.article_nav_link):not(.breadcrumb_link) {
  color: rgb(49, 79, 63);
  color: color(display-p3 0.22014 0.30800 0.25261);
  color: var(--moss);
  border-bottom: 0.0625rem solid rgb(94, 121, 106);
  border-bottom: 0.0625rem solid color(display-p3 0.38885 0.47177 0.41797);
  border-bottom: 0.0625rem solid var(--moss-soft);
  transition: color 0.2s, border-color 0.2s;
}
.ckeditor_content a:not(.share_btn):not(.back_link):not(.article_nav_link):not(.breadcrumb_link):hover {
  color: #2a2a28;
  color: var(--ink);
  border-bottom-color: #2a2a28;
  border-bottom-color: var(--ink);
}
.ckeditor_content strong {
  font-weight: 700;
  color: #2a2a28;
  color: var(--ink);
}
.ckeditor_content em {
  font-style: italic;
}
.ckeditor_content img {
  max-width: 100%;
  height: auto;
  border-radius: 0.125rem;
}
.ckeditor_content figure {
  margin: 2.5rem 0;
}
.ckeditor_content figure figcaption {
  margin-top: 0.1875rem;
  font-family: "Noto Sans TC", -apple-system, BlinkMacSystemFont, sans-serif;
  font-family: var(--sans);
  font-size: calc(0.78125rem * var(--font-scale));
  color: #88908d;
  color: var(--muted);
  text-align: center;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.ckeditor_content {
  /* CKEditor image styles */
}
.ckeditor_content figure.image-style-side {
  float: right;
  max-width: 45%;
  margin: 0 0 1.25rem 1.75rem;
}
@media (orientation: portrait) {
  .ckeditor_content figure.image-style-side {
    float: none;
    max-width: 100%;
    margin: 2rem 0;
  }
}
.ckeditor_content figure.image-style-side:after {
  content: "";
  display: block;
  clear: both;
}
.ckeditor_content figure.image-style-align-left {
  float: left;
  max-width: 45%;
  margin: 0 1.75rem 1.25rem 0;
}
@media (orientation: portrait) {
  .ckeditor_content figure.image-style-align-left {
    float: none;
    max-width: 100%;
    margin: 2rem 0;
  }
}
.ckeditor_content figure.image-style-block-align-center {
  margin: 2.5rem auto;
}
.ckeditor_content figure.image-style-block-align-center:nth-child(1) {
  margin-top: 0;
}
.ckeditor_content {
  /* tables */
}
.ckeditor_content table {
  width: 100%;
  border-collapse: collapse;
  margin: 2rem 0;
  font-size: calc(0.875rem * var(--font-scale));
}
.ckeditor_content table th,
.ckeditor_content table td {
  padding: 0.75rem 1rem;
  border: 0.0625rem solid #dbdcdc;
  border: 0.0625rem solid var(--line);
  text-align: left;
  line-height: 1.7;
}
.ckeditor_content table th {
  background: #f5f5f3;
  background: var(--bg-warm);
  font-family: "Noto Serif TC", "Songti TC", serif;
  font-family: var(--serif-tc);
  font-weight: 500;
  color: #2a2a28;
  color: var(--ink);
  letter-spacing: 0.04em;
}
.ckeditor_content table tbody tr:hover {
  background: rgba(245, 245, 243, 0.6);
}
@media screen and (max-width: 480px) {
  .ckeditor_content table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}
.ckeditor_content hr {
  border: 0;
  border-top: 0.0625rem solid #dbdcdc;
  border-top: 0.0625rem solid var(--line);
  margin: 3rem 0;
}
.ckeditor_content pre,
.ckeditor_content code {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-family: var(--mono);
  background: #f5f5f3;
  background: var(--bg-warm);
  color: #2a2a28;
  color: var(--ink);
}
.ckeditor_content code {
  font-size: calc(0.8125rem * var(--font-scale));
  padding: 0.125rem 0.375rem;
  border-radius: 0.125rem;
}
.ckeditor_content pre {
  padding: 1.25rem;
  margin: 1.75rem 0;
  overflow-x: auto;
  font-size: calc(0.8125rem * var(--font-scale));
  line-height: 1.7;
  border-radius: 0.125rem;
}
.ckeditor_content {
  /* CKEditor 對齊類別 */
}
.ckeditor_content .text-align-left {
  text-align: left;
}
.ckeditor_content .text-align-center {
  text-align: center;
}
.ckeditor_content .text-align-right {
  text-align: right;
}
.ckeditor_content .text-align-justify {
  text-align: justify;
}
@media (orientation: portrait) {
  .ckeditor_content {
    line-height: 1.88;
  }
  .ckeditor_content img {
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
  }
}
@media screen and (max-width: 480px) {
  .ckeditor_content h2 {
    font-size: calc(1.375rem * var(--font-scale));
    margin: 2.5rem 0 0.875rem;
    padding-left: 0.75rem;
  }
  .ckeditor_content h3 {
    font-size: calc(1.125rem * var(--font-scale));
    margin: 1.75rem 0 0.625rem;
  }
  .ckeditor_content figure {
    margin: 1.75rem 0;
  }
  .ckeditor_content blockquote {
    margin: 1.75rem 0;
    padding: 1rem 1.25rem;
  }
}

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