/* ============================================
   葬儀供物注文プラグイン共通スタイル
   PCでは大きめの字、スマホは端末設定を尊重
   =============================================== */

/* ベースフォント */
.funeral-order-input,
.funeral-order-input *,
.funeral-detail,
.funeral-detail *,
.funeral-front-top,
.funeral-front-top *,
.funeral-confirm,
.funeral-confirm *,
.funeral-payment,
.funeral-payment *,
.funeral-complete,
.funeral-complete * {
    font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN",
                 "Yu Gothic UI", "Yu Gothic", "Meiryo", sans-serif;
}

/* ============================================
   全ページ共通：生成り背景（和の落ち着いた色調）
   box-shadow + clip-path で viewport 幅まで拡張
   =============================================== */
/* body に適用してページ全高に背景が広がるようにする */
body:has(.funeral-front-top),
body:has(.funeral-detail),
body:has(.funeral-order-input),
body:has(.funeral-confirm),
body:has(.funeral-payment),
body:has(.funeral-complete),
body:has(.funeral-order-confirm),
body:has(.fnr-payment),
body:has(.fnr-complete) {
    background-color: #fafafa !important;
}

body:has(.funeral-front-top) .ec-layoutRole,
body:has(.funeral-detail) .ec-layoutRole,
body:has(.funeral-order-input) .ec-layoutRole,
body:has(.funeral-confirm) .ec-layoutRole,
body:has(.funeral-payment) .ec-layoutRole,
body:has(.funeral-complete) .ec-layoutRole,
body:has(.funeral-order-confirm) .ec-layoutRole,
body:has(.fnr-payment) .ec-layoutRole,
body:has(.fnr-complete) .ec-layoutRole,
body:has(.funeral-front-top) .ec-layoutRole__main,
body:has(.funeral-detail) .ec-layoutRole__main,
body:has(.funeral-order-input) .ec-layoutRole__main,
body:has(.funeral-confirm) .ec-layoutRole__main,
body:has(.funeral-payment) .ec-layoutRole__main,
body:has(.funeral-complete) .ec-layoutRole__main,
body:has(.funeral-order-confirm) .ec-layoutRole__main,
body:has(.fnr-payment) .ec-layoutRole__main,
body:has(.fnr-complete) .ec-layoutRole__main {
    background-color: #fafafa !important;
}

/* ===== 本文フォントサイズ（PC） ===== */
.funeral-order-input,
.funeral-detail,
.funeral-front-top,
.funeral-confirm,
.funeral-payment,
.funeral-complete {
    font-size: 17px !important;
    line-height: 1.8 !important;
}

/* ===== 見出し ===== */
.funeral-order-input__section-heading,
.fo-funeral-info__heading,
.funeral-detail__info-heading,
.funeral-cart__heading,
.funeral-front-top h2,
.funeral-detail h2,
.funeral-confirm h2,
.funeral-payment h2 {
    font-size: 1.2em !important;
    line-height: 1.5 !important;
}

.ec-pageHeader h1 {
    font-size: 1.4em !important;
    line-height: 1.5 !important;
}

/* ===== 葬儀一覧の日付タブ ===== */
.funeral-date-tab {
    padding: 14px 20px !important;
}
.funeral-date-tab__month { font-size: 1em !important; }
.funeral-date-tab__day { font-size: 1.6em !important; font-weight: bold; }
.funeral-date-tab__week { font-size: 1em !important; }

/* 葬儀カード */
.funeral-card {
    padding: 20px !important;
}
.funeral-card__family {
    font-size: 1.2em !important;
    line-height: 1.5 !important;
    margin-bottom: 10px;
}
.funeral-card__info dt,
.funeral-card__info dd {
    font-size: 1em !important;
    line-height: 1.7 !important;
}
.funeral-card__deadline {
    font-weight: bold;
}
.funeral-card__action {
    font-size: 1.05em !important;
    padding-top: 12px !important;
}

/* 葬儀一覧のリード文 */
.funeral-front-top__lead {
    font-size: 1em !important;
    line-height: 1.8 !important;
}
.funeral-date-panel__heading {
    font-size: 1.1em !important;
}

/* ===== 葬儀詳細のご葬儀情報 ===== */
.funeral-detail__info {
    padding: 20px !important;
}
.funeral-detail__info-lead {
    font-size: 1em !important;
    line-height: 1.8 !important;
}
.funeral-detail__info-dl dt,
.funeral-detail__info-dl dd {
    font-size: 1em !important;
    line-height: 1.7 !important;
    padding: 10px 0 !important;
}
.funeral-detail__deadline {
    font-weight: bold;
}

/* カート内容テーブル */
.funeral-cart__table,
.funeral-cart__table th,
.funeral-cart__table td {
    font-size: 1em !important;
    line-height: 1.6 !important;
}
.funeral-cart__table th,
.funeral-cart__table td {
    padding: 14px !important;
}

/* 商品名・価格（詳細画面） */
.kmt-product-card__name,
.kmt-product-card__title {
    font-size: 1.1em !important;
    line-height: 1.5 !important;
}
.kmt-product-card__price {
    font-size: 1.3em !important;
    font-weight: bold;
}

/* 電話誘導 */
.kmt-product-card__phone-text {
    font-size: 1em !important;
    line-height: 1.6 !important;
}
.kmt-product-card__phone-link {
    font-size: 1.05em !important;
    padding: 14px 20px !important;
    line-height: 1.6 !important;
}
.kmt-product-card__phone-link strong {
    font-size: 1.3em !important;
}

/* ===== 入力欄サイズ ===== */
.funeral-order-input__form-input input,
.funeral-order-input__form-input select,
.funeral-order-input__form-input textarea,
.sender-card__textarea,
.funeral-order-input input[type="text"],
.funeral-order-input input[type="email"],
.funeral-order-input input[type="tel"],
.funeral-order-input input[type="number"],
.funeral-order-input select,
.funeral-order-input textarea {
    font-size: 18px !important;
    padding: 14px 14px !important;
    line-height: 1.6 !important;
}

.funeral-order-input__form-input select {
    min-width: 220px;
}

textarea, .sender-card__textarea {
    font-size: 17px !important;
    padding: 12px 14px !important;
}

/* ===== ラベル ===== */
.funeral-order-input__form-label,
.funeral-order-input__form-label label,
.sender-card__label {
    font-size: 1em !important;
    line-height: 1.6 !important;
}

.funeral-order-input__name-sublabel {
    font-size: 0.9em !important;
}

/* ===== ヒント・エラー ===== */
.funeral-order-input__hint,
.funeral-order-input__postal-status {
    font-size: 0.9em !important;
    line-height: 1.6 !important;
}

.funeral-order-input__error,
.invalid-feedback,
ul.list-unstyled li {
    font-size: 0.95em !important;
    line-height: 1.6 !important;
}

.funeral-order-input__email-notice {
    font-size: 0.95em !important;
    line-height: 1.8 !important;
    padding: 16px 0 !important;
}

/* ===== ボタン ===== */
.funeral-order-input__btn-next,
.funeral-order-input__btn-back,
.funeral-order-input__postal-btn,
.kmt-product-card__cart-btn {
    font-size: 1.05em !important;
    line-height: 1.5 !important;
}
.funeral-order-input__btn-next {
    font-size: 1.15em !important;
    padding: 18px 32px !important;
    min-height: 56px;
}
.funeral-order-input__btn-back {
    padding: 14px 24px !important;
}
.funeral-order-input__postal-btn {
    padding: 12px 18px !important;
}
.kmt-product-card__cart-btn {
    font-size: 1em !important;
    padding: 12px 20px !important;
    min-height: 48px;
}

/* ===== 必須マーク ===== */
.required-mark,
.optional-mark {
    font-size: 0.8em !important;
    padding: 4px 10px !important;
    line-height: 1.3 !important;
}

/* ===== 差出人セクション ===== */
.sender-card__name { font-size: 1.05em !important; }
.sender-card__price { font-size: 1.05em !important; font-weight: bold; }
.sender-card__image img {
    width: 160px !important;
    height: 160px !important;
}
.sender-layout__examples {
    flex: 0 0 350px !important;
}

/* 合計金額 */
.funeral-order-input__total {
    font-size: 1.2em !important;
}
.funeral-order-input__total strong {
    font-size: 1.5em !important;
}

/* ご葬儀情報テーブル */
.fo-funeral-info__label,
.fo-funeral-info__value {
    font-size: 1em !important;
    padding: 14px 16px !important;
    line-height: 1.6 !important;
}
.fo-funeral-info__label {
    flex: 0 0 130px !important;
}
.fo-funeral-info__lead {
    font-size: 1em !important;
    padding: 20px 20px 12px !important;
}

/* ステップ表示 */
.fo-steps__label {
    font-size: 1em !important;
    padding: 14px 10px !important;
}
.fo-steps__item {
    font-size: 0.95em !important;
    padding: 16px 20px 16px 30px !important;
}
.fo-steps__num { font-size: 1.1em !important; }

/* パンくず */
.funeral-order-input__breadcrumb,
.funeral-detail__breadcrumb {
    font-size: 0.95em !important;
    line-height: 1.8 !important;
    margin-bottom: 20px !important;
}

/* 葬儀概要（入力画面上部） */
.funeral-order-input__funeral-info {
    font-size: 1em !important;
    padding: 16px 20px !important;
    line-height: 1.7 !important;
}

/* ラジオ・チェックボックス */
.funeral-order-input input[type="radio"],
.funeral-order-input input[type="checkbox"] {
    width: 20px;
    height: 20px;
    vertical-align: middle;
    margin-right: 8px;
}

/* ===== スマホ（端末設定を尊重、控えめに） ===== */
@media (max-width: 768px) {
    .funeral-order-input,
    .funeral-detail,
    .funeral-front-top,
    .funeral-confirm,
    .funeral-payment,
    .funeral-complete {
        font-size: 15px !important;
        line-height: 1.7 !important;
    }

    /* iOSの自動ズーム回避に16pxを維持 */
    .funeral-order-input__form-input input,
    .funeral-order-input__form-input select,
    .funeral-order-input__form-input textarea,
    .sender-card__textarea {
        font-size: 16px !important;
        padding: 12px !important;
    }

    .fo-funeral-info__label {
        flex: 0 0 100px !important;
        font-size: 0.95em !important;
    }

    .sender-card__image img {
        width: 130px !important;
        height: 130px !important;
    }
}

/* ===== カートボタン リフト演出（詳細画面の商品カード） ===== */
.kmt-product-card__cart-btn {
    transition: all 0.2s ease-out !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}
.kmt-product-card__cart-btn:hover {
    background: #e08a28 !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 16px rgba(242, 155, 59, 0.4) !important;
}
.kmt-product-card__cart-btn:active {
    transform: translateY(-1px) !important;
    box-shadow: 0 2px 8px rgba(242, 155, 59, 0.3) !important;
}

/* ============================================
   新カート UI (.kmt-cart)
   PC:   1行表示（画像 名前・単価 ±数量 小計 削除）
   スマホ: 2段表示（上段：画像 名前 削除 / 下段：±数量 小計）
   =============================================== */
.kmt-cart {
    background: #fff;
    border: 1px solid #e8e4ed;
    border-radius: 6px;
    overflow: hidden;
    margin: 24px 0;
}
.kmt-cart__header {
    background: linear-gradient(to right, var(--kmt-main), var(--kmt-accent-light));
    color: #fff;
    padding: 14px 22px;
    font-size: 1.2em;
    font-weight: 500;
    letter-spacing: 0.05em;
    border-radius: 4px 4px 0 0;
}
.kmt-cart__header-title {
    display: block;
}
.kmt-cart__body {
    padding: 6px 22px;
}

/* PC: .kmt-cart__item を flex コンテナにし、item-top/bottom は display:contents で
   透過させて中身を一列に並べる */
.kmt-cart__item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    border-top: 1px solid #f0ecf4;
}
.kmt-cart__item:first-child {
    border-top: none;
}
.kmt-cart__item-top,
.kmt-cart__item-bottom {
    display: contents;
}

/* PC 表示順: 画像 → 名前情報 → 数量 → 小計 → 削除 */
.kmt-cart__item-img    { order: 1; }
.kmt-cart__item-info   { order: 2; flex: 1; min-width: 0; }
.kmt-cart__qty-ctrl    { order: 3; }
.kmt-cart__item-sub    { order: 4; }
.kmt-cart__item-del    { order: 5; }

.kmt-cart__item-img {
    width: 100px;
    height: 100px;
    background: #f7f7f7;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}
.kmt-cart__item-img img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.kmt-cart__item-name {
    font-size: 15px;
    color: #333;
    margin-bottom: 4px;
    font-weight: 500;
    line-height: 1.4;
}
.kmt-cart__item-price {
    font-size: 13px;
    color: #888;
}
.kmt-cart__item-sub {
    font-size: 16px;
    color: #d9344f;
    font-weight: 700;
    white-space: nowrap;
    min-width: 90px;
    text-align: right;
    margin: 0 10px;
}
.kmt-cart__item-del {
    background: #fff;
    border: 1px solid #ddd;
    color: #666;
    padding: 6px 14px;
    border-radius: 4px;
    font-size: 13px;
    cursor: pointer;
    flex-shrink: 0;
    line-height: 1;
    transition: all 0.15s;
}
.kmt-cart__item-del:hover {
    background: #f5f5f5;
    color: #d9344f;
    border-color: #d9344f;
}

/* 数量コントロール */
.kmt-cart__qty-ctrl {
    display: inline-flex;
    align-items: center;
    border: 1px solid #d0ccd8;
    border-radius: 4px;
    overflow: hidden;
    background: #fff;
    flex-shrink: 0;
}
.kmt-cart__qty-btn {
    width: 36px;
    height: 36px;
    background: #f5f3f9;
    color: var(--kmt-main);
    border: none;
    font-size: 17px;
    font-weight: 500;
    cursor: pointer;
    line-height: 1;
    outline: none;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.15s;
    font-family: inherit;
    padding: 0;
}
.kmt-cart__qty-btn:hover {
    background: #e8e4ed;
}
.kmt-cart__qty-btn:active {
    background: #d8d4e0;
}
.kmt-cart__qty-btn:disabled {
    color: #bbb;
    cursor: not-allowed;
    background: #fafafa;
}
.kmt-cart__qty-btn:focus {
    outline: none;
}
.kmt-cart__qty-val {
    min-width: 40px;
    text-align: center;
    font-size: 15px;
    color: #333;
    font-weight: 500;
    padding: 0 8px;
    user-select: none;
}

/* フッター: 右下に合計とボタン */
.kmt-cart__foot {
    background: #f7f5fb;
    padding: 18px 22px;
    border-top: 1px solid #e8e4ed;
}
.kmt-cart__total-block {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
}
.kmt-cart__total-row {
    display: flex;
    align-items: baseline;
    gap: 14px;
}
.kmt-cart__total-label {
    font-size: 14px;
    color: #555;
    letter-spacing: 1px;
}
.kmt-cart__total-val {
    font-size: 28px;
    color: #d9344f;
    font-weight: 700;
    line-height: 1.1;
}
.kmt-cart__checkout-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 28px;
    background: #d9344f;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 500;
    transition: all 0.2s ease-out;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.kmt-cart__checkout-btn:hover {
    background: #c02a42;
    color: #fff;
    transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(217, 52, 79, 0.4);
}
.kmt-cart__checkout-btn:active {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(217, 52, 79, 0.3);
}

/* スマホ（768px以下）: 2段レイアウト */
@media (max-width: 768px) {
    .kmt-cart__body { padding: 6px 14px; }
    .kmt-cart__foot { padding: 14px; }

    /* PC のフラット化を解除して本来の2段構造へ戻す */
    .kmt-cart__item {
        display: block;
    }
    .kmt-cart__item-top {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 10px;
    }
    .kmt-cart__item-bottom {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding-left: 94px;
    }

    .kmt-cart__item-img {
        width: 80px;
        height: 80px;
    }
    .kmt-cart__item-name {
        font-size: 14px;
    }
    .kmt-cart__item-price {
        font-size: 12px;
    }
    .kmt-cart__item-sub {
        font-size: 15px;
        min-width: 0;
        margin: 0;
    }
    .kmt-cart__item-del {
        font-size: 13px;
        padding: 4px 10px;
    }

    .kmt-cart__qty-btn {
        width: 32px;
        height: 32px;
        font-size: 16px;
    }

    .kmt-cart__total-block {
        align-items: stretch;
    }
    .kmt-cart__total-row {
        justify-content: space-between;
    }
    .kmt-cart__total-val {
        font-size: 24px;
    }
    .kmt-cart__checkout-btn {
        width: 100%;
        padding: 14px;
    }
}

/* ============================================
   ヒーロー画像（花）— 一覧・詳細で共用
   =============================================== */
.fo-hero {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    height: 200px;
    overflow: hidden;
    margin-top: 0;
    margin-bottom: 0;
}
.fo-hero__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right center;
    display: block;
}
.fo-hero__overlay {
    position: absolute;
    inset: 0;
    background: transparent;
}
.fo-hero__inner {
    position: absolute;
    top: 42%;
    left: 6%;
    transform: translateY(-50%);
    color: #000;
    max-width: 55%;
}
.fo-hero__en {
    font-size: 12px;
    letter-spacing: 6px;
    opacity: 0.9;
    margin-bottom: 10px;
}
.fo-hero__title {
    font-size: 32px !important;
    margin: 0 !important;
    font-weight: 500 !important;
    letter-spacing: 4px !important;
    color: #000 !important;
    line-height: 1.3 !important;
    font-family: "Noto Sans JP", "Hiragino Sans", "Yu Gothic UI", sans-serif !important;
}
.fo-hero__rule {
    margin-top: 14px;
    width: 60px;
    height: 2px;
    background: #000;
    opacity: 1;
}
@media (max-width: 600px) {
    .fo-hero { height: 160px; margin-bottom: 0; }
    .fo-hero__title { font-size: 20px !important; letter-spacing: 1px !important; white-space: nowrap; }
    .fo-hero__en { font-size: 10px; letter-spacing: 4px; }
    .fo-hero__inner { max-width: 90%; left: 5%; }
}
.fo-hero--center .fo-hero__overlay {
    background: transparent;
}
.fo-hero--center .fo-hero__inner {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 90%;
    text-align: center;
}
.fo-hero--center .fo-hero__rule {
    margin: 14px auto 0;
}

/* ヒーロー直後コンテンツの余白（ヒーローと重ならずバランスよく配置） */
.fo-hero-below {
    margin-top: 40px !important;
}
@media (max-width: 600px) {
    .fo-hero-below {
        margin-top: 30px !important;
    }
}

/* 強制：全ページ（payment/complete含む）の背景を生成り統一 */
html:has(.fnr-payment),
html:has(.fnr-complete),
html:has(.funeral-order-confirm),
html:has(.funeral-order-input),
html:has(.funeral-front-top),
html:has(.funeral-detail) {
    background-color: #FAF9F5 !important;
}
html:has(.fnr-payment) body,
html:has(.fnr-complete) body,
html:has(.funeral-order-confirm) body,
html:has(.funeral-order-input) body,
html:has(.funeral-front-top) body,
html:has(.funeral-detail) body {
    background-color: #FAF9F5 !important;
}


/* ===== FuneralOrder 共通ボタン（payment風、全ページ統一） ===== */
.fnr-buttons {
    display: flex;
    gap: 12px;
    margin: 24px auto 0;
    flex-wrap: wrap;
    max-width: 820px;
}
.fnr-btn {
    flex: 1;
    min-width: 140px;
    padding: 14px 20px;
    border-radius: 6px;
    font-size: 1.05em;
    font-weight: bold;
    border: none;
    cursor: pointer;
    text-align: center;
    text-decoration: none;
    transition: opacity 0.2s, background 0.2s;
    display: inline-block;
    box-sizing: border-box;
}
.fnr-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.fnr-btn--back {
    background: #fff;
    border: 2px solid var(--kmt-main);
    color: var(--kmt-main);
}
.fnr-btn--back:hover {
    background: #f4f2fb;
    color: var(--kmt-main);
}
.fnr-btn--pay {
    background: var(--kmt-main);
    color: #fff;
}
.fnr-btn--pay:hover:not(:disabled) {
    background: #301f6d;
    color: #fff;
}

/* ===== Square決済案内フッター（全ページ共通） ===== */
.fnr-square-notice {
    margin-top: 28px;
    padding: 24px 20px;
    text-align: center;
    border-top: 1px solid #bbb;
}
.fnr-square-notice__logo {
    display: block;
    height: 32px;
    width: auto;
    margin: 0 auto 12px;
}
.fnr-square-notice__text {
    font-size: 13px;
    color: #666;
    line-height: 1.8;
}
.fnr-square-notice__text strong {
    color: #333;
}
.fnr-square-notice__tech {
    font-size: 11px;
    color: #888;
}

/* ====================================================================
 * Phase 2-A.10 新命名規則 kmt-* スタイル群
 * 2026-05-10 追加開始
 * 既存の fnr-* / fo-* / ext-* / kex-* スタイルは段階移行のため当面残す
 * ==================================================================== */

/* --------- CSS 変数 --------- */
:root {
    --kmt-main: #3F2A8C;
    --kmt-accent: #7A77BC;
    --kmt-accent-light: #534AB7;
    --kmt-bg: #FAF9F5;
    --kmt-bg-soft: #F4F2FB;
    --kmt-text: #333333;
    --kmt-text-sub: #666666;
    --kmt-text-light: #888888;
    --kmt-border: #ddd;
    --kmt-border-soft: #e0dcee;
    --kmt-gold: #b08a3a;
    --kmt-danger: #d9344f;
    --kmt-cell-bg: #e8e4f0;
}

/* --------- kmt-hero --------- */
.kmt-hero { position: relative; width: 100vw; margin-left: calc(50% - 50vw); height: 200px; overflow: hidden; margin-bottom: 24px; }
.kmt-hero__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kmt-hero__overlay { display: none; }
.kmt-hero__inner { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; color: #333; width: 100%; }
.kmt-hero__en { font-size: 14px; letter-spacing: 0.2em; margin-bottom: 4px; opacity: 0.9; }
.kmt-hero__title { font-size: 28px; font-weight: bold; margin: 0; letter-spacing: 0.05em; color: #333; }
.kmt-hero__rule { width: 30px; height: 1px; background: rgba(0,0,0,0.4); margin: 12px auto 0; }
@media (max-width: 600px) {
    .kmt-hero { height: 160px; }
    .kmt-hero__title { font-size: 22px; }
    .kmt-hero__en { font-size: 12px; }
}

/* --------- kmt-breadcrumb --------- */
.kmt-breadcrumb { padding: 12px 0; font-size: 14px; color: var(--kmt-text-light); max-width: 820px; margin: 0 auto; }
.kmt-breadcrumb a { color: var(--kmt-main); text-decoration: none; }
.kmt-breadcrumb a:hover { text-decoration: underline; }

/* --------- kmt-step-indicator --------- */
.kmt-step-indicator { display: flex; background: #fff; border: 1px solid var(--kmt-border); border-radius: 4px; overflow: hidden; margin: 0 auto 28px; max-width: 820px; }
.kmt-step-indicator__step { flex: 1; padding: 18px 8px 18px 28px; background: #ece9e1; color: var(--kmt-text-light); font-size: 15px; font-weight: 500; text-align: center; clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 50%, calc(100% - 16px) 100%, 0 100%, 16px 50%); margin-left: -16px; white-space: nowrap; }
.kmt-step-indicator__step--first { padding-left: 18px; clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 50%, calc(100% - 16px) 100%, 0 100%); margin-left: 0; }
.kmt-step-indicator__step--last { clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 16px 50%); }
.kmt-step-indicator__step.is-done { background: var(--kmt-accent); color: #fff; }
.kmt-step-indicator__step.is-active { background: var(--kmt-main); color: #fff; }
@media (max-width: 600px) {
    .kmt-step-indicator__step { font-size: 12px; padding: 14px 4px 14px 22px; }
    .kmt-step-indicator__step--first { padding-left: 14px; }
}

/* --------- kmt-thanks --------- */
.kmt-thanks { background: #fff; border: 1px solid var(--kmt-border); border-radius: 4px; overflow: hidden; margin: 0 auto 20px; max-width: 820px; }
.kmt-thanks__heading { background: var(--kmt-main); color: #fff; padding: 10px 20px; font-size: 14px; font-weight: bold; }
.kmt-thanks__body { text-align: center; padding: 32px 20px; }
.kmt-thanks__msg { color: var(--kmt-main); font-size: 17px; font-weight: bold; margin: 0; }
.kmt-thanks__divider { width: 30px; height: 1px; background: var(--kmt-gold); margin: 22px auto; }
.kmt-thanks__order-label { font-size: 11px; color: #8b6820; font-weight: bold; letter-spacing: .1em; margin-bottom: 4px; }
.kmt-thanks__order-num { font-size: 26px; font-weight: bold; color: var(--kmt-text); letter-spacing: 2px; }
.kmt-thanks__mail { color: var(--kmt-text-sub); font-size: 13px; line-height: 1.9; }
.kmt-thanks__mail strong { color: var(--kmt-text); }
.kmt-thanks__mail-note { font-size: 12px; color: #999; display: inline-block; margin-top: 6px; }

/* --------- kmt-funeral-info --------- */
.kmt-funeral-info { border: 1px solid var(--kmt-border); border-radius: 4px; margin: 0 auto 20px; overflow: hidden; background: #fff; max-width: 820px; }
.kmt-funeral-info__heading { background: var(--kmt-main); color: #fff; padding: 10px 20px; margin: 0; font-size: 14px; font-weight: bold; }
.kmt-funeral-info__table { padding: 16px 20px 20px; }
.kmt-funeral-info__row { display: flex; gap: 16px; }
.kmt-funeral-info__row + .kmt-funeral-info__row { margin-top: 8px; }
.kmt-funeral-info__cell { flex: 1; display: flex; align-items: center; border: 1px solid var(--kmt-border); }
.kmt-funeral-info__label { flex: 0 0 100px; padding: 10px 12px; background: var(--kmt-cell-bg); color: var(--kmt-text); font-weight: bold; font-size: 13px; text-align: center; border-right: 1px solid var(--kmt-border); }
.kmt-funeral-info__value { flex: 1; padding: 10px 12px; font-size: 13px; color: var(--kmt-text); }
@media (max-width: 600px) {
    .kmt-funeral-info__row { flex-direction: column; gap: 8px; }
    .kmt-funeral-info__row + .kmt-funeral-info__row { margin-top: 8px; }
}

/* --------- kmt-section（汎用セクション） --------- */
.kmt-section { background: #fff; border: 1px solid var(--kmt-border); border-radius: 4px; margin: 0 auto 20px; overflow: hidden; max-width: 820px; }
.kmt-section__heading { background: var(--kmt-main); color: #fff; padding: 10px 20px; font-size: 14px; font-weight: bold; }
.kmt-section__body { padding: 0; }

/* --------- kmt-table（汎用テーブル） --------- */
.kmt-table { width: 100%; border-collapse: collapse; }
.kmt-table th, .kmt-table td { padding: 10px 12px; text-align: left; border: 1px solid var(--kmt-border); font-size: 13px; vertical-align: top; }
.kmt-table th { width: 200px; background: var(--kmt-cell-bg); color: var(--kmt-text); font-weight: bold; text-align: center; }
.kmt-table--info th { width: 180px; }
.kmt-table__total { font-weight: bold; color: var(--kmt-main); font-size: 15px; }
@media (max-width: 600px) {
    .kmt-table th { width: 100px; font-size: 12px; padding: 10px; }
    .kmt-table td { font-size: 13px; padding: 10px; }
}

/* --------- kmt-contact（お問い合わせ枠） --------- */
.kmt-contact { text-align: center; color: var(--kmt-text-sub); padding: 0 0 16px; font-size: 15px; line-height: 1.7; }
.kmt-contact__label { font-size: 12px; color: var(--kmt-text-light); margin-bottom: 2px; }
.kmt-contact__name { color: var(--kmt-text); font-size: 22px; font-weight: bold; letter-spacing: 0.05em; }
.kmt-contact__tel-wrap { position: relative; margin-top: 10px; }
.kmt-contact__tel { color: var(--kmt-main); font-weight: bold; text-decoration: none; font-size: 38px; letter-spacing: 2px; position: relative; display: inline-block; }
.kmt-contact__tel-icon { position: absolute; right: 100%; top: 50%; transform: translateY(-50%); padding-right: 12px; font-size: 32px; line-height: 1; }
@media (max-width: 600px) {
    .kmt-contact { font-size: 14px; }
    .kmt-contact__name { font-size: 18px; }
    .kmt-contact__tel { font-size: 30px; letter-spacing: 1.5px; }
    .kmt-contact__tel-icon { font-size: 26px; padding-right: 10px; }
}

/* --------- kmt-square-notice --------- */
.kmt-square-notice { display: flex; align-items: center; gap: 16px; padding: 16px 20px; background: #f7f6fa; border: 1px solid var(--kmt-border-soft); border-radius: 6px; max-width: 820px; margin: 16px auto 0; }
.kmt-square-notice__logo { width: 60px; height: auto; flex-shrink: 0; }
.kmt-square-notice__text { font-size: 12px; color: var(--kmt-text-sub); line-height: 1.6; }
.kmt-square-notice__text strong { color: var(--kmt-text); }
.kmt-square-notice__tech { color: #888; font-size: 11px; display: block; margin-top: 4px; }

/* --------- kmt-footer-group --------- */
.kmt-footer-group { margin: 28px auto 0; padding-top: 24px; border-top: 1px solid var(--kmt-border); max-width: 820px; }

/* --------- kmt-btn / kmt-buttons --------- */
.kmt-buttons { display: flex; gap: 12px; margin: 24px auto 0; flex-wrap: wrap; max-width: 820px; }
.kmt-btn { flex: 1; min-width: 140px; padding: 14px 20px; border-radius: 6px; font-size: 1.05em; font-weight: bold; text-align: center; text-decoration: none; transition: opacity .2s, background .2s; border: none; cursor: pointer; display: inline-block; box-sizing: border-box; }
.kmt-btn--primary { background: var(--kmt-main); color: #fff; }
.kmt-btn--primary:hover { background: #301f6d; color: #fff; }
.kmt-btn--outline { background: #fff; border: 2px solid var(--kmt-main); color: var(--kmt-main); }
.kmt-btn--outline:hover { background: var(--kmt-bg-soft); }
.kmt-btn--danger { background: var(--kmt-danger); color: #fff; }
@media (max-width: 600px) {
    .kmt-btn { min-width: 100%; }
}

/* --------- 印刷用 --------- */
@media print {
    .kmt-step-indicator, .kmt-buttons, .kmt-breadcrumb { display: none; }
}

/* ====================================================================
 * Phase 2-A.10 新命名規則 kmt-* 追加終了
 * ==================================================================== */

/* --------- kmt-square-notice 修正版（2026-05-10 PM、上記定義を上書き） --------- */
.kmt-square-notice { display: block; text-align: center; padding: 24px 16px; margin: 16px auto 0; max-width: 820px; background: transparent; border: none; border-radius: 0; }
.kmt-square-notice__logo { width: 120px; height: auto; margin-bottom: 12px; display: inline-block; flex-shrink: initial; }
.kmt-square-notice__text { font-size: 13px; color: var(--kmt-text-sub); line-height: 1.8; }
.kmt-square-notice__text strong { color: var(--kmt-text); }
.kmt-square-notice__tech { color: #999; font-size: 11px; display: block; margin-top: 4px; }

/* ===========================================================================
   ご注文者情報入力ステップ専用（input.twig 統一版）
   Phase 2-A.10.6 で追加
   =========================================================================== */

/* ラッパー */
.kmt-input{max-width:820px;margin:0 auto;padding:20px 16px 60px}

/* ご葬儀情報（input版・リード文用） */
.kmt-funeral-info--input .kmt-funeral-info__lead{text-align:center;padding:16px 20px 8px;font-size:.9em;color:#555;margin:0}

/* セクション（札名版オーバーライド） */

/* 入力フォーム共通 */
.kmt-form{display:flex;flex-direction:column;gap:16px}
.kmt-form__lead{font-size:.9em;color:#666;margin:0 0 16px}
.kmt-form__row{display:grid;grid-template-columns:200px 1fr;gap:16px;align-items:start}
.kmt-form__label{font-size:.95em;padding-top:10px;color:#333;display:flex;align-items:center;gap:8px}
.kmt-form__label label{margin:0}
.kmt-form__input input,.kmt-form__input select,.kmt-form__input textarea{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:1em}
.kmt-form__input select{width:auto;min-width:200px}
.kmt-form__hint{font-size:.85em;color:#888;margin:4px 0 0}
.kmt-form__email-notice{padding:12px 0 8px;color:#c41e3a;font-size:.9em;line-height:1.7}
.kmt-form__email-notice p{margin:0 0 4px}
.kmt-form__email-notice p:last-child{margin-bottom:0}
.kmt-form__email-notice strong{color:#8b0000}
.kmt-form__name-split{display:flex;gap:12px}
.kmt-form__name-half{flex:1}
.kmt-form__name-sublabel{font-size:.8em;color:#888;margin-bottom:4px}
.kmt-form__postal-wrap{display:flex;gap:8px;align-items:center}
.kmt-form__postal-wrap input{max-width:160px}
.kmt-form__postal-btn{padding:8px 14px;background:var(--kmt-accent);color:#fff;border:none;border-radius:4px;font-size:.9em;cursor:pointer;white-space:nowrap;transition:background .15s}
.kmt-form__postal-btn:hover{background:var(--kmt-main)}
.kmt-form__postal-btn:disabled{background:#ccc;cursor:not-allowed}
.kmt-form__postal-status{font-size:.85em;margin:6px 0 0;min-height:1em}
.kmt-form__postal-status.is-success{color:#2b7a2b}
.kmt-form__postal-status.is-error{color:#dc3545}
.kmt-form__total{text-align:right;padding-top:16px;border-top:2px solid var(--kmt-main);font-size:1.1em;margin-top:16px}
.kmt-form__total strong{color:var(--kmt-main);font-size:1.4em;margin-left:8px}
.kmt-form__error{color:#dc3545;font-size:.85em;margin:4px 0 0}

/* 札名レイアウト */
.kmt-sender-layout{display:flex;gap:20px;align-items:flex-start}
.kmt-sender-layout__products{flex:1;min-width:0}
.kmt-sender-layout__examples{flex:0 0 300px;position:sticky;top:20px}
.kmt-sender-layout__examples-img{width:100%;height:auto;border:1px solid #e0dce8;border-radius:4px;padding:8px;background:#fff}

/* 札名カード */
.kmt-sender-card{display:flex;flex-direction:row;gap:16px;padding:16px;margin-bottom:16px;border:1px solid #e6dfd3;border-radius:4px;background:#fdfbf7;min-height:231px}
.kmt-sender-card__product-info{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
.kmt-sender-card__image{flex:0 0 180px;align-self:flex-start}
.kmt-sender-card__image img{width:180px;height:180px;object-fit:contain;border:1px solid #eee;border-radius:4px;background:#fff;display:block}
.kmt-sender-card__name{font-weight:bold;color:#333;font-size:1em}
.kmt-sender-card__price{font-weight:bold;color:var(--kmt-main);font-size:1em}
.kmt-sender-card__input-row{margin-top:0;flex:1;display:flex;flex-direction:column;min-height:0}
.kmt-sender-card__label{display:block;font-size:.85em;color:#555;margin-bottom:4px}
.kmt-sender-card__label .required-mark{margin-left:8px}
.kmt-sender-card__textarea{width:100%;padding:8px 10px;border:1px solid #ccc;border-radius:4px;font-size:.95em;resize:none !important;font-family:inherit;flex:1;min-height:80px}
.kmt-sender-card__textarea.is-error{border-color:#dc3545;background:#fff5f5}
.kmt-sender-card__textarea:focus{outline:none;border-color:var(--kmt-accent);box-shadow:0 0 0 2px rgba(122,119,188,0.2)}

/* 領収書のご案内 アコーディオン */
.kmt-receipt-notice{background:#fff;border:1px solid var(--kmt-accent);border-radius:6px;margin-bottom:24px;overflow:hidden}
.kmt-receipt-notice__summary{list-style:none;cursor:pointer;padding:14px 20px;display:flex;gap:14px;align-items:center;transition:background .15s}
.kmt-receipt-notice__summary::-webkit-details-marker{display:none}
.kmt-receipt-notice__summary:hover{background:#faf9fc}
.kmt-receipt-notice__icon{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--kmt-main);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:bold;font-family:"Times New Roman","YuMincho",serif;font-style:italic}
.kmt-receipt-notice__title{flex:1;font-weight:bold;color:var(--kmt-main);font-size:15px}
.kmt-receipt-notice__arrow{flex:0 0 16px;color:var(--kmt-accent);font-size:12px;transition:transform .2s}
.kmt-receipt-notice__arrow::before{content:"\25BC"}
.kmt-receipt-notice[open] .kmt-receipt-notice__arrow{transform:rotate(180deg)}
.kmt-receipt-notice__body{padding:0 20px 14px 62px;color:#333;font-size:14px;line-height:1.7}
.kmt-receipt-notice__item{margin:0 0 2px;font-size:14px}
.kmt-receipt-notice__item:last-child{margin-bottom:0}
.kmt-receipt-notice__item strong{color:var(--kmt-main)}

/* 必須・任意マーク（共通） */
.required-mark{display:inline-block;padding:2px 6px;background:#dc3545;color:#fff;font-size:.75em;border-radius:2px;font-weight:normal;white-space:nowrap;flex-shrink:0}
.optional-mark{display:inline-block;padding:2px 6px;background:#888;color:#fff;font-size:.75em;border-radius:2px;font-weight:normal;white-space:nowrap;flex-shrink:0}

/* Symfony Form エラー */
.invalid-feedback,ul.list-unstyled li{color:#dc3545;font-size:.85em;margin:4px 0 0;list-style:none}

/* プレースホルダーを薄く */
.kmt-input input::placeholder,
.kmt-input textarea::placeholder{color:#c8c4d4;opacity:1}

/* picture 要素を子の img と同じサイズで表示 */
picture{display:contents}

/* レスポンシブ（input.twig 関連） */
@media(max-width:768px){
.kmt-form__row{grid-template-columns:1fr;gap:4px}
.kmt-form__label{padding-top:0}
.kmt-form__label:empty{display:none}
.kmt-form__postal-wrap{flex-direction:column;align-items:stretch}
.kmt-form__postal-wrap input{max-width:100%}
.kmt-sender-layout{flex-direction:column}
.kmt-sender-layout__products{width:100%;flex:none}
.kmt-sender-layout__examples{flex:none;width:100%;position:static}
.kmt-sender-card{padding:12px;min-height:auto}
.kmt-sender-card__product-row{gap:12px}
.kmt-sender-card__image{flex:0 0 140px}
.kmt-sender-card__image img{width:140px;height:140px}
.kmt-sender-card__name{font-size:.95em}
.kmt-sender-card__price{font-size:.95em}
.kmt-sender-card__input-row{width:100%}
.kmt-sender-card__textarea{width:100%;box-sizing:border-box;min-height:50px}
.kmt-receipt-notice__summary{padding:12px 14px;gap:10px}
.kmt-receipt-notice__title{font-size:14px}
.kmt-receipt-notice__body{padding:0 14px 12px 52px;font-size:13px}
.kmt-receipt-notice__item{font-size:13px}
}

/* ===========================================================================
   ご注文内容ご確認ステップ専用(confirm.twig 統一版)
   Phase 2-A.10.7 で追加
   =========================================================================== */

/* ラッパー */
.kmt-confirm{max-width:820px;margin:0 auto;padding:20px 16px 60px}


/* 注意書きボックス(紫アウトライン+iアイコン・汎用) */
.kmt-notice{background:#fff;border:1px solid var(--kmt-accent);border-radius:6px;padding:16px 20px;margin-bottom:24px;display:flex;gap:14px;align-items:flex-start}
.kmt-notice__icon{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--kmt-main);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:bold;font-family:"Times New Roman","YuMincho",serif;font-style:italic;margin-top:2px}
.kmt-notice__body{flex:1;color:#333;font-size:15px;line-height:1.7}
.kmt-notice__title{margin:0 0 4px;font-weight:bold;color:var(--kmt-main)}
.kmt-notice__text{margin:0;font-size:14px}


/* ===========================================================================
   input/confirm 用 .kmt-section オーバーライド (Phase 2-A.10.7 根本修正版)
   元の .kmt-section{padding:0;max-width:820px;overflow:hidden}は complete用。
   input/confirm では padding:20px+負margin見出しで紫帯がセクション角に張り付く。
   =========================================================================== */
.kmt-input .kmt-section,
.kmt-confirm .kmt-section,
.fnr-payment .kmt-section {
    max-width: 820px;
    padding: 20px;
    margin: 0 auto 24px auto;
    overflow: visible;
}
.kmt-input .kmt-section__heading,
.kmt-confirm .kmt-section__heading,
.fnr-payment .kmt-section__heading {
    margin: -20px -20px 20px;
    padding: 12px 20px;
    border-radius: 4px 4px 0 0;
    font-size: 1.05em;
}

/* ====================================================================
   Breadcrumb font-size 統一 (Phase 2-A.10.8 2026-05-11)
   全画面のパンくずを font-size: 14px に統一
   ====================================================================
*/
.kmt-breadcrumb,
.kmt-breadcrumb a,
.kmt-breadcrumb span,
.funeral-order-input__breadcrumb,
.funeral-detail__breadcrumb,
.funeral-order-payment__breadcrumb,
.ext-products__breadcrumb,
.ext-input__breadcrumb,
.ext-confirm__breadcrumb {
    font-size: 14px !important;
    line-height: 1.6 !important;
}


/* ===== fnr-agreement 幅統一 (2026-05-11) ===== */
.fnr-agreement { max-width: 820px; margin-left: auto; margin-right: auto; box-sizing: border-box; }


/* ===== 完了画面 トップページへボタン (External/complete.twig 専用、幅820px) 2026-05-11 ===== */
.fnr-home-link-wrap {
    max-width: 820px;
    margin: 30px auto 20px;
    padding: 0;
    box-sizing: border-box;
}
@media (max-width: 600px) {
    .fnr-home-link-wrap { padding: 0 16px; }
}
.fnr-home-link {
    display: block;
    width: 100%;
    padding: 16px 24px;
    background: var(--kmt-main);
    color: #fff !important;
    text-align: center;
    text-decoration: none;
    font-weight: bold;
    font-size: 15px;
    border-radius: 4px;
    box-sizing: border-box;
    transition: background 0.15s;
}
.fnr-home-link:hover {
    background: #2e1f6b;
    color: #fff !important;
    text-decoration: none;
}
/* ===== kmt-flash (Phase 2-A.10.9.5 External/index refactor 2026-05-11) ===== */
.kmt-flash { padding: 12px 16px; border-radius: 4px; margin: 16px auto; font-size: 14px; max-width: 820px; box-sizing: border-box; }
.kmt-flash--success { background: #e8f5e9; border-left: 4px solid #4caf50; color: #2e7d32; }
.kmt-flash--error { background: #ffebee; border-left: 4px solid #f44336; color: #c62828; }

/* ===== DateTimeType セレクト群の横並びコンパクト化 (Phase 2-A.10.9.5 2026-05-11) ===== */
.kmt-form__input--datetime { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.kmt-form__input--datetime select { width: auto; min-width: 105px; flex-shrink: 0; padding: 8px 28px 8px 12px; font-size: 14px; }

/* ====================================================================
 * Phase 2-A.10 Funeral/detail kmt-* 化対応
 * 2026-05-12 追加: kmt-funeral-info--detail モード（葬儀詳細画面用）
 * ==================================================================== */

/* --------- kmt-funeral-info--detail（Funeral/detail 用拡張）--------- */
.kmt-funeral-info--detail {
    margin-bottom: 30px;
}

/* 締切ボックス */
.kmt-funeral-info__deadline {
    margin: 0 20px 16px;
    padding: 12px 16px;
    background: #fff5f5;
    border: 1px solid #f5c6cb;
    border-left: 4px solid var(--kmt-danger);
    border-radius: 3px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.kmt-funeral-info__deadline-label {
    flex: 0 0 auto;
    padding: 4px 10px;
    background: var(--kmt-danger);
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    border-radius: 2px;
}
.kmt-funeral-info__deadline-value {
    flex: 1;
    color: var(--kmt-danger);
    font-size: 14px;
    font-weight: bold;
}

/* 公開メモ */
.kmt-funeral-info__public-note {
    margin: 0 20px 20px;
    padding: 12px 16px;
    background: var(--kmt-bg);
    border-radius: 3px;
    font-size: 13px;
    color: var(--kmt-text);
    line-height: 1.7;
    white-space: pre-line;
}

@media (max-width: 600px) {
    .kmt-funeral-info__deadline {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }
    .kmt-funeral-info__deadline-value {
        font-size: 13px;
    }
}


/* ====================================================================
 * Phase 2-A.10 Funeral/detail kmt-* 化対応
 * 2026-05-12 追加: kmt-category-nav（カテゴリアンカーナビ・案6-E+6-F）
 * ==================================================================== */

/* カテゴリアンカーナビ（案6-E+6-F / プレミアム立体感 + 現在地ハイライト） */
.kmt-category-nav {
    margin: 32px 0;
    padding: 6px;
}
.kmt-category-nav__header {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 16px;
    padding-left: 4px;
}
.kmt-category-nav__en {
    font-size: 11px;
    color: #aaa;
    letter-spacing: 3px;
    font-weight: 500;
}
.kmt-category-nav__line {
    flex: 1;
    height: 1px;
    background: #e0dcd5;
}
.kmt-category-nav__count {
    font-size: 12px;
    color: #888;
}
.kmt-category-nav__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}
.kmt-category-nav__item {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px 10px;
    background: #fff;
    color: var(--kmt-main);
    text-decoration: none;
    border: none;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 500;
    text-align: center;
    line-height: 1.4;
    box-shadow: 0 1px 3px rgba(63, 42, 140, .08), 0 10px 24px -8px rgba(63, 42, 140, .18);
    transition: transform .2s ease-out, box-shadow .2s ease-out, background .25s ease-out, color .25s ease-out;
    min-height: 52px;
}
.kmt-category-nav__item:hover {
    transform: translateY(-3px);
    box-shadow: 0 2px 6px rgba(63, 42, 140, .12), 0 16px 32px -10px rgba(63, 42, 140, .28);
    color: var(--kmt-main);
}
.kmt-category-nav__item.is-active {
    background: linear-gradient(to right, var(--kmt-main), var(--kmt-accent-light));
    color: #fff;
    box-shadow: 0 6px 18px rgba(63, 42, 140, .3);
    transform: translateY(-2px);
}
.kmt-category-nav__item.is-active:hover {
    color: #fff;
    transform: translateY(-3px);
}

/* タブレット（3列） */
@media (max-width: 900px) {
    .kmt-category-nav__grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
    .kmt-category-nav__item { padding: 16px 8px; font-size: 12.5px; }
}

/* スマホ（2列） */
@media (max-width: 600px) {
    .kmt-category-nav { margin: 36px 0 24px; }
    .kmt-category-nav__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .kmt-category-nav__item { padding: 14px 8px; font-size: 12px; min-height: 46px; }
}


/* ====================================================================
 * Phase 2-A.10 Funeral/detail Phase 2D クリーンアップ
 * 2026-05-12 追加: kmt-funeral-detail / kmt-category-section / kmt-product-list / kmt-product-card 系を一気に集約
 * （inline <style> から完全移行・遺物 CSS（fd-info, fd-hero, funeral-cart）は削除）
 * ==================================================================== */

/* ===== kmt-funeral-detail（葬儀詳細ページのコンテナ + 警告/no-products）===== */
.kmt-funeral-detail { max-width: 1000px; margin: 0 auto; padding: 20px 16px 60px; }
.kmt-funeral-detail__deadline-warning {
    background: #fff3cd; border: 1px solid #ffc107; padding: 16px;
    border-radius: 4px; margin: 24px 0; text-align: center;
}
.kmt-funeral-detail__deadline-warning strong { color: #b00; }
.kmt-funeral-detail__no-products {
    padding: 40px 16px; text-align: center; background: #f7f7f7; border-radius: 4px;
}

/* ===== カテゴリセクション（薄ラベンダー背景） ===== */
.kmt-category-section { margin: 40px 0; scroll-margin-top: 20px; }
.kmt-category-section__heading {
    font-size: 1.3em; padding: 14px 22px; margin: 0;
    background: linear-gradient(to right, var(--kmt-main), var(--kmt-accent-light)); color: #fff;
    border-radius: 4px 4px 0 0;
    font-weight: 500;
    letter-spacing: 0.05em;
}
.kmt-category-section__body {
    background: #ebeaf5;
    padding: 24px 20px;
    border-radius: 0 0 4px 4px;
    border: 1px solid #d4d1e8;
    border-top: none;
}

/* ===== 商品リスト（2列グリッド） ===== */
.kmt-product-list {
    list-style: none; padding: 0; margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

/* ===== 商品カード ===== */
.kmt-product-card {
    border: 1px solid #e0dce8;
    border-radius: 6px;
    background: #fff;
    overflow: hidden;
    transition: box-shadow .15s, border-color .15s;
    display: flex;
    flex-direction: column;
}
.kmt-product-card:hover {
    border-color: var(--kmt-main);
    box-shadow: 0 2px 12px rgba(63, 42, 140, .1);
}
.kmt-product-card__image {
    width: 100%;
    height: 300px;
    padding-top: 12px;
    box-sizing: border-box;
    background: #f7f7f7;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}
.kmt-product-card__image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.kmt-product-card__body {
    padding: 14px 16px 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.kmt-product-card__name-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
    margin-bottom: 10px;
}
.kmt-product-card__name {
    font-size: 1.1em;
    margin: 0;
    line-height: 1.4;
    color: var(--kmt-main);
    font-weight: 500;
    flex: 1;
    min-width: 0;
}
.kmt-product-card__code {
    font-size: .85em;
    color: #888;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 4px;
}
.kmt-product-card__desc {
    font-size: .9em;
    color: #555;
    margin: 0 0 14px;
    line-height: 1.7;
    flex: 1;
}
.kmt-product-card__price-row {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: flex-end;
    margin-bottom: 14px;
}
.kmt-product-card__unit-badge {
    display: inline-block;
    background: #d9344f;
    color: #fff;
    font-size: .85em;
    padding: 3px 10px;
    border-radius: 3px;
    font-weight: 500;
    line-height: 1.3;
}
.kmt-product-card__price {
    font-size: 1.3em;
    font-weight: bold;
    color: #d9344f;
    line-height: 1.2;
}
.kmt-product-card__price-unit {
    font-size: .65em;
    font-weight: normal;
    color: #888;
    margin-left: 2px;
}
.kmt-product-card__order-form {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    margin: 0;
    justify-content: space-between;
}
.kmt-product-card__qty-label { font-size: .9em; color: #555; margin: 0; }
.kmt-product-card__qty-select {
    width: 70px; padding: 8px 6px; border: 1px solid #ccc;
    border-radius: 4px; font-size: 1em; text-align: center; background: #fff;
}

/* ===== 商品カード - カートに入れるボタン（オレンジ） ===== */
.kmt-product-card__cart-btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 18px;
    background: #f29b3b;
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 1em;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease-out; box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    line-height: 1.4;
}
.kmt-product-card__cart-btn:hover { background: #e08a28; transform: translateY(-3px); box-shadow: 0 6px 16px rgba(242,155,59,0.4); }
.kmt-product-card__cart-btn:active { transform: translateY(-1px); box-shadow: 0 2px 8px rgba(242,155,59,0.3); }

/* ===== 商品カード - 電話番号案内（受付終了時） ===== */
.kmt-product-card__phone-guide { text-align: center; padding: 8px 0; }
.kmt-product-card__phone-text { font-size: .85em; color: #999; margin: 0 0 8px; }
.kmt-product-card__phone-link {
    display: inline-block; padding: 10px 18px; background: #f5f5f5;
    border: 1px solid #ddd; border-radius: 4px;
    color: #333; text-decoration: none; font-size: .9em;
    line-height: 1.5; transition: all 0.2s ease-out; box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
.kmt-product-card__phone-link:hover { background: #eee; color: #333; }
.kmt-product-card__phone-link strong { color: var(--kmt-main); font-size: 1.15em; }

/* ===== 商品カード - 汎用アクション（受付終了表示用） ===== */
.kmt-product-card__action { text-align: center; margin-top: auto; }
.kmt-product-card__btn {
    display: inline-block; padding: 10px 20px; background: var(--kmt-main);
    color: #fff; text-decoration: none; border-radius: 4px;
    font-size: .9em; transition: background .15s; min-width: 160px;
}
.kmt-product-card__btn:hover { background: #301f6d; color: #fff; }
.kmt-product-card__btn--disabled { background: #ccc; cursor: not-allowed; }
.kmt-product-card__btn--disabled:hover { background: #ccc; }

/* ===== <picture> 要素を子の img と同じサイズで表示（WebP対応） ===== */
.kmt-product-card picture {
    display: contents;
}

/* ===== レスポンシブ（タブレット〜スマホ） ===== */
@media (max-width: 768px) {
    .kmt-product-list { grid-template-columns: 1fr; gap: 16px; }
    .kmt-category-section__body { padding: 16px 12px; }
    .kmt-product-card__image {
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .kmt-product-card__body {
        padding: 18px 20px 20px;
    }
    .kmt-product-card__order-form { justify-content: center; }
}

/* ===== フローティング「カートを確認」ボタン ===== */
.kmt-cart-floating {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: linear-gradient(to right, var(--kmt-main), var(--kmt-accent-light));
    color: #fff;
    padding: 14px 22px;
    border-radius: 999px;
    box-shadow: 0 4px 16px rgba(63, 42, 140, 0.35);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: 14px;
    z-index: 999;
    transition: transform 0.2s, box-shadow 0.2s, opacity 0.3s;
}
.kmt-cart-floating:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(63, 42, 140, 0.5);
    color: #fff;
    text-decoration: none;
}
.kmt-cart-floating.is-hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateY(16px);
}
@media (max-width: 768px) {
    .kmt-cart-floating {
        bottom: 16px;
        right: 16px;
        padding: 12px 18px;
        font-size: 13px;
    }
}

/* ============================================================
   お届け先（他社会館）partial - 編集リンク（2026-05-12）
   _funeral_info_external.twig が editUrl 引数付きで呼ばれた時のみ表示
   ============================================================ */
.kmt-funeral-info__title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}
.kmt-funeral-info__title .kmt-funeral-info__heading {
    margin-bottom: 0;
}
.kmt-funeral-info__edit {
    font-size: 13px;
    font-weight: normal;
    color: #5d5040;
    text-decoration: underline;
}
.kmt-funeral-info__edit:hover {
    color: #000;
}


/* ============================================================
   Payment 共通スタイル (Phase 2-A.10.8 2026-05-19)
   3カテゴリ共通: 自社葬儀 / 外部配送 / お盆
   inline <style> から共通化、CSS変数を --kmt-* に統一
   ============================================================ */

/* payment 本体ラッパー */
.fnr-payment {
    max-width: 820px;
    margin: 0 auto;
    padding: 20px 16px 60px;
    color: var(--kmt-text);
    line-height: 1.7;
}

/* お支払い方法 (v5: 実input ラジオ) */
.fnr-pay-method-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 18px;
}
.fnr-pay-method-option {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 18px;
    border: 2px solid var(--kmt-border-soft);
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}
.fnr-pay-method-option:hover {
    border-color: var(--kmt-accent);
    background: var(--kmt-bg-soft);
}
.fnr-pay-method-option input[type="radio"] {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    accent-color: var(--kmt-main);
    flex-shrink: 0;
    cursor: pointer;
}
.fnr-pay-method-option:has(input:checked) {
    border-color: var(--kmt-main);
    background: var(--kmt-bg-soft);
}
.fnr-pay-method-option__body { flex: 1; }
.fnr-pay-method-option__title {
    font-weight: bold;
    color: var(--kmt-text);
    font-size: 15px;
    margin-bottom: 4px;
}
.fnr-pay-method-option__note {
    font-size: 12px;
    color: var(--kmt-text-sub);
}

/* カード情報入力枠 (Square SDK) */
.fnr-card-input-wrap {
    background: #fff;
    padding: 18px;
    border-radius: 6px;
    border: 2px solid var(--kmt-accent);
    margin-bottom: 14px;
}
.fnr-card-input-wrap__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.fnr-card-input-wrap__label {
    font-weight: bold;
    color: var(--kmt-main);
    font-size: 14px;
    margin: 0;
}
.fnr-card-input-wrap__brands {
    max-width: 260px;
    flex-shrink: 1;
    min-width: 0;
}
.fnr-card-input-wrap__brands img {
    display: block;
    width: 100%;
    height: auto;
}
#card-container { min-height: 60px; }
#card-container .sq-card-iframe-container { border-radius: 6px; }

/* カード名義入力フィールド */
.fnr-cardholder-field { margin-top: 12px; }
.fnr-cardholder-field label {
    display: block;
    font-size: 0.9em;
    color: var(--kmt-text-sub);
    margin-bottom: 4px;
}
.fnr-cardholder-field input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--kmt-border-soft);
    border-radius: 4px;
    font-size: 1em;
    box-sizing: border-box;
}

/* 同意チェックボックス (max-width は 1184 行の既存定義と共存) */
.fnr-agreement {
    margin-top: 20px;
    padding: 14px 16px;
    background: var(--kmt-bg-soft);
    border-radius: 6px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.fnr-agreement input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin-top: 3px;
    flex: 0 0 auto;
    accent-color: var(--kmt-main);
}
.fnr-agreement label { cursor: pointer; font-size: 13px; }

/* エラーメッセージ */
.fnr-error-msg {
    padding: 12px 16px;
    background: #fff2f4;
    border: 1px solid #f5c2c7;
    border-radius: 6px;
    color: var(--kmt-danger);
    margin-bottom: 16px;
    display: none;
}
.fnr-error-msg.is-visible { display: block; }

/* ローディング表示 */
.fnr-loading {
    display: none;
    text-align: center;
    padding: 20px;
    color: var(--kmt-main);
}
.fnr-loading.is-visible { display: block; }
.fnr-loading::before {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid #ddd;
    border-top-color: var(--kmt-main);
    border-radius: 50%;
    animation: fnr-spin 0.8s linear infinite;
    vertical-align: middle;
    margin-right: 8px;
}
@keyframes fnr-spin { to { transform: rotate(360deg); } }

/* SANDBOX バッジ */
.fnr-sandbox-badge {
    display: inline-block;
    padding: 4px 10px;
    background: #ffc107;
    color: #333;
    font-size: 0.85em;
    font-weight: bold;
    border-radius: 4px;
    margin-left: 8px;
}

/* レスポンシブ */
@media (max-width: 768px) {
    .fnr-card-input-wrap__brands { max-width: 200px; }
}
@media (max-width: 600px) {
    .fnr-buttons { flex-direction: column; }
    .fnr-card-input-wrap__header { flex-direction: column; align-items: flex-start; }
    .fnr-card-input-wrap__brands { max-width: 100%; }
}

/* ===== kmt-flash-dialog (Plan 1 ダイアログ化 2026-05-19) ===== */
.kmt-flash-dialog {
    border: none;
    border-radius: 8px;
    padding: 28px 32px;
    max-width: 420px;
    width: 90%;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
    background: #fff;
    color: var(--kmt-text);
}
.kmt-flash-dialog::backdrop {
    background: rgba(0, 0, 0, 0.5);
}
.kmt-flash-dialog__icon {
    font-size: 36px;
    color: var(--kmt-danger);
    text-align: center;
    margin-bottom: 8px;
    line-height: 1;
}
.kmt-flash-dialog__title {
    font-size: 17px;
    font-weight: bold;
    text-align: center;
    margin: 0 0 14px;
    color: var(--kmt-text);
}
.kmt-flash-dialog__message {
    font-size: 14px;
    color: var(--kmt-text-sub);
    margin: 0 0 20px;
    text-align: center;
    line-height: 1.6;
}
.kmt-flash-dialog__close {
    display: block;
    margin: 0 auto;
    padding: 10px 32px;
    background: var(--kmt-main);
    color: #fff;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    transition: background .15s;
}
.kmt-flash-dialog__close:hover {
    background: var(--kmt-accent-light);
}

/* ============================================================
   kmt-review-card : ご注文内容レビュー用カード (confirm/payment画面)
   _order_review.twig 専用、kmt-sender-card (フォーム入力用) と独立
   ============================================================ */
.kmt-review-card{display:flex;gap:16px;padding:0 0 20px 0;margin-bottom:20px;border-bottom:1px solid #eee}
.kmt-review-card:last-of-type{padding-bottom:0;margin-bottom:0;border-bottom:none}
.kmt-review-card__image{flex:0 0 180px}
.kmt-review-card__image img{width:180px;height:180px;object-fit:contain;border:1px solid #e6dfd3;border-radius:4px;background:#fff}
.kmt-review-card__body{flex:1;min-width:0}
.kmt-review-card__top{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:10px;border-bottom:1px solid #eee;flex-wrap:wrap;gap:8px}
.kmt-review-card__top-left .kmt-review-card__name{font-size:16px;font-weight:bold;color:#333}
.kmt-review-card__unit-price{font-size:12px;color:#888;margin-top:3px}
.kmt-review-card__top-right{text-align:right}
.kmt-review-card__qty-label{font-size:12px;color:#666}
.kmt-review-card__subtotal{font-size:18px;font-weight:bold;color:var(--kmt-main);margin-top:2px}
.kmt-review-card__senders-box{margin-top:12px;background:#faf6eb;border-left:4px solid #b08a3a;padding:12px 16px}
.kmt-review-card__senders-label{font-size:11px;color:#8b6820;font-weight:bold;letter-spacing:.05em}
.kmt-review-card__senders-list{margin-top:6px}
.kmt-review-card__sender-item{font-size:18px;color:#222;font-weight:bold;line-height:1.7;letter-spacing:.02em;font-family:"YuMincho","Yu Mincho","Hiragino Mincho ProN","游明朝","ＭＳ Ｐ明朝","MS PMincho",serif}

/* スマホ */
@media (max-width: 600px){
    .kmt-review-card{gap:12px}
    .kmt-review-card__image{flex:0 0 140px}
    .kmt-review-card__image img{width:140px;height:140px}
    .kmt-review-card__top{flex-direction:column;gap:2px}
    .kmt-review-card__top-right{text-align:left}
    .kmt-review-card__top-left .kmt-review-card__name{font-size:14px}
    .kmt-review-card__unit-price{display:none}
    .kmt-review-card__qty-label{font-size:11px}
    .kmt-review-card__subtotal{font-size:16px}
    .kmt-review-card__senders-label{font-size:11px}
    .kmt-review-card__sender-item{font-size:13px}
}

/* ===========================================================================
   Toast 通知 (kmt-toast)
   showToast(message, type) で動的生成。type: error (default) / success / info
   =========================================================================== */
.kmt-toast-container{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);display:flex;flex-direction:column-reverse;gap:8px;z-index:9999;pointer-events:none;max-width:90vw}
.kmt-toast{display:flex;align-items:center;gap:12px;min-width:280px;max-width:480px;padding:14px 18px;background:#fff;color:#18181b;border:1px solid #e4e4e7;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.04);font-size:14px;line-height:1.5;opacity:0;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease;pointer-events:auto}
.kmt-toast.is-visible{opacity:1;transform:translateY(0)}
.kmt-toast__icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:11px;font-weight:600;color:#fff;flex-shrink:0;line-height:1}
.kmt-toast--error .kmt-toast__icon{background:#ef4444}
.kmt-toast--success .kmt-toast__icon{background:#22c55e}
.kmt-toast--info .kmt-toast__icon{background:#3b82f6}
.kmt-toast__message{flex:1}
.kmt-toast__close{font-size:14px;cursor:pointer;opacity:.4;color:#18181b;flex-shrink:0;padding:0 4px;line-height:1;user-select:none}
.kmt-toast__close:hover,.kmt-toast__close:focus{opacity:.8;outline:none}
@media(max-width:768px){
    .kmt-toast-container{left:16px;right:16px;bottom:16px;transform:none;max-width:none}
    .kmt-toast{min-width:0;max-width:none;width:100%;box-sizing:border-box}
}

/* --------- kmt-hero 内蔵パンくず（ヒーロー左上に重ねる） --------- */
.kmt-hero__breadcrumb {
    position: absolute;
    top: 18px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 1180px;
    box-sizing: border-box;
    padding: 0 24px;
    z-index: 2;
    display: flex;
    justify-content: flex-start;
    line-height: 1.4;
}
/* テキストの質で見せる: ブランド色・14px・字間（下地なし） */
.kmt-hero__breadcrumb-inner {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    font-family: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: var(--kmt-main);
}
.kmt-hero__breadcrumb a { color: var(--kmt-main); text-decoration: none; }
.kmt-hero__breadcrumb a:hover { text-decoration: underline; }
.kmt-hero__breadcrumb-inner > span:last-child { color: var(--kmt-text-sub); }
.kmt-hero__breadcrumb-sep { color: var(--kmt-accent); font-weight: 400; }
.kmt-hero--plain { background: var(--kmt-bg-soft); }
@media (max-width: 600px) {
    .kmt-hero__breadcrumb { top: 12px; }
    .kmt-hero__breadcrumb-inner { font-size: 12px; gap: 8px; }
}
