@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.17
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* =========================================================
 * Beetle House カブ王 カスタムスタイル
 * 方針: !important は使わず詳細度で勝負。
 *       SWELL カスタマイザーで対応できる箇所はそちらに委譲。
 * ========================================================= */

:root {
    --kabuou-font-jp: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
    --kabuou-color-price: #962c15;       /* 価格 */
    --kabuou-color-stock-in: #4b7;       /* 在庫あり */
    --kabuou-color-stock-out: #de0000;   /* 在庫切れ */
    --kabuou-color-accent: #E47A13;      /* オレンジアクセント */
    --kabuou-color-cool: #28B8B8;        /* クール便ティール */
}

body,
.l-content {
    font-family: var(--kabuou-font-jp);
}

/* =========================================================
 * WooCommerce 商品一覧グリッド (メインコンテンツ)
 * ========================================================= */
body .l-mainContent .woocommerce ul.products,
body .l-mainContent .woocommerce-page ul.products {
    display: grid;
    gap: 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}

body .l-mainContent .woocommerce ul.products.columns-1 { grid-template-columns: repeat(1, 1fr); }
body .l-mainContent .woocommerce ul.products.columns-2 { grid-template-columns: repeat(2, 1fr); }
body .l-mainContent .woocommerce ul.products.columns-3 { grid-template-columns: repeat(3, 1fr); }
body .l-mainContent .woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); }
body .l-mainContent .woocommerce ul.products.columns-5 { grid-template-columns: repeat(5, 1fr); }
body .l-mainContent .woocommerce ul.products.columns-6 { grid-template-columns: repeat(6, 1fr); }

body .l-mainContent .woocommerce ul.products:not([class*="columns-"]) {
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 959px) {
    body .l-mainContent .woocommerce ul.products.columns-4,
    body .l-mainContent .woocommerce ul.products.columns-5,
    body .l-mainContent .woocommerce ul.products.columns-6,
    body .l-mainContent .woocommerce ul.products:not([class*="columns-"]) {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 599px) {
    body .l-mainContent .woocommerce ul.products.columns-2,
    body .l-mainContent .woocommerce ul.products.columns-3,
    body .l-mainContent .woocommerce ul.products.columns-4,
    body .l-mainContent .woocommerce ul.products.columns-5,
    body .l-mainContent .woocommerce ul.products.columns-6,
    body .l-mainContent .woocommerce ul.products:not([class*="columns-"]) {
        grid-template-columns: repeat(2, 1fr);
    }
    body .l-mainContent .woocommerce ul.products.columns-1 {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* WC の clearfix / 互換用ダミー li を grid から除外 */
body .l-mainContent .woocommerce ul.products::before,
body .l-mainContent .woocommerce ul.products::after {
    content: none;
    display: none;
}
body .l-mainContent .woocommerce ul.products > li:not(.product),
body .l-mainContent .woocommerce ul.products > .clear {
    display: none;
}

/* 商品カード */
body .l-mainContent .woocommerce ul.products li.product {
    background: #ffffff;
    transition: box-shadow 0.2s;
    padding: 12px;
    border-radius: 4px;
    border: 1px solid #f0f0f0;
    width: auto;
    margin: 0;
    float: none;
    display: flex;
    flex-direction: column;
    height: 100%;
}
body .l-mainContent .woocommerce ul.products li.product:hover {
    box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

/* サムネイル: 4:3 横長 (max-height で巨大画像の暴れを抑止) */
body .woocommerce ul.products li.product img,
body .woocommerce ul.products li.product a img,
body .woocommerce ul.products li.product figure img,
body .woocommerce ul.products li.product .wp-post-image,
body .woocommerce ul.products li.product img.attachment-woocommerce_thumbnail {
    aspect-ratio: 4 / 3 !important;
    object-fit: cover !important;
    width: 100% !important;
    height: auto !important;
    max-height: 280px !important;
    margin: 0 0 8px 0;
    border-radius: 2px;
    display: block;
}

body .woocommerce ul.products li.product {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* 商品名: 3行省略 */
body .l-mainContent .woocommerce ul.products li.product .woocommerce-loop-product__title,
body .l-mainContent .woocommerce ul.products li.product h2,
body .l-mainContent .woocommerce ul.products li.product h3 {
    background: transparent;
    color: #444;
    font-size: 0.95rem;
    line-height: 1.4;
    margin: 8px 0;
    padding: 0;
    text-align: left;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex-grow: 1;
}

body .l-mainContent .woocommerce ul.products li.product .price {
    color: var(--kabuou-color-price);
    margin: 4px 0 8px 0;
    font-size: 1.05rem;
    font-weight: bold;
}

body .l-mainContent .woocommerce ul.products li.product .button,
body .l-mainContent .woocommerce ul.products li.product a.added_to_cart {
    background-color: var(--kabuou-color-accent);
    color: #fff;
    border-radius: 2px;
    padding: 8px 12px;
    font-size: 0.85rem;
    margin-top: auto;
    display: inline-block;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
    border: none;
    font-weight: bold;
}
body .l-mainContent .woocommerce ul.products li.product .button:hover {
    background-color: #c66510;
    color: #fff;
}

body .l-mainContent .woocommerce ul.products li.product.outofstock .button {
    background-color: #999;
    cursor: not-allowed;
}

/* =========================================================
 * 単一商品詳細ページ
 * ========================================================= */
body .product .product_title.entry-title {
    font-size: 1.375rem;
    font-weight: bold;
    color: #444;
    line-height: 1.4;
}

.product.type-product .woocommerce div.product p.price,
.product.type-product .woocommerce div.product span.price {
    color: var(--kabuou-color-price);
    font-size: 1.125rem;
    font-weight: bold;
}
.product.type-product .woocommerce div.product p.price ins,
.product.type-product .woocommerce div.product span.price ins {
    text-decoration: none;
}

.product.type-product .woocommerce div.product p.in-stock,
.product.type-product .woocommerce div.product .stock.in-stock {
    color: var(--kabuou-color-stock-in);
    font-weight: bold;
}
.product.type-product .woocommerce div.product p.out-of-stock,
.product.type-product .woocommerce div.product .stock.out-of-stock {
    color: var(--kabuou-color-stock-out);
    font-weight: bold;
}

.product.type-product .woocommerce div.product .sku_wrapper {
    color: #707070;
    font-size: 0.875rem;
}

/* 関連商品見出し */
body .woocommerce-Tabs-panel--description h2,
body .woocommerce .related h2,
body .woocommerce .upsells h2,
body .woocommerce .cross-sells h2 {
    color: #c71;
    font-size: 1rem;
    border-left: 4px solid var(--kabuou-color-accent);
    padding-left: 12px;
    margin-bottom: 1em;
}

/* カート追加ボタン (商品詳細) */
.product.type-product .woocommerce a.button,
.product.type-product .woocommerce button.button,
.product.type-product .woocommerce input.button,
.product.type-product .woocommerce a.button.alt,
.product.type-product .woocommerce button.button.alt {
    background-color: var(--kabuou-color-accent);
    color: #fff;
    border-radius: 2px;
    font-weight: bold;
    padding: 10px 24px;
    border: none;
}
.product.type-product .woocommerce a.button:hover,
.product.type-product .woocommerce button.button:hover {
    background-color: #c66510;
    color: #fff;
}

/* =========================================================
 * 商品バッジ (NEW / オススメ等)
 * ========================================================= */
.product .product-tags {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 5;
}
.product .product-tags .badge {
    display: inline-block;
    padding: 2px 8px;
    margin-right: 4px;
    color: #fff;
    font-size: 0.75rem;
    border-radius: 2px;
    font-weight: bold;
}
.product .product-tags .badge-new        { background: #de0000; }
.product .product-tags .badge-recommend  { background: var(--kabuou-color-accent); }
.product .product-tags .badge-limited    { background: #962c15; }
.product .product-tags .badge-staff      { background: #28B8B8; }
.product .product-tags .badge-season     { background: #4b7; }
.product .product-tags .badge-reservation{ background: #707070; }

/* =========================================================
 * サイドバー内 商品ウィジェット ([products] ショートコード)
 * ========================================================= */
body .l-sidebar .woocommerce ul.products,
body .widget .woocommerce ul.products {
    display: block;
    grid-template-columns: none;
    margin: 0;
    padding: 0;
}
body .l-sidebar .woocommerce ul.products li.product,
body .widget .woocommerce ul.products li.product {
    display: block;
    width: 100%;
    float: none;
    margin: 0 0 12px 0;
    padding: 8px;
    border: 1px solid #eee;
    background: #fff;
    box-sizing: border-box;
}
body .l-sidebar .woocommerce ul.products li.product img,
body .widget .woocommerce ul.products li.product img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
    margin-bottom: 4px;
}
body .l-sidebar .woocommerce ul.products li.product .woocommerce-loop-product__title,
body .widget .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 0.85rem;
    margin: 4px 0;
    -webkit-line-clamp: 2;
    flex-grow: 0;
}
body .l-sidebar .woocommerce ul.products li.product .button,
body .widget .woocommerce ul.products li.product .button {
    font-size: 0.75rem;
    padding: 4px 8px;
    margin-top: 4px;
}

/* =========================================================
 * 商品説明内の必読事項 (.important_text_val)
 * ========================================================= */
.entry-content .important_text_val,
.product_content .important_text_val {
    background: #fff8e8;
    border-left: 4px solid var(--kabuou-color-accent);
    padding: 12px 16px;
    margin: 1em 0;
    border-radius: 0 4px 4px 0;
}

/* =========================================================
 * 全体レイアウト: コンテナ幅
 * ========================================================= */
.l-content,
.l-container {
    max-width: 1400px;
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    box-sizing: border-box;
}

body.archive.woocommerce .l-content,
body.woocommerce-shop .l-content {
    max-width: 1600px;
}

body .post_content,
body .entry-content {
    max-width: 100%;
}

/* Word 由来 <font> タグの font-family/size を打ち消す */
.entry-content font[face],
.entry-content font[size] {
    font-family: inherit;
    font-size: inherit;
}

/* =========================================================
 * カテゴリページ
 * ========================================================= */
.woocommerce .term-description {
    margin-bottom: 2em;
}
.woocommerce .product-category {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 4px;
    overflow: hidden;
}

/* =========================================================
 * 検索結果なし / お知らせ
 * ========================================================= */
.woocommerce-info,
.woocommerce-no-products-found {
    background: #fff8e8;
    border-left: 4px solid var(--kabuou-color-accent);
    color: #444;
}

/* =========================================================
 * Contact Form 7
 * ========================================================= */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form textarea {
    border: 1px solid #ccc;
    padding: 8px 12px;
    border-radius: 2px;
    width: 100%;
}
.wpcf7-form .required_mark {
    color: #de0000;
    font-size: 0.75rem;
    background: #fee;
    padding: 1px 6px;
    border-radius: 2px;
    margin-left: 4px;
}
.wpcf7-form input[type="submit"] {
    background-color: var(--kabuou-color-accent);
    color: #fff;
    border: none;
    padding: 12px 32px;
    border-radius: 2px;
    cursor: pointer;
    font-weight: bold;
    font-size: 1rem;
}
.wpcf7-form input[type="submit"]:hover {
    background-color: #c66510;
}

/* =========================================================
 * モバイル: 商品名・価格の文字サイズ
 * ========================================================= */
@media (max-width: 768px) {
    body .l-mainContent .woocommerce ul.products li.product .woocommerce-loop-product__title {
        font-size: 0.85rem;
    }
    body .l-mainContent .woocommerce ul.products li.product .price {
        font-size: 0.95rem;
    }
}

/* =========================================================
 * 配送サイズ別 送料表 [shipping_size_table]
 * ========================================================= */
.shipping-size-table {
    margin: 1.2em 0;
    padding: 1em;
    background: #fff8e8;
    border: 1px solid #e6d8b8;
    border-radius: 4px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.shipping-size-table__title {
    font-size: 0.95rem;
    font-weight: 700;
    margin: 0 0 0.6em;
    color: var(--kabuou-color-price);
}
.shipping-size-table table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
    background: #fff;
}
.shipping-size-table th,
.shipping-size-table td {
    border: 1px solid #e0d8c8;
    padding: 6px 8px;
    text-align: center;
    white-space: nowrap;
}
.shipping-size-table thead th {
    background: #f5f1e6;
    font-weight: 700;
    color: #333;
}
.shipping-size-table tbody td:first-child {
    text-align: left;
    background: #faf6e8;
    font-weight: 500;
    white-space: normal;
    line-height: 1.4;
    min-width: 7em;
}
.shipping-size-table__pref {
    display: block;
    margin-top: 2px;
    font-size: 0.72rem;
    font-weight: 400;
    color: #777;
}
.shipping-size-table__note {
    font-size: 0.78rem;
    color: #666;
    margin: 0.6em 0 0;
}
@media (max-width: 599px) {
    .shipping-size-table {
        padding: 0.5em;
    }
    .shipping-size-table table {
        font-size: 0.72rem;
    }
    .shipping-size-table th,
    .shipping-size-table td {
        padding: 4px 5px;
    }
    .shipping-size-table tbody td:first-child {
        min-width: 5.5em;
    }
    .shipping-size-table__pref {
        font-size: 0.62rem;
        line-height: 1.3;
    }
}

/* =========================================================
 * 営業日カレンダー [biz_calendar]
 * ========================================================= */
.biz-calendar {
    font-size: 0.85rem;
    line-height: 1.4;
}
.biz-calendar__month + .biz-calendar__month {
    margin-top: 16px;
}
.biz-calendar__title {
    text-align: center;
    font-weight: 700;
    margin-bottom: 6px;
    color: #333;
}
.biz-calendar__table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}
.biz-calendar__head,
.biz-calendar__day,
.biz-calendar__blank {
    text-align: center;
    padding: 4px 0;
    border: 1px solid #eee;
}
.biz-calendar__head {
    background: #f7f7f7;
    font-weight: 600;
    font-size: 0.78rem;
}
.biz-calendar__head.is-sun,
.biz-calendar__day.is-sun {
    color: #c0392b;
}
.biz-calendar__head.is-sat,
.biz-calendar__day.is-sat {
    color: #2471a3;
}
.biz-calendar__day.is-closed {
    background: #ffe2e2;
    color: #c0392b;
    font-weight: 700;
}
.biz-calendar__day.is-today {
    outline: 2px solid #e07b1a;
    outline-offset: -2px;
    font-weight: 700;
}
.biz-calendar__blank {
    background: #fafafa;
    border-color: #f5f5f5;
}
.biz-calendar__legend {
    margin-top: 8px;
    font-size: 0.75rem;
    color: #666;
    display: flex;
    align-items: center;
    gap: 6px;
}
.biz-calendar__legend-mark {
    display: inline-block;
    width: 12px;
    height: 12px;
    background: #ffe2e2;
    border: 1px solid #e8c7c7;
}

/* =========================================================
 * WooCommerce Gutenberg ブロック (.wc-block-grid 系)
 * ========================================================= */
body .wc-block-grid .wc-block-grid__products {
    display: grid;
    gap: 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}
body .wc-block-grid.has-1-columns .wc-block-grid__products { grid-template-columns: repeat(1, 1fr); }
body .wc-block-grid.has-2-columns .wc-block-grid__products { grid-template-columns: repeat(2, 1fr); }
body .wc-block-grid.has-3-columns .wc-block-grid__products { grid-template-columns: repeat(3, 1fr); }
body .wc-block-grid.has-4-columns .wc-block-grid__products { grid-template-columns: repeat(4, 1fr); }
body .wc-block-grid.has-5-columns .wc-block-grid__products { grid-template-columns: repeat(5, 1fr); }
body .wc-block-grid.has-6-columns .wc-block-grid__products { grid-template-columns: repeat(6, 1fr); }

@media (max-width: 959px) {
    body .wc-block-grid.has-4-columns .wc-block-grid__products,
    body .wc-block-grid.has-5-columns .wc-block-grid__products,
    body .wc-block-grid.has-6-columns .wc-block-grid__products {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 599px) {
    body .wc-block-grid.has-2-columns .wc-block-grid__products,
    body .wc-block-grid.has-3-columns .wc-block-grid__products,
    body .wc-block-grid.has-4-columns .wc-block-grid__products,
    body .wc-block-grid.has-5-columns .wc-block-grid__products,
    body .wc-block-grid.has-6-columns .wc-block-grid__products {
        grid-template-columns: repeat(2, 1fr);
    }
}

body .wc-block-grid .wc-block-grid__product,
body .wc-block-grid.has-1-columns .wc-block-grid__product,
body .wc-block-grid.has-2-columns .wc-block-grid__product,
body .wc-block-grid.has-3-columns .wc-block-grid__product,
body .wc-block-grid.has-4-columns .wc-block-grid__product,
body .wc-block-grid.has-5-columns .wc-block-grid__product,
body .wc-block-grid.has-6-columns .wc-block-grid__product {
    flex: none;
    max-width: none;
    background: #ffffff;
    transition: box-shadow 0.2s;
    padding: 12px;
    border-radius: 4px;
    border: 1px solid #f0f0f0;
    display: flex;
    flex-direction: column;
    margin: 0;
    width: auto;
    list-style: none;
    text-align: left;
}
body .wc-block-grid__product:hover {
    box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

body .wc-block-grid__product-link {
    color: inherit;
    text-decoration: none;
    display: block;
}

body .wc-block-grid__product-image {
    margin: 0 0 8px 0;
}
body .wc-block-grid__product-image img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
    height: auto;
    border-radius: 2px;
    display: block;
}

body .wc-block-grid__product-title {
    color: #444;
    font-size: 0.95rem;
    line-height: 1.4;
    margin: 8px 0;
    text-align: left;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex-grow: 1;
}

body .wc-block-grid__product-price {
    color: var(--kabuou-color-price);
    margin: 4px 0 8px 0;
    font-size: 1.05rem;
    font-weight: bold;
}
body .wc-block-grid__product-price .woocommerce-Price-amount {
    color: inherit;
}

body .wc-block-grid__product-add-to-cart .wp-block-button__link {
    background-color: var(--kabuou-color-accent);
    color: #fff;
    border-radius: 2px;
    padding: 8px 12px;
    font-size: 0.85rem;
    margin-top: auto;
    display: block;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
    border: none;
    font-weight: bold;
    text-decoration: none;
}
body .wc-block-grid__product-add-to-cart .wp-block-button__link:hover {
    background-color: #c66510;
    color: #fff;
}

/* カテゴリーリスト */
body .wc-block-product-categories-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
body .wc-block-product-categories-list-item {
    padding: 8px 0;
    border-bottom: 1px dashed #eee;
}
body .wc-block-product-categories-list-item:last-child {
    border-bottom: none;
}
body .wc-block-product-categories-list-item > a {
    color: #444;
    text-decoration: none;
    font-weight: 500;
}
body .wc-block-product-categories-list-item > a:hover {
    color: var(--kabuou-color-accent);
}
body .wc-block-product-categories-list-item-count {
    color: #999;
    font-size: 0.85rem;
    margin-left: 6px;
}
body .wc-block-product-categories-list .wc-block-product-categories-list--depth-1 {
    margin: 6px 0 0 16px;
    padding-left: 12px;
    border-left: 2px solid #f0f0f0;
}
body .wc-block-product-categories-list .wc-block-product-categories-list--depth-1 .wc-block-product-categories-list-item {
    padding: 4px 0;
    border-bottom: none;
}
body .wc-block-product-categories-list .wc-block-product-categories-list--depth-1 .wc-block-product-categories-list-item > a {
    font-weight: 400;
    font-size: 0.92em;
}

/* =========================================================
 * SNS シェアボタン (.c-shareBtns) — ピル型
 * ========================================================= */
body .c-shareBtns {
    margin: 0;
}

body .c-shareBtns__list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-start;
    padding: 0;
    margin: 0;
    list-style: none;
}

/* SWELL の flex:1 を打ち消して内容幅に */
body .c-shareBtns:not(.-style-btn-small) .c-shareBtns__item,
body .c-shareBtns__item {
    flex: 0 0 auto;
    margin: 0;
    padding: 0;
}

/* SWELL の global a 色を上書きするため、<li> ではなく <a> に color を当てる
   (background-color: currentColor で背景色として継承される) */
body .c-shareBtns__item.-facebook  > .c-shareBtns__btn { color: #3b5998; }
body .c-shareBtns__item.-twitter   > .c-shareBtns__btn { color: #1da1f2; }
body .c-shareBtns__item.-twitter-x > .c-shareBtns__btn { color: #000000; }
body .c-shareBtns__item.-line      > .c-shareBtns__btn { color: #00c300; }
body .c-shareBtns__item.-hatebu    > .c-shareBtns__btn { color: #00a4de; }
body .c-shareBtns__item.-pocket    > .c-shareBtns__btn { color: #ef3f56; }
body .c-shareBtns__item.-pinterest > .c-shareBtns__btn { color: #bb0f23; }

body .c-shareBtns__btn {
    background-color: currentColor;
    border-radius: 999px;
    padding: 8px 16px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    line-height: 1;
    text-decoration: none;
    transition: opacity 0.2s, transform 0.2s;
}
body .c-shareBtns__btn:hover {
    opacity: 0.85;
    transform: translateY(-1px);
}

body .c-shareBtns__icon {
    color: #fff;
    --the-icon-size: 14px;
    width: 14px;
    height: 14px;
    line-height: 1;
    margin: 0;
}

/* ラベルテキストはテンプレートに無いため ::after で生成 */
body .c-shareBtns__btn::after {
    color: #fff;
    font-size: 13px;
    font-weight: bold;
    line-height: 1;
    white-space: nowrap;
}
body .c-shareBtns__item.-facebook .c-shareBtns__btn::after  { content: "Facebook"; }
body .c-shareBtns__item.-twitter .c-shareBtns__btn::after,
body .c-shareBtns__item.-twitter-x .c-shareBtns__btn::after { content: "ポスト"; }
body .c-shareBtns__item.-line .c-shareBtns__btn::after      { content: "LINEで送る"; }

/* 前後記事リンク <ul> のデフォルト disc マーカーを打ち消す */
body .p-pnLinks {
    list-style: none;
    padding-left: 0;
}

/* =========================================================
 * 商品詳細ページ: 価格・在庫・メタ情報の視認性
 * ========================================================= */
.product.type-product .summary > .price {
    font-size: 1.8em;
    font-weight: 700;
    color: var(--kabuou-color-price);
    margin: 0.5em 0 1em;
    line-height: 1.2;
}
.product.type-product .summary > .price .woocommerce-Price-currencySymbol {
    font-size: 0.7em;
    margin-left: 0.15em;
}

.product.type-product .woocommerce-product-details__short-description {
    border-top: 1px solid #e6e0d4;
    border-bottom: 1px solid #e6e0d4;
    padding: 1em 0;
    margin: 1em 0;
    line-height: 1.7;
    font-size: 0.95em;
}
.product.type-product .woocommerce-product-details__short-description p {
    margin: 0;
}

/* 在庫ステータス: バッジ */
.product.type-product .summary p.stock {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 4px;
    font-weight: 700;
    font-size: 0.95em;
    margin: 0.5em 0 1.2em;
    line-height: 1;
}
.product.type-product .summary p.stock.out-of-stock {
    background-color: var(--kabuou-color-stock-out);
    color: #fff;
}
.product.type-product .summary p.stock.in-stock {
    background-color: var(--kabuou-color-stock-in);
    color: #fff;
}

/* 商品メタ (商品コード / カテゴリー / タグ) */
.product.type-product .product_meta {
    border-top: 1px solid #e6e0d4;
    padding-top: 1em;
    margin-top: 1.5em;
    font-size: 0.9em;
    line-height: 1.8;
}
.product.type-product .product_meta > span {
    display: block;
    color: #555;
    padding: 4px 0;
}
.product.type-product .product_meta > span:not(:last-child) {
    border-bottom: 1px dotted #ddd;
}
.product.type-product .product_meta .sku {
    font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
    color: #222;
    font-weight: 600;
    background-color: #f5f1e6;
    padding: 1px 6px;
    border-radius: 3px;
    margin-left: 4px;
}
.product.type-product .product_meta a {
    color: var(--kabuou-color-link, #0783c2);
    text-decoration: none;
}
.product.type-product .product_meta a:hover {
    text-decoration: underline;
}

/* 商品詳細「お買い物カゴに追加」ボタン (デフォルトの紫を上書き) */
.product.type-product .single_add_to_cart_button,
.product.type-product button.single_add_to_cart_button {
    background-color: var(--kabuou-color-accent);
    border-color: var(--kabuou-color-accent);
    color: #fff;
    font-weight: bold;
    border-radius: 2px;
    padding: 12px 24px;
    transition: background-color 0.2s;
}
.product.type-product .single_add_to_cart_button:hover,
.product.type-product button.single_add_to_cart_button:hover {
    background-color: #c66510;
    border-color: #c66510;
    color: #fff;
}

/* =========================================================
 * サイドバー: 商品カテゴリーウィジェット (アコーディオン)
 * ========================================================= */
body .l-sidebar .widget_product_categories {
    margin-bottom: 24px;
}
body .l-sidebar .widget_product_categories .c-widget__title {
    background: var(--kabuou-color-main, #2D2020);
    color: #fff;
    font-size: 0.95rem;
    font-weight: 700;
    padding: 12px 14px;
    margin: 0;
    border-radius: 4px 4px 0 0;
    line-height: 1.3;
}

body .l-sidebar .widget_product_categories ul.product-categories {
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid #ddd;
    border-top: none;
    border-radius: 0 0 4px 4px;
    overflow: hidden;
    background: #fff;
}

body .l-sidebar .widget_product_categories li.cat-item {
    list-style: none;
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #ececec;
}
body .l-sidebar .widget_product_categories li.cat-item:last-child {
    border-bottom: none;
}

/* 親カテゴリのリンク行 */
body .l-sidebar .widget_product_categories ul.product-categories > li.cat-item > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 11px 36px 11px 14px;
    background: #f4f1ea;
    color: #333;
    font-weight: 700;
    font-size: 0.92rem;
    text-decoration: none;
    transition: background 0.2s;
    position: relative;
}
body .l-sidebar .widget_product_categories ul.product-categories > li.cat-item > a:hover {
    background: #e8e2d2;
    color: var(--kabuou-color-accent);
}

/* 子なしカテゴリは右に「›」 */
body .l-sidebar .widget_product_categories ul.product-categories > li.cat-item:not(.cat-parent) > a::after {
    content: "›";
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #999;
    font-weight: 400;
    font-size: 1.2em;
    line-height: 1;
}

/* 開閉ボタンの絶対配置基準 */
body .l-sidebar .widget_product_categories ul.product-categories > li.cat-parent {
    position: relative;
}

/* 開閉ボタン (functions.php の JS で挿入) */
body .l-sidebar .widget_product_categories .cat-toggle {
    position: absolute;
    top: 0;
    right: 0;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    border-left: 1px solid #ddd;
    cursor: pointer;
    padding: 0;
    margin: 0;
    transition: background 0.15s;
    z-index: 2;
}
body .l-sidebar .widget_product_categories .cat-toggle:hover {
    background: rgba(228, 122, 19, 0.1);
}
/* 三角アイコン (▼ = 閉、▲ = 開) */
body .l-sidebar .widget_product_categories .cat-toggle::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 5px 0 5px;
    border-color: var(--kabuou-color-stock-out, #de0000) transparent transparent transparent;
    transition: transform 0.2s;
}
body .l-sidebar .widget_product_categories li.cat-parent.is-open > .cat-toggle::before {
    transform: translate(-50%, -50%) rotate(180deg);
}

/* 親リンクの右パディング (開閉ボタンとの重なり防止) */
body .l-sidebar .widget_product_categories ul.product-categories > li.cat-parent > a {
    padding-right: 50px;
}

/* 子カテゴリ <ul> はデフォルト非表示、is-open で展開 */
body .l-sidebar .widget_product_categories li.cat-parent > ul.children {
    display: none;
}
body .l-sidebar .widget_product_categories li.cat-parent.is-open > ul.children {
    display: block;
    animation: catFadeIn 0.2s ease-out;
}
@keyframes catFadeIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* 親リンク横の (0) は隠す */
body .l-sidebar .widget_product_categories li.cat-item > a + span.count {
    display: none;
}
body .l-sidebar .widget_product_categories li.cat-item span.count {
    color: #888;
    font-weight: 400;
    font-size: 0.85em;
    margin-left: 4px;
}

/* 子カテゴリ */
body .l-sidebar .widget_product_categories ul.children {
    list-style: none;
    margin: 0;
    padding: 6px 0;
    background: #fff;
    border-top: 1px solid #ececec;
}
body .l-sidebar .widget_product_categories ul.children li.cat-item {
    border-bottom: none;
}
body .l-sidebar .widget_product_categories ul.children li.cat-item > a {
    display: flex;
    align-items: center;
    padding: 8px 14px 8px 28px;
    background: transparent;
    color: #555;
    font-weight: 400;
    font-size: 0.88rem;
    text-decoration: none;
    transition: color 0.2s, background 0.2s;
    position: relative;
}
body .l-sidebar .widget_product_categories ul.children li.cat-item > a:hover {
    color: var(--kabuou-color-accent);
    background: #fafafa;
}
body .l-sidebar .widget_product_categories ul.children li.cat-item > a::before {
    content: "●";
    color: var(--kabuou-color-stock-out, #de0000);
    font-size: 0.6em;
    margin-right: 8px;
    line-height: 1;
}
body .l-sidebar .widget_product_categories ul.children li.cat-item > a::after {
    content: none;
}
body .l-sidebar .widget_product_categories ul.children li.cat-item span.count {
    display: inline;
    color: #999;
    font-size: 0.78em;
}

/* =========================================================
 * TOP「売れ筋ランキング」(.is-ranking-section)
 *   1〜3 位: 金/銀/銅 + 1 位は王冠アイコン、4 位以降: グレー
 *   グリッドは .is-ranking-section に直接当てる (フロントページの
 *   レイアウト次第で .l-mainContent ラッパーが付かず、WC デフォルトの
 *   float レイアウトにフォールバックして隣接要素と重なるため)
 * ========================================================= */
.is-ranking-section {
    padding: 8px 4px;
    margin: 8px 0 24px;
}

.is-ranking-section .woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin: 0;
    padding: 8px 4px;
    list-style: none;
    counter-reset: ranking;
}
.is-ranking-section .woocommerce ul.products::before,
.is-ranking-section .woocommerce ul.products::after {
    content: none;
    display: none;
}
.is-ranking-section .woocommerce ul.products > li:not(.product),
.is-ranking-section .woocommerce ul.products > .clear {
    display: none;
}
.is-ranking-section .woocommerce ul.products li.product {
    position: relative;
    overflow: visible;  /* 順位バッジがカード外にはみ出すため */
    width: auto;
    margin: 0;
    float: none;
    min-width: 0;
    counter-increment: ranking;
}

@media (max-width: 959px) {
    .is-ranking-section .woocommerce ul.products {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 599px) {
    .is-ranking-section .woocommerce ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* 順位バッジ (4 位以降のデフォルト) */
.is-ranking-section .woocommerce ul.products li.product::before {
    content: counter(ranking);
    position: absolute;
    top: -12px;
    left: -12px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #888;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 800;
    font-family: "Georgia", "Hiragino Mincho ProN", serif;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    box-shadow: 0 3px 8px rgba(0,0,0,0.25);
    border: 3px solid #fff;
    line-height: 1;
}

/* 1 位: 金 */
.is-ranking-section .woocommerce ul.products li.product:nth-child(1)::before {
    background: linear-gradient(135deg, #ffd700 0%, #ff9f1c 100%);
    color: #5a3a00;
    font-size: 1.5rem;
    width: 50px;
    height: 50px;
    box-shadow: 0 4px 12px rgba(255, 159, 28, 0.5);
}
.is-ranking-section .woocommerce ul.products li.product:nth-child(1)::after {
    content: "👑";
    position: absolute;
    top: -28px;
    left: -2px;
    font-size: 1.5rem;
    z-index: 6;
    transform: rotate(-22deg);
    filter: drop-shadow(0 2px 3px rgba(0,0,0,0.2));
}

/* 2 位: 銀 */
.is-ranking-section .woocommerce ul.products li.product:nth-child(2)::before {
    background: linear-gradient(135deg, #e0e0e0 0%, #a0a0a0 100%);
    color: #333;
    box-shadow: 0 4px 10px rgba(160, 160, 160, 0.5);
}

/* 3 位: 銅 */
.is-ranking-section .woocommerce ul.products li.product:nth-child(3)::before {
    background: linear-gradient(135deg, #d68b56 0%, #8b4513 100%);
    color: #fff;
    box-shadow: 0 4px 10px rgba(139, 69, 19, 0.5);
}

/* =========================================================
 * メインビジュアル (ヒーロー) スライダーの高さ
 *   SWELL の -height-set モードでカスタマイザー値が反映されないため、
 *   子テーマ側で直接指定。PC: 30vw、SP: 40vh
 * ========================================================= */
body .p-mainVisual.-height-set,
body .p-mainVisual.-height-set .p-mainVisual__inner,
body .p-mainVisual.-height-set .swiper,
body .p-mainVisual.-height-set .swiper-wrapper,
body .p-mainVisual.-height-set .swiper-slide {
    height: 30vw;
    min-height: 240px;
    max-height: 580px;
}
@media (max-width: 599px) {
    body .p-mainVisual.-height-set,
    body .p-mainVisual.-height-set .p-mainVisual__inner,
    body .p-mainVisual.-height-set .swiper,
    body .p-mainVisual.-height-set .swiper-wrapper,
    body .p-mainVisual.-height-set .swiper-slide {
        height: 40vh;
        min-height: 200px;
        max-height: 360px;
    }
}
body .p-mainVisual.-height-set img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* =========================================================
 * サイドバー「価格から探す」ウィジェット (widget_price_filter)
 * ========================================================= */
body .woocommerce .widget_price_filter .price_slider.ui-slider,
body .woocommerce .widget_price_filter .price_slider_wrapper .ui-widget-content {
    height: 8px;
    background: #e8e2d2;
    border-radius: 4px;
    border: none;
    margin: 18px 12px 24px;
    position: relative;
}
body .woocommerce .widget_price_filter .price_slider .ui-slider-range {
    background: var(--kabuou-color-accent);
    height: 8px;
    border-radius: 4px;
}
/* つまみ */
body .woocommerce .widget_price_filter .price_slider .ui-slider-handle {
    width: 22px;
    height: 22px;
    top: -7px;
    margin-left: -11px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid var(--kabuou-color-accent);
    box-shadow: 0 2px 6px rgba(0,0,0,0.18);
    cursor: ew-resize;
    transition: transform 0.12s, box-shadow 0.12s;
}
body .woocommerce .widget_price_filter .price_slider .ui-slider-handle:hover {
    transform: scale(1.12);
    box-shadow: 0 3px 10px rgba(228,122,19,0.45);
}
body .woocommerce .widget_price_filter .price_slider .ui-slider-handle:active,
body .woocommerce .widget_price_filter .price_slider .ui-slider-handle.ui-state-active {
    background: var(--kabuou-color-accent);
}

body .woocommerce .widget_price_filter .price_slider_amount {
    font-size: 0.92em;
    color: #555;
    margin-top: 8px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}
body .woocommerce .widget_price_filter .price_slider_amount .price_label {
    color: #333;
    font-weight: 600;
}

body .woocommerce .widget_price_filter .price_slider_amount .button {
    background: var(--kabuou-color-accent);
    color: #fff;
    border: none;
    border-radius: 3px;
    padding: 7px 14px;
    font-weight: 700;
    font-size: 0.88em;
    cursor: pointer;
    transition: background 0.15s;
    margin-left: auto;
}
body .woocommerce .widget_price_filter .price_slider_amount .button:hover {
    background: #c66510;
    color: #fff;
}

/* =========================================================
 * TOP「新着商品 / おすすめ商品」横スライダー (.is-product-slider)
 *   横スクロール + scroll-snap、矢印は functions.php の JS で挿入
 * ========================================================= */
.is-product-slider {
    position: relative;
    margin: 8px 0 32px;
    padding: 0;
}

.is-product-slider .woocommerce ul.products {
    display: flex !important;
    flex-wrap: nowrap;
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 8px;
    padding: 4px 4px 18px;
    margin: 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--kabuou-color-main, #2D2020) #ece8df;
}
.is-product-slider .woocommerce ul.products::-webkit-scrollbar {
    height: 6px;
}
.is-product-slider .woocommerce ul.products::-webkit-scrollbar-track {
    background: #ece8df;
    border-radius: 3px;
}
.is-product-slider .woocommerce ul.products::-webkit-scrollbar-thumb {
    background: var(--kabuou-color-main, #2D2020);
    border-radius: 3px;
    opacity: 0.7;
}

/* カード固定幅 (PC: 4 / タブレット: 3 / SP: 2 列) */
.is-product-slider .woocommerce ul.products li.product {
    flex: 0 0 calc((100% - 48px) / 4);
    scroll-snap-align: start;
    min-width: 0;
}
@media (max-width: 959px) {
    .is-product-slider .woocommerce ul.products li.product {
        flex-basis: calc((100% - 32px) / 3);
    }
}
@media (max-width: 599px) {
    .is-product-slider .woocommerce ul.products li.product {
        flex-basis: calc((100% - 16px) / 2);
    }
}

/* 矢印ボタン */
.is-product-slider .slider-arrow {
    position: absolute;
    top: calc(50% - 25px);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid #d8d2c4;
    box-shadow: 0 3px 10px rgba(0,0,0,0.12);
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--kabuou-color-main, #2D2020);
    font-size: 1.4rem;
    line-height: 1;
    padding: 0;
    transition: transform 0.15s, background 0.15s, opacity 0.15s;
    opacity: 0.85;
}
.is-product-slider .slider-arrow:hover {
    background: var(--kabuou-color-main, #2D2020);
    color: #fff;
    transform: scale(1.08);
    opacity: 1;
}
.is-product-slider .slider-arrow:disabled {
    opacity: 0.25;
    cursor: default;
    background: rgba(255,255,255,0.85);
    color: #999;
    transform: none;
}
.is-product-slider .slider-arrow.-prev { left: -8px; }
.is-product-slider .slider-arrow.-next { right: -8px; }
@media (max-width: 599px) {
    /* SP は指スワイプ前提 */
    .is-product-slider .slider-arrow { display: none; }
}
