/* ═══════════════════════════════════════════════════════════════════
   元件樣式 — Header、Footer、Button、Card、Form 等
═══════════════════════════════════════════════════════════════════ */

/* ── 無障礙：跳過導覽 ── */
.skip-link {
  position: absolute; top: -100%; left: var(--space-4);
  background: var(--color-accent); color: #fff;
  padding: var(--space-2) var(--space-4);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  font-weight: 600; z-index: 9999; font-size: var(--text-sm);
}
.skip-link:focus { top: 0; }

/* ── 公告列 ── */
.announcement-bar {
  background: var(--color-accent); color: #fff;
  text-align: center; padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs); font-weight: 500;
}

/* ── HEADER ── */
.site-header {
  background: var(--color-bg-dark);
  height: var(--header-h); display: flex; align-items: center;
  position: sticky; top: 0; z-index: 100;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); }
.site-logo {
  display: flex; align-items: center; gap: var(--space-2);
  color: #fff; font-size: var(--text-lg); font-weight: 700; letter-spacing: -.02em;
  text-decoration: none;
  flex-shrink: 0;
}
.site-logo img,
.custom-logo,
.custom-logo-link img {
  max-width: 160px !important;
  height: auto !important;
  max-height: 48px !important;
  object-fit: contain;
}
.custom-logo-link { display: inline-flex; align-items: center; }
.logo-icon {
  width: 32px; height: 32px; background: var(--color-accent);
  border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.main-nav { display: flex; align-items: center; gap: var(--space-1); flex: 1 1 auto; min-width: 0; justify-content: center; }
.main-nav-list,
.main-nav ul,
.main-nav > ul,
nav.main-nav ul.main-nav-list {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: var(--space-1);
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  flex-wrap: nowrap;
}
.main-nav-list li,
.main-nav-list .menu-item {
  display: inline-flex !important;
  margin: 0; padding: 0; list-style: none;
}
.main-nav a,
.main-nav-list a {
  color: rgba(255,255,255,.75); font-size: var(--text-sm); font-weight: 500;
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  transition: var(--transition); white-space: nowrap; text-decoration: none;
}
.main-nav a:hover, .main-nav a.current-menu-item, .main-nav a.active,
.main-nav-list a:hover, .main-nav-list .current-menu-item > a { color: #fff; background: rgba(255,255,255,.08); }
.header-tools { display: flex; align-items: center; gap: var(--space-3); }
.icon-btn {
  width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.75); border-radius: var(--radius-sm); transition: var(--transition);
  position: relative; text-decoration: none;
}
.icon-btn:hover { color: #fff; background: rgba(255,255,255,.08); }
.cart-badge {
  position: absolute; top: 4px; right: 4px;
  background: var(--color-accent); color: #fff;
  font-size: 9px; font-weight: 700; min-width: 16px; height: 16px;
  border-radius: var(--radius-full); display: flex; align-items: center; justify-content: center; padding: 0 3px;
}
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  width: 40px; height: 40px; justify-content: center; align-items: center;
  color: rgba(255,255,255,.8);
}
.hamburger span { display: block; width: 22px; height: 2px; background: currentColor; border-radius: 2px; transition: var(--transition); }
.hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── 行動版選單抽屜 ── */
.mobile-menu { position: fixed; inset: 0; z-index: 999; }
.mobile-menu[hidden] { display: none; }
.mobile-menu-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); }
.mobile-menu-drawer {
  position: absolute; top: 0; right: 0; bottom: 0; width: min(320px, 85vw);
  background: var(--color-bg-dark); padding: var(--space-6);
  overflow-y: auto; display: flex; flex-direction: column; gap: var(--space-4);
}
.mobile-menu-close {
  align-self: flex-end; color: rgba(255,255,255,.6); font-size: 20px;
  padding: var(--space-2); border-radius: var(--radius-sm); transition: var(--transition);
}
.mobile-menu-close:hover { color: #fff; background: rgba(255,255,255,.08); }
/* ── 搜尋彈出層 ── */
.allspectra-search-overlay {
  position: fixed; inset: 0; z-index: 9000;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 15vh;
}
.allspectra-search-overlay[hidden] { display: none; }
.allspectra-search-backdrop {
  position: absolute; inset: 0;
  background: rgba(10, 10, 10, .85);
  backdrop-filter: blur(4px);
}
.allspectra-search-panel {
  position: relative; z-index: 1;
  width: min(640px, 90vw);
}
.allspectra-search-form-popup {
  display: flex; align-items: center; gap: var(--space-2);
  background: #1a1a1a; border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: var(--space-3);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.allspectra-search-form-popup input[type="search"] {
  flex: 1; background: transparent; border: none; outline: none;
  color: #fff; font-size: var(--text-lg);
  padding: var(--space-2) var(--space-3);
  font-family: inherit;
}
.allspectra-search-form-popup input[type="search"]::placeholder { color: rgba(255,255,255,.4); }
.allspectra-search-form-popup button {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  background: transparent; border: none; color: rgba(255,255,255,.7);
  border-radius: var(--radius-md); cursor: pointer;
  transition: var(--transition);
}
.allspectra-search-form-popup button:hover { background: rgba(255,255,255,.08); color: #fff; }
.allspectra-search-form-popup button[type="submit"] { background: var(--color-accent); color: #fff; }
.allspectra-search-form-popup button[type="submit"]:hover { background: var(--color-accent-hover); }

.mobile-nav-list,
.mobile-menu nav ul { display: flex; flex-direction: column; gap: 2px; list-style: none; margin: 0; padding: 0; }
.mobile-nav-list a,
.mobile-menu nav a { display: block; color: rgba(255,255,255,.75); padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-size: var(--text-base); transition: var(--transition); text-decoration: none; }
.mobile-nav-list a:hover,
.mobile-menu nav a:hover { color: #fff; background: rgba(255,255,255,.08); }

/* ── FOOTER ── */
.site-footer { background: var(--color-bg-dark); color: rgba(255,255,255,.6); padding: var(--space-16) 0 var(--space-8); }
.footer-logo { margin-bottom: var(--space-4); }
.footer-brand p { font-size: var(--text-sm); line-height: 1.8; max-width: 280px; }
.social-links { display: flex; gap: var(--space-4); margin-top: var(--space-6); }
.social-links a { color: rgba(255,255,255,.4); transition: var(--transition); }
.social-links a:hover { color: #fff; }
.footer-col-title { color: #fff; font-size: var(--text-sm); font-weight: 700; margin-bottom: var(--space-4); letter-spacing: .02em; }
.footer-links { display: flex; flex-direction: column; gap: var(--space-3); }
.footer-links a { font-size: var(--text-sm); transition: var(--transition); }
.footer-links a:hover { color: #fff; }
.payment-icons { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-3); }
.payment-icon {
  background: rgba(255,255,255,.08); color: rgba(255,255,255,.6);
  padding: 4px 10px; border-radius: var(--radius-sm);
  font-size: 11px; font-weight: 600; font-family: monospace;
  border: 1px solid rgba(255,255,255,.1);
}
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: var(--space-8); font-size: var(--text-xs);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap;
}
.footer-legal-links { display: flex; gap: var(--space-6); flex-wrap: wrap; }
.footer-legal-links a { color: rgba(255,255,255,.4); transition: var(--transition); }
.footer-legal-links a:hover { color: rgba(255,255,255,.8); }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: 0.75rem 1.75rem; font-size: var(--text-sm); font-weight: 600;
  letter-spacing: 0.01em; border-radius: var(--radius-md);
  min-height: var(--btn-min-h); transition: var(--transition); white-space: nowrap;
  text-decoration: none; cursor: pointer; border: 2px solid transparent;
}
.btn-primary   { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.btn-primary:hover { background: #222; border-color: #222; transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-accent    { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.btn-accent:hover { background: var(--color-accent-hover); border-color: var(--color-accent-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-outline   { background: transparent; color: var(--color-primary); border-color: var(--color-primary); }
.btn-outline:hover { background: var(--color-primary); color: #fff; }
.btn-outline-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.5); }
.btn-outline-light:hover { background: rgba(255,255,255,.1); border-color: #fff; }
.btn-sm { padding: 0.5rem 1.25rem; font-size: var(--text-xs); min-height: 36px; }
.btn-lg { padding: 1rem 2.5rem; font-size: var(--text-base); }

/* ── CARDS ── */
.product-card {
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden; transition: var(--transition);
}
.product-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: transparent; }
.product-thumb {
  aspect-ratio: 1/1; background: var(--color-bg-secondary);
  display: flex; align-items: center; justify-content: center;
  font-size: 64px; position: relative; overflow: hidden;
}
.product-thumb img { width: 100%; height: 100%; object-fit: cover; }
.product-badge {
  position: absolute; top: var(--space-3); left: var(--space-3);
  background: var(--color-accent); color: #fff;
  font-size: 10px; font-weight: 700; padding: 3px 8px;
  border-radius: var(--radius-sm); letter-spacing: .05em;
}
.product-badge.sale { background: var(--color-error); }
.product-info { padding: var(--space-4); }
.product-category { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-1); }
.product-name { font-size: var(--text-sm); font-weight: 600; margin-bottom: var(--space-3); line-height: 1.4; }
.product-name a { text-decoration: none; color: inherit; }
.product-name a:hover { color: var(--color-accent); }
.product-price-row { display: flex; align-items: center; justify-content: space-between; }
.add-cart-btn {
  width: 36px; height: 36px; background: var(--color-primary); color: #fff;
  border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center;
  font-size: 20px; line-height: 1; transition: var(--transition); text-decoration: none;
}
.add-cart-btn:hover, .add-cart-btn.added { background: var(--color-accent); }
.feature-card {
  text-align: center; padding: var(--space-8);
  background: var(--color-bg); border-radius: var(--radius-lg);
  border: 1px solid var(--color-border); transition: var(--transition);
}
.feature-card:hover { box-shadow: var(--shadow-md); border-color: transparent; }
.feature-icon {
  width: 64px; height: 64px; background: rgba(37,99,235,.08);
  border-radius: var(--radius-lg); margin: 0 auto var(--space-4);
  display: flex; align-items: center; justify-content: center; font-size: 28px;
}
.feature-title { font-size: var(--text-lg); font-weight: 700; margin-bottom: var(--space-2); }
.feature-desc  { color: var(--color-text-muted); font-size: var(--text-sm); line-height: 1.7; }
.testimonial-card {
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-6); transition: var(--transition);
}
.testimonial-card:hover { box-shadow: var(--shadow-md); }
.testimonial-stars  { color: #f59e0b; margin-bottom: var(--space-4); font-size: 14px; }
.testimonial-text   { color: var(--color-text-muted); font-size: var(--text-sm); line-height: 1.8; margin-bottom: var(--space-4); }
.testimonial-author { display: flex; align-items: center; gap: var(--space-3); }
.author-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--color-bg-secondary); display: flex; align-items: center; justify-content: center; font-size: 20px; }
.author-name    { font-size: var(--text-sm); font-weight: 600; }
.author-product { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ── HERO 元件 ── */
.hero-badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: rgba(37,99,235,.15); color: #93c5fd;
  border: 1px solid rgba(37,99,235,.3);
  padding: var(--space-1) var(--space-3); border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: var(--space-6);
}
.hero-badge .dot { width: 6px; height: 6px; background: #3b82f6; border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.hero h1 { color: #fff; font-size: var(--text-4xl); font-weight: 700; line-height: 1.1; letter-spacing: -.03em; margin-bottom: var(--space-6); }
.hero h1 em { font-style: normal; color: var(--color-accent); }
.hero-desc { color: rgba(255,255,255,.6); font-size: var(--text-lg); line-height: 1.7; margin-bottom: var(--space-8); }
.hero-cta  { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.hero-stats { display: flex; gap: var(--space-8); margin-top: var(--space-12); padding-top: var(--space-8); border-top: 1px solid rgba(255,255,255,.08); }
.hero-stat-num   { color: #fff; font-size: var(--text-2xl); font-weight: 700; }
.hero-stat-label { color: rgba(255,255,255,.45); font-size: var(--text-xs); margin-top: 2px; }
.hero-product-card {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-xl); padding: var(--space-8); text-align: center; color: #fff;
  max-width: 340px; width: 100%; backdrop-filter: blur(10px);
}
.hero-product-img {
  width: 200px; height: 200px; margin: 0 auto var(--space-6);
  background: rgba(255,255,255,.05); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 72px;
}
.hero-product-name  { font-size: var(--text-lg); font-weight: 600; margin-bottom: var(--space-2); }
.hero-product-price { font-size: var(--text-2xl); font-weight: 700; color: var(--color-accent); }
.hero-product-orig  { font-size: var(--text-sm); color: rgba(255,255,255,.4); text-decoration: line-through; margin-left: var(--space-2); }
.hero-product-tag { display: inline-block; background: rgba(37,99,235,.2); color: #93c5fd; font-size: var(--text-xs); padding: 3px 10px; border-radius: var(--radius-full); margin-top: var(--space-4); }

/* ── 分類卡片 ── */
.cat-earphones { background: linear-gradient(135deg, #0f172a, #1e3a5f); }
.cat-coating   { background: linear-gradient(135deg, #0f2818, #1a4a2e); }
.cat-overlay { padding: var(--space-8); background: linear-gradient(to top, rgba(0,0,0,.7), transparent); width: 100%; }
.cat-icon  { font-size: 56px; position: absolute; right: var(--space-8); top: 50%; transform: translateY(-60%); opacity: .8; }
.cat-label { color: rgba(255,255,255,.6); font-size: var(--text-xs); font-weight: 600; letter-spacing: .1em; text-transform: uppercase; margin-bottom: var(--space-1); }
.cat-title { color: #fff; font-size: var(--text-xl); font-weight: 700; margin-bottom: var(--space-3); }
.cat-link  { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--color-accent); font-size: var(--text-sm); font-weight: 600; }

/* ── 促銷橫幅 ── */
.promo-banner {
  background: linear-gradient(135deg, #0f2818, #1a4a2e, #0f2818);
  border-radius: var(--radius-xl); position: relative; overflow: hidden;
  padding: var(--space-16) var(--space-12);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-8);
}
.promo-banner::before {
  content: ''; position: absolute; top: -50px; right: -50px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(22,163,74,.15), transparent 70%);
  border-radius: 50%;
}
.promo-tag   { color: #86efac; font-size: var(--text-xs); font-weight: 600; letter-spacing: .1em; text-transform: uppercase; margin-bottom: var(--space-3); }
.promo-title { color: #fff; font-size: var(--text-3xl); font-weight: 700; margin-bottom: var(--space-4); }
.promo-desc  { color: rgba(255,255,255,.6); font-size: var(--text-base); line-height: 1.7; }
.promo-visual { font-size: 96px; flex-shrink: 0; opacity: .8; }

/* ── 表單 ── */
.form-group   { margin-bottom: var(--space-4); }
.form-label   { display: block; font-size: var(--text-sm); font-weight: 600; margin-bottom: var(--space-2); }
.form-label .required { color: var(--color-error); margin-left: 2px; }
.form-input {
  width: 100%; padding: 0.75rem 1rem;
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  font-size: var(--text-sm); font-family: inherit;
  transition: var(--transition); min-height: var(--input-min-h);
  background: var(--color-bg); color: var(--color-primary);
}
.form-input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(37,99,235,.12); }
.form-input:invalid:not(:placeholder-shown) { border-color: var(--color-error); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } }

/* ── 結帳元件 ── */
.checkout-section-title { font-size: var(--text-xl); font-weight: 700; margin-bottom: var(--space-6); padding-bottom: var(--space-4); border-bottom: 2px solid var(--color-border); }
.order-summary { background: var(--color-bg-secondary); border-radius: var(--radius-lg); padding: var(--space-6); position: sticky; top: calc(var(--header-h) + 1rem); }
.order-items { display: flex; flex-direction: column; gap: var(--space-4); margin-bottom: var(--space-4); }
.order-item { display: flex; align-items: center; gap: var(--space-3); }
.order-item-img { width: 52px; height: 52px; background: var(--color-bg); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; font-size: 24px; flex-shrink: 0; overflow: hidden; }
.order-item-img img { width: 100%; height: 100%; object-fit: cover; }
.order-item-name { font-size: var(--text-sm); font-weight: 600; flex: 1; }
.order-item-qty  { font-size: var(--text-xs); color: var(--color-text-muted); }
.order-item-price { font-size: var(--text-sm); font-weight: 700; white-space: nowrap; }
.order-totals { border-top: 1px solid var(--color-border); padding-top: var(--space-4); display: flex; flex-direction: column; gap: var(--space-3); }
.total-row { display: flex; justify-content: space-between; font-size: var(--text-sm); }
.total-row.final { font-size: var(--text-lg); font-weight: 700; padding-top: var(--space-3); border-top: 1px solid var(--color-border); }
.coupon-row { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); }
.coupon-input { flex: 1; padding: var(--space-2) var(--space-3); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); font-size: var(--text-sm); background: var(--color-bg); }
.checkout-submit {
  width: 100%; padding: 1rem; margin-top: var(--space-6);
  background: var(--color-accent); color: #fff; font-weight: 700; font-size: var(--text-base);
  border-radius: var(--radius-md); border: none; cursor: pointer; transition: var(--transition);
  min-height: 52px; display: flex; align-items: center; justify-content: center; gap: var(--space-3);
}
.checkout-submit:hover { background: var(--color-accent-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.trust-badges { display: flex; gap: var(--space-4); justify-content: center; margin-top: var(--space-4); flex-wrap: wrap; }
.trust-badge  { display: flex; align-items: center; gap: var(--space-1); font-size: var(--text-xs); color: var(--color-text-muted); }
.checkout-trust-badges { display: flex; gap: var(--space-3); justify-content: center; margin-top: var(--space-3); flex-wrap: wrap; }

/* ── 物流選擇 ── */
.logistics-options { display: flex; flex-direction: column; gap: var(--space-3); }
.logistics-option {
  display: flex; align-items: center; gap: var(--space-3);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-4); cursor: pointer; transition: var(--transition);
}
.logistics-option:hover, .logistics-option.selected { border-color: var(--color-accent); background: rgba(37,99,235,.04); }
.logistics-option input[type="radio"] { width: 18px; height: 18px; accent-color: var(--color-accent); flex-shrink: 0; }
.logistics-icon { font-size: 24px; width: 36px; text-align: center; flex-shrink: 0; }
.logistics-name { font-weight: 600; font-size: var(--text-sm); }
.logistics-fee  { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 2px; }
.logistics-free { color: var(--color-success); }
.cvs-select-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-4); font-size: var(--text-sm); font-weight: 600;
  background: var(--color-bg-secondary); border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md); cursor: pointer; transition: var(--transition);
  margin-top: var(--space-3);
}
.cvs-select-btn:hover { border-color: var(--color-accent); color: var(--color-accent); }
.cvs-store-display {
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg); border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md); font-size: var(--text-sm);
  margin-bottom: var(--space-2);
}
.cvs-store-display.has-store { border-color: var(--color-success); color: var(--color-success); font-weight: 600; }

/* ── 結帳步驟 ── */
.checkout-steps { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-muted); }
.step-item { padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); }
.step-item.active { background: var(--color-accent); color: #fff; font-weight: 600; }

/* ── 政策頁面 ── */
.policy-content { max-width: 860px; }
.policy-toc { background: var(--color-bg-secondary); padding: var(--space-6); border-radius: var(--radius-lg); margin-bottom: var(--space-12); border-left: 4px solid var(--color-accent); }
.entry-content h2 { font-size: var(--text-xl); font-weight: 700; margin-top: var(--space-12); margin-bottom: var(--space-4); padding-top: var(--space-8); border-top: 1px solid var(--color-border); }
.entry-content h2:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.entry-content h3 { font-size: var(--text-lg); font-weight: 600; margin-top: var(--space-6); margin-bottom: var(--space-3); }
.entry-content p  { margin-bottom: var(--space-4); line-height: 1.8; }
.entry-content ul, .entry-content ol { padding-left: var(--space-6); margin-bottom: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); list-style: disc; }
.entry-content ol { list-style: decimal; }
.entry-content li { line-height: 1.7; }
.entry-content a  { color: var(--color-accent); text-decoration: underline; }
.entry-content table { width: 100%; border-collapse: collapse; margin-bottom: var(--space-6); font-size: var(--text-sm); }
.entry-content th, .entry-content td { padding: var(--space-3) var(--space-4); border: 1px solid var(--color-border); text-align: left; }
.entry-content th { background: var(--color-bg-secondary); font-weight: 700; }

/* ── WooCommerce 麵包屑 ── */
.woocommerce-breadcrumb { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-2); }
.woocommerce-breadcrumb a { color: var(--color-text-muted); }
.woocommerce-breadcrumb a:hover { color: var(--color-primary); }

/* ── RWD ── */
@media (max-width: 768px) {
  .main-nav { display: none; }
  .hamburger { display: flex; }
  .hero-cta { flex-direction: column; }
  .hero-stats { gap: var(--space-6); }
  .promo-banner { flex-direction: column; padding: var(--space-8); }
  .promo-visual { display: none; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}
