/* ===========================================================
   Haruru 官網 · site.css
   Based on Haruru Design System v0.1
   中文主體 · 英文為氣質眉批 · 大器版型
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Noto+Serif+TC:wght@300;400;500;600;700&family=Noto+Sans+TC:wght@300;400;500;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  /* CORE COLORS */
  --c-paper:#F5F4F0;
  --c-paper-dim:#EDEBE5;
  --c-paper-warm:#EAE6DB;
  --c-ink:#0E0E0E;
  --c-ink-soft:#1A1A1A;
  --c-fire:#FF4D1F;
  --c-fire-100:#FFE3D8;
  --c-fire-300:#FF6A3D;
  --c-fire-700:#C23714;

  /* NEUTRAL */
  --c-line:#D8D6CF;
  --c-line-soft:#E4E2DB;
  --c-mute-soft:#9F9D97;
  --c-mute:#7A7874;

  /* TYPE FAMILIES */
  --en:'Spectral', serif;
  --zh-d:'Noto Serif TC', serif;
  --zh-s:'Noto Sans TC', -apple-system, sans-serif;
  --mono:'JetBrains Mono', monospace;

  /* SPACING (4px base) */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px;
  --sp-5:24px; --sp-6:32px; --sp-7:48px; --sp-8:64px;
  --sp-9:80px; --sp-10:120px; --sp-11:160px; --sp-12:240px;

  /* LAYOUT */
  --max:1440px;
  --gutter:clamp(24px, 4vw, 72px);

  /* RADIUS */
  --r-sm:4px; --r-md:8px; --r-lg:12px; --r-full:999px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--c-paper);
  color:var(--c-ink);
  font-family:var(--zh-s);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--c-fire);color:var(--c-paper)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Noise texture — 設計系統核心紙質感 */
body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1000;
  mix-blend-mode:multiply;
  opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===========================================================
   NAV 導覽（放大 — UI 人性化）
   =========================================================== */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(245,244,240,.88);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--c-line);
}
.site-nav-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:20px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--sp-6);
}
.brand{
  display:flex;align-items:center;gap:12px;
  font-family:var(--en);
  font-weight:500;
  font-size:22px;
  letter-spacing:-.01em;
}
.brand .dot{
  width:8px;height:8px;
  background:var(--c-fire);
  border-radius:50%;
}
.brand .zh{
  font-family:var(--zh-d);
  font-weight:400;
  font-size:15px;
  color:var(--c-mute);
  margin-left:4px;
  letter-spacing:.02em;
}
.site-nav-links{
  display:flex;
  gap:var(--sp-5);
  font-family:var(--zh-s);
  font-size:16px;          /* 放大到 16px，桌面閱讀舒服 */
  font-weight:400;
  color:var(--c-ink);
}
.site-nav-links a{
  padding:10px 4px;
  position:relative;
  transition:color .25s;
}
.site-nav-links a::after{
  content:'';
  position:absolute;
  bottom:2px;left:0;
  height:1px;width:0;
  background:var(--c-fire);
  transition:width .3s ease;
}
.site-nav-links a:hover,
.site-nav-links a.active{color:var(--c-fire)}
.site-nav-links a:hover::after,
.site-nav-links a.active::after{width:100%}

.nav-cta{
  font-family:var(--zh-s);
  font-weight:500;
  font-size:15px;
  background:var(--c-ink);
  color:var(--c-paper);
  padding:12px 26px;
  border-radius:999px;
  transition:all .25s ease;
  display:inline-flex;align-items:center;gap:8px;
}
.nav-cta:hover{background:var(--c-fire);transform:translateY(-1px)}
.nav-cta .ar{font-family:var(--en);font-size:18px;font-style:italic}

.menu-btn{
  display:none;
  background:none;border:none;cursor:pointer;
  font-size:22px;color:var(--c-ink);
}

@media (max-width:960px){
  .site-nav-links{display:none}
  .site-nav-links.open{
    display:flex;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;
    background:var(--c-paper);
    padding:var(--sp-6) var(--gutter);
    gap:var(--sp-5);
    border-bottom:1px solid var(--c-line);
    font-size:18px;
  }
  .menu-btn{display:block}
}

/* ===========================================================
   UTILITIES
   =========================================================== */
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Italic safety (Spectral 尾巴切掉修正) */
.italic-safe{padding-block:.12em .08em;line-height:1.12}

/* ===========================================================
   次要連結（原「完整了解 GEO 是什麼 →」）
   克制版 + 橘色從左滑入 + 箭頭變橘色右移
   =========================================================== */
.lead-link{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:var(--zh-s);
  font-weight:500;
  font-size:17px;
  color:var(--c-ink);
  padding:4px 0 12px;
  position:relative;
  transition:gap .3s ease;
}
.lead-link::before{
  /* 底線：預設 1px 黑色細線 */
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:1px;
  background:var(--c-ink);
  z-index:1;
}
.lead-link::after{
  /* 橘色滑入線：預設寬度 0，hover 時從左滑到右 */
  content:'';
  position:absolute;
  bottom:0;left:0;
  height:2px;
  width:0;
  background:var(--c-fire);
  transition:width .45s cubic-bezier(.2,.8,.2,1);
  z-index:2;
}
.lead-link .ar{
  font-family:var(--en);
  font-style:italic;
  font-size:22px;
  color:var(--c-ink);
  transition:color .3s ease .15s, transform .35s ease .15s;
  /* 延遲 .15s 讓箭頭在橘線滑到尾端時才變色 */
}
.lead-link:hover::after{width:100%}
.lead-link:hover .ar{
  color:var(--c-fire);
  transform:translateX(6px);
}

/* ===========================================================
   MARQUEE 跑馬燈
   =========================================================== */
.marquee{
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
  padding:var(--sp-5) 0;
  overflow:hidden;
  background:var(--c-paper-dim);
  position:relative;
}
.marquee-track{
  display:inline-flex;
  gap:var(--sp-7);
  animation:marquee 40s linear infinite;
  font-family:var(--en);
  font-style:italic;
  font-weight:400;
  font-size:24px;
  color:var(--c-mute);
  white-space:nowrap;
  letter-spacing:-.01em;
  will-change:transform;
  /* 永遠保持足夠寬度，確保移動有空間 */
  padding-right:var(--sp-7);
}
.marquee-track span{
  display:inline-flex;
  align-items:center;
  gap:var(--sp-7);
  flex-shrink:0;
}
.marquee-track .dot{
  width:6px;height:6px;
  background:var(--c-fire);
  border-radius:50%;
  flex-shrink:0;
}
/* 動畫：移動一組內容的距離（50%），配合重複組確保無縫循環 */
@keyframes marquee{
  from{transform:translate3d(0, 0, 0)}
  to{transform:translate3d(-50%, 0, 0)}
}
@media (max-width:860px){
  .marquee-track{
    font-size:19px;
    gap:var(--sp-5);
    animation-duration:30s;
  }
  .marquee-track span{gap:var(--sp-5)}
}
/* 尊重動畫偏好 */
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none}
}

/* ===========================================================
   CLOSING CTA
   英文眉批 → 中文主標 → 中文副標 → 說明內文 → 圓形 CTA
   =========================================================== */
.closing{
  background:var(--c-fire);
  color:var(--c-ink);
  padding:var(--sp-10) var(--gutter) var(--sp-10);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.closing-inner{max-width:960px;margin:0 auto;position:relative}

/* 英文眉批 — Spectral Italic，呼應 Haruru 品牌精神 */
.closing-eyebrow{
  font-family:var(--en);
  font-style:italic;
  font-weight:400;
  font-size:19px;
  color:var(--c-ink);
  margin-bottom:var(--sp-7);
  letter-spacing:.01em;
  opacity:.85;
}

/* 中文主標 — 最大字，有魄力，一行不斷句 */
.closing-title{
  font-family:var(--zh-d);
  font-weight:300;
  font-size:clamp(44px, 8vw, 120px);
  line-height:1.1;
  letter-spacing:-.03em;
  margin-bottom:var(--sp-4);
  color:var(--c-ink);
  white-space:nowrap;
}
@media (max-width:520px){
  .closing-title{
    white-space:normal;
    font-size:clamp(36px, 11vw, 56px);
  }
}
.closing-title em{
  font-style:normal;
  color:var(--c-ink);
  font-weight:400;
}

/* 中文副標 — 呼應主標，延續節奏 */
.closing-subtitle{
  font-family:var(--zh-d);
  font-weight:400;
  font-size:clamp(20px, 2.4vw, 28px);
  line-height:1.4;
  letter-spacing:-.01em;
  color:var(--c-ink);
  margin-bottom:var(--sp-6);
  opacity:.88;
}

/* 分隔線 */
.closing-divider{
  width:60px;
  height:1px;
  background:var(--c-ink);
  margin:0 auto var(--sp-6);
  opacity:.35;
}

/* 說明內文 — 尊重、專業、讓人信賴 */
.closing-body{
  font-family:var(--zh-s);
  font-size:18px;
  max-width:600px;
  margin:0 auto var(--sp-8);
  line-height:1.9;
  color:var(--c-ink);
  opacity:.88;
}

/* 圓形 CTA — 呼應 Hero 頂部圓形 */
.closing-cta-wrap{
  display:flex;
  justify-content:center;
  align-items:center;
  margin-bottom:var(--sp-6);
}
.closing-cta-circle{
  position:relative;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:clamp(220px, 22vw, 280px);
  height:clamp(220px, 22vw, 280px);
  border-radius:50%;
  background:var(--c-ink);
  color:var(--c-paper);
  font-family:var(--zh-s);
  font-weight:500;
  font-size:18px;
  letter-spacing:.02em;
  gap:12px;
  transition:transform .4s cubic-bezier(.2,.8,.2,1),
             background .35s ease;
  /* 呼吸律動（光暈由 ::before 負責） */
  animation:closingPulse 3s ease-in-out infinite;
}
.closing-cta-circle::before{
  /* 外圈光暈，1.5 秒擴散循環 */
  content:'';
  position:absolute;
  inset:-8px;
  border-radius:50%;
  background:transparent;
  border:2px solid var(--c-paper);
  opacity:0;
  pointer-events:none;
  animation:closingGlow 1.5s ease-out infinite;
}
.closing-cta-circle .ar{
  font-family:var(--en);
  font-style:italic;
  font-size:28px;
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}

/* 呼吸律動 — 輕微 scale 波動 */
@keyframes closingPulse{
  0%, 100%{transform:scale(1)}
  50%{transform:scale(1.03)}
}

/* 光暈擴散 — 1.5 秒循環 */
@keyframes closingGlow{
  0%{
    transform:scale(0.95);
    opacity:0;
  }
  40%{
    opacity:0.5;
  }
  100%{
    transform:scale(1.25);
    opacity:0;
  }
}

/* Hover：停止呼吸、光暈停止、整個放大、箭頭右移、變米白色 */
.closing-cta-circle:hover{
  animation:none;
  transform:scale(1.08);
  background:var(--c-paper);
  color:var(--c-ink);
}
.closing-cta-circle:hover::before{
  animation:none;
  opacity:0;
}
.closing-cta-circle:hover .ar{
  transform:translateX(6px);
}

/* 輔助聯絡資訊 */
.closing-aux{
  margin-top:var(--sp-6);
  font-family:var(--zh-s);
  font-size:15px;
  color:var(--c-ink);
  opacity:.7;
  letter-spacing:.02em;
}
.closing-aux a{
  color:var(--c-ink);
  border-bottom:1px solid rgba(14,14,14,.3);
  padding-bottom:2px;
  transition:border-color .25s;
}
.closing-aux a:hover{border-bottom-color:var(--c-ink)}

@media (max-width:860px){
  .closing{padding:var(--sp-9) 24px var(--sp-8)}
  .closing-eyebrow{font-size:16px;margin-bottom:var(--sp-6)}
  .closing-subtitle{font-size:20px}
  .closing-body{font-size:16px}
}

/* 尊重使用者偏好 — 關閉動畫時停止呼吸 */
@media (prefers-reduced-motion: reduce){
  .closing-cta-circle,
  .closing-cta-circle::before{
    animation:none;
  }
}

/* ===========================================================
   FOOTER
   =========================================================== */
footer.site{
  background:var(--c-ink);
  color:var(--c-paper);
  padding:var(--sp-8) var(--gutter) var(--sp-6);
}
.footer-inner{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:var(--sp-5);
}
.footer-brand{grid-column:1 / 5}
.footer-brand .logo{
  font-family:var(--en);
  font-weight:500;
  font-size:28px;
  letter-spacing:-.01em;
}
.footer-brand .logo .zh{
  font-family:var(--zh-d);
  font-weight:400;
  font-size:16px;
  color:rgba(245,244,240,.6);
  margin-left:8px;
}
.footer-brand .tag{
  margin-top:16px;
  font-family:var(--zh-s);
  font-size:15px;
  color:rgba(245,244,240,.7);
  line-height:1.75;
  max-width:300px;
}
.footer-col{grid-column:span 2}
.footer-col h5{
  font-family:var(--en);
  font-style:italic;
  font-size:15px;
  color:var(--c-fire);
  margin-bottom:var(--sp-4);
  font-weight:500;
  letter-spacing:.01em;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:12px}
.footer-col a{
  font-family:var(--zh-s);
  font-size:15px;
  color:rgba(245,244,240,.75);
  transition:color .2s;
}
.footer-col a:hover{color:var(--c-fire)}
.footer-bottom{
  max-width:var(--max);
  margin:var(--sp-7) auto 0;
  padding-top:var(--sp-5);
  border-top:1px solid rgba(245,244,240,.15);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:var(--sp-4);
  font-family:var(--mono);
  font-size:12px;
  color:rgba(245,244,240,.4);
  letter-spacing:.08em;
  text-transform:uppercase;
}
@media (max-width:860px){
  .footer-brand, .footer-col{grid-column:1 / 13}
}

/* ===========================================================
   INNER PAGE 內頁共用樣式
   所有非首頁的頁面都用這些 class
   =========================================================== */

/* 內頁 Hero */
.page-hero{
  max-width:var(--max);
  margin:0 auto;
  padding:calc(var(--sp-11) + 30px) var(--gutter) var(--sp-9);
}
.page-hero-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:var(--sp-5);
  align-items:end;
}
.page-hero .breadcrumb{
  grid-column:1 / 13;
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-mute);
  margin-bottom:var(--sp-7);
}
.page-hero .breadcrumb a{color:var(--c-mute);transition:color .2s}
.page-hero .breadcrumb a:hover{color:var(--c-fire)}
.page-hero .breadcrumb .sep{margin:0 12px;opacity:.4}
.page-hero .breadcrumb .now{color:var(--c-ink)}

.page-hero-kicker{
  grid-column:1 / 5;
  font-family:var(--en);
  font-style:italic;
  font-size:17px;
  color:var(--c-ink);
  padding-bottom:var(--sp-4);
  opacity:.85;
}
.page-hero-kicker .mono{
  display:block;
  margin-top:var(--sp-3);
  font-family:var(--mono);
  font-style:normal;
  font-size:13px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--c-mute);
  opacity:1;
}
.page-hero-kicker .mono::before{content:'—— ';color:var(--c-fire)}

.page-hero-title{
  grid-column:1 / 11;
  margin-top:var(--sp-7);
  font-family:var(--zh-d);
  font-weight:300;
  font-size:clamp(48px, 8.5vw, 120px);
  line-height:1.05;
  letter-spacing:-.03em;
  color:var(--c-ink);
}
.page-hero-title em{
  font-family:var(--en);
  font-style:italic;
  font-weight:400;
  color:var(--c-fire);
}

.page-hero-bottom{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:var(--sp-5);
  margin-top:var(--sp-8);
  padding-top:var(--sp-6);
  border-top:1px solid var(--c-line);
}
.page-hero-lead{
  grid-column:1 / 9;
  font-family:var(--zh-s);
  font-size:18px;
  line-height:1.85;
  color:var(--c-ink-soft);
  max-width:760px;
}
.page-hero-lead strong{
  font-weight:500;
  border-bottom:2px solid var(--c-fire);
  padding-bottom:2px;
}

@media (max-width:860px){
  .page-hero{padding:120px 24px var(--sp-8)}
  .page-hero-kicker, .page-hero-title{grid-column:1 / 13}
  .page-hero-lead{grid-column:1 / 13}
}

/* 內頁 Section 標頭（跟首頁 .sec-head 共用） */
.page-section{
  max-width:var(--max);
  margin:0 auto;
  padding:var(--sp-10) var(--gutter);
}
.page-section.narrow{max-width:1000px}

/* 大塊內容 */
.rich-text{
  font-family:var(--zh-s);
  font-size:17px;
  line-height:1.9;
  color:var(--c-ink-soft);
  max-width:760px;
}
.rich-text p{margin-bottom:var(--sp-5)}
.rich-text p:last-child{margin-bottom:0}
.rich-text strong{
  font-weight:500;
  border-bottom:2px solid var(--c-fire);
  padding-bottom:2px;
}
.rich-text h3{
  font-family:var(--zh-d);
  font-weight:500;
  font-size:28px;
  line-height:1.25;
  margin:var(--sp-7) 0 var(--sp-4);
  color:var(--c-ink);
  letter-spacing:-.01em;
}
.rich-text h3 .num{
  font-family:var(--mono);
  font-weight:500;
  font-size:14px;
  color:var(--c-fire);
  letter-spacing:.12em;
  display:block;
  margin-bottom:var(--sp-2);
}
.rich-text ul{
  list-style:none;
  margin-bottom:var(--sp-5);
}
.rich-text ul li{
  padding-left:24px;
  position:relative;
  margin-bottom:var(--sp-3);
}
.rich-text ul li::before{
  content:'—';
  position:absolute;
  left:0;
  color:var(--c-fire);
  font-weight:500;
}

/* 內頁 Section 標頭（大型，置中兩列） */
.inner-sec-head{
  max-width:var(--max);
  margin:0 auto;
  padding:var(--sp-10) var(--gutter) var(--sp-7);
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:var(--sp-5);
  align-items:end;
  border-bottom:1px solid var(--c-ink);
}
.inner-sec-head .lbl{
  grid-column:1 / 3;
  font-family:var(--mono);
  font-size:14px;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-fire);
  padding-bottom:16px;
}
.inner-sec-head .tit{
  grid-column:3 / 10;
  font-family:var(--zh-d);
  font-weight:300;
  font-size:clamp(36px, 5vw, 64px);
  line-height:1.12;
  letter-spacing:-.025em;
  color:var(--c-ink);
}
.inner-sec-head .tit em{
  font-family:var(--en);
  font-style:italic;
  font-weight:400;
  color:var(--c-fire);
}
.inner-sec-head .tit .en-eyebrow{
  display:block;
  font-family:var(--en);
  font-style:italic;
  font-size:20px;
  color:var(--c-fire);
  margin-bottom:var(--sp-3);
  letter-spacing:.005em;
}
.inner-sec-head .note{
  grid-column:10 / 13;
  justify-self:end;
  text-align:right;
  font-family:var(--zh-s);
  font-size:15px;
  line-height:1.75;
  color:var(--c-mute);
  max-width:300px;
  padding-bottom:16px;
}
@media (max-width:860px){
  .inner-sec-head{padding:var(--sp-9) 24px var(--sp-5)}
  .inner-sec-head .lbl,
  .inner-sec-head .tit,
  .inner-sec-head .note{
    grid-column:1 / 13;
    justify-self:start;
    text-align:left;
    max-width:none;
  }
  .inner-sec-head .tit{margin-top:var(--sp-4)}
}

/* 服務頁特徵清單（4 欄） */
.feature-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:var(--sp-4);
  max-width:var(--max);
  margin:0 auto;
  padding:var(--sp-7) var(--gutter);
}
.feature{
  background:var(--c-paper-dim);
  border:1px solid var(--c-line);
  border-radius:var(--r-md);
  padding:var(--sp-6) var(--sp-5);
  transition:transform .3s ease, border-color .3s ease;
}
.feature:hover{
  transform:translateY(-4px);
  border-color:var(--c-fire);
}
.feature .num{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.12em;
  color:var(--c-fire);
  margin-bottom:var(--sp-4);
}
.feature .en{
  font-family:var(--en);
  font-style:italic;
  font-size:17px;
  color:var(--c-fire);
  margin-bottom:var(--sp-2);
}
.feature h3{
  font-family:var(--zh-d);
  font-weight:500;
  font-size:22px;
  line-height:1.3;
  color:var(--c-ink);
  margin-bottom:var(--sp-4);
  letter-spacing:-.005em;
}
.feature p{
  font-family:var(--zh-s);
  font-size:14px;
  line-height:1.75;
  color:var(--c-ink-soft);
}
@media (max-width:960px){
  .feature-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:520px){
  .feature-grid{grid-template-columns:1fr}
}

/* FAQ 元件 */
.faq-list{
  max-width:900px;
  margin:0 auto;
  padding:var(--sp-7) var(--gutter);
}
.faq-item{
  border-bottom:1px solid var(--c-line);
  padding:var(--sp-6) 0;
  cursor:pointer;
}
.faq-item:first-child{border-top:1px solid var(--c-ink)}
.faq-item summary{
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:var(--sp-5);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q{
  font-family:var(--zh-d);
  font-weight:500;
  font-size:22px;
  line-height:1.4;
  color:var(--c-ink);
  letter-spacing:-.005em;
}
.faq-toggle{
  font-family:var(--en);
  font-size:24px;
  color:var(--c-fire);
  transition:transform .3s;
  flex-shrink:0;
}
.faq-item[open] .faq-toggle{transform:rotate(45deg)}
.faq-a{
  font-family:var(--zh-s);
  font-size:16px;
  line-height:1.85;
  color:var(--c-ink-soft);
  margin-top:var(--sp-5);
  padding-top:var(--sp-5);
  border-top:1px dashed var(--c-line);
}

/* 案例頁：單一案例詳細 */
.case-detail{
  max-width:var(--max);
  margin:0 auto;
  padding:var(--sp-10) var(--gutter);
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:var(--sp-5);
}
.case-detail .side{
  grid-column:1 / 4;
  position:sticky;
  top:100px;
  align-self:start;
}
.case-detail .side dl{display:flex;flex-direction:column;gap:var(--sp-5)}
.case-detail .side dt{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--c-fire);
  margin-bottom:4px;
}
.case-detail .side dd{
  font-family:var(--zh-s);
  font-size:14px;
  color:var(--c-ink-soft);
  line-height:1.6;
}
.case-detail .main{
  grid-column:5 / 13;
}
@media (max-width:860px){
  .case-detail{grid-template-columns:1fr;padding:var(--sp-9) 24px}
  .case-detail .side,.case-detail .main{grid-column:1;position:static}
}

/* 團隊成員卡片 */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--sp-5);
  max-width:var(--max);
  margin:0 auto;
  padding:var(--sp-7) var(--gutter);
}
.team-card{
  background:var(--c-paper-dim);
  border-radius:var(--r-md);
  padding:var(--sp-6);
  border:1px solid var(--c-line);
}
.team-card .role{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-fire);
  margin-bottom:var(--sp-4);
}
.team-card h3{
  font-family:var(--zh-d);
  font-weight:500;
  font-size:24px;
  color:var(--c-ink);
  margin-bottom:var(--sp-1);
}
.team-card .en{
  font-family:var(--en);
  font-style:italic;
  font-size:16px;
  color:var(--c-mute);
  margin-bottom:var(--sp-4);
}
.team-card p{
  font-family:var(--zh-s);
  font-size:14px;
  line-height:1.75;
  color:var(--c-ink-soft);
}
@media (max-width:860px){
  .team-grid{grid-template-columns:1fr}
}

/* 聯絡頁表單 */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-8);
  max-width:var(--max);
  margin:0 auto;
  padding:var(--sp-10) var(--gutter);
}
.contact-info h3{
  font-family:var(--zh-d);
  font-weight:500;
  font-size:28px;
  margin-bottom:var(--sp-6);
  color:var(--c-ink);
}
.contact-info dl{display:flex;flex-direction:column;gap:var(--sp-5)}
.contact-info dt{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-fire);
  margin-bottom:var(--sp-2);
}
.contact-info dd{
  font-family:var(--zh-s);
  font-size:17px;
  color:var(--c-ink);
}
.contact-info a{
  color:var(--c-ink);
  border-bottom:1px solid var(--c-ink);
  padding-bottom:1px;
  transition:color .2s, border-color .2s;
}
.contact-info a:hover{color:var(--c-fire);border-color:var(--c-fire)}

.contact-form{
  background:var(--c-paper-dim);
  border:1px solid var(--c-line);
  border-radius:var(--r-md);
  padding:var(--sp-7) var(--sp-6);
}
.contact-form label{
  display:block;
  font-family:var(--zh-s);
  font-size:14px;
  font-weight:500;
  color:var(--c-ink);
  margin-bottom:var(--sp-2);
}
.contact-form input,
.contact-form textarea,
.contact-form select{
  width:100%;
  padding:12px 14px;
  font-family:var(--zh-s);
  font-size:15px;
  background:var(--c-paper);
  border:1px solid var(--c-line);
  border-radius:var(--r-sm);
  color:var(--c-ink);
  margin-bottom:var(--sp-5);
  transition:border-color .2s;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus{
  outline:none;
  border-color:var(--c-fire);
}
.contact-form textarea{min-height:120px;resize:vertical;font-family:var(--zh-s)}
.contact-form button{
  background:var(--c-ink);
  color:var(--c-paper);
  border:none;
  padding:14px 32px;
  border-radius:999px;
  font-family:var(--zh-s);
  font-size:15px;
  font-weight:500;
  cursor:pointer;
  transition:all .25s;
}
.contact-form button:hover{background:var(--c-fire)}
@media (max-width:860px){
  .contact-grid{grid-template-columns:1fr;padding:var(--sp-9) 24px;gap:var(--sp-7)}
}

/* ===========================================================
   手機版閱讀強化（統一提升字級與可讀性）
   =========================================================== */
@media (max-width:860px){
  /* 內文可讀性基準：16 → 17 */
  body{font-size:17px;line-height:1.75}

  /* Hero Lead 手機版放大 */
  .hero-lead{font-size:17px;line-height:1.85}

  /* 次要連結放大，更好點擊 */
  .lead-link{font-size:17px;gap:12px;padding:6px 0 14px}
  .lead-link .ar{font-size:22px}

  /* Why 區塊手機版 */
  .why-copy{font-size:26px;line-height:1.45}
  .why-small{font-size:15px;line-height:1.85}
  .why-stat-label{font-size:15px;line-height:1.75}

  /* Journey 卡片手機版放大 */
  .j-stage{font-size:12px}
  .j-en{font-size:18px}
  .j-title{font-size:24px;line-height:1.3}
  .j-quote{font-size:14px;padding:14px 16px}
  .j-desc{font-size:15px;line-height:1.8}
  .j-tags span{font-size:12px;padding:5px 12px}

  /* Services 深色區手機版 */
  .s-num{font-size:13px}
  .s-name{font-size:26px}
  .s-name .en{font-size:16px}
  .s-body{font-size:15px;line-height:1.8}
  .s-tags span{font-size:12px;padding:5px 12px}

  /* Stories 案例手機版放大 */
  .story-year{font-size:14px}
  .story-industry{font-size:18px}
  .story-title{font-size:22px;line-height:1.35}
  .story-services{font-size:14px;line-height:1.7}
  .stories-head .more{font-size:14px;padding:11px 22px}

  /* Section 標頭手機版 */
  .sec-label{font-size:13px}
  .sec-title .en-eyebrow{font-size:17px}
  .sec-lead{font-size:15px;line-height:1.8}

  .services-head .lbl{font-size:13px}
  .services-head .tit .en-eyebrow{font-size:17px}
  .services-head .lead{font-size:15px;line-height:1.8}

  .stories-head .lbl{font-size:13px}
  .stories-head .tit .en-eyebrow{font-size:17px}

  /* 內頁專用 */
  .page-hero-kicker{font-size:16px}
  .page-hero-kicker .mono{font-size:13px}
  .page-hero-lead{font-size:16px;line-height:1.85}
  .breadcrumb{font-size:12px}

  .rich-text{font-size:16px;line-height:1.9}
  .rich-text h3{font-size:24px;line-height:1.3}
  .rich-text ul li{font-size:16px}

  .inner-sec-head .lbl{font-size:13px}
  .inner-sec-head .tit{font-size:32px}
  .inner-sec-head .tit .en-eyebrow{font-size:17px}
  .inner-sec-head .note{font-size:15px;line-height:1.75}

  /* FAQ 手機版放大 */
  .faq-q{font-size:19px;line-height:1.45}
  .faq-a{font-size:15px;line-height:1.85}
  .faq-toggle{font-size:22px}
  .faq-item{padding:var(--sp-5) 0}

  /* 特徵卡片 */
  .feature h3{font-size:20px}
  .feature p{font-size:15px;line-height:1.8}
  .feature .en{font-size:16px}

  /* 團隊卡片 */
  .team-card h3{font-size:22px}
  .team-card .en{font-size:15px}
  .team-card p{font-size:15px;line-height:1.8}

  /* 聯絡頁 */
  .contact-info h3{font-size:24px}
  .contact-info dd{font-size:16px}
  .contact-form input, .contact-form textarea, .contact-form select{font-size:16px;padding:14px}
  .contact-form button{font-size:16px;padding:16px 36px}

  /* Closing 手機版 */
  .closing-eyebrow{font-size:16px}
  .closing-subtitle{font-size:18px;line-height:1.45}
  .closing-body{font-size:16px;line-height:1.9}
  .closing-aux{font-size:14px}

  /* Process 手機版 */
  .step-main h3{font-size:22px;line-height:1.35}
  .step-main p{font-size:15px;line-height:1.85}
  .step-deliverable{font-size:14px;line-height:1.75}
  .step-phase{font-size:11px}

  /* Footer 手機版放大 */
  .footer-brand .tag{font-size:14px}
  .footer-col h5{font-size:14px}
  .footer-col a{font-size:14px}

  /* Nav 行動版下拉 */
  .site-nav-links.open{font-size:19px;gap:var(--sp-5)}
  .nav-cta{font-size:14px;padding:10px 20px}

  /* CTA 按鈕觸控區域放大 */
  .closing-cta-circle{
    width:clamp(200px, 70vw, 260px);
    height:clamp(200px, 70vw, 260px);
    font-size:18px;
  }
}

/* 極小螢幕（< 480px）再加強 */
@media (max-width:480px){
  .page-hero-title{font-size:clamp(40px, 11vw, 56px)}
  .hero-title{font-size:clamp(44px, 13vw, 72px)}
  .sec-title{font-size:clamp(32px, 9vw, 44px)}
  .inner-sec-head .tit{font-size:28px}
  .closing-title{font-size:clamp(32px, 10vw, 48px)}
  .why-copy{font-size:22px}
}
