/* ============================================
   紐西蘭旅遊攻略 — 共用元件樣式
   shin-components.css v2.0
   適用：所有文章頁面（WordPress block 內容）
   ============================================ */

/* === 按鈕使用規範 ===
   shin-btn-fire     → 主推聯盟連結（OKB、Booking 最推薦選項），含「阿新推薦」徽章
   shin-btn          → 主要操作（訂閱、下載、了解更多）
   shin-btn-secondary → 次要聯盟連結（第 2 推薦選項，如威訊）
   shin-btn-muted    → 低優先選項（適用小眾/限定情境，如 DJB）
   shin-btn-book     → 住宿/活動訂購按鈕（amber，Booking 語意）
   shin-btn-accent   → 限用於 Lead Magnet 內部
   ⚠️ 禁止在按鈕上使用 inline style background-color 覆蓋
   ============================================ */

/* --- CSS Variables --- */
:root {
  /* === 品牌主色 === */
  --shin-primary: #0E7490;
  --shin-primary-light: #0891B2;
  --shin-accent: #F59E0B;

  /* === 深色層次（峽灣深水、夜空） === */
  --shin-deep: #0C4A6E;
  --shin-deep-grad: #0F172A;

  /* === 探險橙（夕陽、CTA 衝動感） === */
  --shin-fire: #EA580C;
  --shin-fire-light: #FB923C;
  --shin-fire-bg: #FFF7ED;

  /* === 自然綠（紐西蘭草原） === */
  --shin-nature: #16A34A;
  --shin-nature-light: #86EFAC;
  --shin-nature-bg: #F0FDF4;

  /* === 背景與邊框 === */
  --shin-bg-blue: #F0F9FF;
  --shin-bg-blue-deep: #E0F2FE;
  --shin-border-blue: #BAE6FD;
  --shin-text-dark: #0F172A;
  --shin-text-mid: #334155;
  --shin-text-light: #64748B;
  --shin-text-muted: #94A3B8;
  --shin-border: #E2E8F0;
  --shin-bg-gray: #F8FAFC;
  --shin-bg-warn: #FFFBEB;
  --shin-border-warn: #F59E0B;
  --shin-success: #059669;
  --shin-bg-success: #ECFDF5;

  /* === 圓角與陰影 === */
  --shin-radius: 8px;
  --shin-radius-lg: 12px;
  --shin-shadow-sm: 0 1px 4px rgba(0,0,0,0.05);
  --shin-shadow-md: 0 4px 12px rgba(0,0,0,0.10);
  --shin-shadow-travel: 0 8px 32px rgba(14, 116, 144, 0.18);
  --shin-content-max: 1000px;

  /* === 漸層系統 === */
  --shin-grad-sunset: linear-gradient(135deg, #EA580C 0%, #F59E0B 100%);
  --shin-grad-nature: linear-gradient(135deg, #0E7490 0%, #16A34A 100%);
  --shin-grad-sky: linear-gradient(180deg, #0C4A6E 0%, #0E7490 40%, #0891B2 100%);

  /* === 字體系統 === */
  --shin-font-heading: 'Noto Serif TC', Georgia, serif;
  --shin-font-body: 'Noto Sans TC', 'PingFang TC', 'Microsoft JhengHei', sans-serif;
  --shin-font-data: 'DM Sans', 'Inter', sans-serif;
}

/* --- 1. Reading Progress Bar --- */
.shin-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--shin-primary), var(--shin-primary-light));
  z-index: 1001;
  transition: width 0.1s;
}

/* --- 2. Headings --- */
.shin-h2 {
  font-family: var(--shin-font-heading);
  font-size: 23px;
  font-weight: 700;
  color: var(--shin-text-dark);
  line-height: 1.4;
  letter-spacing: 0.02em;
  background: none;
  border: none;
  padding: 0 0 10px 8px;
  margin-top: 56px;
  margin-bottom: 20px;
  position: relative;
}
.shin-h2::after {
  content: '';
  display: block;
  height: 3px;
  width: 100%;
  margin-top: 8px;
  background: linear-gradient(
    to right,
    var(--shin-primary) 0%,
    var(--shin-accent) 45%,
    rgba(245, 158, 11, 0.15) 75%,
    transparent 100%
  );
  border-radius: 2px;
}
.shin-h3 {
  font-family: var(--shin-font-body);
  font-size: 18px;
  font-weight: 700;
  color: var(--shin-text-mid);
  border: none;
  padding-left: 14px;
  padding-bottom: 0;
  margin-top: 32px;
  margin-bottom: 12px;
  line-height: 1.5;
  position: relative;
}
.shin-h3::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.15em;
  bottom: 0.15em;
  width: 4px;
  background: linear-gradient(to bottom, var(--shin-primary), var(--shin-accent));
  border-radius: 2px;
}

/* --- 3. Quick Overview Box --- */
.shin-overview {
  background-color: var(--shin-bg-blue);
  border: 1px solid var(--shin-border-blue);
  border-top: 3px solid var(--shin-primary);
  border-radius: var(--shin-radius-lg);
  padding: 12px 16px;
  margin: 16px 0 8px;
  box-shadow: var(--shin-shadow-sm);
}
.shin-overview-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--shin-primary);
  margin-bottom: 8px;
}
.shin-overview-content {
  font-size: 15px;
  line-height: 1.7;
  color: var(--shin-text-mid);
  margin: 0;
}

/* --- 4. Table of Contents --- */
.shin-toc {
  background-color: #FFFFFF;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius-lg);
  padding: 12px 16px;
  margin: 8px 0 20px;
  box-shadow: var(--shin-shadow-sm);
}
.shin-toc summary {
  font-size: 17px;
  font-weight: 700;
  color: var(--shin-primary);
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 44px;
}
.shin-toc summary::-webkit-details-marker { display: none; }
.shin-toc ol {
  padding-left: 20px;
  margin: 8px 0 0;
}
.shin-toc li {
  margin-bottom: 4px;
}
.shin-toc a {
  color: var(--shin-text-mid);
  text-decoration: none;
  font-size: 14px;
}
.shin-toc a:hover {
  color: var(--shin-primary);
}

/* --- 5. FAQ Accordion --- */
.shin-faq-item {
  border: 1px solid #E2E8F0;
  border-left: 3px solid #CBD5E1;
  border-radius: 0 8px 8px 0;
  margin-bottom: 8px;
  background: #FFFFFF;
  transition: border-color 0.25s, box-shadow 0.25s, background 0.25s;
}
.shin-faq-item summary {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 52px;
  line-height: 1.5;
}
.shin-faq-item summary:hover {
  background: #F8FAFC;
}
.shin-faq-item summary::-webkit-details-marker { display: none; }
.shin-faq-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 28px;
  padding: 0 8px;
  background: #F1F5F9;
  color: #64748B;
  font-size: 12px;
  font-weight: 700;
  border-radius: 14px;
  flex-shrink: 0;
  transition: background 0.25s, color 0.25s;
}
.shin-faq-item[open] .shin-faq-num {
  background: var(--shin-primary);
  color: #FFF;
}
.shin-faq-item .shin-faq-body,
.shin-faq-item .shin-faq-a {
  padding: 12px 24px 18px 60px;
  font-size: 14px;
  line-height: 1.8;
  color: var(--shin-text-mid);
}
.shin-faq-item .shin-faq-body p,
.shin-faq-item .shin-faq-a p {
  margin: 0;
}
/* FAQ variant: minimal (Queenstown style) */
.shin-faq-minimal {
  padding: 10px 0;
  border-bottom: 1px solid #E5E7EB;
}
.shin-faq-minimal summary {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-primary);
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
  min-height: 44px;
}
.shin-faq-minimal summary::-webkit-details-marker { display: none; }

/* FAQ +/- icon */
.faq-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #F1F5F9;
  color: #94A3B8;
  font-size: 16px;
  font-weight: 400;
  flex-shrink: 0;
  margin-left: auto;
  transition: background 0.25s, color 0.25s, transform 0.25s;
  line-height: 1;
}
.shin-faq-item[open] .faq-icon {
  background: #ECFDF5;
  color: #059669;
  transform: rotate(45deg);
}
/* Legacy arrow support */
.faq-arrow {
  font-size: 14px;
  display: inline-block;
  transition: transform 0.2s;
  flex-shrink: 0;
  margin-left: auto;
}
details[open] .faq-arrow {
  transform: rotate(180deg);
}
/* FAQ open state visual feedback */
.shin-faq-item[open] {
  border-left-color: var(--shin-primary);
  border-color: #BAE6FD;
  background: #F0F9FF;
  box-shadow: 0 2px 8px rgba(14,116,144,0.06);
}

/* FAQ header bar */
.shin-faq-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  padding: 12px 16px;
  background: linear-gradient(135deg, #F0F9FF 0%, #E0F2FE 100%);
  border-radius: 10px;
  border: 1px solid #BAE6FD;
}
.shin-faq-header p {
  font-size: 14px;
  color: #0C4A6E;
  margin: 0;
  font-weight: 600;
}
/* Toggle all FAQs button */
.shin-faq-toggle-all {
  background: #FFF;
  border: 1px solid #BAE6FD;
  border-radius: 6px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--shin-primary);
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.shin-faq-toggle-all:hover {
  background: var(--shin-primary);
  color: #FFF;
}
@media (max-width: 480px) {
  .shin-faq-item .shin-faq-body,
  .shin-faq-item .shin-faq-a { padding-left: 16px; padding-right: 16px; }
  .shin-faq-num { min-width: 28px; height: 24px; font-size: 11px; }
}

/* --- 6. CTA Buttons --- */
.shin-btn {
  display: block;
  text-align: center;
  font-size: 15px;
  font-weight: 600;
  padding: 12px 18px;
  border-radius: var(--shin-radius);
  text-decoration: none;
  min-height: 44px;
  box-sizing: border-box;
  transition: background-color 0.2s, transform 0.15s;
  color: #FFFFFF;
  background: var(--shin-primary);
}
.shin-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.1);
}
.shin-btn-secondary {
  background: var(--shin-primary-light);
}
.shin-btn-muted {
  background: #475569;
}
.shin-btn-accent {
  background: var(--shin-accent);
}
.shin-btn-fire {
  display: inline-block;
  text-align: center;
  text-decoration: none;
  background: var(--shin-fire) !important;
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  padding: 14px 24px !important;
  box-shadow: 0 4px 14px rgba(234, 88, 12, 0.25) !important;
  border-radius: var(--shin-radius) !important;
  position: relative;
  box-sizing: border-box;
  max-width: 100%;
}
.shin-btn-fire:hover {
  background: #C2410C !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(234, 88, 12, 0.35) !important;
}
.shin-btn-fire::before {
  content: "\2605\0020\963F\65B0\63A8\85A6";
  position: absolute;
  top: -10px;
  right: 12px;
  background: var(--shin-fire);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  line-height: 1.3;
}
.shin-btn-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}

/* --- 6b. CTA Inline Layout (左文字 右按鈕) --- */
.shin-cta-inline {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
}
.shin-cta-inline > p {
  flex: 1;
  min-width: 200px;
}
.shin-cta-inline > p:last-of-type {
  margin-bottom: 0 !important;
}
.shin-cta-inline > div {
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .shin-cta-inline {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  .shin-cta-inline > div {
    width: 100%;
  }
}

/* --- 7. Card Grid --- */
.shin-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  margin-bottom: 24px;
  width: 100%;
  box-sizing: border-box;
}
/* 2-column variant (related articles) */
.shin-card-grid-2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
  width: 100%;
  box-sizing: border-box;
}

/* --- 8. Card Link (Activity / Hotel / Related) --- */
.shin-card {
  display: block;
  text-decoration: none;
  border: 1px solid var(--shin-border);
  border-radius: 10px;
  padding: 12px 14px;
  background: #FFFFFF;
  box-shadow: var(--shin-shadow-sm);
  transition: box-shadow 0.2s, transform 0.2s;
}
.shin-card:hover {
  box-shadow: var(--shin-shadow-md);
  transform: translateY(-2px);
}
.shin-card-badge {
  font-size: 12px;
  color: #0E7490;
  background: #E0F2FE;
  border: 1px solid #BAE6FD;
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  margin: 0 0 6px;
  font-weight: 600;
}
.shin-card-badge-accent {
  background: #FEF3C7;
  color: #92400E;
  border-color: #FDE68A;
}
.shin-card-badge-gray {
  background: #F1F5F9;
  color: #475569;
  border-color: #CBD5E1;
}
.shin-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 4px;
}
.shin-card-desc {
  font-size: 12px;
  color: var(--shin-text-light);
  margin: 0 0 6px;
  line-height: 1.5;
}
.shin-card-price {
  font-size: 14px;
  font-weight: 700;
  color: var(--shin-primary);
  margin: 0;
}
/* Hotel card rating badge */
.shin-card-rating {
  background: var(--shin-primary);
  color: #FFF;
  padding: 1px 6px;
  border-radius: 3px;
  font-weight: 700;
  font-size: 12px;
}

/* --- 8b. Hotel Card (方案三：價格+按鈕同行) --- */
.shin-hotel-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius-lg);
  background: #FFFFFF;
  box-shadow: var(--shin-shadow-sm);
  transition: box-shadow 0.2s;
  overflow: hidden;
}
.shin-hotel-card:hover {
  box-shadow: var(--shin-shadow-md);
}
.shin-hotel-card .shin-card-body {
  padding: 12px 14px 0;
  flex: 1;
}
.shin-hotel-card .shin-card-badge {
  margin-bottom: 4px;
}
.shin-hotel-card .shin-card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 4px;
}
.shin-hotel-card .shin-card-desc {
  font-size: 12px;
  color: var(--shin-text-light);
  margin: 0 0 6px;
  line-height: 1.5;
}
.shin-card-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  border-top: 1px solid var(--shin-border);
  margin-top: 8px;
}
.shin-price-block {
  display: flex;
  align-items: baseline;
  gap: 3px;
  flex-shrink: 0;
}
.shin-price-from {
  font-size: 11px;
  color: var(--shin-text-muted);
}
.shin-price-num {
  font-size: 15px;
  font-weight: 800;
  color: var(--shin-primary);
}
.shin-price-unit {
  font-size: 11px;
  color: var(--shin-text-muted);
}
.shin-btn-book {
  flex-shrink: 0;
  padding: 8px 14px;
  background: var(--shin-accent);
  color: #FFFFFF;
  border-radius: var(--shin-radius);
  font-weight: 700;
  font-size: 13px;
  text-decoration: none;
  white-space: nowrap;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  transition: background 0.2s, transform 0.15s;
}
.shin-btn-book:hover {
  background: #D97706;
  transform: translateY(-1px);
}
.shin-hotel-card .shin-card-rating {
  margin-right: 4px;
}
.shin-card-sub-links {
  font-size: 11px;
  color: var(--shin-text-muted);
  padding: 0 14px 6px;
}
.shin-card-sub-links a {
  color: var(--shin-primary);
  text-decoration: none;
  font-weight: 600;
}
.shin-card-sub-links a:hover {
  text-decoration: underline;
}
.shin-affiliate-note {
  font-size: 11px;
  color: var(--shin-text-muted);
  padding: 0 14px 10px;
  line-height: 1.4;
}
/* 手機：價格+按鈕堆疊 */
@media (max-width: 480px) {
  .shin-card-action {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .shin-btn-book {
    width: 100%;
    justify-content: center;
  }
}

/* --- 9. Booking Platform CTAs --- */
.shin-booking-ctas {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  max-width: var(--shin-content-max);
}
.shin-booking-btn {
  flex: 1;
  min-width: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px 16px;
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 700;
  border-radius: var(--shin-radius);
  text-decoration: none;
  transition: opacity 0.2s;
}
.shin-booking-btn:hover {
  opacity: 0.9;
}
/* Platform brand colors */
.shin-booking-btn-booking  { background: #003580; }
.shin-booking-btn-agoda    { background: #5542F6; }
.shin-booking-btn-trip     { background: #287DFA; }
.shin-booking-btn-klook    { background: #E31837; }
.shin-booking-btn-kkday    { background: #FF6B35; }

/* --- 10. Info / Tip Boxes --- */
.shin-info-box {
  background: var(--shin-bg-blue);
  border: 1px solid var(--shin-border);
  border-left: 4px solid var(--shin-text-muted);
  border-radius: var(--shin-radius);
  padding: 10px 14px;
  margin-bottom: 12px;
}
.shin-info-label {
  font-size: 15px;
  color: var(--shin-text-mid);
  margin-bottom: 4px;
}
.shin-tip-box {
  background-color: #FAFAFA;
  border: 1px solid var(--shin-border);
  border-left: 3px solid var(--shin-accent);
  border-radius: var(--shin-radius);
  padding: 12px 16px;
  margin: 16px 0;
}
/* Warning box (orange left border) */
.shin-warn-box {
  background: #FAFAFA;
  border: 1px solid #E2E8F0;
  border-left: 3px solid var(--shin-fire, #EA580C);
  border-radius: var(--shin-radius);
  padding: 12px 16px;
  margin: 14px 0;
}
/* Subtle tip variant (left border) */
.shin-tip-subtle {
  background-color: #FAFAFA;
  border: 1px solid var(--shin-border);
  border-left: 3px solid var(--shin-accent);
  border-radius: var(--shin-radius);
  padding: 8px 12px;
  margin: 8px 0;
}

/* --- 11. Quick Booking Summary (Expandable) --- */
.shin-quick-buy {
  background: linear-gradient(135deg, var(--shin-bg-blue), var(--shin-bg-blue-deep));
  border: 1px solid var(--shin-border-blue);
  border-radius: 10px;
  padding: 12px 16px;
  margin: 16px 0;
}
.shin-quick-buy summary {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-primary);
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 44px;
}
.shin-quick-buy summary::-webkit-details-marker { display: none; }

/* --- 12. Comparison Table --- */
.shin-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 12px 0 16px;
}
.shin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  min-width: 480px;
}
.shin-table thead tr {
  background-color: var(--shin-primary);
}
.shin-table th {
  padding: 10px 14px;
  text-align: left;
  background-color: var(--shin-primary);
  color: #FFFFFF;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.shin-table td {
  padding: 10px 14px;
  color: var(--shin-text-mid);
  font-size: 14px;
  line-height: 1.6;
  border-bottom: 1px solid #F1F5F9;
}
.shin-table tbody tr:nth-child(odd) td {
  background-color: #FAFAFA;
}
.shin-table tbody tr:nth-child(even) td {
  background-color: #FFFFFF;
}
.shin-table tbody tr {
  transition: background 0.1s;
}
.shin-table tbody tr:hover td {
  background-color: var(--shin-bg-blue);
}
/* Highlight column */
.shin-table .shin-col-highlight {
  font-weight: 700;
  color: var(--shin-primary);
}
/* OKB recommended column background */
.shin-table .shin-col-okb {
  background-color: rgba(14, 116, 144, 0.05);
}


/* --- 13. Lead Magnet Box --- */
.shin-lead-magnet {
  border: 2px solid var(--shin-primary);
  border-radius: var(--shin-radius-lg);
  padding: 20px;
  margin: 28px 0;
  background: linear-gradient(135deg, var(--shin-bg-blue) 0%, var(--shin-bg-success) 100%);
  text-align: center;
}
.shin-lead-magnet-icon {
  font-size: 28px;
  margin: 0 0 6px;
}
.shin-lead-magnet-title {
  font-size: 18px;
  font-weight: 800;
  color: var(--shin-text-dark);
  margin: 0 0 6px;
}
.shin-lead-magnet-desc {
  font-size: 14px;
  color: var(--shin-text-mid);
  margin: 0 0 14px;
  line-height: 1.6;
}
.shin-lead-magnet .shin-btn {
  max-width: 320px;
  margin: 0 auto;
}
.shin-lead-magnet-disclaimer {
  font-size: 12px;
  color: var(--shin-text-light);
  margin: 8px 0 0;
}

/* --- 14. Floating CTA (Mobile) --- */
.shin-float-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 998;
  background: #FFFFFF;
  border-top: 1px solid var(--shin-border);
  padding: 10px 16px;
  padding-bottom: max(10px, env(safe-area-inset-bottom));
  box-shadow: 0 -2px 12px rgba(0,0,0,0.10);
  display: flex;
  align-items: center;
  gap: 10px;
  transform: translateY(100%);
  transition: transform 0.3s ease;
}
.shin-float-cta.visible {
  transform: translateY(0);
}
.shin-float-cta-text {
  font-size: 13px;
  color: var(--shin-text-mid);
  flex: 1;
  line-height: 1.3;
  margin: 0;
}
.shin-float-cta-text strong {
  color: var(--shin-primary);
  font-size: 14px;
}
.shin-float-cta-btn {
  background: var(--shin-primary);
  color: #FFF;
  font-size: 14px;
  font-weight: 700;
  padding: 10px 16px;
  border-radius: var(--shin-radius);
  text-decoration: none;
  white-space: nowrap;
  min-height: 44px;
  display: flex;
  align-items: center;
}
.shin-float-cta-btn:hover {
  background: var(--shin-primary-light);
}
/* Float CTA: gradient variant (Queenstown style) */
.shin-float-cta-gradient {
  background: linear-gradient(135deg, var(--shin-primary), var(--shin-primary-light));
  border-top: none;
}
.shin-float-cta-gradient .shin-float-cta-text {
  color: #FFFFFF;
}
.shin-float-cta-gradient .shin-float-cta-text strong {
  color: #FFFFFF;
}
.shin-float-cta-gradient .shin-float-cta-btn {
  background: var(--shin-accent);
}

@media (min-width: 769px) {
  .shin-float-cta {
    display: none !important;
  }
}

/* --- 15. Back to Top --- */
.shin-back-top {
  position: fixed;
  bottom: 80px;
  right: 24px;
  width: 44px;
  height: 44px;
  background: var(--shin-primary);
  color: #FFFFFF;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.3s;
}
.shin-back-top.visible {
  opacity: 0.85;
  visibility: visible;
}

/* --- 16. Separator --- */
.shin-sep {
  margin: 40px 0 32px;
  border: none;
  border-top: 3px solid var(--shin-border-blue);
  opacity: 0.7;
}

/* --- 17. Affiliate Disclosure --- */
.shin-disclosure {
  font-size: 10px !important;
  color: var(--shin-text-light);
  background: transparent;
  border-radius: 0;
  padding: 0 0 10px;
  margin-bottom: 4px;
  line-height: 1.5;
  opacity: 0.75;
}

/* --- 18. Gradient Boxes --- */
.shin-box-gradient-blue {
  background: linear-gradient(135deg, var(--shin-bg-blue), var(--shin-bg-blue-deep));
  border: 2px solid var(--shin-primary);
  border-radius: var(--shin-radius-lg);
  padding: 16px 20px;
  margin: 16px 0;
  box-shadow: 0 2px 8px rgba(14,116,144,0.12);
}
.shin-box-gradient-warn {
  background: linear-gradient(135deg, #FFFBEB, #FEF3C7);
  border: 2px dashed var(--shin-accent);
  border-radius: var(--shin-radius-lg);
  padding: 14px 18px;
  margin: 16px 0;
  text-align: center;
}

/* --- 19. Body Paragraph --- */
.shin-p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--shin-text-mid);
  margin-bottom: 10px;
}

/* --- 20. Responsive Image --- */
.shin-img {
  margin: 1.5em 0;
  padding: 0;
  text-align: center;
  border-radius: var(--shin-radius-lg);
  overflow: hidden;
  box-shadow: var(--shin-shadow-sm);
  background: #fff;
}
.shin-img img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--shin-radius-lg) var(--shin-radius-lg) 0 0;
}
.shin-img figcaption {
  font-size: 0.85em;
  line-height: 1.6;
  color: var(--shin-text-light);
  padding: 10px 16px;
  background: var(--shin-bg-gray);
  border-top: 2px solid var(--shin-primary);
  text-align: center;
  letter-spacing: 0.01em;
}
.shin-img-cover {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  max-height: 400px;
}

/* --- 21. Callout Box (top-border accent) --- */
.shin-callout {
  border: 1px solid var(--shin-border);
  border-top: 3px solid var(--shin-primary);
  border-radius: var(--shin-radius-lg);
  padding: 16px;
  margin-bottom: 16px;
  background: #FFFFFF;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.shin-callout-green {
  border-color: #D1FAE5;
  border-top-color: var(--shin-success);
}
.shin-callout-cyan {
  border-color: var(--shin-border-blue);
  border-top-color: var(--shin-primary-light);
}

/* --- 22. Icon Circle --- */
.shin-icon-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 800;
  margin-right: 10px;
  flex-shrink: 0;
  background: var(--shin-primary);
}
.shin-icon-circle-green { background: var(--shin-success); }
.shin-icon-circle-cyan  { background: var(--shin-primary-light); }
.shin-icon-circle-amber { background: var(--shin-accent); }
.shin-icon-circle-lg {
  width: 40px;
  height: 40px;
  font-size: 18px;
}

/* --- 23. Badge Pill --- */
.shin-badge {
  display: inline-block;
  font-size: 15px;
  border-radius: 20px;
  padding: 3px 10px;
}
.shin-badge-cyan   { color: #0891B2; background: #ECFEFF; border: 1px solid #A5F3FC; }
.shin-badge-teal   { color: #0E7490; background: #F0FDFA; border: 1px solid #99F6E4; }
.shin-badge-amber  { color: #92400E; background: #FEF3C7; border: 1px solid #FDE68A; }
.shin-badge-yellow { color: #F59E0B; background: #FFFBEB; border: 1px solid #FDE68A; }
.shin-badge-green  { color: #059669; background: #ECFDF5; border: 1px solid #A7F3D0; }
.shin-badge-bold {
  font-weight: 700;
  padding: 4px 12px;
}

/* --- 24. Flex Utilities --- */
.shin-flex-start {
  display: flex;
  align-items: flex-start;
  margin-bottom: 10px;
}
.shin-flex-between {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px;
}
.shin-flex-between-center {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.shin-flex-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.shin-flex-center {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

/* --- 25. Styled Link --- */
.shin-link {
  color: var(--shin-primary);
  font-weight: 600;
  text-decoration: underline;
}

/* --- 26. Meta Label --- */
.shin-meta {
  margin: 0;
  font-size: 13px;
  color: var(--shin-text-light);
}
.shin-meta-bold {
  margin: 0 0 2px;
  font-size: 13px;
  color: var(--shin-text-light);
  font-weight: 600;
}

/* --- 27. Card with Image --- */
.shin-card-img {
  background: #FFFFFF;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius-lg);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  overflow: hidden;
  margin-bottom: 16px;
}

/* --- 28. Background Boxes --- */
.shin-bg-blue-box {
  background: var(--shin-bg-blue);
  border-radius: var(--shin-radius);
  padding: 10px 14px;
  margin-bottom: 12px;
}
.shin-bg-green-box {
  background: #F0FDF4;
  border-radius: var(--shin-radius);
  padding: 10px 14px;
  margin-bottom: 12px;
}

/* --- 29. Status Label --- */
.shin-label-green {
  font-size: 13px;
  font-weight: 700;
  background: #ECFDF5;
  color: var(--shin-success);
  border-radius: 6px;
  padding: 2px 8px;
  margin-left: 8px;
}

/* --- 30. Extended Button Colors --- */
.shin-btn-booking { background: #003580; }
.shin-btn-agoda   { background: #5341C4; }
.shin-btn-trip    { background: #007BC8; }
.shin-btn-klook   { background: #E31837; }
.shin-btn-kkday   { background: #FF6B35; }
.shin-btn-green   { background: var(--shin-success); }
.shin-btn-amber   { background: var(--shin-accent); }
.shin-btn-inline {
  display: inline-flex;
  align-items: center;
}
.shin-btn-flex {
  display: block;
  flex: 1;
  min-width: 140px;
  text-align: center;
}

/* --- 31. Table Enhancements --- */
.shin-table caption {
  text-align: left;
  font-size: 14px;
  color: var(--shin-text-light);
  margin-bottom: 4px;
  caption-side: top;
}
/* Table header row colors — set on th directly (background-color not inherited) */
.shin-table th { background-color: var(--shin-primary); }
/* Row with teal first-cell emphasis */
.shin-table td:first-child { color: var(--shin-text-mid); }
.shin-table .shin-td-bold { font-weight: 600; color: var(--shin-text-dark); }
.shin-table .shin-td-teal { font-weight: 700; color: var(--shin-primary); }
.shin-table .shin-td-green { font-weight: 700; color: var(--shin-success); }
.shin-table .shin-td-amber { font-weight: 700; color: #92400E; }
.shin-table .shin-td-red { font-weight: 700; color: #DC2626; }
.shin-table .shin-td-light { color: var(--shin-text-light); }

/* --- 32. Heading in Card --- */
.shin-heading-card {
  font-size: 18px;
  font-weight: 700;
  color: var(--shin-text-dark);
  min-width: 0;
  flex: 1;
  word-break: break-word;
}
.shin-heading-sub {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  color: var(--shin-text-dark);
  min-width: 0;
  word-break: break-word;
}
.shin-heading-item {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 4px;
}

/* --- 33. List Item Indent --- */
.shin-list-indent {
  position: relative;
  padding: 8px 0 16px 20px;
}

/* --- 34. Price/Emoji Label --- */
.shin-price-tag {
  font-size: 14px;
  color: var(--shin-primary);
  flex-shrink: 0;
  margin-left: 8px;
}

/* --- 35. Table Wrap with box style --- */
.shin-table-wrap-box {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 12px 0 16px;
  border-radius: 10px;
  border: 1px solid var(--shin-border);
  box-shadow: var(--shin-shadow-sm);
}

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 768px) {
  .shin-h2 {
    font-size: 19px;
    padding: 0 0 10px 8px;
    margin-top: 40px;
  }
  .shin-h3 {
    font-size: 16px;
    margin-top: 24px;
    padding-left: 14px;
  }
  .shin-card-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 8px;
  }
  .shin-card-grid-2 {
    grid-template-columns: 1fr;
  }
  .shin-booking-ctas {
    flex-direction: column;
  }
  .shin-booking-btn {
    min-width: 100%;
  }
  .shin-btn-row {
    flex-direction: column;
  }
  .shin-table {
    font-size: 13px;
  }
  .shin-table th,
  .shin-table td {
    padding: 6px 8px;
  }
  .shin-lead-magnet {
    padding: 16px;
  }
  .shin-overview,
  .shin-toc,
  .shin-quick-buy {
    padding: 10px 12px;
  }
}

@media (max-width: 480px) {
  .shin-card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ============================================
   v2.0 旅遊感升級 — 2026-04-08
   ============================================ */

/* --- 36. Hero 圖片（文章封面區） --- */
.shin-hero {
  position: relative;
  width: 100%;
  border-radius: var(--shin-radius-lg);
  overflow: hidden;
  margin: 0 0 28px 0;
  aspect-ratio: 16 / 7;
  background: var(--shin-deep);
  box-shadow: var(--shin-shadow-travel);
}
.shin-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(1.1) brightness(0.92);
  animation: kenBurns 6s ease-out forwards;
}
@keyframes kenBurns {
  0%   { transform: scale(1.05); }
  100% { transform: scale(1.0); }
}
.shin-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 20%,
    rgba(12, 74, 110, 0.15) 50%,
    rgba(12, 74, 110, 0.60) 80%,
    rgba(12, 74, 110, 0.80) 100%
  );
  pointer-events: none;
}
.shin-hero-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 24px 20px 20px;
  z-index: 1;
  color: #FFFFFF; /* 強制 Hero 內所有文字白色 */
}
.shin-hero-content h1,
.shin-hero-content h2,
.shin-hero-content h3,
.shin-hero-content .shin-h2,
.shin-hero-content .shin-h3,
.shin-hero-content p {
  color: #FFFFFF !important;
  border: none;
  text-shadow: 0 2px 8px rgba(0,0,0,0.45); /* 加陰影讓文字更清晰 */
}
.shin-hero-content .shin-h2::after,
.shin-hero-content .shin-h3::before {
  display: none;
}
.shin-hero-eyebrow {
  font-family: var(--shin-font-data);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: 6px;
}
.shin-hero-caption {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.5;
  margin: 0;
}
.shin-hero-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 0;
  border-bottom: 1px solid var(--shin-border-blue);
  margin-bottom: 20px;
}
.shin-hero-meta-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  color: var(--shin-text-light);
}
.shin-hero-meta-item strong {
  color: var(--shin-text-dark);
  font-weight: 600;
}
@media (max-width: 768px) {
  .shin-hero {
    aspect-ratio: 4 / 3;
    border-radius: 0;
    margin: 0 -16px 20px;
  }
  .shin-hero-content {
    padding: 20px 16px 16px;
  }
}

/* --- 37. CTA 按鈕升級：活力版 --- */
.shin-btn-adventure {
  display: block;
  text-align: center;
  font-family: var(--shin-font-body);
  font-size: 15px;
  font-weight: 700;
  padding: 13px 22px;
  border-radius: 50px;
  text-decoration: none;
  min-height: 48px;
  box-sizing: border-box;
  color: #FFFFFF;
  background: var(--shin-grad-sunset);
  box-shadow: 0 4px 16px rgba(234, 88, 12, 0.35);
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
  letter-spacing: 0.02em;
}
.shin-btn-adventure:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(234, 88, 12, 0.45);
  filter: brightness(1.05);
}
.shin-btn-adventure:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(234, 88, 12, 0.30);
}

/* 主色漸層 CTA */
.shin-btn-primary-grad {
  display: block;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  padding: 13px 22px;
  border-radius: 50px;
  text-decoration: none;
  min-height: 48px;
  box-sizing: border-box;
  color: #FFFFFF;
  background: linear-gradient(135deg, var(--shin-deep) 0%, var(--shin-primary-light) 100%);
  box-shadow: 0 4px 16px rgba(14, 116, 144, 0.30);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  letter-spacing: 0.02em;
}
.shin-btn-primary-grad:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(14, 116, 144, 0.40);
  filter: brightness(1.08);
}

/* 輪廓按鈕 */
.shin-btn-outline {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  padding: 11px 20px;
  border-radius: 50px;
  text-decoration: none;
  min-height: 44px;
  box-sizing: border-box;
  color: var(--shin-primary);
  background: transparent;
  border: 2px solid var(--shin-primary);
  transition: background-color 0.2s, color 0.2s, transform 0.2s;
}
.shin-btn-outline:hover {
  background: var(--shin-primary);
  color: #FFFFFF;
  transform: translateY(-1px);
}

/* 按鈕箭頭動畫 */
.shin-btn-arrow::after {
  content: ' →';
  display: inline-block;
  transition: transform 0.2s;
}
.shin-btn-arrow:hover::after {
  transform: translateX(4px);
}

/* --- 38. 圖片帶封面卡片 --- */
.shin-card-photo {
  display: block;
  text-decoration: none;
  border-radius: var(--shin-radius-lg);
  overflow: hidden;
  background: #FFFFFF;
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
  transition: box-shadow 0.25s ease, transform 0.25s ease;
  border: 1px solid var(--shin-border);
}
.shin-card-photo:hover {
  box-shadow: 0 8px 28px rgba(14, 116, 144, 0.18);
  transform: translateY(-4px);
}
.shin-card-photo-img {
  position: relative;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--shin-bg-blue-deep);
}
.shin-card-photo-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.shin-card-photo:hover .shin-card-photo-img img {
  transform: scale(1.06);
}
.shin-card-photo-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--shin-primary);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: 0.03em;
}
.shin-card-photo-badge-fire { background: var(--shin-fire); }
.shin-card-photo-badge-nature { background: var(--shin-nature); }
.shin-card-photo-body {
  padding: 12px 14px;
}
.shin-card-photo-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 4px;
  line-height: 1.4;
  transition: color 0.2s;
}
.shin-card-photo:hover .shin-card-photo-title {
  color: var(--shin-primary);
}
.shin-card-photo-meta {
  font-size: 12px;
  color: var(--shin-text-light);
  margin: 0 0 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.shin-card-photo-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--shin-border);
}
.shin-card-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
  margin: 16px 0 28px;
}
@media (max-width: 640px) {
  .shin-card-photo-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}
@media (max-width: 360px) {
  .shin-card-photo-grid {
    grid-template-columns: 1fr;
  }
}

/* --- 39. 旅遊感分隔線 --- */
.shin-sep-mountain {
  display: block;
  width: 100%;
  height: 40px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'%3E%3Cpath d='M0,60 L0,40 L100,20 L200,35 L350,5 L500,30 L650,8 L800,28 L950,10 L1100,32 L1200,15 L1200,60 Z' fill='%23F0F9FF'/%3E%3C/svg%3E");
  background-size: cover;
  background-repeat: no-repeat;
  margin: 0;
  border: none;
}
.shin-sep-wave {
  display: block;
  width: 100%;
  height: 48px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 80' preserveAspectRatio='none'%3E%3Cpath d='M0,40 C300,80 900,0 1200,40 L1200,80 L0,80 Z' fill='%230E7490' opacity='0.08'/%3E%3C/svg%3E");
  background-size: cover;
  margin: 24px 0;
  border: none;
}
.shin-sep-dash {
  border: none;
  border-top: 2px dashed var(--shin-border-blue);
  margin: 28px 0;
  opacity: 0.6;
}

/* --- 40. 頁面節奏區塊 --- */
.shin-section-dark {
  background: linear-gradient(135deg, var(--shin-deep) 0%, var(--shin-primary) 100%);
  border-radius: var(--shin-radius-lg);
  padding: 28px 24px;
  margin: 32px 0;
  color: #FFFFFF;
}
.shin-section-dark .shin-h2,
.shin-section-dark .shin-h3 {
  color: #FFFFFF;
}
.shin-section-dark .shin-h2::after {
  background: linear-gradient(to right, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0.2) 60%, transparent 100%);
}
.shin-section-dark .shin-h3::before {
  background: rgba(255,255,255,0.5);
}
.shin-section-dark .shin-p {
  color: rgba(255,255,255,0.85);
}
.shin-section-nature {
  background: linear-gradient(135deg, var(--shin-nature-bg), #ECFDF5);
  border: 1px solid var(--shin-nature-light);
  border-radius: var(--shin-radius-lg);
  padding: 24px;
  margin: 28px 0;
}
.shin-section-warm {
  background: linear-gradient(135deg, #FFFBEB, #FEF3C7);
  border-radius: var(--shin-radius-lg);
  padding: 20px 24px;
  margin: 24px 0;
  border-left: 4px solid var(--shin-accent);
}

/* --- 41. 引言大字 --- */
.shin-pullquote {
  font-family: var(--shin-font-heading);
  font-size: clamp(18px, 3vw, 26px);
  font-weight: 700;
  color: var(--shin-deep);
  line-height: 1.5;
  text-align: center;
  padding: 32px 24px;
  margin: 32px 0;
  position: relative;
  font-style: italic;
}
.shin-pullquote::before {
  content: '\201C';
  font-size: 80px;
  line-height: 0.5;
  color: var(--shin-border-blue);
  position: absolute;
  top: 24px;
  left: 10px;
  font-family: Georgia, serif;
}
.shin-pullquote::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--shin-primary), var(--shin-accent));
  margin: 16px auto 0;
  border-radius: 2px;
}

/* --- 42. 統計數字展示 --- */
.shin-stats-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin: 20px 0;
}
.shin-stat-item {
  flex: 1;
  min-width: 120px;
  text-align: center;
  padding: 16px 12px;
  background: var(--shin-bg-blue);
  border-radius: var(--shin-radius-lg);
  border: 1px solid var(--shin-border-blue);
}
.shin-stat-num {
  font-family: var(--shin-font-data);
  font-size: clamp(24px, 4vw, 36px);
  font-weight: 900;
  color: var(--shin-primary);
  line-height: 1;
  display: block;
  margin-bottom: 4px;
}
.shin-stat-label {
  font-size: 12px;
  color: var(--shin-text-light);
  line-height: 1.3;
}

/* --- 43. 圖文並排 --- */
.shin-text-image {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
  margin: 28px 0;
}
.shin-text-image img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--shin-radius-lg);
  box-shadow: var(--shin-shadow-md);
}
@media (max-width: 640px) {
  .shin-text-image {
    grid-template-columns: 1fr;
  }
}

/* --- 44. 浮動 CTA 升級版（探險風） --- */
.shin-float-cta-adventure {
  background: linear-gradient(135deg, var(--shin-deep) 0%, var(--shin-primary) 100%);
  border-top: none;
  box-shadow: 0 -4px 20px rgba(12, 74, 110, 0.20);
}
.shin-float-cta-adventure .shin-float-cta-btn {
  background: var(--shin-grad-sunset);
  box-shadow: 0 2px 10px rgba(234, 88, 12, 0.40);
  border-radius: 50px;
}
.shin-float-cta-adventure .shin-float-cta-text {
  color: rgba(255,255,255,0.85);
}
.shin-float-cta-adventure .shin-float-cta-text strong {
  color: #FFFFFF;
}

/* --- 45. 高光文字 --- */
.shin-highlight {
  background: linear-gradient(transparent 60%, rgba(245, 158, 11, 0.30) 60%);
  padding-bottom: 1px;
}

/* --- 46. 地點標籤 --- */
.shin-location-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--shin-text-light);
  background: var(--shin-bg-gray);
  border-radius: 20px;
  padding: 3px 10px 3px 6px;
}

/* --- 47. 里程碑（行程天數標記） --- */
.shin-milestone {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: linear-gradient(135deg, var(--shin-bg-blue), var(--shin-bg-blue-deep));
  border-radius: 50px;
  margin: 20px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--shin-deep);
  box-shadow: 0 2px 8px rgba(14, 116, 144, 0.12);
}
.shin-milestone-num {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--shin-primary);
  color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--shin-font-data);
  font-size: 14px;
  font-weight: 800;
  flex-shrink: 0;
}

/* --- 48. 作者名片 --- */
.shin-author-mini {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0 16px;
  border-bottom: 1px solid var(--shin-border);
  margin-bottom: 16px;
}
.shin-author-mini img {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.shin-author-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0;
}
.shin-author-desc {
  font-size: 12px;
  color: var(--shin-text-light);
  margin: 0;
  line-height: 1.4;
}
.shin-author-date {
  margin-left: auto;
  font-size: 12px;
  color: var(--shin-text-muted);
  white-space: nowrap;
}

/* --- 49. CSS 星級評分 --- */
.shin-star {
  display: inline-block;
  width: 14px;
  height: 14px;
  background: var(--shin-accent);
  clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
  margin-right: 1px;
  vertical-align: middle;
}
.shin-star-empty { background: #CBD5E1; }
.shin-star-half { background: linear-gradient(90deg, var(--shin-accent) 50%, #CBD5E1 50%); }

/* --- 50. 微互動 --- */
@media (prefers-reduced-motion: no-preference) {
  .shin-fade-in {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 0.5s ease, transform 0.5s ease;
  }
  .shin-fade-in.visible {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 連結底線動畫 */
.entry-content a:not(.shin-btn):not(.shin-btn-adventure):not(.shin-card):not(.shin-card-photo):not(.shin-btn-book):not(.shin-btn-primary-grad):not(.shin-btn-outline) {
  text-decoration: none;
  background-image: linear-gradient(var(--shin-primary), var(--shin-primary));
  background-size: 0% 1px;
  background-repeat: no-repeat;
  background-position: left bottom;
  transition: background-size 0.25s ease, color 0.2s;
  color: var(--shin-primary);
}
.entry-content a:not(.shin-btn):not(.shin-btn-adventure):not(.shin-card):not(.shin-card-photo):not(.shin-btn-book):not(.shin-btn-primary-grad):not(.shin-btn-outline):hover {
  background-size: 100% 1px;
}

/* --- 51. 季節主題覆蓋 --- */
.shin-theme-summer {
  --shin-primary: #0891B2;
  --shin-accent: #F97316;
  --shin-bg-blue: #FFF7ED;
}
.shin-theme-winter {
  --shin-primary: #1E40AF;
  --shin-accent: #60A5FA;
  --shin-bg-blue: #EFF6FF;
}
.shin-theme-adventure {
  --shin-primary: #065F46;
  --shin-accent: #F59E0B;
  --shin-bg-blue: #F0FDF4;
}

/* --- 43. Step Grid & Step Card --- */
.shin-step-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 16px 0;
}
.shin-step-grid > .shin-step-span { grid-column: 1 / -1; }
.shin-step-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  border: 1px solid var(--shin-border, #E2E8F0);
  border-radius: 12px;
  padding: 18px;
  background: #FFFFFF;
  transition: box-shadow 0.2s, transform 0.2s;
}
.shin-step-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.06); transform: translateY(-1px); }
.shin-step-card-warn {
  border-color: #FDE68A;
  border-left: 4px solid #F59E0B;
  background: #FFFBEB;
}
.shin-step-card-success {
  border-color: #A7F3D0;
  border-left: 4px solid #10B981;
  background: #F0FDF4;
}
.shin-step-num {
  min-width: 36px;
  height: 36px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 16px;
  color: #FFF;
  flex-shrink: 0;
}
.shin-row-recommend {
  background: #FFF7ED !important;
}

/* === 景點卡片 Badge 整合型 === */
.shin-spot-card {
  display: block;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  border-top: 3px solid #0E7490;
  padding: 0;
  background: #FFFFFF;
  margin-bottom: 20px;
  overflow: hidden;
  transition: box-shadow 0.25s, transform 0.2s;
}
.shin-spot-card:hover { box-shadow: 0 6px 24px rgba(14,116,144,0.12); transform: translateY(-2px); }
.shin-spot-card.green { border-top-color: #059669; }
.shin-spot-card.amber { border-top-color: #D97706; }
.shin-spot-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px 10px;
  background: #F8FAFC;
  border-bottom: 1px solid #F1F5F9;
}
.shin-spot-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  padding: 0 8px;
  background: #0E7490;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  color: #FFF;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}
.shin-spot-card.green .shin-spot-num { background: #059669; }
.shin-spot-card.amber .shin-spot-num { background: #D97706; }
.shin-spot-title { font-size: 16px; font-weight: 700; color: #0C4A6E; margin: 0; line-height: 1.4; }
.shin-spot-body { padding: 12px 20px 16px; }
.shin-spot-meta {
  font-size: 13px; color: #64748B; margin: 0 0 10px;
  padding: 6px 10px; background: #F0F9FF; border-radius: 6px; line-height: 1.5;
}
.shin-spot-card.green .shin-spot-meta { background: #F0FDF4; }
.shin-spot-card.amber .shin-spot-meta { background: #FFFBEB; }
.shin-spot-body p { font-size: 14px; line-height: 1.75; color: #334155; margin: 0; }
.shin-spot-body p + p { margin-top: 8px; }
.shin-spot-body .shin-img { margin: 10px -20px 0; overflow: hidden; }
.shin-spot-body .shin-img img { width: 100%; border-radius: 0; display: block; }
.shin-spot-body .shin-img figcaption { font-size: 12px; color: #64748B; padding: 6px 20px; background: #F8FAFC; }

/* === 住宿按鈕主次層級 === */
.shin-rec-btn-group { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
.shin-rec-btn-primary {
  display: flex; align-items: center; justify-content: center;
  width: 100%; padding: 10px 14px;
  background: #0E7490; color: #FFF !important;
  font-size: 13px; font-weight: 700;
  border-radius: 8px; text-decoration: none; text-align: center;
  transition: background 0.2s; box-sizing: border-box;
}
.shin-rec-btn-primary:hover { background: #0C5F75; }
.shin-rec-btn-secondary-row { display: flex; gap: 6px; }
.shin-rec-btn-secondary {
  flex: 1; display: flex; align-items: center; justify-content: center;
  padding: 8px 10px;
  background: #F8FAFC; color: #334155 !important;
  border: 1px solid #E2E8F0;
  font-size: 12px; font-weight: 600;
  border-radius: 6px; text-decoration: none; text-align: center;
  transition: background 0.2s, border-color 0.2s; box-sizing: border-box;
}
.shin-rec-btn-secondary:hover { background: #E0F2FE; border-color: #BAE6FD; color: #0E7490 !important; }

/* === 推薦卡片 2×3 Grid === */
.shin-rec-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 16px 0;
}

@media (max-width: 767px) {
  .shin-spot-card:hover { transform: none; }
  .shin-spot-header { padding: 12px 14px 8px; }
  .shin-spot-body { padding: 10px 14px 14px; }
  .shin-spot-body .shin-img { margin: 10px -14px 0; }
  .shin-spot-body .shin-img figcaption { padding: 6px 14px; }
  .shin-step-grid { grid-template-columns: 1fr; }
  .shin-step-card:hover { transform: none; }
  .shin-rec-grid { gap: 12px; }
  .shin-rec-card { padding: 12px; }
}
@media (max-width: 480px) {
  .shin-rec-grid { grid-template-columns: 1fr; }
  .shin-rec-card:hover { transform: none; }
}

/* ============================================
   v2.1 UI 設計升級 — 2026-04-11
   P0: 比較表手機卡片、CTA 層級、信任元素
   P1: Key Takeaway、價格日期、首欄 sticky
   P2: H3 重設計、作者區塊、Stats 改版
   ============================================ */

/* --- P0-1: 比較表手機端卡片堆疊 --- */
/* 使用方式：在 .shin-table 加上 class="shin-table shin-table-card" */
/* 並在每個 <td> 加上 data-label="欄位名稱" */
@media (max-width: 768px) {
  .shin-table-wrap .shin-table.shin-table-card thead {
    display: none;
  }
  .shin-table-wrap .shin-table.shin-table-card,
  .shin-table-wrap .shin-table.shin-table-card tbody,
  .shin-table-wrap .shin-table.shin-table-card tr {
    display: block;
    width: 100%;
  }
  .shin-table-wrap .shin-table.shin-table-card tbody tr {
    border: 1px solid var(--shin-border);
    border-left: 3px solid var(--shin-primary);
    border-radius: var(--shin-radius-lg);
    margin-bottom: 14px;
    padding: 14px;
    background: #ffffff;
    box-shadow: var(--shin-shadow-sm);
    min-width: unset;
  }
  .shin-table-wrap .shin-table.shin-table-card td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    border: none;
    padding: 7px 0;
    border-bottom: 1px solid var(--shin-border);
    font-size: 13px;
    min-height: 36px;
  }
  .shin-table-wrap .shin-table.shin-table-card td:last-child {
    border-bottom: none;
    padding-bottom: 0;
  }
  .shin-table-wrap .shin-table.shin-table-card td::before {
    content: attr(data-label);
    font-weight: 700;
    color: var(--shin-text-dark);
    font-size: 12px;
    flex-shrink: 0;
    min-width: 72px;
  }
  .shin-table-wrap .shin-table.shin-table-card tr.shin-row-recommend {
    border-left-color: var(--shin-fire);
    background: var(--shin-fire-bg) !important;
  }
}

/* --- P1-2: 比較表首欄 sticky（橫向滑動時保留品名欄） --- */
/* 使用方式：在 .shin-table 加上 class="shin-table shin-table-sticky" */
.shin-table.shin-table-sticky th:first-child,
.shin-table.shin-table-sticky td:first-child {
  position: sticky;
  left: 0;
  z-index: 2;
  background: inherit;
}
.shin-table.shin-table-sticky thead th:first-child {
  background: #0F4C5C;
  z-index: 3;
}
.shin-table.shin-table-sticky tbody tr:nth-child(odd) td:first-child {
  background: var(--shin-bg-blue);
}
.shin-table.shin-table-sticky tbody tr:nth-child(even) td:first-child {
  background: #ffffff;
}

/* --- P1-1: 「阿新精選」決策卡片（比較表正下方） --- */
.shin-pick-card {
  position: relative;
  border: 2px solid var(--shin-fire);
  border-radius: var(--shin-radius-lg);
  padding: 22px 20px 18px;
  margin: 6px 0 20px;
  background: var(--shin-fire-bg);
}
.shin-pick-badge {
  position: absolute;
  top: -13px;
  left: 20px;
  background: var(--shin-fire);
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: 20px;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.shin-pick-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--shin-text-dark);
  margin: 4px 0 6px;
}
.shin-pick-desc {
  font-size: 14px;
  color: var(--shin-text-mid);
  margin: 0 0 14px;
  line-height: 1.6;
}
.shin-pick-card .shin-disclosure {
  margin-top: 8px;
  margin-bottom: 0;
  background: transparent;
  padding: 4px 0 0;
}

/* --- P1-1: 推薦理由微型說明（CTA 按鈕上方） --- */
.shin-recommend-reason {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  font-size: 12px;
  color: var(--shin-text-light);
  background: rgba(255,255,255,0.7);
  border-radius: var(--shin-radius);
  padding: 6px 10px;
  margin-bottom: 10px;
  line-height: 1.5;
}
.shin-recommend-reason::before {
  content: "✓";
  color: var(--shin-success);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

/* --- P1-1: 「阿新實測」徽章 --- */
.shin-tested-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: var(--shin-primary);
  background: var(--shin-bg-blue);
  border: 1px solid var(--shin-border-blue);
  border-radius: 20px;
  padding: 2px 10px;
  margin-left: 6px;
  vertical-align: middle;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.shin-tested-badge-fire {
  color: var(--shin-fire);
  background: var(--shin-fire-bg);
  border-color: #FDBA74;
}

/* --- P1-3: Key Takeaway 段落重點摘要 --- */
.shin-takeaway {
  background: linear-gradient(135deg, #F0F9FF, #E0F2FE);
  border-left: 4px solid var(--shin-primary);
  border-radius: 0 var(--shin-radius) var(--shin-radius) 0;
  padding: 12px 16px 14px;
  margin: 24px 0 10px;
  font-size: 14px;
  color: var(--shin-deep);
  line-height: 1.7;
}
.shin-takeaway-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--shin-primary);
  margin-bottom: 5px;
  text-transform: uppercase;
}

/* --- P1-4: 價格更新日期標示 --- */
.shin-price-updated {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--shin-text-muted);
  border: 1px solid var(--shin-border);
  border-radius: 4px;
  padding: 2px 7px;
  margin-left: 6px;
  vertical-align: middle;
  white-space: nowrap;
  background: var(--shin-bg-gray);
}

/* --- Float CTA 關閉按鈕 --- */
.shin-float-close {
  background: none;
  border: none;
  color: var(--shin-text-muted);
  font-size: 18px;
  cursor: pointer;
  padding: 4px 6px;
  flex-shrink: 0;
  line-height: 1;
  border-radius: 4px;
  transition: color 0.2s;
}
.shin-float-close:hover {
  color: var(--shin-text-dark);
}

/* --- P2-1: 作者信任區塊增強 --- */
.shin-author-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.shin-author-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--shin-text-light);
  background: var(--shin-bg-gray);
  border: 1px solid var(--shin-border);
  border-radius: 20px;
  padding: 2px 10px;
}
.shin-author-trust-item strong {
  color: var(--shin-text-mid);
  font-weight: 700;
}

/* --- P2-3: Stats Row 數據亮點（深色版，文章開頭用） --- */
.shin-stats-row-highlight {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 10px;
  margin: 20px 0 28px;
  padding: 20px 16px;
  background: linear-gradient(135deg, var(--shin-deep) 0%, var(--shin-primary) 100%);
  border-radius: var(--shin-radius-lg);
  box-shadow: var(--shin-shadow-travel);
}
.shin-stats-row-highlight .shin-stat-item {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--shin-radius);
  padding: 14px 10px;
  text-align: center;
}
.shin-stats-row-highlight .shin-stat-num {
  color: #ffffff;
  font-size: clamp(20px, 4vw, 30px);
}
.shin-stats-row-highlight .shin-stat-label {
  color: rgba(255,255,255,0.72);
  font-size: 11px;
}
@media (max-width: 480px) {
  .shin-stats-row-highlight {
    grid-template-columns: repeat(2, 1fr);
    padding: 14px;
    gap: 8px;
  }
}

/* --- 內文排版優化（WordPress 內容區） --- */
/* 行距 1.75 + 段落間距（寬度跟隨版面，不設限制） */
.dynamic-entry-content p {
  line-height: 1.75;
  margin-bottom: 1.4em;
}
/* 比較表、圖片、元件保留較大寬度 */
.dynamic-entry-content .shin-table-wrap,
.dynamic-entry-content .shin-stats-row,
.dynamic-entry-content .shin-stats-row-highlight,
.dynamic-entry-content .shin-card-grid,
.dynamic-entry-content .shin-card-grid-2,
.dynamic-entry-content figure {
  max-width: 100%;
}

/* ============================================
   shin-post-meta — 文章 meta 條（作者/日期/閱讀時間）
   ============================================ */
.shin-post-meta {
  font-size: 13px;
  color: var(--shin-text-light);
  margin: 0 0 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
  line-height: 1.5;
}
.shin-post-meta a {
  color: var(--shin-primary);
  text-decoration: none;
}
.shin-post-meta a:hover { text-decoration: underline; }
.shin-meta-sep { color: var(--shin-border); margin: 0 2px; }
.shin-meta-author { font-weight: 600; color: var(--shin-text-mid); }

/* ============================================
   shin-related-posts — 延伸閱讀卡片區
   ============================================ */
.shin-related-posts {
  margin: 40px 0 24px;
  padding: 24px;
  background: var(--shin-bg-gray);
  border-radius: var(--shin-radius-lg);
  border: 1px solid var(--shin-border);
}
.shin-related-title {
  font-family: var(--shin-font-heading);
  font-size: 16px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--shin-primary);
  display: inline-block;
}
.shin-related-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.shin-related-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius);
  text-decoration: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.shin-related-item:hover {
  border-color: var(--shin-primary);
  box-shadow: var(--shin-shadow-sm);
}
.shin-related-label {
  font-size: 11px;
  color: var(--shin-primary);
  font-weight: 700;
}
.shin-related-text {
  font-size: 14px;
  color: var(--shin-text-dark);
  font-weight: 600;
  line-height: 1.4;
}
@media (max-width: 600px) {
  .shin-related-grid { grid-template-columns: 1fr; }
}

/* ============================================
   shin-author-box — 作者介紹區塊
   ============================================ */
.shin-author-box {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 20px 24px;
  background: var(--shin-bg-blue);
  border: 1px solid var(--shin-border-blue);
  border-radius: var(--shin-radius-lg);
  margin: 24px 0;
}
.shin-author-avatar {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--shin-primary);
  color: #fff;
  font-family: var(--shin-font-heading);
  font-size: 22px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.shin-author-info { flex: 1; }
.shin-author-name {
  font-family: var(--shin-font-heading);
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 6px;
}
.shin-author-bio {
  font-size: 13px;
  color: var(--shin-text-mid);
  line-height: 1.7;
  margin: 0;
}
@media (max-width: 480px) {
  .shin-author-box { flex-direction: column; gap: 12px; }
}

/* ============================================
   shin-floating-cta — 浮動 CTA 條
   ============================================ */
.shin-floating-cta {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999;
  align-items: center;
  gap: 8px;
  background: #fff;
  border: 1px solid var(--shin-border);
  border-radius: 50px;
  padding: 8px 8px 8px 16px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}
.shin-floating-close {
  background: none;
  border: none;
  color: var(--shin-text-muted);
  cursor: pointer;
  font-size: 14px;
  padding: 4px 6px;
  border-radius: 50%;
  line-height: 1;
}
.shin-floating-close:hover { background: var(--shin-bg-gray); }

/* ============================================
   shin-pros-cons — 優缺點雙欄（比較文用）
   ============================================ */
.shin-pros-cons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 16px 0;
}
.shin-pros, .shin-cons {
  border-radius: var(--shin-radius);
  padding: 14px 16px;
}
.shin-pros {
  background: var(--shin-bg-success);
  border: 1px solid #86EFAC;
}
.shin-cons {
  background: #FFF5F5;
  border: 1px solid #FECACA;
}
.shin-pros-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--shin-success);
  margin: 0 0 8px;
}
.shin-cons-title {
  font-size: 13px;
  font-weight: 700;
  color: #DC2626;
  margin: 0 0 8px;
}
.shin-pros ul, .shin-cons ul {
  margin: 0;
  padding-left: 18px;
  font-size: 13px;
  line-height: 1.7;
}
.shin-pros ul { color: #065F46; }
.shin-cons ul { color: #7F1D1D; }
@media (max-width: 600px) {
  .shin-pros-cons { grid-template-columns: 1fr; }
}

/* --- 色彩語意明確化備注 ---
   amber (#F59E0B) = 資訊性元素（提示框、警告、Badge）
   fire  (#EA580C) = 所有可點擊主要 CTA 按鈕（shin-btn-fire）
   teal  (#0E7490) = 品牌主色、次要 CTA、連結、H3 border
   shin-btn-accent（amber）已軟廢棄，新文章請改用 shin-btn-fire 或 shin-btn-outline
--- */

/* ============================================
   shin-step-list — 步驟流程元件（v1.0）
   用途：租車/簽證/購票等 Step by Step 流程
   ============================================ */
.shin-step-list {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
  counter-reset: shin-step;
}
.shin-step-list li {
  counter-increment: shin-step;
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 0;
  position: relative;
}
/* 連接線 */
.shin-step-list li:not(:last-child)::before {
  content: '';
  position: absolute;
  left: 19px;
  top: 44px;
  bottom: -8px;
  width: 2px;
  background: var(--shin-border-blue);
  z-index: 0;
}
.shin-step-list li + li {
  margin-top: 8px;
}
.shin-step-num {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--shin-primary);
  color: #fff;
  font-family: var(--shin-font-data);
  font-size: 16px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  margin-top: 2px;
}
.shin-step-num::after {
  content: counter(shin-step);
}
.shin-step-body {
  flex: 1;
  background: var(--shin-bg-blue);
  border: 1px solid var(--shin-border-blue);
  border-radius: var(--shin-radius);
  padding: 14px 16px;
  margin-bottom: 8px;
}
.shin-step-body h4,
.shin-step-title {
  font-family: var(--shin-font-heading);
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 6px;
}
.shin-step-body p,
.shin-step-desc {
  font-size: 14px;
  color: var(--shin-text-mid);
  margin: 0;
  line-height: 1.7;
}
.shin-step-body .shin-step-tip {
  font-size: 12px;
  color: var(--shin-primary);
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.shin-step-body .shin-step-tip::before {
  content: '💡';
  font-size: 13px;
}
/* 完成步驟樣式 */
.shin-step-list li.done .shin-step-num {
  background: var(--shin-success);
}
.shin-step-list li.done .shin-step-num::after {
  content: '✓';
}
@media (max-width: 480px) {
  .shin-step-list li:not(:last-child)::before {
    left: 15px;
  }
  .shin-step-num {
    width: 32px;
    height: 32px;
    font-size: 14px;
  }
  .shin-step-body {
    padding: 12px 14px;
  }
}

/* ============================================
   shin-timeline — 行程時間軸元件（v1.0）
   用途：一日遊/多日行程時間軸
   ============================================ */
.shin-timeline {
  position: relative;
  margin: 0 0 32px;
  padding: 0;
  list-style: none;
}
/* 垂直軸線 */
.shin-timeline::before {
  content: '';
  position: absolute;
  left: 52px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--shin-primary) 0%, var(--shin-border) 100%);
}
.shin-timeline-item {
  display: flex;
  gap: 0;
  align-items: flex-start;
  margin-bottom: 4px;
  position: relative;
}
/* 時間標籤 */
.shin-timeline-time {
  flex-shrink: 0;
  width: 44px;
  font-family: var(--shin-font-data);
  font-size: 11px;
  font-weight: 700;
  color: var(--shin-primary);
  text-align: right;
  padding-top: 14px;
  line-height: 1.2;
}
/* 圓點 */
.shin-timeline-dot {
  flex-shrink: 0;
  width: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 16px;
  position: relative;
  z-index: 1;
}
.shin-timeline-dot::before {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--shin-primary);
  border: 2px solid #fff;
  box-shadow: 0 0 0 2px var(--shin-primary);
  flex-shrink: 0;
}
.shin-timeline-item.highlight .shin-timeline-dot::before {
  background: var(--shin-fire);
  box-shadow: 0 0 0 2px var(--shin-fire);
  width: 14px;
  height: 14px;
}
/* 內容卡片 */
.shin-timeline-content {
  flex: 1;
  background: #fff;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius);
  padding: 12px 16px;
  margin: 8px 0 8px 10px;
  box-shadow: var(--shin-shadow-sm);
  transition: box-shadow 0.2s;
}
.shin-timeline-content:hover {
  box-shadow: var(--shin-shadow-md);
}
.shin-timeline-item.highlight .shin-timeline-content {
  border-color: var(--shin-fire-light);
  background: var(--shin-fire-bg);
}
.shin-timeline-title {
  font-family: var(--shin-font-heading);
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 4px;
}
.shin-timeline-desc {
  font-size: 13px;
  color: var(--shin-text-mid);
  line-height: 1.65;
  margin: 0;
}
.shin-timeline-meta {
  display: flex;
  gap: 12px;
  margin-top: 6px;
  flex-wrap: wrap;
}
.shin-timeline-tag {
  font-size: 11px;
  color: var(--shin-text-muted);
  background: var(--shin-bg-gray);
  padding: 2px 8px;
  border-radius: 20px;
  white-space: nowrap;
}
.shin-timeline-item.highlight .shin-timeline-tag {
  background: rgba(234, 88, 12, 0.08);
  color: var(--shin-fire);
}
@media (max-width: 480px) {
  .shin-timeline::before {
    left: 42px;
  }
  .shin-timeline-time {
    width: 34px;
    font-size: 10px;
  }
  .shin-timeline-content {
    padding: 10px 12px;
  }
  .shin-timeline-title {
    font-size: 14px;
  }
}

/* ============================================
   v3.0 UI 優化 — 2026-04-15
   summary-box / toc / alert / cta-card 補齊
   ============================================ */

/* --- A1. Summary Box（30秒快速看重點）--- */
/* --- A1. 30秒摘要框 v2（重新設計） --- */
.shin-summary-box {
  background: #FFFFFF;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius-lg);
  overflow: hidden;
  margin: 0 0 24px;
  box-shadow: var(--shin-shadow-md);
}
/* 標題色帶 */
.shin-summary-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--shin-primary);
  color: #FFFFFF;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 10px 18px;
  margin: 0;
}
.shin-summary-badge {
  font-size: 10px;
  font-weight: 700;
  background: rgba(255,255,255,0.2);
  color: #fff;
  border-radius: 20px;
  padding: 2px 8px;
  letter-spacing: 0.04em;
}
/* 統計數字列 */
.shin-summary-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: 1px solid var(--shin-border);
}
.shin-summary-stat {
  text-align: center;
  padding: 12px 6px;
  border-right: 1px solid var(--shin-border);
}
.shin-summary-stat:last-child { border-right: none; }
.shin-summary-stat .stat-big {
  display: block;
  font-size: 22px;
  font-weight: 800;
  color: var(--shin-primary);
  line-height: 1.1;
}
.shin-summary-stat .stat-lbl {
  display: block;
  font-size: 11px;
  color: var(--shin-text-muted);
  margin-top: 3px;
  line-height: 1.4;
}
/* 資訊格 */
.shin-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}
.shin-summary-item {
  padding: 10px 16px;
  border-bottom: 1px solid #F8FAFC;
  border-right: 1px solid #F8FAFC;
}
.shin-summary-item:nth-child(even) { border-right: none; }
.shin-summary-item-label {
  display: block;
  font-size: 10px;
  font-weight: 800;
  color: var(--shin-primary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 3px;
}
.shin-summary-item-val {
  font-size: 13px;
  color: var(--shin-text-mid);
  line-height: 1.55;
  margin: 0;
}
/* 舊版相容：純列表模式 */
.shin-summary-list {
  margin: 0;
  padding: 12px 18px;
  list-style: none;
}
.shin-summary-list li {
  font-size: 14px;
  color: var(--shin-text-mid);
  line-height: 1.75;
  padding: 5px 0 5px 16px;
  position: relative;
  border-bottom: 1px solid #F1F5F9;
}
.shin-summary-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.shin-summary-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 13px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--shin-primary);
  opacity: 0.5;
}
@media (max-width: 480px) {
  .shin-summary-stats { grid-template-columns: repeat(3, 1fr); }
  .shin-summary-grid  { grid-template-columns: 1fr; }
  .shin-summary-item  { border-right: none; }
}

/* --- A2. TOC 重新設計 --- */
.shin-toc {
  background: #FFFFFF;
  border: 1px solid var(--shin-border);
  border-top: 3px solid var(--shin-primary);
  border-radius: 0 0 var(--shin-radius-lg) var(--shin-radius-lg);
  padding: 0;
  margin: 8px 0 28px;
  box-shadow: var(--shin-shadow-sm);
  overflow: hidden;
}
.shin-toc-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 18px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--shin-text-dark);
  cursor: pointer;
  user-select: none;
  border-bottom: 1px solid var(--shin-border);
  transition: background 0.15s;
}
.shin-toc-title:hover {
  background: var(--shin-bg-gray);
}
.shin-toc-toggle {
  font-size: 11px;
  color: var(--shin-text-muted);
  transition: transform 0.25s;
  display: inline-block;
}
.shin-toc.collapsed .shin-toc-toggle {
  transform: rotate(-90deg);
}
.shin-toc-list {
  list-style: none;
  margin: 0;
  padding: 6px 0;
  counter-reset: toc-num;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.shin-toc.collapsed .shin-toc-list {
  display: none;
}
.shin-toc-list li {
  counter-increment: toc-num;
  margin: 0;
}
.shin-toc-list li a {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 7px 18px;
  font-size: 14px;
  color: var(--shin-text-mid);
  text-decoration: none;
  transition: color 0.15s, background 0.15s;
}
.shin-toc-list li a::before {
  content: counter(toc-num, decimal);
  font-size: 11px;
  font-weight: 700;
  color: var(--shin-primary);
  background: var(--shin-bg-blue);
  border-radius: 3px;
  padding: 1px 5px;
  flex-shrink: 0;
  min-width: 18px;
  text-align: center;
  line-height: 1.6;
}
.shin-toc-list li a:hover {
  color: var(--shin-primary);
  background: var(--shin-bg-blue);
}
@media (max-width: 600px) {
  .shin-toc-list {
    grid-template-columns: 1fr;
  }
  .shin-toc-list li a {
    padding: 6px 14px;
    font-size: 13px;
  }
}

/* --- A3. Alert Box（警告/重要提醒）--- */
.shin-alert-box {
  background: #FAFAFA;
  border: 1px solid #E2E8F0;
  border-left: 3px solid var(--shin-accent);
  border-radius: var(--shin-radius);
  padding: 11px 16px;
  font-size: 14px;
  line-height: 1.75;
  color: var(--shin-text-mid);
  margin: 14px 0;
}

/* --- A4. CTA Card（文章內行動區塊）--- */
.shin-cta-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--shin-bg-gray);
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius-lg);
  padding: 16px 20px;
  margin: 28px 0;
}
.shin-cta-text {
  flex: 1;
  min-width: 0;
}
.shin-cta-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  margin: 0 0 4px;
  line-height: 1.5;
}
.shin-cta-desc {
  font-size: 13px;
  color: var(--shin-text-light);
  margin: 0;
  line-height: 1.65;
}
.shin-cta-desc a {
  color: var(--shin-primary);
  text-decoration: none;
  font-weight: 600;
}
.shin-cta-desc a:hover {
  text-decoration: underline;
}
@media (max-width: 600px) {
  .shin-cta-card {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .shin-cta-card .shin-btn,
  .shin-cta-card .shin-btn-fire,
  .shin-cta-card [class^="shin-btn"] {
    display: block;
    text-align: center;
  }
}

/* ============================================
   A5. FAQ 重新設計 v3 — 2026-04-15
   ============================================ */

/* 容器 */
.shin-faq {
  margin: 0 0 28px;
}

/* 每一題卡片 */
.shin-faq-item {
  background: #FFFFFF;
  border: 1px solid var(--shin-border);
  border-radius: var(--shin-radius-lg);
  margin-bottom: 8px;
  overflow: hidden;
  transition: box-shadow 0.15s;
}
.shin-faq-item:hover {
  box-shadow: var(--shin-shadow-sm);
}

/* 問題列 */
.shin-faq-q {
  font-size: 15px;
  font-weight: 700;
  color: var(--shin-text-dark);
  line-height: 1.55;
  padding: 14px 16px 14px 50px;
  position: relative;
  margin: 0;
}
/* Q 徽章 */
.shin-faq-q::before {
  content: 'Q';
  position: absolute;
  left: 14px;
  top: 13px;
  width: 24px;
  height: 24px;
  background: var(--shin-primary);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 800;
  border-radius: 50%;
  text-align: center;
  line-height: 24px;
  flex-shrink: 0;
}

/* 答案列 */
.shin-faq-item .shin-faq-a,
.shin-faq-item .shin-faq-body {
  font-size: 14px;
  line-height: 1.85;
  color: var(--shin-text-mid);
  padding: 12px 16px 14px 50px;
  border-top: 1px solid #F1F5F9;
  background: var(--shin-bg-gray);
  margin: 0;
  position: relative;
}
/* A 標記 */
.shin-faq-item .shin-faq-a::before,
.shin-faq-item .shin-faq-body::before {
  content: 'A';
  position: absolute;
  left: 14px;
  top: 12px;
  width: 24px;
  height: 24px;
  background: #F1F5F9;
  color: var(--shin-text-light);
  font-size: 11px;
  font-weight: 800;
  border-radius: 50%;
  text-align: center;
  line-height: 24px;
}
.shin-faq-item .shin-faq-a p,
.shin-faq-item .shin-faq-body p {
  margin: 0;
}

@media (max-width: 480px) {
  .shin-faq-q {
    font-size: 14px;
    padding: 12px 12px 12px 44px;
  }
  .shin-faq-q::before {
    left: 12px;
    top: 11px;
    width: 22px;
    height: 22px;
    line-height: 22px;
    font-size: 10px;
  }
  .shin-faq-item .shin-faq-a,
  .shin-faq-item .shin-faq-body {
    padding: 10px 12px 12px 44px;
    font-size: 13px;
  }
  .shin-faq-item .shin-faq-a::before,
  .shin-faq-item .shin-faq-body::before {
    left: 12px;
    width: 22px;
    height: 22px;
    line-height: 22px;
    font-size: 10px;
  }
}

/* ============================================
   A6. 表格補完 — 2026-04-15
   ============================================ */

/* shin-comparison-table alias（舊文章向後相容） */
.shin-comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  min-width: 480px;
}
.shin-comparison-table th {
  padding: 10px 14px;
  text-align: left;
  background-color: var(--shin-primary);
  color: #FFFFFF;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.shin-comparison-table td {
  padding: 10px 14px;
  color: var(--shin-text-mid);
  font-size: 14px;
  line-height: 1.6;
  border-bottom: 1px solid #F1F5F9;
}
.shin-comparison-table tbody tr:nth-child(odd) td { background: #FAFAFA; }
.shin-comparison-table tbody tr:nth-child(even) td { background: #FFFFFF; }
.shin-comparison-table tbody tr { transition: background 0.1s; }
.shin-comparison-table tbody tr:hover td { background: var(--shin-bg-blue); }

/* 推薦行高亮 */
.shin-table-highlight td,
.shin-comparison-table tr.shin-table-highlight td {
  background: rgba(14,116,144,0.06);
  font-weight: 600;
}

/* 推薦徽章 */
.shin-badge-recommend {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  background: var(--shin-primary);
  color: #fff;
  border-radius: 4px;
  padding: 1px 6px;
  margin-left: 6px;
  vertical-align: middle;
  white-space: nowrap;
}

@media (max-width: 768px) {
  .shin-comparison-table { font-size: 13px; }
  .shin-comparison-table th,
  .shin-comparison-table td { padding: 7px 10px; }
}

/* ============================================================
   v3.1 補充元件 — 2026-04-15
   shin-card-grid-3 / shin-hotel-btn-pair / shin-map-embed
   ============================================================ */

/* 3 欄卡片網格 */
.shin-card-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 24px;
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .shin-card-grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .shin-card-grid-3 { grid-template-columns: 1fr; }
}

/* 住宿卡片雙 CTA 按鈕列 */
.shin-hotel-btn-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 8px 12px 12px;
}
.shin-btn-booking-sm {
  display: block;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 4px;
  border-radius: 6px;
  text-decoration: none;
  background: #003580;
  color: #fff !important;
  transition: opacity 0.15s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.shin-btn-agoda-sm {
  display: block;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 4px;
  border-radius: 6px;
  text-decoration: none;
  background: #E6003C;
  color: #fff !important;
  transition: opacity 0.15s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.shin-btn-booking-sm:hover,
.shin-btn-agoda-sm:hover { opacity: 0.85; }

/* 地圖嵌入容器 */
.shin-map-embed {
  margin: 16px 0 20px;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.shin-map-embed iframe {
  display: block;
  width: 100%;
  border: 0;
  border-radius: 10px;
}

/* 住宿卡片等高標題行（3欄格中使用） */
.shin-hotel-card .shin-hotel-tier {
  display: inline-block;
  font-size: 10px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 20px;
  margin-bottom: 5px;
}
.shin-tier-luxury { background: #FEF3C7; color: #92400E; }
.shin-tier-mid    { background: #EDE9FE; color: #4C1D95; }
.shin-tier-budget { background: #DCFCE7; color: #14532D; }

/* 住宿卡片價格區塊上間距 */
.shin-hotel-card .shin-price-block { margin-top: 6px; }

/* 浮動 CTA 中的 btn-fire 隱藏 badge（避免溢出膠囊容器） */
.shin-floating-cta .shin-btn-fire::before { display: none; }
.shin-floating-cta .shin-btn-fire { padding: 10px 18px !important; font-size: 14px !important; }

/* --- 住宿卡片 CTA 重設計 v3 --- */
/* 左右各半：Booking amber 主要 + Agoda 框線次要 */
.shin-hotel-cta {
  display: flex;
  flex-direction: row;
  gap: 8px;
  padding: 8px 12px 14px;
}
/* 主要訂房按鈕：amber 左半 */
.shin-btn-hotel-book {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: var(--shin-accent);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  padding: 9px 4px;
  border-radius: 8px;
  text-decoration: none;
  transition: background 0.15s, transform 0.15s;
  white-space: nowrap;
  line-height: 1.3;
}
.shin-btn-hotel-book:hover {
  background: #D97706;
  transform: translateY(-1px);
}
/* 次要比價按鈕：框線右半 */
.shin-btn-hotel-compare {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--shin-primary);
  border: 1.5px solid var(--shin-primary);
  border-radius: 8px;
  text-decoration: none;
  padding: 9px 4px;
  line-height: 1.3;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.shin-btn-hotel-compare:hover {
  background: var(--shin-primary);
  color: #fff;
  text-decoration: none;
}

/* ============================================
   v2 推薦文 / 活動文通用元件（2026-04-18 併入）
   來源：templates/template-recommendation.html
   使用文章：Post 49086 皇后鎮極限運動 v2
   ============================================ */

/* 備註框 tip / warn（圓形徽章 + 漸層背景） */
.adv-note { position: relative; margin: 22px 0; padding: 16px 18px 16px 62px; background: #fff; border: 1px solid #E2E8F0; border-left: 4px solid var(--shin-primary); border-radius: 12px; box-shadow: 0 2px 8px rgba(15,23,42,.05); font-size: 15px; line-height: 1.8; color: #334155; }
.adv-note::before { content: ""; position: absolute; left: 14px; top: 14px; width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; background: #ECFEFF; border: 1.5px solid #A5F3FC; }
.adv-note .adv-note-title { display: block; font-size: 16px; font-weight: 700; color: #0F172A; margin-bottom: 4px; letter-spacing: .01em; }
.adv-note p { margin: 0; }
.adv-note.tip { border-left-color: var(--shin-primary); background: linear-gradient(180deg,#F0FDFA 0%,#fff 100%); }
.adv-note.tip::before { content: "💡"; background: #CCFBF1; border-color: #5EEAD4; }
.adv-note.warn { border-left-color: var(--shin-accent); background: linear-gradient(180deg,#FFFBEB 0%,#fff 100%); }
.adv-note.warn::before { content: "⚠️"; background: #FEF3C7; border-color: #FCD34D; }

/* OKB eSIM 推廣卡 */
.adv-esim-cta { display: flex; gap: 16px; align-items: flex-start; margin: 24px 0; padding: 20px 22px; background: linear-gradient(135deg,#FFF7ED 0%,#FFEDD5 100%); border: 1.5px solid #FDBA74; border-radius: 14px; box-shadow: 0 4px 12px rgba(234,88,12,.08); }
.adv-esim-icon { flex-shrink: 0; width: 48px; height: 48px; border-radius: 50%; background: #fff; border: 2px solid #FB923C; display: flex; align-items: center; justify-content: center; font-size: 24px; box-shadow: 0 2px 6px rgba(234,88,12,.15); }
.adv-esim-body { flex: 1; }
.adv-esim-title { display: block; font-size: 17px; font-weight: 800; color: #7C2D12; margin-bottom: 6px; letter-spacing: .01em; }
.adv-esim-body p { font-size: 14.5px; line-height: 1.75; color: #431407; margin: 0 0 12px; }
.adv-esim-btn { display: inline-flex; align-items: center; gap: 4px; background: #EA580C; color: #fff !important; padding: 10px 18px; border-radius: 8px; font-size: 14.5px; font-weight: 700; text-decoration: none; box-shadow: 0 2px 6px rgba(234,88,12,.3); transition: all .2s; }
.adv-esim-btn:hover { background: #C2410C; transform: translateY(-1px); box-shadow: 0 4px 10px rgba(234,88,12,.4); }
@media (max-width: 480px) {
  .adv-esim-cta { flex-direction: column; gap: 12px; padding: 16px 18px; }
  .adv-esim-icon { width: 44px; height: 44px; }
}

/* 圖片 overlay caption */
.adv-fig-overlay { position: relative; margin: 14px 0; border-radius: 10px; overflow: hidden; line-height: 0; }
.adv-fig-overlay img { display: block; width: 100%; height: auto; }
.adv-fig-overlay figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 26px 18px 14px; background: linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.55) 55%,rgba(0,0,0,0) 100%); color: #fff; font-size: 14px; line-height: 1.6; letter-spacing: .01em; text-shadow: 0 1px 3px rgba(0,0,0,.45); font-weight: 500; }
@media (max-width: 640px) {
  .adv-fig-overlay figcaption { padding: 22px 14px 12px; font-size: 13px; }
}

/* 住宿 / 推薦 3×N Grid（Booking + Agoda 雙 CTA） */
.adv-hotel-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin: 14px 0 18px; }
@media (max-width: 768px) { .adv-hotel-grid { grid-template-columns: repeat(2,1fr); gap: 12px; } }
@media (max-width: 480px) { .adv-hotel-grid { grid-template-columns: 1fr; } }
.adv-hotel-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; transition: all .2s; }
.adv-hotel-card:hover { border-color: var(--shin-primary); box-shadow: 0 4px 14px rgba(14,116,144,.10); transform: translateY(-2px); }
.adv-hotel-thumb { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.adv-hotel-body { padding: 14px 16px 16px; display: flex; flex-direction: column; flex: 1; }
.adv-hotel-badge { display: inline-block; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 6px; margin-bottom: 8px; align-self: flex-start; }
.adv-hotel-badge.lux { background: #FEF3C7; color: #92400E; }
.adv-hotel-badge.mid { background: #DBEAFE; color: #1E40AF; }
.adv-hotel-badge.bud { background: #DCFCE7; color: #166534; }
.adv-hotel-name { font-size: 15px; font-weight: 700; color: #0F172A; margin-bottom: 6px; line-height: 1.4; }
.adv-hotel-feat { font-size: 13px; color: #475569; line-height: 1.65; flex: 1; margin-bottom: 10px; }
.adv-hotel-price { font-size: 13px; color: var(--shin-primary); font-weight: 600; margin-bottom: 10px; }
.adv-hotel-btns { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: auto; }
.adv-hotel-btn { display: flex; align-items: center; justify-content: center; gap: 4px; background: #003B95; color: #fff !important; padding: 10px 8px; border-radius: 8px; font-size: 12.5px; font-weight: 700; text-decoration: none; transition: all .2s; box-shadow: 0 1px 3px rgba(0,0,0,.08); letter-spacing: .01em; }
.adv-hotel-btn:hover { background: #002a6d; transform: translateY(-1px); box-shadow: 0 3px 8px rgba(0,59,149,.25); }
.adv-hotel-btn.agoda { background: #D62B47; }
.adv-hotel-btn.agoda:hover { background: #a31f36; box-shadow: 0 3px 8px rgba(214,43,71,.25); }
@media (max-width: 380px) { .adv-hotel-btns { grid-template-columns: 1fr; } }

/* 聯盟 CTA 按鈕 Klook / KKday / Trip.com */
.adv-cta-row { display: flex; gap: 10px; flex-wrap: wrap; margin: 14px 0; }
.adv-btn-klook, .adv-btn-kkday, .adv-btn-trip { display: inline-flex; align-items: center; justify-content: center; flex: 1; min-width: 180px; padding: 12px 18px; border-radius: 8px; font-size: 14.5px; font-weight: 700; text-decoration: none; transition: all .2s; color: #fff !important; }
.adv-btn-klook { background: #FF5B00; box-shadow: 0 2px 6px rgba(255,91,0,.25); }
.adv-btn-klook:hover { background: #E04F00; transform: translateY(-1px); box-shadow: 0 4px 10px rgba(255,91,0,.35); }
.adv-btn-kkday { background: #E53935; box-shadow: 0 2px 6px rgba(229,57,53,.25); }
.adv-btn-kkday:hover { background: #B71C1C; transform: translateY(-1px); box-shadow: 0 4px 10px rgba(229,57,53,.35); }
.adv-btn-trip { background: #2577E3; box-shadow: 0 2px 6px rgba(37,119,227,.2); }
.adv-btn-trip:hover { background: #1A5BB8; transform: translateY(-1px); box-shadow: 0 4px 10px rgba(37,119,227,.3); }

/* 活動 / 推薦項目卡 */
.adv-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; overflow: hidden; margin: 18px 0; box-shadow: 0 2px 6px rgba(15,23,42,.04); }
.adv-card-body { padding: 18px 20px 20px; }
.adv-meta-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
.adv-pill { display: inline-block; font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 20px; background: #F1F5F9; color: #475569; }
.adv-price-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin: 14px 0; }
.adv-price-item { background: #F8FAFC; border: 1px solid #E2E8F0; border-radius: 8px; padding: 10px 12px; text-align: center; }
.adv-price-label { font-size: 12px; color: #64748B; margin-bottom: 4px; }
.adv-price-nzd { font-size: 16px; font-weight: 700; color: #0F172A; margin-bottom: 2px; }
.adv-price-twd { font-size: 12px; color: #94A3B8; }
@media (max-width: 480px) { .adv-price-row { grid-template-columns: 1fr 1fr; } }

/* FAQ details 展開式 */
.adv-faq-item { background: #fff; border: 1px solid #E2E8F0; border-radius: 10px; margin-bottom: 10px; overflow: hidden; transition: all .2s; }
.adv-faq-item:hover { border-color: var(--shin-primary); }
.adv-faq-item[open] { border-color: var(--shin-primary); box-shadow: 0 2px 8px rgba(14,116,144,.08); }
.adv-faq-q { padding: 14px 48px 14px 18px; font-size: 15px; font-weight: 700; color: #0F172A; cursor: pointer; position: relative; list-style: none; }
.adv-faq-q::-webkit-details-marker { display: none; }
.adv-faq-q::after { content: "＋"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); font-size: 20px; color: var(--shin-primary); transition: transform .2s; }
.adv-faq-item[open] .adv-faq-q::after { content: "−"; }
.adv-faq-body { padding: 0 18px 16px; font-size: 14.5px; line-height: 1.8; color: #334155; }


/* ============================================
   shin-components v3 增補組件
   --------------------------------------------
   新增：qt-toc 分組目錄、shin-tc-btn 交通卡 CTA、
         shin-cta-split 左右 50/50 CTA、shin-inline-cta 文內 CTA、
         shin-faq v2（絕對定位 Q/+ icon）、is-draft 標記、
         UI v2 tweaks（figure、table-hint、sep 呼吸）
   版本：2026-04-23
   作用：全站可重用，無需再 inline 到文章內
   ============================================ */

/* === qt-toc 分組目錄（pillar/hub 文章專用）=== */
.qt-toc{position:relative;margin:28px 0;padding:22px 24px 20px;background:linear-gradient(135deg,#F0FDFA 0%,#FFFFFF 55%,#FEF3C7 100%);border:1px solid #CBD5E1;border-radius:16px;box-shadow:0 4px 18px rgba(14,116,144,.08);}
.qt-toc::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#0E7490 0%,#14B8A6 50%,#F59E0B 100%);border-radius:16px 16px 0 0;}
.qt-toc-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;margin-bottom:14px;flex-wrap:wrap;gap:8px;}
.qt-toc-head h3{margin:0;font-size:18px;font-weight:800;color:#0E7490;letter-spacing:.02em;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.qt-toc-head h3 .qt-toc-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#0E7490,#14B8A6);color:#fff;font-size:14px;font-weight:800;flex-shrink:0;}
.qt-toc-toggle{font-size:13px;color:#0E7490;font-weight:700;padding:4px 10px;border-radius:6px;background:rgba(14,116,144,.08);}
.qt-toc-section{margin-top:14px;}
.qt-toc-section-title{font-size:13px;font-weight:800;color:#0E7490;letter-spacing:.06em;margin:0 0 8px;text-transform:uppercase;}
.qt-toc-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.qt-toc-list a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:#fff;border:1px solid #E2E8F0;color:#0F172A;text-decoration:none;font-size:14px;transition:all .15s ease;}
.qt-toc-list a:hover{border-color:#0E7490;background:#F0FDFA;transform:translateX(3px);}
.qt-toc-num{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:linear-gradient(135deg,#0E7490,#14B8A6);color:#fff;font-size:11px;font-weight:800;}
@media(max-width:640px){.qt-toc-list{grid-template-columns:1fr;}}

/* === FAQ v2（絕對定位 Q badge + ± 圖示）=== */
.shin-faq-item{background:#fff;border:1px solid #E2E8F0;border-radius:10px;margin-bottom:10px;overflow:hidden;transition:border-color .2s ease;}
.shin-faq-item[open]{border-color:#0E7490;box-shadow:0 3px 12px rgba(14,116,144,.08);}
.shin-faq-item summary.shin-faq-q{list-style:none;cursor:pointer;position:relative;padding:16px 50px 16px 58px;font-size:15.5px;font-weight:700;color:#0F172A;line-height:1.55;display:block;}
.shin-faq-item summary.shin-faq-q::-webkit-details-marker{display:none;}
.shin-faq-item summary.shin-faq-q::before{content:"Q";position:absolute;left:16px;top:14px;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,#0E7490,#14B8A6);color:#fff;font-size:14px;font-weight:800;font-family:Georgia,serif;line-height:1;}
.shin-faq-item summary.shin-faq-q::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:22px;color:#0E7490;font-weight:400;transition:transform .2s ease;line-height:1;}
.shin-faq-item[open] summary.shin-faq-q::after{transform:translateY(-50%) rotate(45deg);}
.shin-faq-item:not([open]) summary.shin-faq-q::after{animation:shinFaqPulse 2.4s ease-in-out infinite;}
@keyframes shinFaqPulse{0%,100%{opacity:.7}50%{opacity:1;transform:translateY(-50%) scale(1.1)}}
.shin-faq-item .shin-faq-body{padding:0 20px 18px 58px;font-size:14.5px;line-height:1.85;color:#334155;}
.shin-faq-item .shin-faq-body p{margin:0 0 10px;}
.shin-faq-item .shin-faq-body p:last-child{margin-bottom:0;}
.shin-faq-item .shin-faq-body ul{margin:8px 0;padding-left:20px;}
@media(max-width:600px){
  .shin-faq-item summary.shin-faq-q{padding:14px 46px 14px 52px;font-size:14.5px;}
  .shin-faq-item summary.shin-faq-q::before{left:14px;top:13px;width:26px;height:26px;font-size:13px;}
  .shin-faq-item summary.shin-faq-q::after{right:14px;}
  .shin-faq-item .shin-faq-body{padding:0 16px 16px 52px;}
}

/* === 交通/比較卡 mini CTA 按鈕 === */
.shin-tc-btn{display:inline-block;margin-top:12px;padding:9px 14px;background:linear-gradient(135deg,#EA580C,#F59E0B);color:#fff !important;font-size:13px;font-weight:700;border-radius:8px;text-decoration:none;transition:all .2s ease;width:100%;box-sizing:border-box;}
.shin-tc-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(234,88,12,.25);filter:brightness(1.05);}
.shin-tc-btn-alt{background:linear-gradient(135deg,#0E7490,#14B8A6);}
.shin-tc-btn-alt:hover{box-shadow:0 6px 14px rgba(14,116,144,.25);}

/* === 左右 50/50 CTA（支柱文結論專用）=== */
.shin-cta-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0 6px;}
.shin-cta-split .shin-cta-half{display:flex;flex-direction:column;justify-content:center;padding:16px 18px;border-radius:12px;text-decoration:none;color:#fff !important;transition:transform .15s ease,box-shadow .15s ease;min-height:88px;}
.shin-cta-split .shin-cta-half:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.15);}
.shin-cta-split .shin-cta-left{background:linear-gradient(135deg,#EA580C,#F59E0B);}
.shin-cta-split .shin-cta-right{background:linear-gradient(135deg,#0E7490,#14B8A6);}
.shin-cta-half-label{font-size:12px;font-weight:700;letter-spacing:.08em;opacity:.9;text-transform:uppercase;}
.shin-cta-half-title{font-size:17px;font-weight:800;margin:2px 0 4px;}
.shin-cta-half-sub{font-size:13px;font-weight:500;opacity:.95;}
@media(max-width:600px){.shin-cta-split{grid-template-columns:1fr;}}

/* === 文內 inline CTA 小卡（段落之間的自然置入）=== */
.shin-inline-cta{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#FFFBEB 0%,#FEF3C7 100%);border:1px solid #FCD34D;border-left:4px solid #EA580C;border-radius:10px;padding:14px 18px;margin:20px 0;text-decoration:none !important;color:#0F172A !important;transition:all .15s ease;}
.shin-inline-cta:hover{background:linear-gradient(135deg,#FEF3C7 0%,#FDE68A 100%);transform:translateX(4px);}
.shin-inline-cta .shin-inline-icon{flex-shrink:0;width:40px;height:40px;border-radius:8px;background:#EA580C;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;}
.shin-inline-cta .shin-inline-body{flex:1;min-width:0;}
.shin-inline-cta .shin-inline-title{font-size:15px;font-weight:700;color:#0F172A;margin-bottom:2px;}
.shin-inline-cta .shin-inline-desc{font-size:13px;color:#64748B;}
.shin-inline-cta .shin-inline-arrow{flex-shrink:0;color:#EA580C;font-weight:800;font-size:18px;}

/* === is-draft 草稿連結標記 === */
a.is-draft{border-bottom:1px dashed #94A3B8;opacity:.78;}
a.is-draft:hover{opacity:1;}

/* === UI v2 tweaks：figure、table-hint、H2 呼吸 === */
figure.shin-figure{margin:24px 0;}
figure.shin-figure img{border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.10);max-width:100%;height:auto;display:block;}
figure.shin-figure figcaption{font-size:13px;color:#64748B;margin-top:10px;line-height:1.6;font-style:italic;}
.shin-table-hint{font-size:12.5px;color:#94A3B8;margin:-4px 0 8px;display:none;}
@media(max-width:640px){.shin-table-hint{display:block;}}
.shin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:16px 0;border-radius:10px;border:1px solid #E2E8F0;}
.shin-table-wrap table{min-width:560px;}

/* === H2 呼吸間距 === */
.shin-sep{border:none;border-top:1px solid #E2E8F0;margin:42px 0;}
@media(max-width:640px){.shin-sep{margin:28px 0;}}

/* === 文章內全面左對齊 override（可選，套用到文章 body class）=== */
.shin-article-noalign .shin-img,
.shin-article-noalign figure.shin-figure,
.shin-article-noalign figure.shin-img{text-align:left;}
.shin-article-noalign .shin-img figcaption,
.shin-article-noalign figure.shin-figure figcaption,
.shin-article-noalign figure.shin-img figcaption{text-align:left;padding:10px 0;background:transparent;border-top:none;}
.shin-article-noalign .shin-btn-row{justify-content:flex-start;}
.shin-article-noalign .shin-month-card,
.shin-article-noalign .shin-tc-btn,
.shin-article-noalign .shin-cluster-card-title,
.shin-article-noalign .shin-cluster-card-desc,
.shin-article-noalign .shin-related-title,
.shin-article-noalign .shin-related-text,
.shin-article-noalign .shin-related-label,
.shin-article-noalign .shin-cta-title,
.shin-article-noalign .shin-cta-desc{text-align:left;}

/* === shin-cluster-map（文章索引網格，pillar 文章用）=== */
.shin-cluster-map{margin:28px 0;}
.shin-cluster-section{margin-bottom:22px;}
.shin-cluster-section-label{font-size:13px;font-weight:800;color:#0E7490;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px;}
.shin-cluster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;}
.shin-cluster-card{display:block;padding:16px 18px;background:#fff;border:1px solid #E2E8F0;border-radius:12px;text-decoration:none;color:#0F172A;transition:all .18s ease;position:relative;overflow:hidden;}
.shin-cluster-card:hover{border-color:#0E7490;box-shadow:0 6px 18px rgba(14,116,144,.10);transform:translateY(-2px);}
.shin-cluster-card-emoji{display:inline-block;font-size:20px;margin-bottom:6px;}
.shin-cluster-card-badge{display:inline-block;font-size:10px;font-weight:700;color:#0E7490;background:#F0FDFA;padding:2px 8px;border-radius:10px;margin-left:6px;vertical-align:middle;}
.shin-cluster-card-title{font-size:15px;font-weight:800;color:#0F172A;margin:2px 0 4px;}
.shin-cluster-card-desc{font-size:13px;color:#64748B;line-height:1.55;}


/* === 全站文章內容左對齊 override（single post 通用，取消 shin-components 預設 center）=== */
.single-post .entry-content .shin-img,
.single-post .entry-content figure.shin-figure,
.single-post .entry-content figure.shin-img,
.single-post .dynamic-entry-content .shin-img,
.single-post .dynamic-entry-content figure.shin-figure,
.single-post .dynamic-entry-content figure.shin-img{text-align:left !important;}
.single-post .entry-content .shin-img figcaption,
.single-post .entry-content figure.shin-figure figcaption,
.single-post .entry-content figure.shin-img figcaption,
.single-post .dynamic-entry-content .shin-img figcaption,
.single-post .dynamic-entry-content figure.shin-figure figcaption,
.single-post .dynamic-entry-content figure.shin-img figcaption{text-align:left !important;padding:10px 0 !important;background:transparent !important;border-top:none !important;}
.single-post .entry-content .shin-btn-row,
.single-post .dynamic-entry-content .shin-btn-row{justify-content:flex-start !important;}
.single-post .entry-content .shin-btn-row>a,
.single-post .dynamic-entry-content .shin-btn-row>a{text-align:left !important;flex:0 0 auto !important;}
.single-post .entry-content .shin-cta-center,
.single-post .dynamic-entry-content .shin-cta-center{text-align:left !important;}
.single-post .entry-content .shin-month-card,
.single-post .entry-content .shin-tc-btn,
.single-post .entry-content .shin-tc-btn-alt,
.single-post .entry-content .shin-cluster-card-title,
.single-post .entry-content .shin-cluster-card-desc,
.single-post .entry-content .shin-cluster-section-label,
.single-post .entry-content .shin-related-title,
.single-post .entry-content .shin-related-text,
.single-post .entry-content .shin-related-label,
.single-post .entry-content .shin-cta-title,
.single-post .entry-content .shin-cta-desc,
.single-post .entry-content .shin-itin-budget,
.single-post .entry-content .shin-itin-card-head,
.single-post .entry-content .shin-spot-title,
.single-post .entry-content .shin-spot-info,
.single-post .dynamic-entry-content .shin-month-card,
.single-post .dynamic-entry-content .shin-tc-btn,
.single-post .dynamic-entry-content .shin-tc-btn-alt,
.single-post .dynamic-entry-content .shin-cluster-card-title,
.single-post .dynamic-entry-content .shin-cluster-card-desc,
.single-post .dynamic-entry-content .shin-cluster-section-label,
.single-post .dynamic-entry-content .shin-related-title,
.single-post .dynamic-entry-content .shin-related-text,
.single-post .dynamic-entry-content .shin-related-label,
.single-post .dynamic-entry-content .shin-cta-title,
.single-post .dynamic-entry-content .shin-cta-desc,
.single-post .dynamic-entry-content .shin-itin-budget,
.single-post .dynamic-entry-content .shin-itin-card-head,
.single-post .dynamic-entry-content .shin-spot-title,
.single-post .dynamic-entry-content .shin-spot-info{text-align:left !important;}
/* 保留特例：FAQ summary 的 Q badge（absolute 定位不受影響）、shin-cta-split 內文字（cta 卡視覺需居中）=== 不覆寫 */

/* === v3.5 patches (Post 49090 team review P0/P1/P2) === */

/* P1-7: Teal variant for inline CTA (color alternation) */
.shin-inline-cta.shin-inline-teal{
  background:linear-gradient(135deg,#F0F9FF 0%,#E0F2FE 100%);
  border-left-color:#0E7490;
}
.shin-inline-cta.shin-inline-teal .shin-inline-icon{
  background:linear-gradient(135deg,#0E7490 0%,#0891B2 100%);
  color:#fff;
}
.shin-inline-cta.shin-inline-teal .shin-inline-arrow{color:#0E7490;}

/* P1-8: Recommended budget card + badge */
.shin-budget-card.is-recommended{
  position:relative;
  box-shadow:0 0 0 3px #F59E0B, 0 8px 24px rgba(245,158,11,.15);
  transform:translateY(-4px);
}
.shin-budget-recommend-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#F59E0B 0%,#EA580C 100%);
  color:#fff;font-size:13px;font-weight:700;
  padding:4px 14px;border-radius:999px;
  box-shadow:0 4px 12px rgba(234,88,12,.35);
  white-space:nowrap;z-index:2;
}

/* P1-9: Tight spacing between H2 and tables */
h2.shin-h2 + .shin-vs-table,
h2.shin-h2 + .shin-table-wrap,
h2.shin-h2 + figure.wp-block-table{margin-top:16px;}

/* P0-6: Mobile conclusion CTA stack */
@media (max-width:480px){
  .shin-conclusion-ctas{flex-direction:column;gap:10px;}
  .shin-conclusion-ctas .shin-btn,
  .shin-conclusion-ctas a.shin-btn-fire,
  .shin-conclusion-ctas a{width:100%;}
}

/* P2-14: Activity grid mobile 1col -> 2col on small screens */
@media (min-width:420px) and (max-width:767px){
  .shin-activity-grid{grid-template-columns:repeat(2,1fr);}
}

/* === v3.6 UI refinements (Post 49090 user feedback) === */

/* 1. shin-summary-box â compact padding */
.shin-summary-box{
  padding:18px 22px !important;
  margin:24px 0 !important;
}
.shin-summary-box .shin-summary-label{
  margin-bottom:6px !important;
}
.shin-summary-box .shin-summary-title,
.shin-summary-box h2.shin-summary-title{
  font-size:20px !important;
  margin:0 0 10px !important;
  line-height:1.4 !important;
}
.shin-summary-box .shin-summary-list{
  margin:0 0 8px !important;
  padding-left:20px !important;
  line-height:1.7 !important;
}
.shin-summary-box .shin-summary-list li{
  margin-bottom:4px !important;
}
.shin-summary-box > p:last-child{
  margin:8px 0 0 !important;
}
@media (max-width:600px){
  .shin-summary-box{padding:14px 16px !important;margin:18px 0 !important;}
  .shin-summary-box .shin-summary-title{font-size:18px !important;}
}

/* 2. shin-budget-card â polished look */
.shin-budget-grid{
  gap:20px !important;
}
.shin-budget-card{
  position:relative;
  padding:24px 20px 22px !important;
  border-radius:14px !important;
  background:#fff;
  border:1px solid #E2E8F0 !important;
  box-shadow:0 2px 8px rgba(15,23,42,.04);
  transition:transform .2s ease, box-shadow .2s ease;
  overflow:hidden;
}
.shin-budget-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,#0E7490 0%,#0891B2 100%);
}
.shin-budget-card.is-recommended::before{
  background:linear-gradient(90deg,#F59E0B 0%,#EA580C 100%);
  height:5px;
}
.shin-budget-card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 24px rgba(15,23,42,.1);
}
.shin-budget-card.is-recommended:hover{
  transform:translateY(-6px);
}
.shin-budget-card-title{
  font-size:17px !important;
  font-weight:700;
  color:#0E7490;
  margin:4px 0 10px !important;
  letter-spacing:.5px;
}
.shin-budget-card.is-recommended .shin-budget-card-title{color:#EA580C;}
.shin-budget-card-price{
  font-size:26px !important;
  font-weight:800;
  color:#0F172A;
  line-height:1.2;
  margin:6px 0 !important;
}
.shin-budget-card-price small,
.shin-budget-card-sub{
  display:block;
  font-size:13px;
  color:#64748B;
  font-weight:500;
  margin-top:4px;
}
.shin-budget-card ul{
  margin:14px 0 0 !important;
  padding-left:0 !important;
  list-style:none;
  border-top:1px dashed #E2E8F0;
  padding-top:12px !important;
}
.shin-budget-card ul li{
  position:relative;
  padding:4px 0 4px 22px;
  font-size:14.5px;
  line-height:1.6;
  color:#334155;
}
.shin-budget-card ul li::before{
  content:"â";
  position:absolute;left:0;top:4px;
  color:#10B981;font-weight:700;
}

/* 3. shin-vs-table â refined table UI */
.shin-vs-table,
.shin-table-wrap table{
  border-collapse:separate !important;
  border-spacing:0 !important;
  width:100%;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 1px 3px rgba(15,23,42,.06);
  border:1px solid #E2E8F0;
  font-size:15px;
}
.shin-vs-table thead th,
.shin-table-wrap thead th{
  background:linear-gradient(135deg,#0E7490 0%,#0891B2 100%) !important;
  color:#fff !important;
  font-weight:600;
  padding:12px 14px !important;
  text-align:left;
  border-bottom:none !important;
  letter-spacing:.3px;
}
.shin-vs-table tbody td,
.shin-table-wrap tbody td{
  padding:11px 14px !important;
  border-bottom:1px solid #F1F5F9 !important;
  color:#334155;
  line-height:1.6;
  vertical-align:top;
}
.shin-vs-table tbody tr:nth-child(even) td,
.shin-table-wrap tbody tr:nth-child(even) td{
  background:#F8FAFC;
}
.shin-vs-table tbody tr:hover td,
.shin-table-wrap tbody tr:hover td{
  background:#ECFEFF !important;
}
.shin-vs-table tbody tr:last-child td,
.shin-table-wrap tbody tr:last-child td{
  border-bottom:none !important;
}
.shin-vs-table tbody td:first-child,
.shin-table-wrap tbody td:first-child{
  font-weight:600;
  color:#0F172A;
}
.shin-vs-table tbody td strong{color:#0E7490;}
@media (max-width:640px){
  .shin-vs-table,
  .shin-table-wrap table{font-size:14px;}
  .shin-vs-table thead th,
  .shin-vs-table tbody td,
  .shin-table-wrap thead th,
  .shin-table-wrap tbody td{padding:9px 10px !important;}
}

/* v3.7: 3-column budget card grid */
.shin-budget-3col{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:20px !important;
  margin:20px 0 !important;
}
.shin-budget-3col > .shin-budget-card{margin-bottom:0 !important;}
@media (max-width:900px){
  .shin-budget-3col{grid-template-columns:1fr !important;gap:16px !important;}
}
