/*
 Theme: MS BlackGold Child - Custom Styles (Final V15 - Absolute Flex)
========================================================
 - 核心修復：使用 flex-wrap: nowrap 強制左右併排，禁止換行
 - 解決問題：總金額掉落、外框破圖、優惠券未展開
 - 保留：Hero, Route, Slider, 商品頁設計全數保留
========================================================
*/

/* =========================
   1. 設計變數（紫金主題）
   ========================= */
:root {
    --mj-bg: #05030b;
    --mj-bg-soft: #070418;
    --mj-text: #e5e2f5;
    --mj-text-soft: rgba(229, 226, 245, 0.78);
    --mj-gold: #d1b36a;
    --mj-gold-soft: rgba(209, 179, 106, 0.78);
    --mj-card-bg: rgba(6, 4, 24, 0.96);

    --mj-radius-lg: 24px;
    --mj-radius-md: 18px;
    --mj-img-margin-left: 60px;
    
    /* 購物車專用變數 */
    --cart-gold-line: #d1b36a;
    --cart-purple-line: rgba(90, 61, 140, 0.8);
}

/* =========================
   2. 基礎排版 & 版心
   ========================= */
body { background: var(--mj-bg); color: var(--mj-text); font-family: system-ui, -apple-system, sans-serif; margin: 0; }
.mj-page-content { background: var(--mj-bg); color: var(--mj-text); }
.mj-container { width: min(1120px, 100% - 32px); margin-inline: auto; }

.mj-section, .mj-domain-section, .rw-section, .sc-section, .cr-section, .ar-section { padding: 80px 0; }
@media (max-width: 768px) { .mj-section, .mj-domain-section, .rw-section, .sc-section, .cr-section, .ar-section { padding: 56px 0; } }

/* =========================
   3. 按鈕系統
   ========================= */
.wp-block-buttons { gap: 16px !important; margin-top: 34px !important; flex-wrap: wrap; }
.wp-block-button .wp-block-button__link, .mj-btn-primary, .mj-btn-outline, .rw-btn, .sc-btn, .cr-btn, .ar-btn { 
    display: inline-flex !important; align-items: center !important; justify-content: center !important; padding: 14px 30px !important; border-radius: 999px !important; font-size: 15px !important; font-weight: 600 !important; letter-spacing: 0.08em !important; text-decoration: none !important; white-space: nowrap !important; transition: transform .25s ease, background .25s ease, box-shadow .25s ease !important; box-shadow: none !important; cursor: pointer;
}
.wp-block-button .wp-block-button__link, .wp-block-button.mj-btn-primary .wp-block-button__link, .mj-btn-primary, .rw-btn, .sc-btn, .cr-btn, .ar-btn {
    background: linear-gradient(180deg, #f1ddab 0%, #d9bd74 100%) !important; color: #1a1a1a !important; border: 1px solid transparent !important; box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 10px 26px rgba(0,0,0,.35) !important;
}
.wp-block-button .wp-block-button__link:hover, .mj-btn-primary:hover { transform: translateY(-2px) !important; filter: brightness(1.05); box-shadow: inset 0 1px 0 rgba(255,255,255,.28), 0 14px 34px rgba(0,0,0,.42) !important; }
.wp-block-button.mj-btn-ghost .wp-block-button__link, .mj-btn-outline { background: transparent !important; color: rgba(217, 189, 116, .95) !important; border: 1px solid rgba(217, 189, 116, .70) !important; }
.wp-block-button.mj-btn-ghost .wp-block-button__link:hover, .mj-btn-outline:hover { transform: translateY(-1px) !important; border-color: rgba(241, 221, 171, .95) !important; color: rgba(241, 221, 171, .98) !important; background: rgba(209, 179, 106, 0.12) !important; }
@media (max-width: 560px){ .wp-block-buttons { gap: 12px !important; } .wp-block-button, .wp-block-button .wp-block-button__link { width: 100% !important; } }

/* =========================
   4. Hero, Domain, Slider, Quickbar, Route, Effects
   ========================= */
.mj-section--hero { background: radial-gradient(circle at top left, rgba(209, 179, 106, 0.16) 0, transparent 55%), radial-gradient(circle at bottom right, rgba(91, 72, 189, 0.45) 0, transparent 55%), var(--mj-bg); background-size: cover; position: relative; overflow: hidden; }
.mj-hero { min-height: min(720px, 100vh); display: flex; align-items: center; position: relative; }
.mj-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at top, rgba(0, 0, 0, 0.55), transparent 60%); pointer-events: none; }
.mj-hero-inner { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: 64px; align-items: center; }
@media (max-width: 900px) { .mj-hero-inner { grid-template-columns: minmax(0, 1fr); gap: 32px; } }
.mj-hero-content { max-width: 560px; }
.mj-hero-eyebrow { font-size: 13px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--mj-gold-soft); margin-bottom: 16px; }
.mj-hero-title { font-size: clamp(36px, 5vw, 48px); line-height: 1.1; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 16px; color: #faf7ff; }
.mj-hero-title .mj-title-group { display: inline-block; white-space: nowrap; }
.mj-hero-lead { font-size: 15px; line-height: 1.7; color: var(--mj-text-soft); margin-bottom: 28px; }
.mj-hero-actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-bottom: 20px; }
.mj-hero-meta { display: flex; flex-wrap: wrap; gap: 16px; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(170, 167, 200, 0.9); }
.mj-hero-media { position: relative; justify-self: center; }
.mj-hero-media-frame { position: relative; border-radius: 28px; padding: 18px; background: radial-gradient(circle at top, rgba(209, 179, 106, 0.2) 0, transparent 60%), linear-gradient(145deg, #1c1233 0%, #05030b 100%); box-shadow: 0 28px 80px rgba(0, 0, 0, 0.85), 0 0 0 1px rgba(255, 255, 255, 0.02); }
.mj-hero-media-inner { border-radius: 20px; overflow: hidden; border: 1px solid rgba(209, 179, 106, 0.55); }
.mj-hero-media-inner img { display: block; width: 100%; height: auto; }
.mj-hero-tag { position: absolute; left: 18px; top: 18px; padding: 4px 12px; border-radius: 999px; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; background: rgba(5, 3, 16, 0.82); color: rgba(229, 226, 245, 0.82); border: 1px solid rgba(209, 179, 106, 0.55); }

.mj-domain-section { position: relative; background: radial-gradient(circle at top, rgba(209, 179, 106, 0.18) 0, transparent 55%), var(--mj-bg); overflow: hidden; }
.mj-domain-section::before { content: ""; position: absolute; left: 0; right: 0; top: -60px; height: 120px; background: linear-gradient(to bottom, #05030b 0%, rgba(5, 3, 11, 0.0) 80%); pointer-events: none; }
.mj-domain-inner { width: min(1120px, 100% - 32px); margin-inline: auto; text-align: center; color: #fdfaf5; }
.mj-domain-title { font-size: clamp(28px, 3.4vw, 32px); letter-spacing: 0.16em; margin-bottom: 8px; }
.mj-domain-subtitle { font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; opacity: 0.7; margin-bottom: 40px; }
.mj-domain-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 26px; }
.mj-domain-pill { display: block; min-width: 220px; max-width: 260px; padding: 20px 32px; border-radius: 999px; text-decoration: none; text-align: center; background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.18) 0, transparent 55%), rgba(8, 5, 24, 0.96); border: 1px solid rgba(209, 179, 106, 0.7); box-shadow: 0 18px 40px rgba(0, 0, 0, 0.85), 0 0 0 1px rgba(0, 0, 0, 0.45); transition: transform 0.16s ease-out, box-shadow 0.16s ease-out, border-color 0.16s ease-out, background 0.16s ease-out; color: #fdfaf5; }
.mj-domain-pill:hover { transform: translateY(-4px); box-shadow: 0 24px 55px rgba(0, 0, 0, 0.95), 0 0 0 1px rgba(209, 179, 106, 0.9); background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.25) 0, transparent 55%), rgba(14, 9, 40, 0.98); }
.mj-domain-pill-title { font-size: 16px; letter-spacing: 0.2em; margin-bottom: 4px; }
.mj-domain-pill-text { font-size: 13px; opacity: 0.8; }
@media (max-width: 600px) { .mj-domain-pill { width: 100%; max-width: 100%; padding-inline: 24px; } }



.mj-section--routes { background: var(--mj-bg); }

.mj-route-grid { 
  display: grid; 
  grid-template-columns: repeat(4, minmax(0, 1fr)); 
  gap: 40px 32px; 
  margin-top: 40px; 
}
@media (max-width: 992px) { 
  .mj-route-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 32px 24px; } 
}
@media (max-width: 600px) { 
  .mj-route-grid { grid-template-columns: 1fr; gap: 24px; } 
}

/* ✅ 關鍵修正：route card 僅在 .mj-route-grid 範圍內生效，避免污染首頁 Home Domains 的 .mj-route__grid */
.mj-route-grid .mj-route-card { 
  background: var(--mj-card-bg); 
  border-radius: 20px; 
  padding: 22px 22px 20px; 
  border: 1px solid rgba(209, 179, 106, 0.55); 
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.75), 0 0 0 1px rgba(0, 0, 0, 0.45); 
  color: #fdfaf5; 
}

.mj-route-grid .mj-route-card__icon { 
  width: 48px; 
  height: 48px; 
  margin-bottom: 16px; 
  border: none; 
  border-radius: 0; 
  position: relative; 
  background-repeat: no-repeat; 
  background-position: center; 
  background-size: 100% auto; 
}

.mj-route-grid .mj-route-card__icon::before, 
.mj-route-grid .mj-route-card__icon::after { 
  content: none !important; 
  display: none !important; 
}

.mj-route-grid .mj-route-card__icon--wood { background-image: url("assets/icons/route-wood.svg"); }
.mj-route-grid .mj-route-card__icon--silver { background-image: url("assets/icons/route-silver.svg"); }
.mj-route-grid .mj-route-card__icon--crystal { background-image: url("assets/icons/route-crystal.svg"); }
.mj-route-grid .mj-route-card__icon--aroma { background-image: url("assets/icons/route-aroma.svg"); }

.mj-route-grid .mj-route-card__subtitle { 
  color: var(--mj-gold) !important; 
  font-weight: 500; 
}

.mj-route-grid .mj-route-card--link { 
  display: block; 
  color: inherit; 
  text-decoration: none; 
}

.mj-route-grid .mj-route-card--link:hover { 
  transform: translateY(-4px); 
  border-color: rgba(209, 179, 106, 0.75); 
  transition: all 0.25s ease-out; 
}


.rw-hero, .sc-hero, .cr-hero, .ar-hero { padding: 120px 20px 80px; text-align: center; }
.rw-hero { background: radial-gradient(circle at center, rgba(209,179,106,0.25) 0%, rgba(8,7,21,1) 55%); }
.sc-hero { background: radial-gradient(circle at center, rgba(209,179,106,0.22) 0%, #080716 55%); }
.cr-hero { background: radial-gradient(circle at center, rgba(152, 201, 255, 0.20) 0%, #080716 55%); }
.ar-hero { background: radial-gradient(circle at center, rgba(165, 140, 255, 0.32) 0%, #080716 60%); }
.rw-symbol, .sc-symbol, .cr-symbol, .ar-symbol { height: auto; margin-bottom: 24px; filter: drop-shadow(0 0 12px rgba(209,179,106,0.55)); animation: mj-glow-pulse 3s infinite ease-in-out; }
.rw-symbol { width: 86px; } .sc-symbol, .ar-symbol { width: 78px; } .cr-symbol { width: 80px; }
@keyframes mj-glow-pulse { 0% { filter: drop-shadow(0 0 8px rgba(209,179,106,0.3)); } 50% { filter: drop-shadow(0 0 16px rgba(209,179,106,0.7)); } 100% { filter: drop-shadow(0 0 8px rgba(209,179,106,0.3)); } }
.rw-title, .sc-title, .cr-title, .ar-title { font-size: 40px; color: #fff; line-height: 1.4; margin-bottom: 12px; letter-spacing: 0.08em; }
.rw-sub, .sc-sub, .cr-sub, .ar-sub { font-size: 19px; color: #d1b36a; opacity: 0.9; }
.rw-container, .sc-container, .cr-container, .ar-container { max-width: 880px; margin: auto; }
.rw-heading, .sc-heading, .cr-heading, .ar-heading { color: #d1b36a; font-size: 28px; margin-bottom: 24px; }
.rw-text, .sc-text, .cr-text, .ar-text { font-size: 18px; line-height: 1.8; color: #eee; opacity: 0.9; }
.rw-list, .sc-list, .cr-list, .ar-list { margin-top: 20px; margin-left: 0; padding-left: 20px; color: #fff; line-height: 2; font-size: 16px; }
.rw-list li strong, .sc-list li strong, .cr-list li strong, .ar-list li strong { color: #d1b36a; }
.sc-cta, .cr-cta, .ar-cta { text-align: center; }
@media (max-width: 768px) { .rw-title, .sc-title, .cr-title, .ar-title { font-size: 30px; } .rw-heading, .sc-heading, .cr-heading, .ar-heading { font-size: 24px; } .rw-section, .sc-section, .cr-section, .ar-section { padding: 60px 16px; } }

.floating-line { position: fixed; right: 32px; bottom: 32px; z-index: 9999; }
.floating-line a { display: block; width: 72px; height: 72px; border-radius: 50%; background-color: #06C755; background-image: url('https://mojay.tw/wp-content/uploads/2025/line-icon.png'); background-position: center; background-repeat: no-repeat; background-size: 60%; border: 3px solid #d1b36a; box-shadow: 0 0 12px rgba(209,179,106,0.55), 0 6px 18px rgba(0,0,0,0.45); transition: transform .28s ease, box-shadow .28s ease; }
.floating-line a:hover { transform: scale(1.10); box-shadow: 0 0 18px rgba(209,179,106,0.85), 0 10px 22px rgba(0,0,0,0.55); }
@media (max-width: 768px) { .floating-line { bottom: 120px !important; } .floating-line a { width: 58px; height: 58px; } }

@media (min-width: 1025px) {
    .site-header--modern .site-header__logo-inner img { max-height: 220px; transition: max-height 0.25s ease, transform 0.25s ease; transform-origin: center top; }
    .site-header--modern.is-header-shrink .site-header__logo-inner img { max-height: 120px; transform: translateY(-6px); }
}

/* =========================================================
   12. WooCommerce 單一商品頁面優化 (隱形磚頭版)
   ========================================================= */
.single-product .woocommerce-product-gallery { max-width: 480px !important; width: 100%; margin-left: var(--mj-img-margin-left) !important; position: relative; border-radius: 16px !important; overflow: visible !important; display: flex !important; flex-direction: column !important; }
.single-product .woocommerce-product-gallery .flex-viewport::after { content: ""; display: block !important; width: 100%; height: 30px !important; background: transparent !important; }
.single-product .woocommerce-product-gallery .flex-viewport { margin-bottom: 0 !important; box-shadow: 0 4px 12px rgba(0,0,0,0.05); border-radius: 16px !important; overflow: hidden; }
.single-product .woocommerce-product-gallery img { border-radius: 16px !important; }
.single-product .woocommerce-product-gallery .onsale { position: absolute !important; left: calc(var(--mj-img-margin-left) - 10px) !important; top: -10px !important; z-index: 999; margin: 0 !important; border-radius: 100% !important; padding: 0.8em !important; line-height: 1 !important; }
.single-product .woocommerce div.product form.cart { display: flex !important; align-items: center; gap: 12px; margin-bottom: 20px; }
.single-product .woocommerce div.product form.cart .quantity .input-text.qty { height: 46px !important; border-radius: 8px !important; font-size: 20px !important; }
.single-product .woocommerce div.product form.cart .single_add_to_cart_button { height: 46px !important; border-radius: 8px !important; padding: 0 32px !important; }
@media (max-width: 768px) { .single-product .woocommerce-product-gallery { margin-left: 0 !important; max-width: 100% !important; } .single-product .woocommerce-product-gallery .onsale { left: -8px !important; } .single-product .woocommerce-product-gallery .flex-viewport::after { height: 20px !important; } }

/* =========================================================
   13. WooCommerce Cart 購物車頁面 (Final V15 - Absolute Flex)
   核心修正：強制左右併排、優惠券核彈展開、外框無破圖
   ========================================================= */

/* A. 頁面版心：限制在 1280px */
body.woocommerce-cart .mj-container,
body.woocommerce-cart .entry-content {
    width: 100% !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

/* B. 整體佈局 (Flexbox 強制不換行) */
/* 鎖定 wrapper，強制橫向排列 */
body.woocommerce-cart .wp-block-woocommerce-cart,
body.woocommerce-cart .wc-block-cart,
body.woocommerce-cart .wc-block-cart-wrapper {
    display: flex !important;
    flex-wrap: nowrap !important; /* [關鍵] 禁止換行，解決掉落問題 */
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 40px !important;
    width: 100% !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
}

/* C. 左側：商品列表 (自動填滿，防爆) */
body.woocommerce-cart .wc-block-cart__main {
    flex: 1 1 auto !important; /* 自動延展 */
    width: 100% !important;
    min-width: 0 !important; /* [關鍵] 防止被內容撐爆 */
    max-width: none !important;
    margin-right: 0 !important;
    border: none !important;
    padding: 0 !important;
}

/* D. 右側：總計與結帳 (固定寬度) */
body.woocommerce-cart .wc-block-cart__sidebar {
    width: 380px !important;
    flex: 0 0 380px !important; /* 固定不縮放 */
    position: sticky !important;
    top: 100px !important;
    
    border: 1px solid var(--cart-purple-line) !important;
    border-radius: 12px !important;
    padding: 24px !important;
    background: #0d0a15 !important;
}

/* E. 商品卡片樣式 (表格分離術 - 完美外框) */
body.woocommerce-cart table.wc-block-cart-items {
    border-collapse: separate !important;
    border-spacing: 0 20px !important; /* 卡片垂直間距 */
    margin-top: -20px !important; /* 修正首項間距 */
}

/* 讓 TR 透明 */
body.woocommerce-cart tr.wc-block-cart-items__row {
    background: transparent !important;
    border: none !important;
}

/* 使用 TD 畫出金色上下邊框 */
body.woocommerce-cart tr.wc-block-cart-items__row td {
    background: rgba(255,255,255,0.02) !important;
    border-top: 1px solid var(--cart-gold-line) !important;
    border-bottom: 1px solid var(--cart-gold-line) !important;
    padding-top: 20px !important;
    padding-bottom: 20px !important;
    vertical-align: middle !important;
}

/* 頭尾圓角封口 (左/右) */
body.woocommerce-cart tr.wc-block-cart-items__row td:first-child {
    border-left: 1px solid var(--cart-gold-line) !important;
    border-top-left-radius: 12px !important;
    border-bottom-left-radius: 12px !important;
    padding-left: 20px !important;
}
body.woocommerce-cart tr.wc-block-cart-items__row td:last-child {
    border-right: 1px solid var(--cart-gold-line) !important;
    border-top-right-radius: 12px !important;
    border-bottom-right-radius: 12px !important;
    padding-right: 20px !important;
}

/* F. 圖片與內容修正 */
body.woocommerce-cart .wc-block-cart-item__image { width: 100px !important; max-width: 100px !important; }
body.woocommerce-cart .wc-block-cart-item__image img { width: 100px !important; height: 100px !important; object-fit: cover !important; border-radius: 8px !important; }

/* G. 優惠券 (核彈級展開 + 黑字) */
/* 隱藏切換按鈕 */
body.woocommerce-cart .wc-block-components-totals-coupon-link,
body.woocommerce-cart .wc-block-components-panel__button { 
    display: none !important; 
}

/* 強制顯示內容面板 (針對所有可能的層級) */
body.woocommerce-cart .wc-block-components-totals-coupon .wc-block-components-panel__content,
body.woocommerce-cart .wc-block-cart__sidebar .wc-block-components-panel__content {
    display: block !important;
    height: auto !important;
    max-height: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    overflow: visible !important;
}

/* 輸入框樣式 */
body.woocommerce-cart .wc-block-components-totals-coupon input[type="text"] {
    color: #000000 !important;       /* 黑字 */
    background-color: #ffffff !important; /* 白底 */
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    padding: 10px !important;
    min-height: 40px !important;
}

/* H. 手機版響應式 (改回單欄堆疊) */
@media (max-width: 1024px) {
    body.woocommerce-cart .wp-block-woocommerce-cart,
    body.woocommerce-cart .wc-block-cart,
    body.woocommerce-cart .wc-block-cart-wrapper {
        flex-direction: column !important; /* 手機版垂直排列 */
        gap: 30px !important;
    }
    
    body.woocommerce-cart .wc-block-cart__main { 
        width: 100% !important; 
        min-width: 0 !important; 
    }
    
    body.woocommerce-cart .wc-block-cart__sidebar { 
        width: 100% !important; 
        flex: none !important; 
        position: static !important; 
    }
}

/* =========================================================
   Footer Ritual About（頁面最下方資訊區塊）
   ========================================================= */

.mj-footer-ritual{
  position: relative;
  padding: clamp(56px, 5vw, 88px) 0;
  background: #05030b;
  overflow: hidden;
}

.mj-footer-ritual__bg{
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(70% 60% at 15% 15%, rgba(209,179,106,.16) 0%, rgba(209,179,106,0) 60%),
    radial-gradient(60% 55% at 85% 20%, rgba(120,82,230,.20) 0%, rgba(120,82,230,0) 62%),
    radial-gradient(60% 60% at 70% 85%, rgba(40,170,255,.10) 0%, rgba(40,170,255,0) 60%);
  pointer-events:none;
  filter: blur(0px);
}

.mj-footer-ritual__inner{
  position: relative;
  z-index: 1;
}

.mj-footer-ritual__head{
  margin-bottom: 22px;
}

.mj-footer-ritual__eyebrow{
  margin: 0 0 10px 0;
  font-size: 12px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(209,179,106,.78);
}

.mj-footer-ritual__title{
  margin: 0;
  font-size: clamp(24px, 2.6vw, 36px);
  line-height: 1.2;
  letter-spacing: .06em;
  color: #f5f2ff;
}

.mj-footer-ritual__title-muted{
  display: inline-block;
  margin-left: 10px;
  color: rgba(234,241,255,.68);
  font-weight: 600;
}

.mj-footer-ritual__grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  gap: clamp(14px, 2vw, 18px);
  margin-top: 18px;
}

@media (max-width: 900px){
  .mj-footer-ritual__grid{ grid-template-columns: 1fr; }
}

.mj-footer-ritual__panel{
  background:
    radial-gradient(120% 140% at 40% 0%,
      rgba(104,78,190,.16) 0%,
      rgba(8,10,18,.92) 55%,
      rgba(6,7,12,.96) 100%);
  border: 1px solid rgba(209,179,106,.42);
  border-radius: 18px;
  padding: 22px 20px;
  box-shadow: 0 14px 40px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.04);
  position: relative;
  overflow: hidden;
}

.mj-footer-ritual__panel::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(60% 60% at 20% 10%,
    rgba(209,179,106,.14) 0%,
    rgba(209,179,106,0) 60%);
  pointer-events:none;
}

.mj-footer-ritual__panel-title{
  font-size: 12px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(234,241,255,.72);
  margin-bottom: 14px;
}

.mj-footer-ritual__list{
  list-style: none;
  padding: 0;
  margin: 0 0 18px 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
}

@media (max-width: 560px){
  .mj-footer-ritual__list{ grid-template-columns: 1fr; }
}

.mj-footer-ritual__list li{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.04);
}

.mj-footer-ritual__list strong{
  color: rgba(209,179,106,.95);
  letter-spacing: .08em;
  font-weight: 700;
}

.mj-footer-ritual__list span{
  color: rgba(234,241,255,.72);
  font-size: 13px;
  letter-spacing: .06em;
  white-space: nowrap;
}

.mj-footer-ritual__micro{
  color: rgba(234,241,255,.70);
  line-height: 1.9;
  font-size: 14px;
  padding-top: 10px;
  border-top: 1px solid rgba(209,179,106,.22);
}

.mj-footer-ritual__poem{
  margin-top: 2px;
}

.mj-footer-ritual__poem p{
  margin: 0 0 10px 0;
  color: rgba(234,241,255,.74);
  font-size: 15px;
  line-height: 1.9;
  letter-spacing: .02em;
}

.mj-footer-ritual__poem-gap{
  margin-bottom: 18px !important;
  color: rgba(234,241,255,.86) !important;
}

.mj-footer-ritual__call{
  margin-top: 14px;
  font-weight: 700;
  letter-spacing: .10em;
}

.mj-footer-ritual__call--gold{
  color: rgba(209,179,106,.98) !important;
  font-size: 18px !important;
}

.mj-footer-ritual__cta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.mj-footer-ritual__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  letter-spacing: .12em;
  font-size: 12px;
  text-transform: uppercase;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease, border-color .18s ease;
  white-space: nowrap;
}

.mj-footer-ritual__btn--ghost{
  color: rgba(209,179,106,.92);
  border: 1px solid rgba(209,179,106,.55);
  background: rgba(209,179,106,.08);
}

.mj-footer-ritual__btn--gold{
  color: #1a1a1a;
  background: linear-gradient(180deg, #f1ddab 0%, #d9bd74 100%);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.20), 0 14px 30px rgba(0,0,0,.50);
}

.mj-footer-ritual__btn:hover{
  transform: translateY(-2px);
  filter: brightness(1.03);
}

.mj-footer-ritual__divider{
  height: 1px;
  background: linear-gradient(90deg, rgba(209,179,106,0), rgba(209,179,106,.45), rgba(209,179,106,0));
  margin: 22px 0 14px;
  opacity: .8;
}

.mj-footer-ritual__note{
  color: rgba(234,241,255,.64);
  font-size: 13px;
  letter-spacing: .04em;
  line-height: 1.9;
  max-width: 920px;
}
/* Footer Ritual: 左欄服務項目加符文 + 右欄 line 結構 */
.mj-footer-ritual__list--runes li{
  display: grid;
  grid-template-columns: 22px auto 1fr;
  align-items: center;
  column-gap: 10px;
}

.mj-footer-ritual__rune{
  width: 20px;
  height: 20px;
  display: block;
  opacity: .95;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.45));
}

.mj-footer-ritual__service{
  color: rgba(209,179,106,.95);
  letter-spacing: .08em;
  font-weight: 800;
}

.mj-footer-ritual__desc{
  color: rgba(234,241,255,.72);
  font-size: 13px;
  letter-spacing: .06em;
  justify-self: end;
  white-space: nowrap;
}

.mj-footer-ritual__poem--lines .mj-footer-ritual__line{
  margin: 0 0 10px 0;
  color: rgba(234,241,255,.74);
  font-size: 15px;
  line-height: 1.9;
  letter-spacing: .02em;
}

.mj-footer-ritual__poem--lines .mj-footer-ritual__line--gap{
  margin-bottom: 18px;
  color: rgba(234,241,255,.86);
}

.mj-footer-ritual__poem--lines .mj-footer-ritual__line--call{
  margin-top: 14px;
  font-weight: 800;
  letter-spacing: .10em;
}

.mj-footer-ritual__poem--lines .mj-footer-ritual__call--gold{
  color: rgba(209,179,106,.98);
}
/* Footer Ritual: 右欄「左句 - 右句」排版（不改其他區塊） */
.mj-footer-ritual__poem--pairs .mj-footer-ritual__pair{
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin: 0 0 14px 0;
  color: rgba(234,241,255,.74);
  font-size: 15px;
  line-height: 1.9;
  letter-spacing: .02em;
}

.mj-footer-ritual__pair-left{
  color: rgba(234,241,255,.82);
  font-weight: 700;
  white-space: nowrap;
}

.mj-footer-ritual__pair-dash{
  opacity: .55;
  transform: translateY(-1px);
}

.mj-footer-ritual__pair-right{
  color: rgba(234,241,255,.74);
}

.mj-footer-ritual__pair--call{
  margin-top: 16px;
  font-weight: 800;
  letter-spacing: .10em;
}

.mj-footer-ritual__pair--call .mj-footer-ritual__pair-left{
  font-weight: 800;
  opacity: .9;
}

.mj-footer-ritual__pair-right--gold{
  color: rgba(209,179,106,.98);
}


/* MJ - Email helper (tight + visible) */
.mj-email-help{
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.mj-email-help__icon{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  opacity: .95;
  border: 1px solid rgba(255,255,255,.22);
}

.mj-email-help__text{
  font-size: 13px;
  line-height: 1.55;
  opacity: .92;
}

body.woocommerce.archive ul.products::before,
body.woocommerce.archive ul.products::after {
    content: none !important;
    display: none !important;
}

/* =========================================================
   FIX (Home / Mobile): Left edge vertical seam caused by .mj-container/.mj-hero
   Strategy:
   1) Make hero container full-bleed (100vw) to remove container padding seam
   2) Force background pseudo layer to overscan beyond viewport
   3) Add a tiny left mask as final insurance (iOS subpixel seam)
   ========================================================= */
@media (max-width: 768px){

  /* 1) 讓 hero 的 container 變成滿版，避免 max-width / padding 造成「左邊切線」 */
  body.home section#hero .mj-container{
    width: 100vw !important;
    max-width: 100vw !important;
    padding-left: 0 !important;
    padding-right: 0 !important;

    /* 把 container 放到視窗正中，避免 100vw + padding 算錯出縫 */
    position: relative !important;
    left: 50% !important;
    transform: translateX(-50%) translateZ(0) !important;
  }

  /* 2) hero 本體也滿版，並且裁切多出部分（讓 overscan 乾淨） */
  body.home section#hero .mj-hero{
    width: 100vw !important;
    overflow: hidden !important;
    transform: translateZ(0) !important;
    backface-visibility: hidden !important;
    -webkit-backface-visibility: hidden !important;
  }

  /* 3) 你的背景主要在 .mj-hero::before，直接讓它超出左側避免露底 */
  body.home section#hero .mj-hero::before{
    left: -10vw !important;
    width: 140vw !important;
    right: auto !important;
    transform: none !important;
  }

  /* 4) 最終保險：吃掉最左邊 2~3px 的「亮縫」 */
  body.home section#hero .mj-hero::after{
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 28px !important;
    height: 100% !important;
    pointer-events: none !important;
    z-index: 5 !important;
    background: linear-gradient(to right,
      rgba(0,0,0,.55) 0,
      rgba(0,0,0,0) 100%);
  }

  /* 5) 文字層要在遮罩之上 */
  body.home section#hero .mj-hero-inner,
  body.home section#hero .mj-hero-content,
  body.home section#hero .mj-hero-titlewrap{
    position: relative !important;
    z-index: 10 !important;
  }
}
