@charset "UTF-8";
/* ===========================================================
＜全体目次＞ 
01.共通パーツ
02.固定ページ・カテゴリページ
03.商品詳細ページ
04.カート
05.チェックアウトページ
============================================================ */
/* ===========================================================
＜01.共通パーツのスタイル＞ 
============================================================ */
.pt0 {
  padding-top: 0;
}

.pb0 {
  padding-bottom: 0;
}

h1, h2, h3,
.c-entry__title,
.c-page-title__title {
  font-family: "Poppins", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-weight: 600;
  color: var(--accent-color);
}

h2 {
  letter-spacing: 0.04em;
  line-height: 1.4;
  font-size: 34px;
  margin-bottom: 1.6em !important; /* ← 少しゆとりを持たせる */
}
@media (max-width: 750px) {
  h2 {
    font-size: 24px;
  }
}

/* 見出し装飾：本文だけ（WooCommerceページは除外） */
body:not(.woocommerce-page) .c-entry__content h3 {
  position: relative;
  color: var(--accent-color);
  padding-bottom: 5px;
  border-bottom: 3px solid #94b3d4;
  margin-bottom: 1.5em;
  font-weight: normal;
}

body:not(.woocommerce-page) .c-entry__content h3::after {
  content: "";
  width: 10rem;
  height: 3px;
  background: var(--accent-color);
  display: inline-block;
  position: absolute;
  left: 0;
  bottom: -3px;
}

.transfer-type h3 {
  margin-top: 5px;
}

.transfer-type h3 a {
  text-decoration: none;
  font-weight: normal;
  font-size: 0.8em;
}

.c-entry-content h2 + h3 {
  margin-top: 1em; /* 追加で余白を確保 */
}

@media (max-width: 767px) {
  html {
    font-size: 14px;
  }
}
.custom-full-width {
  max-width: none;
  width: 100vw;
  margin-left: calc(-1 * (100vw - 100%) / 2) !important;
  margin-right: calc(-1 * (100vw - 100%) / 2) !important;
}

.product-tags {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  column-gap: 8px;
  padding-top: 15px;
}

.product-tag {
  background-color: rgb(237, 205, 66);
  color: #000;
  padding: 3px 15px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: normal;
  margin-bottom: 10px;
}
@media screen and (max-width: 500px) {
  .product-tag {
    padding: 3px 10px;
    font-size: 10px;
  }
}

.smb-media-text__caption {
  font-size: 0.9rem; /* 約14px */
  color: #888;
  text-align: center;
  margin-top: 0.8em;
  line-height: 1.5;
}

.single_add_to_cart_button,
.checkout-button,
.woocommerce-account button,
.place-order .button {
  border-radius: 30px !important;
  width: 60%;
  text-transform: uppercase;
}

.l-contents__inner:first-child {
  padding-top: 15px;
}
@media screen and (max-width: 500px) {
  .l-contents__inner:first-child {
    padding-top: 0;
  }
}

/* ===========================================================
＜ヘッダー・ハンバーガー内コンテンツ＞ 
============================================================ */
.xoo-wsc-sc-bkcont {
  margin-top: 4px;
}

.xoo-wsc-sc-subt {
  display: none !important;
}

@media (max-width: 1023px) {
  /* -----------------------------------------
   * 1. サイドカートトリガー：右上固定
   *    DOMのどこにあっても強制固定
   * ----------------------------------------- */
  .xoo-wsc-cart-trigger {
    position: fixed !important;
    top: 10px !important;
    right: 12px !important;
    z-index: 2147483647 !important;
    display: inline-flex;
    align-items: center;
  }
  /* -----------------------------------------
   * 2. サイドカートのラッパーが高さを
   *    持ってページを押すのを防ぐ
   * ----------------------------------------- */
  .xoo-wsc-sc-cont {
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }
  /* -----------------------------------------
   * 3. ヘッダー内に残る「SMの箱」を潰す
   * ----------------------------------------- */
  .p-header-content.p-header-content--sm,
  .p-header-content--sm .c-container,
  .p-header-content--sm .c-header-content {
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }
  /* -----------------------------------------
   * 4. カート内の金額・テキストを完全非表示
   *    （¥0 / ¥30,000 対策）
   * ----------------------------------------- */
  /* -----------------------------------------
   * 5. ハンバーガーメニュー：左上固定
   * ----------------------------------------- */
  .l-header .u-invisible-lg-up {
    position: fixed !important;
    top: 10px !important;
    left: 12px !important;
    z-index: 2147483647 !important;
  }
  /* -----------------------------------------
   * 6. ロゴ中央寄せ（左右に固定UI分の余白）
   * ----------------------------------------- */
  .l-header .c-container {
    padding-left: 56px !important;
    padding-right: 56px !important;
  }
  .l-header .c-row.c-row--nowrap > .c-row__col.c-row__col--auto {
    flex: 1 1 100%;
    text-align: center;
  }
  .l-header .c-row.c-row--nowrap > .c-row__col.c-row__col--auto .custom-logo-link,
  .l-header .c-row.c-row--nowrap > .c-row__col.c-row__col--auto .c-site-branding {
    display: inline-block;
    padding-left: 35px;
    padding-right: 45px;
    box-sizing: border-box;
  }
  /* -----------------------------------------
   * 7. サイドカート表示時にカートアイコンを非表示にする
   * ----------------------------------------- */
  body.xoo-wsc-cart-opened .xoo-wsc-cart-trigger,
  body.xoo-wsc-cart-active .xoo-wsc-cart-trigger {
    display: none !important;
  }
}
/* ===========================================================
//ドロワーの設定 
============================================================ */
.c-drawer {
  width: 100%;
  top: 50px;
  background: #f3f5f7;
  color: var(--accent-color);
}
.c-drawer a {
  font-size: 18px;
  font-family: "Poppins", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  border-bottom: 1px solid #dce2e8;
  padding: 15px 0 0 25px;
}

/* ===========================================================
パンくず周り 
============================================================ */
.p-breadcrumbs-wrapper {
  padding-left: 10px;
  padding-right: 10px;
}

/* パンくず：現在ページ“以外”のリンクだけ下線 */
.c-breadcrumbs a:not([aria-current=page]) {
  text-decoration: underline;
  color: var(--accent-color);
}

/* 現在ページは下線なし（aのままなので明示的に消す） */
.c-breadcrumbs a[aria-current=page] {
  text-decoration: none;
  cursor: default;
  pointer-events: none; /* 任意：クリックさせない */
}

/* ===========================================================
＜記事ページ（ブログ）のスタイル：目次＞ 
============================================================ */
/* ===========================================================
＜02.固定ページ・カテゴリページのスタイル：目次＞ 
============================================================ */
.c-page-header[data-has-image=true] {
  height: clamp(3.125rem, -3.125rem + 13.02vw, 12.5rem);
  height: clamp(8.125rem, 1.875rem + 13.02vw, 17.5rem);
}
@media screen and (max-width: 500px) {
  .c-page-header[data-has-image=true] {
    height: 100px;
  }
}

.c-page-header__title {
  text-align: center;
}

.c-page-header__bgimage img {
  filter: blur(2px) brightness(0.6);
}

@media screen and (max-width: 500px) {
  .c-page-header__title {
    font-size: 24px;
  }
}
.l-contents__inner:last-child {
  padding-bottom: 200px;
}

/* ===========================================================
03.商品詳細ページ

03-01.商品詳細ページ全体に関する設定
03-02.右側の商品情報エリアに関する設定
03-03.右側の「商品タイトル」「価格幅」「簡易説明」に関する設定
03-04.右側のオプション項目（白背景エリア）に関する設定
03-05.商品説明エリア（下の本文エリア）

============================================================ */
.single-product {
  /* =======================
  03-01.商品詳細ページ全体に関する設定
  ========================== */
  /* =======================
  03-02.右側の商品情報エリアに関する設定
  ========================== */
  /* =======================
  03-03.右側の「商品タイトル」「価格幅」「簡易説明」「車種」に関する設定
  ========================== */
  /* =======================
  03-04.右側のオプション項目（白背景エリア）に関する設定
  ========================== */
  /* =======================
  03-05.右側の合計金額に関する設定
  ========================== */
  /* =======================
  03-05.右側のカート周りに関する設定
  ========================== */
  /* =======================
  03-05.商品説明エリア（下の本文エリア）
  ========================== */
}
.single-product .l-contents__inner {
  margin-top: 0;
}
@media screen and (max-width: 500px) {
  .single-product .c-fluid-container {
    padding-right: 0;
    padding-left: 0;
  }
  .single-product .l-header__content {
    padding-right: 15px;
    padding-left: 15px;
  }
  .single-product .p-entry-content {
    margin-top: 0;
  }
}
.single-product .entry-summary {
  background-color: #f3f5f7;
  width: 50%;
  padding: 30px 30px 10px;
}
@media screen and (max-width: 500px) {
  .single-product .entry-summary {
    width: 100%;
    padding: 10px 20px 10px;
  }
}
.single-product .product_title {
  font-size: 34px !important;
  color: var(--accent-color);
  margin-top: 10px !important;
  line-height: 1.4 !important;
}
@media screen and (max-width: 500px) {
  .single-product .product_title {
    font-size: 25px !important;
  }
}
.single-product .product_title + p.price {
  display: none;
}
.single-product .woocommerce-variation-price bdi {
  font-size: 24px;
  color: #bb1414;
  font-weight: normal;
}
.single-product .wc-pao-addon-container {
  background: #fff;
  padding: 20px 50px 10px 20px;
  border-radius: 15px;
  margin: 20px 0 15px;
}
.single-product .wc-pao-addon-wrap label .woocommerce-Price-amount {
  color: #bb1414;
  font-weight: 500;
}
.single-product .wc-pao-col1 {
  width: 80%;
}
.single-product .wc-pao-subtotal-line {
  border-top: 4px double #000 !important;
  border-bottom: 0;
}
.single-product .wc-pao-subtotal-line .price {
  font-size: 28px !important;
  color: #bb1414 !important;
}
.single-product .product-addon-totals {
  border: none;
}
.single-product .product-addon-totals strong {
  font-weight: normal;
}
.single-product .quantity input.input-text.qty.text {
  border: none !important;
}
.single-product .woocommerce-variation-add-to-cart {
  justify-content: space-around;
  flex-wrap: nowrap !important;
}
.single-product .woocommerce-tabs ul.tabs {
  display: none;
}
.single-product .entry-content > h2:first-of-type {
  display: none;
}

/* ===========================================================
04.カートページ
============================================================ */
.woocommerce-cart .c-entry__title {
  text-align: center;
  padding-bottom: 20px;
}
.woocommerce-cart .wc-block-cart__totals-title {
  display: block !important;
  font-size: 0;
  padding-bottom: 20px;
}
.woocommerce-cart .wc-block-cart-items__header {
  font-size: 18px !important;
  font-weight: bold;
}
.woocommerce-cart .wc-block-cart__totals-title::after {
  content: "Cart total";
  font-size: 20px;
  font-weight: 600;
}
.woocommerce-cart .wp-block-woocommerce-product-collection {
  padding-top: 100px;
}
.woocommerce-cart .wp-block-woocommerce-product-collection h2 {
  font-size: 1.2em !important;
}
.woocommerce-cart .wp-block-woocommerce-product-collection li h2 {
  font-size: 0.9em !important;
  font-weight: normal;
}
.wc-block-cart__empty-cart__title {
  display: none;
}

.wc-block-product-new {
  display: none;
}

/* ===========================================================
05.チェックアウトページ
============================================================ */
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
  border-top: none;
  border: 1px dashed var(--accent-color) !important;
}

#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment {
  background-color: #f3f5f7 !important;
}

.woocommerce-checkout .c-entry__title {
  text-align: center;
  text-align: left;
}
.woocommerce-checkout h3 {
  background: var(--accent-color);
  border-radius: 10px;
  color: #fff;
  padding: 10px 10px 10px 20px;
  margin-top: 30px;
}
.woocommerce-checkout .input-text {
  padding: 0.65em;
}

/* Checkout: Order Note textarea を広くする */
.woocommerce-checkout textarea#additional_order_comments {
  min-height: 160px;
  resize: vertical; /* 縦方向だけユーザーが伸ばせる */
}

.woocommerce form .form-row label {
  line-height: 1.5 !important;
}

/* Checkoutのプライバシー通知文を非表示 */
.woocommerce-privacy-policy-text {
  display: none;
}

/* Checkout: PLACE ORDER を中央寄せ */
.woocommerce-checkout #place_order {
  float: none !important;
  display: block;
  margin: 0 auto;
  padding: 12px;
}

.woocommerce-checkout .l-footer-widget-area {
  margin-top: 5em;
}