/* ==========================================================================
   GROVYN — Blog Footer CTA 三卡片改版 + 彈窗（2026-05-27）
   依賴：blog-single.css（.cta-block / .cta-title / .cta-sub / .cta-link 基底）
        sensory-tokens.css / ts-tokens.css（--ts-* tokens）
        grovyn-login-dropdown.css（註冊卡 .grovyn-login-card 視覺，本檔只加置中外殼）
   命名空間 .bcta-* 與 .cta-social/.cta-member/.cta-about，避免干擾頁首登入系統。
   深色：body.grovyn-dark-mode（與 blog-shared.css 一致）。
   ========================================================================== */

/* ============================================================
 * 1. 三卡片：對齊修正（右大卡撐到與左欄總高一致）+ 新版視覺
 * ============================================================ */
.footer-ctas { align-items: stretch; }
.footer-ctas .col { display: flex; flex-direction: column; }
.footer-ctas .col .cta-block { flex: 1 1 auto; }
.footer-ctas .col-r { display: flex; }
.footer-ctas .col-r .cta-block { flex: 1 1 auto; width: 100%; }
@media (max-width: 800px) { .footer-ctas .col .cta-block { flex: 0 0 auto; } }

/* 整張卡不再是連結（只有內部按鈕/圖示可點）→ 取消 .cta-block 基底的 cursor:pointer */
.cta-social, .cta-member, .cta-about { color: var(--ts-cream); cursor: default; }
.cta-block .bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.cta-block .scrim { position: absolute; inset: 0; z-index: 2; }
.cta-block > .inner { position: relative; z-index: 3; flex: 1; display: flex; flex-direction: column; justify-content: space-between; }

.cta-eyebrow {
  font-family: var(--ts-font-mono, 'JetBrains Mono', monospace);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  opacity: 0.78; margin-bottom: 10px;
}
/* scrim：上方加深（標題在卡片頂端，需要更暗的襯底才讀得到） */
.cta-social .scrim { background: linear-gradient(165deg, rgba(24,30,38,0.66) 0%, rgba(18,24,30,0.84) 100%); }
.cta-member .scrim { background: linear-gradient(165deg, rgba(30,40,26,0.60) 0%, rgba(24,34,22,0.88) 100%); }
.cta-about { min-height: 380px; }
.cta-about .scrim { background: linear-gradient(170deg, rgba(26,24,16,0.50) 0%, rgba(24,26,18,0.30) 45%, rgba(22,26,18,0.74) 100%); }
.cta-about .cta-title { font-size: 1.7rem; max-width: 11em; }
.cta-about .cta-sub { font-size: 0.92rem; }

/* 文字對比修正：grovyn-overrides.css 的 h1-h6/[class*="title"] 把標題染成 navy，
   這裡強制卡片標題用米色 + 文字陰影（對比 specificity 0,2,0 > overrides 的 0,1,0） */
.cta-social .cta-title, .cta-member .cta-title, .cta-about .cta-title {
  color: var(--ts-cream);
  text-shadow: 0 2px 14px rgba(0,0,0,0.55), 0 1px 3px rgba(0,0,0,0.5);
}
.cta-social .cta-sub, .cta-member .cta-sub, .cta-about .cta-sub {
  text-shadow: 0 1px 6px rgba(0,0,0,0.5);
}
.cta-social .cta-eyebrow, .cta-member .cta-eyebrow { text-shadow: 0 1px 4px rgba(0,0,0,0.5); }
@media (max-width: 800px) { .cta-about { min-height: 280px; } }

/* 自媒體：三個圖示按鈕 */
.social-row { display: flex; gap: 14px; margin-top: 18px; }
.social-btn {
  width: 48px; height: 48px; border-radius: 50%; padding: 0; font: inherit;
  display: flex; align-items: center; justify-content: center;
  background: rgba(245,241,234,0.12); border: 1px solid rgba(245,241,234,0.28);
  color: var(--ts-cream); text-decoration: none; backdrop-filter: blur(4px);
  transition: transform 0.25s var(--ts-ease-natural, cubic-bezier(0.33,0.1,0.25,1)), background 0.25s, border-color 0.25s;
}
.social-btn svg { width: 21px; height: 21px; }
.social-btn:hover { transform: translateY(-3px) scale(1.06); }
.social-btn.ig:hover { background: #E1306C; border-color: #E1306C; }
.social-btn.pod:hover { background: #8A56E2; border-color: #8A56E2; }
.social-btn.yt:hover { background: #FF0000; border-color: #FF0000; }

/* 會員卡：好處短句 */
.member-perks { list-style: none; display: flex; flex-direction: column; gap: 9px; margin: 14px 0 0; padding: 0; }
.member-perks li { display: flex; align-items: flex-start; gap: 9px; font-size: 0.84rem; line-height: 1.5; opacity: 0.92; }
.member-perks svg { width: 16px; height: 16px; flex: none; margin-top: 2px; opacity: 0.85; }

/* ============================================================
 * 2. 彈窗共用：backdrop（背景模糊）+ modal 殼 + 關閉鈕
 * ============================================================ */
.bcta-backdrop {
  position: fixed; inset: 0; z-index: 1200;
  background: rgba(20,24,32,0.5); backdrop-filter: blur(8px);
  opacity: 0; pointer-events: none; transition: opacity 0.35s var(--ts-ease-natural, cubic-bezier(0.33,0.1,0.25,1));
}
.bcta-backdrop[data-open="true"] { opacity: 1; pointer-events: auto; }

.bcta-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0.97);
  z-index: 1201; max-height: calc(100vh - 120px); overflow-y: auto;
  border-radius: 22px; box-shadow: 0 30px 80px rgba(10,14,20,0.4);
  opacity: 0; pointer-events: none;
  transition: opacity 0.35s var(--ts-ease-natural, cubic-bezier(0.33,0.1,0.25,1)), transform 0.35s var(--ts-ease-natural, cubic-bezier(0.33,0.1,0.25,1));
}
.bcta-modal[data-open="true"] { opacity: 1; transform: translate(-50%,-50%) scale(1); pointer-events: auto; }

.bcta-close {
  position: absolute; top: 16px; right: 16px; z-index: 6;
  width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid rgba(238,234,231,0.3); background: rgba(20,24,30,0.35); backdrop-filter: blur(6px);
  color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background 0.25s, transform 0.25s;
}
.bcta-close:hover { background: rgba(20,24,30,0.6); transform: rotate(90deg); }
.bcta-close svg { width: 18px; height: 18px; }

/* ============================================================
 * 3. 故事 modal
 * ============================================================ */
.bcta-story { width: min(760px, calc(100% - 32px)); background: #F8F6F2; color: var(--ts-navy); }
body.grovyn-dark-mode .bcta-story { background: #212531; color: #ECE7DF; }
.bcta-story-hero { position: relative; height: 230px; overflow: hidden; }
.bcta-story-hero img { width: 100%; height: 100%; object-fit: cover; }
.bcta-story-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,24,18,0.10) 0%, rgba(20,24,18,0.40) 55%, rgba(20,24,18,0.78) 100%); }
.bcta-story-label { position: absolute; left: 30px; bottom: 22px; z-index: 2; color: var(--ts-cream); }
.bcta-story-eyebrow { font-family: var(--ts-font-mono, monospace); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.8; }
.bcta-story-label h2 { font-family: var(--ts-font-serif-zh, serif); font-weight: 500; font-size: 1.7rem; letter-spacing: 0.04em; margin-top: 6px; color: var(--ts-cream); text-shadow: 0 2px 14px rgba(0,0,0,0.6), 0 1px 3px rgba(0,0,0,0.5); }
.bcta-story-body { padding: 34px clamp(26px, 5vw, 52px) 44px; }
.bcta-story-body .lede { font-family: var(--ts-font-serif-zh, serif); font-size: 1.12rem; line-height: 1.9; margin-bottom: 24px; }
.bcta-story-body p { font-size: 0.95rem; line-height: 2; margin-bottom: 18px; }
.bcta-story-sep { width: 46px; height: 2px; background: var(--ts-forest); opacity: 0.5; margin: 30px auto; }
body.grovyn-dark-mode .bcta-story-sep { background: var(--ts-moss); }
.bcta-story-pull { font-family: var(--ts-font-serif-zh, serif); font-size: 1.18rem; line-height: 1.8; color: var(--ts-forest); text-align: center; padding: 8px 0; margin: 6px 0 22px; }
body.grovyn-dark-mode .bcta-story-pull { color: var(--ts-moss); }
.bcta-story-sign { font-family: var(--ts-font-serif-zh, serif); font-size: 1rem; text-align: right; color: #5A6172; margin-top: 28px; }
body.grovyn-dark-mode .bcta-story-sign { color: #A3A7B3; }

/* ============================================================
 * 4. 第 1 段：會員好處（背景圖 + 森林綠遮罩）
 * ============================================================ */
.bcta-perks { width: min(440px, calc(100% - 32px)); overflow: hidden; color: var(--ts-cream); }
.bcta-perks-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.bcta-perks-scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(165deg, rgba(40,55,31,0.74) 0%, rgba(28,38,24,0.94) 100%); }
.bcta-perks-inner { position: relative; z-index: 2; padding: 40px 34px 34px; }
.bcta-perks-eyebrow { font-family: var(--ts-font-mono, monospace); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.72; }
.bcta-perks h2 { font-family: var(--ts-font-serif-zh, serif); font-weight: 500; font-size: 1.5rem; line-height: 1.45; letter-spacing: 0.04em; margin: 12px 0 6px; color: var(--ts-cream); }
.bcta-perks-free { display: inline-block; font-family: var(--ts-font-mono, monospace); font-size: 11px; letter-spacing: 0.12em; background: rgba(238,231,141,0.20); color: var(--ts-sun); padding: 5px 12px; border-radius: 999px; margin-bottom: 22px; }
.bcta-perks-list { list-style: none; display: flex; flex-direction: column; padding: 0; margin: 0; }
.bcta-perks-list li { display: flex; gap: 14px; padding: 15px 0; border-top: 1px solid rgba(238,234,231,0.16); }
.bcta-perks-list li:first-child { border-top: none; }
.bcta-perks-list .ico { width: 38px; height: 38px; flex: none; border-radius: 11px; background: rgba(238,234,231,0.13); display: flex; align-items: center; justify-content: center; }
.bcta-perks-list .ico svg { width: 20px; height: 20px; stroke: var(--ts-sun); fill: none; }
.bcta-perks-list h3 { font-size: 0.96rem; font-weight: 500; margin: 0 0 3px; color: var(--ts-cream); }
.bcta-perks-list p { font-size: 0.8rem; line-height: 1.55; opacity: 0.82; margin: 0; }
.bcta-perks-cta { display: block; width: 100%; margin-top: 26px; padding: 15px; border: none; border-radius: 999px; background: var(--ts-cream); color: var(--ts-navy); font-family: var(--ts-font-sans-zh, sans-serif); font-size: 0.95rem; font-weight: 500; letter-spacing: 0.08em; cursor: pointer; transition: transform 0.2s var(--ts-ease-natural, ease), background 0.25s; }
.bcta-perks-cta:hover { background: var(--ts-sun); transform: translateY(-2px); }
.bcta-perks-login { display: block; text-align: center; margin-top: 15px; font-size: 0.82rem; color: rgba(238,234,231,0.78); background: none; border: none; cursor: pointer; width: 100%; font-family: var(--ts-font-sans-zh, sans-serif); }
.bcta-perks-login u { color: var(--ts-sun); text-decoration: none; border-bottom: 1px solid rgba(238,231,141,0.5); }

/* ============================================================
 * 5. 第 2 段：註冊卡置中外殼（卡片內部視覺沿用 .grovyn-login-card）
 * ============================================================ */
.bcta-reg-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0.97);
  z-index: 1201; opacity: 0; pointer-events: none;
  transition: opacity 0.35s var(--ts-ease-natural, cubic-bezier(0.33,0.1,0.25,1)), transform 0.35s var(--ts-ease-natural, cubic-bezier(0.33,0.1,0.25,1));
}
.bcta-reg-modal[data-open="true"] { opacity: 1; transform: translate(-50%,-50%) scale(1); pointer-events: auto; }
/* 置中情境下不要用 dropdown 的 720px 固定高，改自適應視窗 */
.bcta-reg-modal .grovyn-login-card { height: min(680px, calc(100vh - 100px)); width: 360px; max-width: calc(100vw - 32px); }
.bcta-reg-back {
  position: absolute; top: 16px; left: 16px; z-index: 6;
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--ts-font-sans-zh, sans-serif); font-size: 12px; letter-spacing: 0.05em;
  color: var(--ts-cream); background: rgba(20,24,30,0.35); backdrop-filter: blur(6px);
  border: 1px solid rgba(238,234,231,0.25); padding: 7px 13px; border-radius: 999px; cursor: pointer;
  transition: background 0.25s;
}
.bcta-reg-back:hover { background: rgba(20,24,30,0.6); }
.bcta-close--oncard { top: 16px; right: 16px; }

/* ============================================================
 * 6. 文章頁文末：分享列 + 相關文章（single.php，對齊 .article-page 760）
 * ============================================================ */
.blog-share {
  max-width: 760px; margin: 48px auto 0;
  background: var(--ts-surface, #F8F6F2); border: 1px solid var(--ts-border, rgba(40,44,60,.10));
  border-radius: 16px; padding: 24px 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap;
}
body.grovyn-dark-mode .blog-share { background: #212531; border-color: rgba(236,231,223,.12); }
.blog-share__title { font-family: var(--ts-font-serif-zh, serif); font-weight: 500; font-size: 1.1rem; letter-spacing: 0.02em; color: var(--ts-navy); margin: 0; }
body.grovyn-dark-mode .blog-share__title { color: #ECE7DF; }
.blog-share__sub { font-size: 0.82rem; color: #5A6172; margin: 3px 0 0; }
body.grovyn-dark-mode .blog-share__sub { color: #A3A7B3; }
.blog-share__row { display: flex; gap: 11px; }
.bshare {
  width: 46px; height: 46px; border-radius: 50%; padding: 0;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--ts-border-strong, rgba(40,44,60,.20)); background: var(--ts-cream);
  color: var(--ts-navy); cursor: pointer; text-decoration: none;
  transition: transform 0.22s var(--ts-ease-natural, ease), background 0.22s, color 0.22s, border-color 0.22s;
}
body.grovyn-dark-mode .bshare { background: #2b3040; color: #ECE7DF; border-color: rgba(236,231,223,.2); }
.bshare svg { width: 20px; height: 20px; }
.bshare:hover { transform: translateY(-3px) scale(1.06); }
.bshare--line:hover { background: #06C755; border-color: #06C755; color: #fff; }
.bshare--fb:hover { background: #1877F2; border-color: #1877F2; color: #fff; }
.bshare--copy:hover { background: var(--ts-forest); border-color: var(--ts-forest); color: var(--ts-cream); }

.blog-related { max-width: 760px; margin: 56px auto 0; }
.blog-related__head { font-family: var(--ts-font-mono, monospace); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: #5A6172; margin-bottom: 18px; }
body.grovyn-dark-mode .blog-related__head { color: #A3A7B3; }
.blog-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 720px) { .blog-related__grid { grid-template-columns: 1fr; } }
.bl-rcard {
  background: var(--ts-surface, #F8F6F2); border: 1px solid var(--ts-border, rgba(40,44,60,.10));
  border-radius: 15px; overflow: hidden; text-decoration: none; color: inherit;
  transition: transform 0.28s var(--ts-ease-natural, ease), box-shadow 0.28s var(--ts-ease-natural, ease);
}
body.grovyn-dark-mode .bl-rcard { background: #212531; border-color: rgba(236,231,223,.12); }
.bl-rcard:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(20,24,30,.16); }
.bl-rcard__img { position: relative; height: 144px; overflow: hidden; }
.bl-rcard__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--ts-ease-natural, ease); }
.bl-rcard:hover .bl-rcard__img img { transform: scale(1.05); }
.bl-rcard__chip { position: absolute; left: 12px; top: 12px; z-index: 2; font-family: var(--ts-font-mono, monospace); font-size: 10px; letter-spacing: 0.06em; color: var(--ts-cream); background: rgba(40,44,60,.55); backdrop-filter: blur(4px); padding: 4px 10px; border-radius: 999px; }
.bl-rcard__body { padding: 15px 16px 17px; }
.bl-rcard__date { font-family: var(--ts-font-mono, monospace); font-size: 10.5px; color: #5A6172; }
body.grovyn-dark-mode .bl-rcard__date { color: #A3A7B3; }
.bl-rcard__title { font-family: var(--ts-font-serif-zh, serif); font-weight: 500; font-size: 1rem; line-height: 1.45; margin: 7px 0 0; color: var(--ts-navy); }
body.grovyn-dark-mode .bl-rcard__title { color: #ECE7DF; }
.bl-rcard__ex { font-size: 0.8rem; color: #5A6172; line-height: 1.55; margin: 8px 0 0; }
body.grovyn-dark-mode .bl-rcard__ex { color: #A3A7B3; }

/* prefers-reduced-motion：拔 transition */
@media (prefers-reduced-motion: reduce) {
  .bcta-backdrop, .bcta-modal, .bcta-reg-modal, .social-btn, .bcta-close, .bcta-perks-cta,
  .bshare, .bl-rcard, .bl-rcard__img img { transition: none !important; }
}
