/**
 * Ketalink - Frontend Styles
 * Version: 1.2.0
 */

/* ============================================
   CSS Variables
   ============================================ */
:root {
    --ketalink-amazon: #ff9900;
    --ketalink-rakuten: #bf0000;
    --ketalink-yahoo: #4c8bf5;
    --ketalink-mercari: #ff0211;
    --ketalink-radius: 8px;
    --ketalink-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    --ketalink-font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Noto Sans JP", sans-serif;
    --ketalink-bg: #fff;
    --ketalink-border: #e2e8f0;
    --ketalink-text: #333;
    --ketalink-text-heading: #1a202c;
    --ketalink-text-sub: #666;
    --ketalink-text-muted: #999;
}

/* ============================================
   Base
   ============================================ */
.ketalink-box {
    max-width: 680px;
    margin: 1.5em auto;
    padding: 0;
    border: 1px solid var(--ketalink-border);
    border-radius: var(--ketalink-radius);
    background: var(--ketalink-bg);
    box-shadow: var(--ketalink-shadow);
    font-family: var(--ketalink-font);
    font-size: 14px;
    line-height: 1.6;
    color: var(--ketalink-text);
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
}
.ketalink-box *, .ketalink-box *::before, .ketalink-box *::after { box-sizing: border-box; }

/* ⑨ 入場アニメーション */
.ketalink-animate { opacity: 0; transform: translateY(24px); transition: opacity 0.5s ease-out, transform 0.5s ease-out; }
.ketalink-animate.is-visible { opacity: 1; transform: translateY(0); }

/* ============================================
   Standard Template
   ============================================ */
.ketalink-tpl-standard .ketalink-inner { display: flex; gap: 16px; padding: 20px; align-items: flex-start; }
.ketalink-tpl-standard .ketalink-image { flex-shrink: 0; width: 160px; }
.ketalink-tpl-standard .ketalink-image img { width: 100%; height: auto; border-radius: 6px; display: block; object-fit: contain; max-height: 160px; }
.ketalink-tpl-standard .ketalink-content { flex: 1; min-width: 0; }

.ketalink-title { font-size: 16px; font-weight: 700; color: var(--ketalink-text-heading); margin: 0 0 6px; line-height: 1.4; }
.ketalink-subtitle { font-size: 12px; color: var(--ketalink-text-sub); margin: -2px 0 6px; line-height: 1.4; }
.ketalink-review-link { font-size: 12px; color: var(--ketalink-text-sub); text-decoration: none; display: inline-block; margin-bottom: 6px; }
.ketalink-review-link:hover { color: var(--ketalink-amazon); text-decoration: underline; }
.ketalink-desc { font-size: 13px; color: var(--ketalink-text-sub); margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.ketalink-price-area { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; line-height: 1.3; }
.ketalink-discount { display: inline-block; background: #cc0c39; color: #fff; font-size: 13px; font-weight: 700; padding: 2px 7px; border-radius: 4px; letter-spacing: -0.02em; }
.ketalink-sale-price { font-size: 20px; font-weight: 800; color: #cc0c39; letter-spacing: -0.02em; }
.ketalink-original-price { font-size: 13px; color: #86868b; text-decoration: line-through; }
.ketalink-current-price { font-size: 17px; font-weight: 700; color: var(--ketalink-text-heading); }
.ketalink-price-note { display: block; width: 100%; font-size: 11px; color: var(--ketalink-text-muted); margin-top: 2px; }

/* ⑤ 価格変動インジケーター */
.ketalink-price-change { display: inline-block; font-size: 12px; font-weight: 700; padding: 2px 8px; border-radius: 4px; line-height: 1.4; animation: ketalink-price-pulse 2s ease-in-out infinite; }
.ketalink-price-down { color: #fff; background: linear-gradient(135deg, #0c8a0c, #10b010); }
.ketalink-price-up { color: #cc0c39; background: rgba(204,12,57,0.1); animation: none; }
@keyframes ketalink-price-pulse { 0%,100% { opacity: 1; } 50% { opacity: .75; } }

/* ③ クーポンコード（別セクション表示） */
.ketalink-coupon { margin-bottom: 12px; }
.ketalink-coupon-note { display: block; font-size: 12px; color: var(--ketalink-text-sub); margin-bottom: 4px; }
.ketalink-coupon-code { display: inline-flex; align-items: center; gap: 6px; background: #fef9e7; border: 1px dashed #e6c200; border-radius: 6px; padding: 6px 10px; font-size: 13px; max-width: 100%; }
.ketalink-coupon-label { font-weight: 600; color: #b08c00; white-space: nowrap; }
.ketalink-coupon-value { font-weight: 700; color: #1a202c; letter-spacing: 0.06em; font-size: 14px; background: none; padding: 0; }
.ketalink-coupon-copy { display: inline-block; background: #ff9900; color: #fff; border: none; border-radius: 4px; padding: 3px 10px; font-size: 11px; font-weight: 700; cursor: pointer; transition: background 0.2s; white-space: nowrap; font-family: inherit; line-height: 1.4; }
.ketalink-coupon-copy:hover { background: #e08800; }
.ketalink-coupon-copy.is-copied { background: #0c8a0c; }

/* ③-b クーポンボタン（ショップボタンと同列配置） */
.ketalink-btn-coupon { position: relative; border: 2px dashed rgba(255,255,255,0.5) !important; }
.ketalink-btn-coupon .ketalink-btn-coupon-icon { margin-right: 4px; font-size: 15px; }
.ketalink-btn-coupon .ketalink-btn-coupon-label { display: inline; }
.ketalink-btn-coupon.is-copied { background-color: #0c8a0c !important; border-style: solid !important; border-color: rgba(255,255,255,0.4) !important; }
.ketalink-btn-coupon.is-copied .ketalink-btn-coupon-icon { display: none; }
.ketalink-btn-coupon.is-copied .ketalink-btn-coupon-label { display: none; }
.ketalink-btn-coupon.is-copied::after { content: 'コピー済み ✓'; font-size: 13px; font-weight: 700; }

/* ============================================
   セール表示
   ============================================ */
.ketalink-sale { background: linear-gradient(135deg, #cc0c39, #e8244a); color: #fff; text-align: center; padding: 7px 16px; font-size: 13px; font-weight: 700; letter-spacing: 0.04em; position: relative; overflow: hidden; }
.ketalink-sale::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.15) 50%, transparent 100%); animation: ketalink-shine 2.5s ease-in-out infinite; }
@keyframes ketalink-shine { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }
.ketalink-box.is-on-sale { border-color: #cc0c39; border-width: 2px; box-shadow: 0 2px 12px rgba(204,12,57,0.12); }
.ketalink-btn-sale-wrap { position: relative; }
.ketalink-btn-sale-badge { position: absolute; top: -8px; right: -6px; background: #cc0c39; color: #fff; font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 3px; z-index: 1; }

/* ② 最安値バッジ */
.ketalink-btn-cheapest-wrap { position: relative; }
.ketalink-btn-cheapest-badge { position: absolute; top: -8px; left: -6px; background: #0c8a0c; color: #fff; font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 3px; z-index: 1; }

/* ============================================
   Buttons
   ============================================ */
.ketalink-buttons { display: flex; flex-direction: column; gap: 8px; }
.ketalink-btn-wrap { display: flex; flex-direction: column; }

/* ── ボタン基本（テーマ上書き完全防止） ── */
.ketalink-box .ketalink-buttons a.ketalink-btn,
.ketalink-box .ketalink-buttons a.ketalink-btn:link,
.ketalink-box .ketalink-buttons a.ketalink-btn:visited,
.ketalink-box .ketalink-buttons a.ketalink-btn:hover,
.ketalink-box .ketalink-buttons a.ketalink-btn:active,
a.ketalink-btn,
a.ketalink-btn:link,
a.ketalink-btn:visited,
a.ketalink-btn:hover {
    display: block !important;
    text-align: center !important;
    padding: 10px 16px !important;
    border-radius: 6px !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s !important;
    cursor: pointer !important;
    border: none !important;
    line-height: 1.4 !important;
    position: relative !important;
    overflow: hidden !important;
    background-image: none !important;
    box-shadow: 0 2px 4px rgba(0,0,0,.1) !important;
    letter-spacing: normal !important;
    text-indent: 0 !important;
    text-transform: none !important;
}
.ketalink-box a.ketalink-btn:hover { opacity: 1 !important; transform: translateY(-2px) !important; box-shadow: 0 4px 12px rgba(0,0,0,.18) !important; }
.ketalink-box a.ketalink-btn:active { transform: scale(0.98) translateY(0) !important; box-shadow: 0 1px 3px rgba(0,0,0,.1) !important; }

/* ショップアイコン（SVG inline） */
.ketalink-btn-icon { display: inline-block; width: 16px; height: 16px; margin-right: 6px; vertical-align: -2px; fill: currentColor; flex-shrink: 0; }

/* ボタンテキスト */
.ketalink-btn .ketalink-btn-text {
    color: #fff !important;
    display: inline !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* ショップ別 */
.ketalink-box a.ketalink-btn-amazon  { background-color: #ff9900 !important; }
.ketalink-box a.ketalink-btn-rakuten { background-color: #bf0000 !important; }
.ketalink-box a.ketalink-btn-yahoo   { background-color: #4c8bf5 !important; }
.ketalink-box a.ketalink-btn-mercari { background-color: #ff0211 !important; }

/* Outline */
.ketalink-box a.ketalink-btn.ketalink-btn-outline { background: transparent !important; box-shadow: none !important; }
.ketalink-box a.ketalink-btn.ketalink-btn-outline:hover { opacity: 1 !important; background: rgba(0,0,0,.04) !important; box-shadow: none !important; }
.ketalink-box a.ketalink-btn.ketalink-btn-outline .ketalink-btn-text { color: inherit !important; }

/* ① マイクロコピー */
.ketalink-microcopy { display: block; text-align: center; font-size: 11px; color: var(--ketalink-text-sub); margin-top: 2px; line-height: 1.3; }

/* ⑥ リップルエフェクト */
.ketalink-ripple .ketalink-ripple-wave { position: absolute; border-radius: 50%; background: rgba(255,255,255,0.4); transform: scale(0); animation: ketalink-ripple-anim 0.6s ease-out; pointer-events: none; }
.ketalink-btn-outline .ketalink-ripple-wave { background: rgba(0,0,0,0.08); }
@keyframes ketalink-ripple-anim { to { transform: scale(4); opacity: 0; } }

/* Out of Stock */
.ketalink-btn-oos { background-color: #b0b8c1 !important; cursor: not-allowed; position: relative; opacity: 0.75; }
.ketalink-btn-oos:hover { opacity: 0.75; transform: none; }
.ketalink-btn-oos::before { content: ""; }

/* Credit */
.ketalink-credit { margin-top: 10px; text-align: right; }
.ketalink-credit small { font-size: 11px; color: #aaa; }
.ketalink-credit a { color: #aaa; text-decoration: none; }
.ketalink-credit a:hover { color: #888; text-decoration: underline; }

/* ============================================
   Other Templates
   ============================================ */
.ketalink-tpl-compact .ketalink-inner { display: flex; gap: 12px; padding: 14px 16px; align-items: center; }
.ketalink-tpl-compact .ketalink-image { flex-shrink: 0; width: 64px; }
.ketalink-tpl-compact .ketalink-image img { width: 64px; height: 64px; border-radius: 6px; object-fit: contain; display: block; }
.ketalink-tpl-compact .ketalink-title { font-size: 14px; margin-bottom: 4px; }
.ketalink-tpl-compact .ketalink-desc { display: none; }
.ketalink-tpl-compact .ketalink-buttons { flex-direction: row; flex-wrap: wrap; }
.ketalink-tpl-compact .ketalink-btn { padding: 6px 14px; font-size: 12px; border-radius: 4px; }

.ketalink-tpl-rich .ketalink-inner { display: flex; flex-direction: column; padding: 0; }
.ketalink-tpl-rich .ketalink-image { width: 100%; }
.ketalink-tpl-rich .ketalink-image img { width: 100%; height: 240px; object-fit: contain; display: block; background: #f8f9fa; padding: 16px; }
.ketalink-tpl-rich .ketalink-content { padding: 20px; }

.ketalink-tpl-horizontal .ketalink-inner { display: flex; gap: 16px; padding: 20px; align-items: center; }
.ketalink-tpl-horizontal .ketalink-image { flex-shrink: 0; width: 100px; }
.ketalink-tpl-horizontal .ketalink-image img { width: 100px; height: 100px; border-radius: 6px; object-fit: contain; display: block; }
.ketalink-tpl-horizontal .ketalink-desc { display: none; }
.ketalink-tpl-horizontal .ketalink-buttons { flex-direction: row; flex-wrap: wrap; }
.ketalink-tpl-horizontal .ketalink-btn { flex: 1; min-width: 120px; }

.ketalink-tpl-vertical .ketalink-inner { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 24px; }
.ketalink-tpl-vertical .ketalink-image { width: 200px; margin-bottom: 12px; }
.ketalink-tpl-vertical .ketalink-image img { width: 200px; height: 200px; border-radius: 8px; object-fit: contain; display: block; }
.ketalink-tpl-vertical .ketalink-buttons { width: 100%; max-width: 320px; }

/* ④ フローティングCTA */
.ketalink-floating-cta { position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999; background: var(--ketalink-bg); border-top: 1px solid var(--ketalink-border); box-shadow: 0 -4px 16px rgba(0,0,0,0.1); padding: 10px 16px; display: flex; align-items: center; gap: 12px; transform: translateY(100%); transition: transform 0.35s ease-out; font-family: var(--ketalink-font); }
.ketalink-floating-cta.is-shown { transform: translateY(0); }
.ketalink-floating-cta-info { flex: 1; min-width: 0; }
.ketalink-floating-cta-price { font-size: 16px; font-weight: 800; color: var(--ketalink-text-heading); }
.ketalink-floating-cta-btn { display: inline-block; padding: 10px 24px; border-radius: 50px; color: #fff !important; font-size: 14px; font-weight: 700; text-decoration: none !important; white-space: nowrap; transition: opacity 0.2s; flex-shrink: 0; }
.ketalink-floating-cta-btn:hover { opacity: 0.85; text-decoration: none !important; color: #fff !important; }
.ketalink-floating-cta-close { background: none; border: none; font-size: 20px; color: var(--ketalink-text-muted); cursor: pointer; padding: 0 4px; line-height: 1; flex-shrink: 0; }

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 560px) {
    .ketalink-title { font-size: 15px; }
    .ketalink-desc { font-size: 12px; }
    .ketalink-btn { padding: 10px 12px; font-size: 13px; }
    .ketalink-tpl-standard .ketalink-inner { flex-direction: column; padding: 16px; gap: 12px; }
    .ketalink-tpl-standard .ketalink-image { width: 100%; display: flex; justify-content: center; }
    .ketalink-tpl-standard .ketalink-image img { width: 120px; height: 120px; max-height: 120px; }
    .ketalink-tpl-standard .ketalink-title, .ketalink-tpl-standard .ketalink-desc, .ketalink-tpl-standard .ketalink-price { text-align: center; }
    .ketalink-tpl-compact .ketalink-inner { flex-direction: column; align-items: stretch; gap: 8px; }
    .ketalink-tpl-compact .ketalink-image { width: 100%; display: flex; justify-content: center; }
    .ketalink-tpl-compact .ketalink-image img { width: 48px; height: 48px; }
    .ketalink-tpl-compact .ketalink-title, .ketalink-tpl-compact .ketalink-price { text-align: center; }
    .ketalink-tpl-compact .ketalink-buttons { justify-content: center; }
    .ketalink-tpl-rich .ketalink-image img { height: 160px; }
    .ketalink-tpl-rich .ketalink-content { padding: 16px; }
    .ketalink-tpl-horizontal .ketalink-inner { flex-direction: column; padding: 16px; }
    .ketalink-tpl-horizontal .ketalink-image { width: 100%; display: flex; justify-content: center; }
    .ketalink-tpl-horizontal .ketalink-image img { width: 80px; height: 80px; }
    .ketalink-tpl-horizontal .ketalink-title, .ketalink-tpl-horizontal .ketalink-price { text-align: center; }
    .ketalink-tpl-horizontal .ketalink-buttons { flex-direction: column; }
    .ketalink-tpl-horizontal .ketalink-btn { min-width: 0; }
    .ketalink-tpl-vertical .ketalink-inner { padding: 20px 16px; }
    .ketalink-tpl-vertical .ketalink-image { width: 140px; }
    .ketalink-tpl-vertical .ketalink-image img { width: 140px; height: 140px; }
    .ketalink-tpl-vertical .ketalink-buttons { max-width: 100%; }
    .ketalink-floating-cta { padding: 8px 12px; gap: 8px; }
    .ketalink-floating-cta-btn { padding: 10px 18px; font-size: 13px; }
}

/* ============================================
   イベントバナー
   ============================================ */
.ketalink-event-banner { position: relative; padding: 12px 16px; text-align: center; font-weight: 700; letter-spacing: 0.04em; overflow: hidden; }
.ketalink-event-banner::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.2) 50%, transparent 100%); animation: ketalink-shine 3s ease-in-out infinite; }
.ketalink-event-name { font-size: 16px; font-weight: 800; position: relative; z-index: 1; }
.ketalink-event-sub { font-size: 11px; opacity: 0.9; margin-top: 2px; position: relative; z-index: 1; font-weight: 600; }
.is-event { border-style: solid; }

.ketalink-event-prime-day { background: linear-gradient(135deg, #00a4e4, #004f9a); color: #fff; }
.ketalink-event-prime-day .ketalink-event-name::before { content: '⚡ '; }
.ketalink-event-prime-day .ketalink-event-name::after { content: ' ⚡'; }
.ketalink-event-black-friday { background: linear-gradient(135deg, #1a1a1a, #333); color: #fff; }
.ketalink-event-black-friday .ketalink-event-name::before { content: '🏷️ '; }
.ketalink-event-new-life { background: linear-gradient(135deg, #ff9900, #ff6f00); color: #fff; }
.ketalink-event-new-life .ketalink-event-name::before { content: '🌸 '; }
.ketalink-event-new-life .ketalink-event-name::after { content: ' 🌸'; }
.ketalink-event-rakuten-super { background: linear-gradient(135deg, #bf0000, #e50012); color: #fff; }
.ketalink-event-rakuten-super .ketalink-event-name::before { content: '🔥 '; }
.ketalink-event-rakuten-super .ketalink-event-name::after { content: ' 🔥'; }
.ketalink-event-rakuten-marathon { background: linear-gradient(135deg, #e50012, #ff4466); color: #fff; }
.ketalink-event-rakuten-marathon .ketalink-event-name::before { content: '🏃 '; }
.ketalink-event-rakuten-marathon .ketalink-event-name::after { content: ' 🏃'; }
.ketalink-event-paypay { background: linear-gradient(135deg, #ff0033, #ff4466); color: #fff; }
.ketalink-event-paypay .ketalink-event-name::before { content: '🎉 '; }
.ketalink-event-paypay .ketalink-event-name::after { content: ' 🎉'; }
.ketalink-event-custom { background: linear-gradient(135deg, #6c5ce7, #a855f7); color: #fff; }
.ketalink-event-custom .ketalink-event-name::before { content: '✨ '; }
.ketalink-event-custom .ketalink-event-name::after { content: ' ✨'; }

@media (max-width: 560px) {
    .ketalink-event-banner { padding: 10px 12px; }
    .ketalink-event-name { font-size: 14px; }
    .ketalink-event-sub { font-size: 10px; }
}

/* ⑦ ダークモード */
@media (prefers-color-scheme: dark) {
    .ketalink-darkmode {
        --ketalink-bg: #1e1e2e;
        --ketalink-border: #3a3a4e;
        --ketalink-shadow: 0 2px 8px rgba(0,0,0,0.3);
        --ketalink-text: #cdd6f4;
        --ketalink-text-heading: #e8eaf0;
        --ketalink-text-sub: #a0a4b8;
        --ketalink-text-muted: #6c7086;
    }
    .ketalink-darkmode .ketalink-coupon-code { background: #2a2a3e; border-color: #b08c00; }
    .ketalink-darkmode .ketalink-coupon-value { color: #f0e68c; }
    .ketalink-darkmode .ketalink-btn-coupon { border-color: rgba(255,255,255,0.3) !important; }
    .ketalink-darkmode .ketalink-original-price { color: #6c7086; }
    .ketalink-darkmode .ketalink-btn-oos { background-color: #4a4a5e !important; }
    .ketalink-darkmode .ketalink-credit small, .ketalink-darkmode .ketalink-credit a { color: #6c7086; }
    .ketalink-darkmode .ketalink-tpl-rich .ketalink-image img { background: #2a2a3e; }
    .ketalink-darkmode .ketalink-floating-cta { background: #1e1e2e; border-top-color: #3a3a4e; }
}

/* ============================================
   画像の配置（右寄せ）
   ============================================ */
.ketalink-img-right .ketalink-inner { flex-direction: row-reverse; }

/* ============================================
   ボタン幅（PC）
   ============================================ */
.ketalink-btnw-text .ketalink-buttons { flex-direction: row; flex-wrap: wrap; }
.ketalink-btnw-text .ketalink-btn { display: inline-block; width: auto; flex: none; }
.ketalink-btnw-col3 .ketalink-buttons { flex-direction: row; flex-wrap: wrap; }
.ketalink-btnw-col3 .ketalink-btn { flex: 1 1 30%; min-width: 0; }
.ketalink-btnw-col2 .ketalink-buttons { flex-direction: row; flex-wrap: wrap; }
.ketalink-btnw-col2 .ketalink-btn { flex: 1 1 45%; min-width: 0; }

/* ============================================
   モバイルレイアウト
   ============================================ */
@media (max-width: 560px) {
    /* 画像の配置：モバイルではrow-reverseもリセット */
    .ketalink-img-right .ketalink-tpl-standard .ketalink-inner,
    .ketalink-img-right .ketalink-tpl-horizontal .ketalink-inner {
        flex-direction: column;
    }
    .ketalink-img-right.ketalink-mobile-side .ketalink-inner {
        flex-direction: row-reverse;
    }

    /* モバイル横並び */
    .ketalink-mobile-side.ketalink-tpl-standard .ketalink-inner {
        flex-direction: row !important;
        gap: 12px;
        align-items: flex-start;
    }
    .ketalink-mobile-side.ketalink-tpl-standard .ketalink-image {
        width: 90px !important;
        display: block;
    }
    .ketalink-mobile-side.ketalink-tpl-standard .ketalink-image img {
        width: 90px !important;
        height: 90px !important;
        max-height: 90px !important;
    }
    .ketalink-mobile-side.ketalink-tpl-standard .ketalink-title,
    .ketalink-mobile-side.ketalink-tpl-standard .ketalink-desc,
    .ketalink-mobile-side.ketalink-tpl-standard .ketalink-price-area {
        text-align: left !important;
    }

    /* ボタン幅（モバイル） — デフォルト1列 */
    .ketalink-btnw-text .ketalink-buttons,
    .ketalink-btnw-col3 .ketalink-buttons,
    .ketalink-btnw-col2 .ketalink-buttons {
        flex-direction: column;
    }
    .ketalink-btnw-text .ketalink-btn,
    .ketalink-btnw-col3 .ketalink-btn,
    .ketalink-btnw-col2 .ketalink-btn {
        display: block; width: auto; flex: none;
    }

    /* モバイル2列 */
    .ketalink-btnw-mobile-col2 .ketalink-buttons {
        flex-direction: row !important;
        flex-wrap: wrap !important;
    }
    .ketalink-btnw-mobile-col2 .ketalink-btn {
        flex: 1 1 45% !important;
        min-width: 0 !important;
    }

    /* セール中は強制1列 */
    .ketalink-box.is-on-sale .ketalink-buttons,
    .ketalink-box.is-event .ketalink-buttons {
        flex-direction: column !important;
    }
    .ketalink-box.is-on-sale .ketalink-btn,
    .ketalink-box.is-event .ketalink-btn {
        flex: none !important;
        width: auto !important;
    }
}

/* ============================================
   Inline Elements
   ============================================ */

/* --- インラインボタン --- */
.ketalink-inline-btn {
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
}

.ketalink-inline-btn__link {
    display: inline-block;
    padding: 6px 16px;
    border-radius: 4px;
    color: #fff !important;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none !important;
    white-space: nowrap;
    transition: opacity .2s, transform .15s;
    font-family: var(--ketalink-font);
}

.ketalink-inline-btn__link:hover {
    opacity: .85;
    transform: translateY(-1px);
    color: #fff !important;
}

.ketalink-inline-btn__link:active {
    transform: translateY(0);
}

/* --- インライン画像 --- */
.ketalink-inline-img {
    display: inline-block;
    vertical-align: middle;
    line-height: 0;
}

.ketalink-inline-img__link {
    display: inline-block;
    border-radius: 4px;
    overflow: hidden;
    transition: opacity .2s, box-shadow .2s;
}

.ketalink-inline-img__link:hover {
    opacity: .85;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .12);
}

.ketalink-inline-img__image {
    display: block;
    object-fit: contain;
    border-radius: 4px;
    background: #f8f9fa;
}

/* --- インラインリンク --- */
.ketalink-inline-link {
    display: inline;
}

.ketalink-inline-link__anchor {
    text-decoration: underline;
    text-underline-offset: 2px;
    font-weight: 600;
    transition: opacity .2s;
}

.ketalink-inline-link__anchor:hover {
    opacity: .7;
}

/* --- テーブル内最適化 --- */
td .ketalink-inline-btn,
th .ketalink-inline-btn {
    margin: 2px 0;
}

td .ketalink-inline-img,
th .ketalink-inline-img {
    margin: 4px 0;
}

/* --- 複数ボタン縦並び（テーブル内） --- */
.ketalink-inline-buttons-stack {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: flex-start;
}

.ketalink-inline-buttons-stack .ketalink-inline-btn__link {
    width: 100%;
    text-align: center;
}

/* --- ダークモード対応 --- */
.ketalink-dark .ketalink-inline-img__image {
    background: #2d2d2d;
}

.ketalink-dark .ketalink-inline-link__anchor {
    filter: brightness(1.2);
}

/* ============================================
   比較テーブル
   ============================================ */
.ketalink-comparison { margin: 24px 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.ketalink-comparison-grid { display: grid; gap: 0; border: 1px solid var(--ketalink-border, #e2e4e7); border-radius: 8px; overflow: hidden; background: var(--ketalink-bg-card, #fff); }
.ketalink-comparison-col { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 20px 16px; border-right: 1px solid var(--ketalink-border, #e2e4e7); }
.ketalink-comparison-col:last-child { border-right: none; }
.ketalink-comparison-img { width: 100%; max-width: 140px; margin-bottom: 12px; }
.ketalink-comparison-img img { width: 100%; height: auto; max-height: 140px; object-fit: contain; border-radius: 6px; }
.ketalink-comparison-title { font-size: 14px; font-weight: 700; line-height: 1.4; margin-bottom: 4px; color: var(--ketalink-text-heading, #1a202c); }
.ketalink-comparison-sub { font-size: 11px; color: var(--ketalink-text-sub, #718096); margin-bottom: 6px; }
.ketalink-comparison-price { font-size: 18px; font-weight: 800; color: #cc0c39; margin-bottom: 12px; }
.ketalink-comparison-btn { display: inline-block; width: 100%; padding: 10px 16px; color: #fff !important; font-size: 13px; font-weight: 700; text-align: center; text-decoration: none !important; transition: opacity .2s, transform .15s; box-shadow: 0 2px 4px rgba(0,0,0,.1); }
.ketalink-comparison-btn:hover { opacity: .88; transform: translateY(-1px); }
@media (max-width: 560px) {
    .ketalink-comparison-grid { grid-template-columns: 1fr !important; }
    .ketalink-comparison-col { border-right: none; border-bottom: 1px solid var(--ketalink-border, #e2e4e7); }
    .ketalink-comparison-col:last-child { border-bottom: none; }
}

/* ── メインリンク（画像・タイトルクリック） ── */
.ketalink-clickable {
    cursor: pointer;
}
.ketalink-image.ketalink-clickable img {
    transition: transform 0.2s ease;
}
.ketalink-image.ketalink-clickable:hover img {
    transform: scale(1.03);
    opacity: 0.85;
}
.ketalink-title.ketalink-clickable:hover {
    text-decoration: underline;
}
