/* ════════════════════════════════════════════════════════════
   BuzzBeaver マスターCSS（完全版・重複整理済み）
   ────────────────────────────────────────────────────────────
   このファイルが既存の「追加CSS」を完全に置き換えます。
   外観 → カスタマイズ → 追加CSS の中身を全部消して、
   このファイルの中身をそのまま貼り付けてください。
   ════════════════════════════════════════════════════════════ */


/* ════════════ ベース ════════════ */

footer .copySection p:nth-child(2) { display: none !important; }

body {
  background-color: #f2f2f2;
  background-image:
    radial-gradient(#cccccc 15%, transparent 15%),
    radial-gradient(#cccccc 15%, transparent 15%);
  background-position: 0 0, 10px 10px;
  background-size: 20px 20px;
}

header.siteHeader, .site-header, .l-header {
  background-color: #1a1a1a !important;
  border-bottom: 4px solid #ccff00;
}
.siteHeaderLogo, .site-header-logo { color: #ccff00 !important; font-weight: 900; }
.global-nav-list > li > a { color: #fff !important; font-weight: bold; }


/* ════════════ ページタイトル帯（Lightning archive header） ════════════ */

div.page-header, div.archive-header, div.section-header, .l-page-header {
  background-color: #1a1a1a !important;
  background-image: none !important;
  border-bottom: none !important;
  padding: 32px 0 !important;
  text-align: center !important;
  box-shadow: 0 6px 0 #000;
  margin-bottom: 24px !important;
}
div.page-header h1, div.archive-header h1, div.section-header h1,
h1.page-header-title, h1.archive-header-title, .l-page-header h1 {
  font-family: Impact, "Arial Black", "Hiragino Kaku Gothic Std", sans-serif !important;
  font-weight: 900 !important; color: #fff !important;
  text-shadow: 4px 4px 0 #ccff00, 6px 6px 0 #000 !important;
  font-size: 3.2rem !important; line-height: 1.2 !important;
  transform: skewX(-10deg) rotate(-3deg) !important;
  display: inline-block !important; background: none !important;
  border: none !important; padding: 0 10px !important; margin: 0 !important;
}


/* ════════════ 記事一覧カード ════════════ */

.vk_post, .media, article.post {
  display: flow-root !important; background: #fff;
  border: 3px solid #1a1a1a !important; box-shadow: 6px 6px 0 #1a1a1a !important;
  margin-bottom: 24px !important; padding: 20px !important;
  border-radius: 0 !important; transition: all 0.1s ease;
}
.vk_post:hover, .media:hover, article.post:hover {
  box-shadow: 8px 8px 0 #ccff00 !important;
  transform: translate(-3px, -3px); background-color: #fffff0;
}
.vk_post_imgOuter, .media-img {
  border: 2px solid #1a1a1a !important; margin-right: 20px !important;
  display: block !important; float: left !important;
  width: 35% !important; max-width: 200px !important;
}
.vk_post_imgOuter img, .media-img img {
  width: 100% !important; height: auto !important;
  vertical-align: bottom; display: block;
}
.vk_post_body, .media-body { display: block !important; overflow: hidden; }
.vk_post_label, .term-label {
  background: #1a1a1a !important; color: #ccff00 !important;
  border: 2px solid #ccff00; font-weight: bold;
  border-radius: 0 !important; transform: skew(-10deg);
  padding: 2px 8px !important; display: inline-block !important; margin-bottom: 10px !important;
}
.vk_post_excerpt, .media-body_excerpt {
  display: -webkit-box !important; -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 3 !important; overflow: hidden !important;
  font-size: 13px !important; color: #666 !important;
  line-height: 1.6 !important; margin-top: 5px !important; clear: both;
}


/* ════════════ 記事本文 見出し ════════════ */

.entry-body h2 {
  background: #1a1a1a; color: #ccff00; padding: 10px 20px;
  border: none; box-shadow: 6px 6px 0 #cccccc;
  transform: skew(-2deg); font-weight: 900; margin-bottom: 30px;
}
.entry-body h2:before, .entry-body h2:after { display: none; }
.entry-body h3 {
  border-bottom: 3px solid #1a1a1a; padding: 10px 0;
  background: transparent; position: relative; margin-top: 40px;
}
.entry-body h3:before {
  content: ""; position: absolute; bottom: 0; left: 0;
  width: 40%; height: 10px; background: #ccff00;
  z-index: -1; transform: skew(-20deg);
}


/* ════════════ サイドバー＆検索 ════════════ */

.widget, .sidebar .widget_block {
  border: 2px solid #1a1a1a; background: #fff;
  box-shadow: 4px 4px 0 #bbbbbb; padding: 15px; margin-bottom: 20px;
}
.widget_search .wp-block-search__inside-wrapper {
  display: flex !important; flex-wrap: nowrap !important;
  align-items: stretch !important; width: 100% !important;
  box-sizing: border-box !important; gap: 0 !important;
  border: 3px solid #1a1a1a !important; box-shadow: 6px 6px 0 #cccccc !important;
}
.widget_search .wp-block-search__input {
  border: none !important; background: #fff !important;
  border-radius: 0 !important; padding: 10px !important;
  flex: 1 1 auto !important; width: auto !important;
  margin: 0 !important; max-width: none !important;
}
.widget_search .wp-block-search__button {
  background-color: #1a1a1a !important; color: #ccff00 !important;
  border: none !important; border-left: 3px solid #1a1a1a !important;
  padding: 0 15px !important; font-weight: 900;
  flex: 0 0 auto !important; width: auto !important;
  margin: 0 !important; white-space: nowrap !important; line-height: 1 !important;
}


/* ════════════ 前へ・次へ ════════════ */

.postNextPrev {
  margin-top: 50px !important; gap: 20px !important;
  display: flex !important; align-items: flex-start !important;
}
.postNextPrev .postNextPrev_link {
  border: 3px solid #1a1a1a !important; box-shadow: 6px 6px 0 #1a1a1a !important;
  background: #fff !important; padding: 15px !important;
  width: 48% !important; min-height: 0 !important; height: auto !important;
  text-decoration: none !important; display: flex !important; flex-direction: column !important;
}
.postNextPrev .postNextPrev_thumb {
  width: 100% !important; height: 150px !important;
  object-fit: cover !important; margin: 0 0 10px 0 !important;
  display: block !important; border: 1px solid #1a1a1a;
}
.postNextPrev .postNextPrev_label {
  background-color: #1a1a1a; color: #ccff00; font-size: 11px;
  font-weight: 900; padding: 2px 6px; transform: skew(-10deg);
  align-self: flex-start; margin-bottom: 5px;
}
.postNextPrev .postNextPrev_title { font-weight: bold; font-size: 14px; color: #1a1a1a; line-height: 1.4; }


/* ════════════ レスポンシブ ベース ════════════ */

@media screen and (max-width: 767px) {
  div.page-header h1, .l-page-header h1 { font-size: 2.2rem !important; }
  .vk_post_imgOuter, .media-img {
    float: none !important; width: 100% !important;
    max-width: none !important; margin-right: 0 !important; margin-bottom: 10px !important;
  }
  .postNextPrev { flex-direction: column !important; }
  .postNextPrev .postNextPrev_link { width: 100% !important; margin-bottom: 20px !important; }
}

@media (max-width: 640px) {
  div.page-header, div.archive-header, div.section-header, .l-page-header,
  body.woocommerce div.page-header, body.woocommerce .l-page-header,
  body.single-product div.page-header, body.single-product .l-page-header {
    padding: 20px 0 !important; margin-bottom: 16px !important;
  }
  div.page-header h1, div.archive-header h1, div.section-header h1, .l-page-header h1 {
    font-size: 1.8rem !important;
  }
}


/* ════════════════════════════════════════════════════════════
   TOPページ（.bb-top）レイアウト制御
   ════════════════════════════════════════════════════════════ */

body:has(.bb-top) .page-header,
body:has(.bb-top) .archive-header,
body:has(.bb-top) .l-page-header,
body:has(.bb-top) .breadcrumb,
body:has(.bb-top) .topicpath,
body:has(.bb-top) .vk_breadcrumb,
body:has(.bb-top) .wp-block-vk-breadcrumb,
body:has(.bb-top) .entry-header,
body:has(.bb-top) .page-title,
body:has(.bb-top) #secondary,
body:has(.bb-top) .subSection,
body:has(.bb-top) .l-site-body__sub,
body:has(.bb-top) .siteContentSubSection,
body:has(.bb-top) aside.widget-area,
body:has(.bb-top) .widget-area,
body:has(.bb-top) .sideSection { display: none !important; }

body:has(.bb-top) .mainSection,
body:has(.bb-top) .l-site-body__main,
body:has(.bb-top) .siteContentMain,
body:has(.bb-top) .container .mainSection,
body:has(.bb-top) .mainSection-base-on-widget-area {
  width: 100% !important; max-width: none !important; flex: 1 1 100% !important;
}
body:has(.bb-top) .entry-body,
body:has(.bb-top) .entry,
body:has(.bb-top) article.page { margin: 0 !important; padding-top: 0 !important; }

.bb-top {
  --bb-lime: #ccff00;
  --bb-black: #1a1a1a;
  width: min(1180px, calc(100% - 32px));
  margin: 28px auto 40px !important;
  padding: 0 !important;
  box-sizing: border-box;
}
.bb-top * { box-sizing: border-box; }


/* === ヒーロー === */
.bb-top .bb-top-hero {
  background: #111 !important;
  border: 3px solid #222 !important;
  box-shadow: 8px 8px 0 #ccff00 !important;
  padding: 52px 48px !important;
  margin-bottom: 28px !important;
  position: relative !important;
  overflow: hidden !important;
}
.bb-top .bb-top-hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: linear-gradient(#ccff00 1px,transparent 1px), linear-gradient(90deg,#ccff00 1px,transparent 1px);
  background-size: 44px 44px; opacity: 0.04;
}
.bb-top .bb-top-hero__eyebrow {
  color: #888 !important; font-size: 11px !important;
  font-weight: 700 !important; letter-spacing: 0.2em !important;
  margin: 0 0 18px !important;
  display: flex; align-items: center; gap: 10px;
}
.bb-top .bb-top-hero__title {
  display: block !important; background: none !important;
  color: #fff !important; font-size: clamp(32px,5vw,58px) !important;
  font-family: Impact,"Arial Black","Hiragino Kaku Gothic Std",sans-serif !important;
  font-weight: 900 !important; line-height: 1.12 !important;
  padding: 0 !important; margin: 0 0 16px !important;
  transform: none !important; text-shadow: none !important;
  box-shadow: none !important; border: none !important;
  transition: opacity 0.3s ease !important;
}
.bb-top .bb-top-hero__title.fade { opacity: 0 !important; }
.bb-top .bb-top-hero__text { color: #777 !important; font-size: 13px !important; line-height: 2 !important; margin: 0 !important; }
.bb-top .bb-top-hero__rotator {
  color: #ccff00 !important; font-size: clamp(16px, 2vw, 22px) !important;
  font-weight: 900 !important; letter-spacing: .04em !important;
  margin: 0 0 18px !important; min-height: 1.6em;
  transition: opacity .3s ease;
}
.bb-top .bb-top-hero__rotator.fade { opacity: 0; }


/* === ヒーローバナー === */
.bb-hero-banner {
  margin-bottom: 32px;
  border: 3px solid #1a1a1a;
  box-shadow: 8px 8px 0 #ccff00;
  line-height: 0; overflow: hidden;
  background: #0a0a1a;
}
.bb-hero-banner__img {
  display: block; width: 100%;
  height: clamp(240px, 38vh, 460px);
  object-fit: cover;
  object-position: center 42%;
}


/* === セクションヘッダー === */
.bb-sh {
  display:flex; align-items:flex-end; gap:14px; margin-bottom:18px;
  justify-content: center; text-align: center;
}
.bb-sh-label {
  font-family: Impact,"Arial Black",sans-serif;
  font-size: 20px; font-weight: 900; letter-spacing: .03em; color: #1a1a1a;
  display: block; flex-shrink: 0;
  background: none !important; box-shadow: none !important;
  transform: none !important; text-shadow: none !important;
  border: none !important; padding: 0 !important; margin: 0 !important;
}
.bb-sh-sub { font-size: 10px; color: #888; font-weight: 700; letter-spacing: .14em; display: block; margin-top: 2px; }
.bb-sh-line { display: none; }


/* === セクションボックス === */
.bb-secbox {
  background: #fff;
  border: 3px solid #1a1a1a;
  box-shadow: 6px 6px 0 #1a1a1a;
  margin-bottom: 28px;
  overflow: hidden;
}
.bb-secbox__head {
  padding: 14px 22px;
  border-bottom: 3px solid #1a1a1a;
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap; justify-content: center;
}
.bb-secbox__head--lime { background: #ccff00; }
.bb-secbox__head--blue { background: #4da6ff; }
.bb-secbox__head--pink { background: #ff69b4; }
.bb-secbox__icon { font-size: 26px; line-height: 1; flex-shrink: 0; }
.bb-secbox__title {
  margin: 0 !important; padding: 0 !important;
  font-family: Impact, "Arial Black", "Hiragino Kaku Gothic Std", sans-serif !important;
  font-size: 22px !important; font-weight: 900 !important;
  color: #1a1a1a !important; letter-spacing: .03em; line-height: 1.2;
  background: none !important; box-shadow: none !important;
  transform: none !important; text-shadow: none !important; border: none !important;
}
.bb-secbox__sub {
  font-size: 11px; font-weight: 700; letter-spacing: .14em;
  color: rgba(0, 0, 0, .65); margin-left: 12px !important;
}
.bb-secbox__num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; background: #1a1a1a;
  font-family: Impact, "Arial Black", "Hiragino Kaku Gothic Std", sans-serif;
  font-size: 20px; font-weight: 900; letter-spacing: -.02em;
  line-height: 1; flex-shrink: 0; transform: skewX(-4deg);
}
.bb-secbox__head--lime .bb-secbox__num { color: #ccff00; }
.bb-secbox__head--blue .bb-secbox__num { color: #4da6ff; }
.bb-secbox__head--pink .bb-secbox__num { color: #ff69b4; }
.bb-secbox__body {
  padding: 22px 24px;
  text-align: center;
}
.bb-secbox__body .bb-tchip {
  padding: 10px 20px !important;
  font-size: 14px !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
}
.bb-secbox__body .bb-chiprow {
  gap: 12px;
  justify-content: center;
}


/* === カテゴリナビ === */
.bb-catnav {
  background: #fff;
  border: 3px solid #1a1a1a;
  box-shadow: 6px 6px 0 #1a1a1a;
  margin-bottom: 28px;
  overflow: hidden;
}
.bb-catnav-tabs { display: flex; background: #1a1a1a; border-bottom: 3px solid #1a1a1a; }
.bb-cattab {
  flex: 1; padding: 14px 6px; border: none;
  border-right: 2px solid #2a2a2a;
  background: transparent; color: #777;
  font-weight: 900; font-size: 12px; font-family: inherit;
  cursor: pointer; line-height: 1.3; letter-spacing: .03em;
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  transition: background .1s, color .1s;
}
.bb-cattab:last-child { border-right: none; }
.bb-cattab .ti { font-size: 18px; }
.bb-cattab:hover:not(.on) { background: #252525; color: #ddd; }
.bb-cattab.on[data-c="lime"]   { background: #ccff00; color: #000; }
.bb-cattab.on[data-c="blue"]   { background: #4da6ff; color: #000; }
.bb-cattab.on[data-c="orange"] { background: #ff8c00; color: #fff; }
.bb-cattab.on[data-c="purple"] { background: #a855f7; color: #fff; }
.bb-cattab.on[data-c="pink"]   { background: #ff69b4; color: #000; }
.bb-catpanel { display: none; padding: 20px 24px; background: #fafafa; }
.bb-catpanel.open { display: block; animation: bbSlide .15s ease; }
@keyframes bbSlide { from{opacity:0;transform:translateY(-5px)} to{opacity:1;transform:none} }
.bb-catpanel[data-c="lime"]   { border-top: 3px solid #ccff00; }
.bb-catpanel[data-c="blue"]   { border-top: 3px solid #4da6ff; }
.bb-catpanel[data-c="orange"] { border-top: 3px solid #ff8c00; }
.bb-catpanel[data-c="purple"] { border-top: 3px solid #a855f7; }
.bb-catpanel[data-c="pink"]   { border-top: 3px solid #ff69b4; }


/* === チップ・タグ === */
.bb-chiprow { display: flex; flex-wrap: wrap; gap: 8px; }
.bb-sublabel {
  font-size: 10px; color: #888; font-weight: 700;
  letter-spacing: .14em; margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.bb-sublabel::before { content:""; display:inline-block; width:3px; height:11px; background:#bbb; border-radius:1px; }
.bb-tchip {
  padding: 7px 14px; background: #fff; border: 2px solid #1a1a1a;
  color: #1a1a1a; font-size: 12px; font-weight: 900;
  cursor: pointer; font-family: inherit;
  box-shadow: 2px 2px 0 #1a1a1a; transition: all .1s;
  text-decoration: none; display: inline-block;
}
.bb-tchip:hover { background: #1a1a1a; color: #fff; }
.bb-tchip.sel { background: #ccff00; color: #000; border-color: #ccff00; }
.bb-tagrow { display:flex; flex-wrap:wrap; gap:8px; padding-top:14px; margin-top:14px; border-top:1px dashed #ddd; }
.bb-tgchip {
  display: inline-block; padding: 7px 14px;
  background: #1a1a1a; color: #ccff00;
  font-size: 12px; font-weight: 900;
  transform: skewX(-4deg); box-shadow: 3px 3px 0 rgba(0,0,0,.15);
  transition: all .1s; text-decoration: none;
}
.bb-tgchip:hover { transform: skewX(-4deg) translate(-2px,-2px); box-shadow: 5px 5px 0 rgba(204,255,0,.3); color: #ccff00; }
.bb-tgchip.bl { color: #4da6ff; }
.bb-tgchip.bl:hover { box-shadow: 5px 5px 0 rgba(77,166,255,.3); }
.bb-coming { display:flex; align-items:center; gap:12px; }
.bb-coming-badge {
  display: inline-block; background: #1a1a1a; color: #a855f7;
  font-size: 10px; font-weight: 900; padding: 3px 10px;
  letter-spacing: .15em; transform: skewX(-6deg);
}
.bb-goods-btn {
  display: inline-block; background: #1a1a1a; color: #ff69b4 !important;
  padding: 10px 20px; font-weight: 900; font-size: 13px;
  text-decoration: none !important; border: 2px solid #ff69b4;
  box-shadow: 4px 4px 0 #ff69b4; transition: all .1s;
}
.bb-goods-btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 #ff69b4; }


/* === FEATURED グリッド === */
.bb-feat-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 18px;
  margin-bottom: 32px;
}
.bb-fc {
  display: flex !important; flex-direction: column !important;
  height: 340px !important; overflow: hidden !important;
  background: #fff !important; border: 3px solid #1a1a1a !important;
  box-shadow: 5px 5px 0 #1a1a1a !important;
  text-decoration: none !important; color: #1a1a1a !important;
  transition: box-shadow .12s, transform .12s !important;
  padding: 0 !important; margin-bottom: 0 !important;
  border-radius: 0 !important;
}
.bb-fc:hover {
  box-shadow: 8px 8px 0 #ccff00 !important;
  transform: translate(-3px,-3px) !important;
  background-color: #fff !important;
}
.bb-fc-thumb {
  position: relative; height: 180px !important;
  flex-shrink: 0; overflow: hidden; display: block !important;
}
.bb-fc-thumb img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important; display: block !important;
  float: none !important; margin: 0 !important;
  border: none !important; max-width: none !important;
  opacity: 1 !important; visibility: visible !important;
  transition: transform .4s;
}
.bb-fc:hover .bb-fc-thumb img { transform: scale(1.07); }
.bb-fc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.45) 0%, transparent 55%);
}
.bb-fc-cat {
  position: absolute; top: 10px; left: 10px;
  display: inline-block; background: #1a1a1a; color: #ccff00;
  font-size: 10px; font-weight: 900; padding: 2px 8px;
  transform: skewX(-8deg); letter-spacing: .08em; line-height: 1.4;
}
.bb-fc-cat.bb-cat--jjk   { background: #1a1a1a; color: #ccff00; }
.bb-fc-cat.bb-cat--op    { background: #1a1a1a; color: #ff4d4d; }
.bb-fc-cat.bb-cat--csm   { background: #1a1a1a; color: #ff8c00; }
.bb-fc-cat.bb-cat--anime { background: #1a1a1a; color: #a855f7; }
.bb-fc-badge {
  position: absolute; top: 10px; right: 10px;
  display: inline-block; font-size: 9px; font-weight: 900;
  padding: 2px 7px; letter-spacing: .15em; transform: skewX(-6deg);
}
.bb-fc-badge.hot  { background:#ff3b30; color:#fff; }
.bb-fc-badge.pick { background:#ccff00; color:#000; }
.bb-fc-badge.new  { background:#34aadc; color:#fff; }
.bb-fc-body {
  flex: 1 !important; display: flex !important; flex-direction: column !important;
  padding: 14px 16px !important; gap: 8px !important;
  overflow: hidden !important; background: #fff !important;
}
.bb-fc-date { font-size:10px; color:#999; font-weight:700; flex-shrink:0; }
.bb-fc-title, .bb-fc h2, .bb-fc h2.bb-fc-title {
  font-size: 14px !important; font-weight: 900 !important;
  line-height: 1.6 !important; color: #1a1a1a !important;
  flex: 1 !important; margin: 0 !important; padding: 0 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important; -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  background: none !important; box-shadow: none !important;
  transform: none !important; text-shadow: none !important; border: none !important;
}
.bb-fc h2::before, .bb-fc h2::after { display: none !important; }
.bb-fc-excerpt {
  font-size:12px; color:#666; line-height:1.8; flex-shrink:0; margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.bb-fc-skel {
  height: 340px;
  background: linear-gradient(110deg, #eee 30%, #f5f5f5 50%, #eee 70%);
  background-size: 200% 100%;
  border: 3px solid #d0d0d0;
  box-shadow: 5px 5px 0 #d0d0d0;
  animation: bbSkel 1.4s linear infinite;
}
@keyframes bbSkel {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}
.bb-fc-error {
  grid-column: 1 / -1;
  padding: 40px 20px;
  text-align: center;
  color: #888;
  background: #fafafa;
  border: 2px dashed #ddd;
}


/* === 2カラム === */
.bb-twocol { display:grid; grid-template-columns:1fr 320px; gap:28px; align-items:start; }
.bb-catgrid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.bb-catcard {
  display:flex; align-items:center; gap:12px;
  background:#fff; border:3px solid #1a1a1a; box-shadow:4px 4px 0 #1a1a1a;
  padding:14px 16px; text-decoration:none !important; color:#1a1a1a !important;
  transition: transform .1s, box-shadow .1s;
}
.bb-catcard:hover { transform:translate(-2px,-2px); }
.bb-catcard--jjk:hover   { box-shadow: 6px 6px 0 #ccff00 !important; }
.bb-catcard--op:hover    { box-shadow: 6px 6px 0 #ff4d4d !important; }
.bb-catcard--csm:hover   { box-shadow: 6px 6px 0 #ff8c00 !important; }
.bb-catcard--other:hover { box-shadow: 6px 6px 0 #4da6ff !important; }
.bb-catcard--goods:hover { box-shadow: 6px 6px 0 #ff69b4 !important; }
.bb-catcard--anime:hover { box-shadow: 6px 6px 0 #a855f7 !important; }
.bb-catic { width:42px; height:42px; border:2px solid #1a1a1a; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.bb-catnm { font-size:14px; font-weight:900; }
.bb-catct { font-size:11px; color:#888; font-weight:600; }
.bb-tagwrap { display:flex; flex-wrap:wrap; gap:8px; }
.bb-taglink {
  display:inline-block; background:#fff; border:2px solid #1a1a1a;
  color:#1a1a1a !important; padding:7px 12px; font-size:12px; font-weight:700;
  box-shadow:2px 2px 0 #1a1a1a; transition:all .1s; text-decoration:none !important;
}
.bb-taglink:hover { background:#1a1a1a; color:#ccff00 !important; transform:translate(-1px,-1px); }


/* === サイドバー === */
.bb-sidebar { display:flex; flex-direction:column; gap:20px; }
.bb-ticker2 {
  background:#1a1a1a; border:3px solid #ccff00;
  padding:10px 14px; display:flex; align-items:flex-start; gap:10px; flex-wrap:wrap;
}
.bb-ticker2-text { color:#ccc; font-size:12px; font-weight:600; line-height:1.7; flex:1; }
.bb-ticker2-static-badge {
  display: inline-block; background: #ccff00; color: #000;
  font-size: 10px; font-weight: 900; padding: 3px 8px;
  letter-spacing: .12em; transform: skewX(-6deg); flex-shrink: 0;
}
.bb-rankbox { background:#fff; border:3px solid #1a1a1a; box-shadow:6px 6px 0 #1a1a1a; padding:20px; }
.bb-rankrow {
  display:flex !important; flex-direction:row !important; flex-wrap:nowrap !important;
  align-items:center !important; gap:12px !important;
  padding:13px 0; border-bottom:1px solid #f0f0f0;
  transition:transform .1s;
  text-decoration:none !important; color:#1a1a1a !important;
}
.bb-rankrow:last-of-type { border-bottom:none; }
.bb-rankrow:hover { transform:translateX(5px); }
.bb-rankno {
  font-size:28px; font-weight:900; min-width:32px; text-align:center;
  font-family:Impact,"Arial Black",sans-serif; line-height:1; flex-shrink:0;
}
.bb-rankno.r1 { color:#ccff00; -webkit-text-stroke:1px #1a1a1a; }
.bb-rankno.r2 { color:#e0e0e0; -webkit-text-stroke:1px #1a1a1a; }
.bb-rankno.r3 { color:#ff8c00; -webkit-text-stroke:1px #1a1a1a; }
.bb-rankno.r4 { color:#ccc; }
.bb-rankinfo { flex:1; min-width:0; }
.bb-rklabel {
  display:inline-block; background:#1a1a1a; color:#ccff00;
  font-size:10px; font-weight:900; padding:2px 8px;
  transform:skewX(-8deg); letter-spacing:.08em;
}
.bb-rklabel.bb-cat--jjk   { background: #1a1a1a; color: #ccff00; }
.bb-rklabel.bb-cat--op    { background: #1a1a1a; color: #ff4d4d; }
.bb-rklabel.bb-cat--csm   { background: #1a1a1a; color: #ff8c00; }
.bb-rklabel.bb-cat--anime { background: #1a1a1a; color: #a855f7; }
.bb-ranktitle { margin:5px 0 0; font-size:12px; font-weight:700; line-height:1.5; }
.bb-rankthumb {
  width:52px; height:52px; object-fit:cover;
  border:2px solid #1a1a1a; flex-shrink:0;
  float:none !important; max-width:none !important;
}
.bb-rankmore {
  display:block; text-align:center; margin-top:16px;
  background:#1a1a1a; color:#ccff00 !important; padding:11px;
  font-weight:900; font-size:12px; letter-spacing:.1em;
  text-decoration:none !important; transition:background .1s;
}
.bb-rankmore:hover { background:#333; }
.bb-about2 { background:#1a1a1a; border:3px solid #ccff00; box-shadow:6px 6px 0 #ccff00; padding:22px; }
.bb-about2-ttl {
  font-family:Impact,"Arial Black",sans-serif; font-size:18px; font-weight:900;
  color:#ccff00; margin:0 0 10px; letter-spacing:.04em;
  background:none !important; box-shadow:none !important; transform:none !important;
}
.bb-about2-txt { color:#aaa; font-size:13px; line-height:1.9; margin:0; }


/* === WP空要素対策（TOP） === */
.bb-top p:empty,
.bb-top br + br,
.bb-catgrid > br, .bb-catnav-tabs > br, .bb-chiprow > br,
.bb-feat-grid > br, .bb-tagwrap > br, .bb-rankbox > br, .bb-rankrow > br {
  display: none !important;
}
.bb-catgrid > *:not(.bb-catcard) { display: none !important; }
.bb-feat-grid > *:not(.bb-fc):not(.bb-fc-skel):not(.bb-fc-error) { display: none !important; }
.bb-catnav-tabs > *:not(.bb-cattab) { display: none !important; }
.bb-chiprow > *:not(.bb-tchip) { display: none !important; }
.bb-tagwrap > *:not(.bb-taglink) { display: none !important; }
.bb-rankrow > *:not(.bb-rankno):not(.bb-rankinfo):not(.bb-rankthumb) { display: none !important; }
.bb-twocol > *:empty { display: none !important; }


/* === TOPページ レスポンシブ === */
@media (max-width:900px) {
  .bb-feat-grid { grid-template-columns:repeat(2,1fr); }
  .bb-twocol    { grid-template-columns:1fr; }
}
@media (max-width: 640px) {
  body:has(.bb-top) .mainSection,
  body:has(.bb-top) .l-site-body__main,
  body:has(.bb-top) .siteContentMain,
  body:has(.bb-top) .entry-body,
  body:has(.bb-top) .entry,
  body:has(.bb-top) article.page,
  body:has(.bb-top) .entry-content {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  .bb-top { margin-top: 0 !important; padding-top: 0 !important; }
  .bb-top .bb-top-hero { padding:28px 20px !important; }
  .bb-hero-banner { box-shadow: 5px 5px 0 #ccff00; margin-bottom: 20px !important; }
  .bb-hero-banner__img { height: auto !important; object-fit: unset !important; }
  .bb-feat-grid  { grid-template-columns:1fr; margin-bottom: 20px; }
  .bb-catgrid    { grid-template-columns:1fr; }
  .bb-catnav-tabs { flex-wrap:wrap; }
  .bb-cattab { flex:0 0 33.33%; border-bottom:2px solid #2a2a2a; }
  .bb-secbox { margin-bottom: 20px !important; }
  .bb-secbox__head { padding: 12px 16px; gap: 10px; }
  .bb-secbox__title { font-size: 18px !important; }
  .bb-secbox__sub { display: none; }
  .bb-secbox__body { padding: 18px; }
  .bb-secbox__num { width: 36px; height: 36px; font-size: 16px; }
  .bb-top .bb-sh[style*="margin-top"] { margin-top: 20px !important; margin-bottom: 12px !important; }
}


/* ════════════════════════════════════════════════════════════
   WooCommerce 共通スタイル
   ════════════════════════════════════════════════════════════ */

/* === 商品ページ全体（汎用セレクタで body class に依存しない） === */
.woocommerce div.product,
.woocommerce-page div.product,
div.product.type-product {
  background: #fff !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 8px 8px 0 #ccff00 !important;
  padding: 32px !important;
  margin-bottom: 32px !important;
  border-radius: 0 !important;
}

.woocommerce div.product .product_title,
.woocommerce div.product h1.product_title {
  font-family: Impact, "Arial Black", "Hiragino Kaku Gothic Std", sans-serif !important;
  font-size: clamp(20px, 2.5vw, 32px) !important;
  font-weight: 900 !important; color: #1a1a1a !important;
  margin: 0 0 16px 0 !important; padding: 0 !important;
  letter-spacing: 0 !important; line-height: 1.25 !important;
  background: none !important; box-shadow: none !important;
  transform: none !important; text-shadow: none !important; border: none !important;
}

.woocommerce div.product p.price,
.woocommerce div.product .price,
.woocommerce-page div.product p.price {
  font-size: 24px !important; font-weight: 900 !important;
  color: #1a1a1a !important;
  background: #ccff00 !important; background-color: #ccff00 !important;
  display: inline-block !important;
  padding: 6px 16px !important; margin: 0 0 24px 0 !important;
  transform: skewX(-6deg) !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 4px 4px 0 #1a1a1a !important;
}
.woocommerce div.product .price .woocommerce-Price-amount,
.woocommerce div.product .price bdi { color: #1a1a1a !important; }


/* === 商品ページ パンくず === */
body.single-product .breadcrumb,
body.single-product .woocommerce-breadcrumb {
  background: #1a1a1a !important; color: #ccff00 !important;
  padding: 12px 20px !important;
  font-size: 12px !important; font-weight: 700 !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 4px 4px 0 #ccff00 !important;
  margin-bottom: 32px !important;
}
body.single-product .breadcrumb a { color: #ccff00 !important; text-decoration: none !important; }


/* === 商品ページ ギャラリー画像 === */
.woocommerce div.product .woocommerce-product-gallery__image img {
  border: 2px solid #1a1a1a !important;
}


/* === サイズ選択ドロップダウン === */
.woocommerce div.product .variations { margin-bottom: 16px !important; }
.woocommerce div.product .variations label {
  font-weight: 900 !important; font-size: 14px !important; color: #1a1a1a !important;
}
.woocommerce div.product .variations select {
  border: 3px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 12px 40px 12px 16px !important;
  font-size: 15px !important; font-weight: 700 !important;
  background-color: #fff !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1a1a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  background-size: 18px !important;
  appearance: none !important; -webkit-appearance: none !important;
  width: 100% !important; height: auto !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
}


/* === form.cart + 数量入力 === */
.woocommerce div.product form.cart { display: block !important; }
.woocommerce div.product .quantity {
  display: block !important;
  margin-bottom: 24px !important;
}
.woocommerce div.product .quantity .qty,
.woocommerce div.product input.qty {
  border: 3px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 10px !important;
  font-size: 16px !important; font-weight: 900 !important;
  width: 70px !important; height: auto !important;
  text-align: center !important;
  background: #fff !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
}


/* === カートボタン（紫を完全に上書き、汎用セレクタ） === */
button.single_add_to_cart_button,
.single_add_to_cart_button,
.woocommerce button.single_add_to_cart_button,
.woocommerce-page button.single_add_to_cart_button,
.woocommerce .single_add_to_cart_button.button.alt,
form.cart button[type="submit"].single_add_to_cart_button,
.woocommerce form.cart .button.alt,
.woocommerce-variation-add-to-cart button {
  background: #1a1a1a !important;
  background-color: #1a1a1a !important;
  background-image: none !important;
  color: #ccff00 !important;
  border: 3px solid #1a1a1a !important;
  border-radius: 0 !important;
  padding: 16px 28px !important;
  font-size: 16px !important; font-weight: 900 !important;
  letter-spacing: 0.05em !important;
  box-shadow: 5px 5px 0 #ccff00 !important;
  text-shadow: none !important;
  transform: none !important;
  width: 100% !important;
  display: block !important;
  margin-top: 8px !important;
  text-align: center !important;
  cursor: pointer !important;
  text-decoration: none !important;
  opacity: 1 !important;
}
.woocommerce button.single_add_to_cart_button:hover {
  background: #ccff00 !important; background-color: #ccff00 !important;
  color: #1a1a1a !important;
  box-shadow: 5px 5px 0 #1a1a1a !important;
}


/* === 商品メタ === */
.woocommerce div.product .product_meta {
  border-top: 2px dashed #ccc !important;
  padding-top: 16px !important; margin-top: 24px !important;
  font-size: 12px !important; color: #666 !important;
}
.woocommerce div.product .product_meta a { color: #1a1a1a !important; font-weight: 700 !important; }


/* === タブナビ === */
.woocommerce-tabs ul.tabs, .woocommerce-tabs ul.wc-tabs {
  background: #1a1a1a !important;
  border: 3px solid #1a1a1a !important;
  display: flex !important;
  padding: 0 !important; margin: 0 !important;
  list-style: none !important;
  flex-wrap: wrap;
}
.woocommerce-tabs ul.tabs li, .woocommerce-tabs ul.wc-tabs li {
  background: transparent !important; border: none !important;
  border-right: 2px solid #333 !important; border-radius: 0 !important;
  margin: 0 !important; padding: 0 !important;
  flex: 0 0 auto !important;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li:last-child { border-right: none !important; }
.woocommerce-tabs ul.tabs li a, .woocommerce-tabs ul.wc-tabs li a {
  color: #888 !important; padding: 14px 28px !important;
  font-weight: 900 !important; font-size: 14px !important;
  display: block !important; text-decoration: none !important;
}
.woocommerce-tabs ul.tabs li.active, .woocommerce-tabs ul.wc-tabs li.active {
  background: #ccff00 !important;
}
.woocommerce-tabs ul.tabs li.active a, .woocommerce-tabs ul.wc-tabs li.active a {
  color: #1a1a1a !important;
}


/* === タブパネル === */
.woocommerce-Tabs-panel, .woocommerce div.product .panel {
  background: #fff !important;
  border: 3px solid #1a1a1a !important;
  border-top: none !important;
  padding: 28px !important;
  box-shadow: 6px 6px 0 #1a1a1a !important;
  margin-bottom: 32px !important;
}
.woocommerce-Tabs-panel h2, .woocommerce div.product .panel h2 {
  display: inline-block !important;
  background: #1a1a1a !important; color: #ccff00 !important;
  font-family: Impact, "Arial Black", sans-serif !important;
  font-size: 18px !important; font-weight: 900 !important;
  padding: 8px 18px !important; margin: 0 0 20px 0 !important;
  transform: skewX(-4deg) !important;
  box-shadow: 4px 4px 0 #ccff00 !important;
  border: none !important; text-shadow: none !important;
  letter-spacing: 0.05em !important;
}
.woocommerce-Tabs-panel p { line-height: 1.9 !important; color: #1a1a1a !important; margin-bottom: 14px !important; }
.woocommerce-Tabs-panel ul { padding-left: 24px !important; margin: 16px 0 !important; }


/* === 商品ページ 非表示要素 === */
body.single-product .widget_products,
body.single-product .widget_recently_viewed_products,
body.single-product .widget_top_rated_products,
body.single-product .widget_recent_products,
body.single-product .widget_product_categories,
body.single-product .widget.woocommerce.widget_products,
body.single-product aside .widget.woocommerce,
body.single-product .related.products,
body.single-product .upsells.products,
body.single-product .relatedPosts,
body.single-product .related-entry-card-wrap,
body.single-product .l-related,
body.single-product section.related,
body.single-product section.upsells,
body.single-product .vk-related-posts,
body.single-product .postNextPrev {
  display: none !important;
}


/* === 商品ページ SP調整 === */
@media (max-width: 640px) {
  .woocommerce div.product {
    padding: 18px !important;
    box-shadow: 4px 4px 0 #ccff00 !important;
    margin-bottom: 24px !important;
  }
  .woocommerce div.product .woocommerce-product-gallery,
  .woocommerce div.product .woocommerce-product-gallery *,
  .woocommerce div.product .woocommerce-product-gallery__wrapper,
  .woocommerce div.product .woocommerce-product-gallery__image,
  .woocommerce div.product figure.woocommerce-product-gallery__wrapper,
  .woocommerce div.product .woocommerce-product-gallery img,
  .woocommerce div.product .woocommerce-product-gallery a,
  .woocommerce div.product .flex-control-thumbs,
  .woocommerce div.product .flex-control-thumbs li,
  .woocommerce div.product .flex-control-thumbs li img {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    background: transparent !important;
  }
  .woocommerce button.single_add_to_cart_button {
    padding: 14px !important;
    box-shadow: 4px 4px 0 #ccff00 !important;
    margin-top: 12px !important;
  }
  .woocommerce div.product .quantity { margin-bottom: 28px !important; }
  .woocommerce-Tabs-panel { padding: 20px !important; box-shadow: 5px 5px 0 #1a1a1a !important; }
  .woocommerce-tabs ul.tabs li a { padding: 12px 18px !important; font-size: 13px !important; }
}


/* ════════════════════════════════════════════════════════════
   ショップ・アーカイブページ
   ════════════════════════════════════════════════════════════ */

/* === 重複「ショップ」h1 を非表示 === */
body.woocommerce .woocommerce-products-header,
body.woocommerce h1.woocommerce-products-header__title,
body.archive .woocommerce-products-header,
body.post-type-archive-product .woocommerce-products-header,
body.tax-product_cat .woocommerce-products-header,
body.woocommerce .entry-body > h1,
body.woocommerce article.page > h1,
body.archive.woocommerce h1.page-title,
body.archive.woocommerce h1.entry-title,
body.post-type-archive-product h1.page-title { display: none !important; }


/* === ショップ パンくず === */
body.woocommerce .breadcrumb,
body.archive.woocommerce .breadcrumb,
body.woocommerce-cart .breadcrumb {
  background: #1a1a1a !important; color: #ccff00 !important;
  padding: 12px 20px !important;
  font-size: 12px !important; font-weight: 700 !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 4px 4px 0 #ccff00 !important;
  margin-bottom: 28px !important;
}
body.woocommerce .breadcrumb a,
body.woocommerce-cart .breadcrumb a { color: #ccff00 !important; text-decoration: none !important; }


/* === 結果カウント＆ソート === */
body.woocommerce .woocommerce-result-count {
  background: #1a1a1a !important; color: #ccff00 !important;
  padding: 8px 14px !important;
  display: inline-block !important;
  font-size: 13px !important; font-weight: 900 !important;
  letter-spacing: 0.05em !important;
  transform: skewX(-4deg); margin: 0 !important;
}
body.woocommerce .woocommerce-ordering select, body.woocommerce select.orderby {
  border: 3px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 10px 40px 10px 16px !important;
  font-size: 14px !important; font-weight: 700 !important;
  background-color: #fff !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1a1a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  background-size: 16px !important;
  appearance: none !important; -webkit-appearance: none !important;
  height: auto !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
  cursor: pointer !important;
}


/* === 商品グリッド === */
body.woocommerce ul.products,
body.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 32px 0 !important;
}


/* === 商品カード（縦積み・block） === */
html body.woocommerce ul.products li.product,
html body.woocommerce-page ul.products li.product {
  display: block !important;
  position: relative !important;
  float: none !important;
  box-sizing: border-box !important;
  padding: 16px !important;
  overflow: visible !important;
  background: #fff !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 6px 6px 0 #1a1a1a !important;
  margin: 0 !important;
  width: auto !important;
  list-style: none !important;
  transition: all .1s ease !important;
}
html body.woocommerce ul.products li.product:hover {
  transform: translate(-3px, -3px);
  box-shadow: 9px 9px 0 #ccff00 !important;
}
html body.woocommerce ul.products li.product > *,
html body.woocommerce-page ul.products li.product > * {
  float: none !important; clear: both !important; position: static !important;
}
html body.woocommerce ul.products li.product::before,
html body.woocommerce ul.products li.product::after { display: none !important; }
html body.woocommerce ul.products li.product > a,
html body.woocommerce ul.products li.product .woocommerce-LoopProduct-link {
  display: block !important; width: 100% !important;
  text-decoration: none !important; color: #1a1a1a !important;
}


/* 商品カード 画像・タイトル・価格 */
body.woocommerce ul.products li.product img,
body.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
  border: 2px solid #1a1a1a !important;
  margin-bottom: 12px !important;
  width: 100% !important; height: auto !important;
  display: block !important;
}
body.woocommerce ul.products li.product .woocommerce-loop-product__title,
body.woocommerce ul.products li.product h2,
body.woocommerce ul.products li.product h3 {
  font-family: inherit !important;
  font-size: 14px !important; font-weight: 900 !important;
  color: #1a1a1a !important;
  margin: 8px 0 !important; padding: 0 !important;
  background: none !important; box-shadow: none !important;
  transform: none !important; text-shadow: none !important; border: none !important;
  line-height: 1.4 !important;
}
html body.woocommerce ul.products li.product .price,
html body.woocommerce ul.products li.product span.price {
  display: block !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin: 14px 0 18px 0 !important;
  font-size: 17px !important; font-weight: 900 !important;
  color: #1a1a1a !important;
  background: #ccff00 !important;
  padding: 4px 12px !important;
  transform: skewX(-6deg);
  border: 2px solid #1a1a1a !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
  float: none !important; clear: both !important; position: static !important;
}


/* 商品カード カートボタン */
html body.woocommerce ul.products li.product .button,
html body.woocommerce ul.products li.product .add_to_cart_button,
html body.woocommerce ul.products li.product a.button {
  display: block !important;
  width: 100% !important; max-width: 100% !important;
  margin: 0 !important;
  padding: 12px 14px !important;
  float: none !important; clear: both !important;
  position: static !important;
  text-align: center !important;
  box-sizing: border-box !important;
  background: #1a1a1a !important; color: #ccff00 !important;
  border: 2px solid #1a1a1a !important;
  border-radius: 0 !important;
  font-size: 12px !important; font-weight: 900 !important;
  letter-spacing: 0.05em !important;
  box-shadow: none !important;
  text-shadow: none !important;
  transform: none !important;
  text-decoration: none !important;
}
html body.woocommerce ul.products li.product .button:hover {
  background: #ccff00 !important; color: #1a1a1a !important;
}


/* === ページネーション === */
body.woocommerce nav.woocommerce-pagination ul {
  border: 3px solid #1a1a1a !important;
  background: #fff !important;
  box-shadow: 4px 4px 0 #1a1a1a !important;
}
body.woocommerce nav.woocommerce-pagination ul li { border-right: 2px solid #1a1a1a !important; }
body.woocommerce nav.woocommerce-pagination ul li:last-child { border-right: none !important; }
body.woocommerce nav.woocommerce-pagination ul li a,
body.woocommerce nav.woocommerce-pagination ul li span {
  font-weight: 900 !important; padding: 10px 16px !important; color: #1a1a1a !important;
}
body.woocommerce nav.woocommerce-pagination ul li span.current,
body.woocommerce nav.woocommerce-pagination ul li a.current {
  background: #ccff00 !important; color: #1a1a1a !important;
}


/* === ショップ サイドバー商品ウィジェット非表示 === */
body.woocommerce-page .widget_products,
body.woocommerce-page .widget_recently_viewed_products,
body.woocommerce-page .widget_top_rated_products,
body.archive.woocommerce .widget_products,
body.woocommerce-cart .widget_products,
body.woocommerce-cart .widget_recently_viewed_products { display: none !important; }


/* === ショップ レスポンシブ === */
@media (max-width: 900px) {
  body.woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; }
}
@media (max-width: 480px) {
  body.woocommerce ul.products { grid-template-columns: 1fr !important; gap: 16px !important; }
  body.woocommerce ul.products li.product { padding: 14px !important; box-shadow: 5px 5px 0 #1a1a1a !important; }
}


/* ════════════════════════════════════════════════════════════
   カートページ
   ════════════════════════════════════════════════════════════ */

body.woocommerce-cart .shop_table.cart,
body.woocommerce-cart table.shop_table_responsive {
  background: #fff !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 6px 6px 0 #1a1a1a !important;
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  margin-bottom: 32px !important;
  border-radius: 0 !important;
}
body.woocommerce-cart .shop_table.cart thead { background: #1a1a1a !important; }
body.woocommerce-cart .shop_table.cart thead th {
  color: #ccff00 !important; font-weight: 900 !important;
  font-size: 13px !important; letter-spacing: 0.05em !important;
  padding: 14px 20px !important;
  text-align: left !important; border: none !important;
}
body.woocommerce-cart .shop_table.cart tbody td {
  padding: 16px 20px !important; vertical-align: middle !important;
  border: none !important; border-bottom: 2px solid #f0f0f0 !important;
}
body.woocommerce-cart .shop_table.cart tbody tr:last-child td { border-bottom: none !important; }
body.woocommerce-cart .product-thumbnail img {
  border: 2px solid #1a1a1a !important;
  max-width: 80px !important; height: auto !important;
}
body.woocommerce-cart .product-name a {
  font-weight: 900 !important; color: #1a1a1a !important;
  text-decoration: none !important; font-size: 14px !important;
}
body.woocommerce-cart .product-price,
body.woocommerce-cart .product-subtotal {
  font-weight: 900 !important; color: #1a1a1a !important; font-size: 15px !important;
}
body.woocommerce-cart .quantity .qty {
  border: 2px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 8px 10px !important; width: 60px !important; height: auto !important;
  text-align: center !important;
  font-weight: 900 !important; font-size: 14px !important;
  background: #fff !important;
  box-shadow: 2px 2px 0 #1a1a1a !important;
}
body.woocommerce-cart .product-remove a.remove {
  background: #ff3b30 !important; color: #fff !important;
  width: 28px !important; height: 28px !important;
  line-height: 28px !important; border-radius: 0 !important;
  font-size: 16px !important; font-weight: 900 !important;
  text-decoration: none !important; text-align: center !important;
}

body.woocommerce-cart .cart_totals {
  background: #fff !important;
  border: 3px solid #1a1a1a !important;
  box-shadow: 6px 6px 0 #1a1a1a !important;
  padding: 24px !important;
  margin-bottom: 32px !important;
}
body.woocommerce-cart .cart_totals h2 {
  font-family: Impact, "Arial Black", sans-serif !important;
  font-size: 20px !important; font-weight: 900 !important;
  margin: 0 0 16px 0 !important; color: #1a1a1a !important;
  background: none !important; box-shadow: none !important;
  transform: none !important; text-shadow: none !important; border: none !important;
  border-bottom: 3px solid #ccff00 !important;
  padding: 0 0 10px 0 !important;
}
body.woocommerce-cart .cart_totals table { width: 100% !important; border-collapse: collapse !important; }
body.woocommerce-cart .cart_totals table th,
body.woocommerce-cart .cart_totals table td {
  padding: 12px 0 !important; border: none !important;
  border-bottom: 1px dashed #ccc !important;
  background: transparent !important;
}
body.woocommerce-cart .cart_totals table th { font-weight: 700 !important; color: #1a1a1a !important; text-align: left !important; }
body.woocommerce-cart .cart_totals table td { font-weight: 900 !important; color: #1a1a1a !important; text-align: right !important; }
body.woocommerce-cart .cart_totals .order-total th,
body.woocommerce-cart .cart_totals .order-total td {
  border-bottom: none !important; padding-top: 16px !important;
}
body.woocommerce-cart .cart_totals .order-total th { font-size: 18px !important; }
body.woocommerce-cart .cart_totals .order-total .amount,
body.woocommerce-cart .cart_totals .order-total bdi {
  background: #ccff00 !important;
  padding: 4px 12px !important;
  display: inline-block !important;
  font-weight: 900 !important; color: #1a1a1a !important;
  font-size: 18px !important;
  border: 2px solid #1a1a1a !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
  transform: skewX(-6deg);
}

body.woocommerce-cart .checkout-button,
body.woocommerce-cart .wc-proceed-to-checkout a.button,
body.woocommerce-cart .wc-proceed-to-checkout .button {
  background: #1a1a1a !important; color: #ccff00 !important;
  border: 3px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 16px 28px !important;
  font-size: 16px !important; font-weight: 900 !important;
  letter-spacing: 0.05em !important;
  box-shadow: 5px 5px 0 #ccff00 !important;
  text-shadow: none !important; transform: none !important;
  width: 100% !important; display: block !important;
  text-align: center !important; text-decoration: none !important;
  box-sizing: border-box !important;
}
body.woocommerce-cart .checkout-button:hover {
  background: #ccff00 !important; color: #1a1a1a !important;
  box-shadow: 5px 5px 0 #1a1a1a !important;
}

body.woocommerce-cart .coupon input[type="text"],
body.woocommerce-cart input#coupon_code {
  border: 3px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 10px 12px !important;
  font-size: 14px !important; font-weight: 700 !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
}
body.woocommerce-cart button[name="apply_coupon"] {
  background: #1a1a1a !important; color: #ccff00 !important;
  border: 3px solid #1a1a1a !important; border-radius: 0 !important;
  padding: 10px 16px !important;
  font-weight: 900 !important; font-size: 13px !important;
  box-shadow: 3px 3px 0 #1a1a1a !important;
  text-shadow: none !important; transform: none !important;
  cursor: pointer !important;
}

@media (max-width: 640px) {
  body.woocommerce-cart .shop_table.cart { box-shadow: 4px 4px 0 #1a1a1a !important; }
  body.woocommerce-cart .cart_totals { box-shadow: 4px 4px 0 #1a1a1a !important; padding: 18px !important; }
  body.woocommerce-cart .checkout-button { padding: 14px !important; box-shadow: 4px 4px 0 #ccff00 !important; }
}


/* ════════════════════════════════════════════════════════════
   チェックアウトページ（上品モード）
   ════════════════════════════════════════════════════════════ */

body.woocommerce-checkout { background:#f5f5f7 !important; background-image:none !important; }
body.woocommerce-checkout #main,
body.woocommerce-checkout .siteContent,
body.woocommerce-checkout .site-body,
body.woocommerce-checkout .l-site-body,
body.woocommerce-checkout .container,
body.woocommerce-checkout .mainSection { background:transparent !important; }
body.woocommerce-checkout .page-header,
body.woocommerce-checkout .archive-header,
body.woocommerce-checkout .section-header,
body.woocommerce-checkout .l-page-header,
body.woocommerce-checkout .entry-header,
body.woocommerce-checkout h1.entry-title,
body.woocommerce-checkout .wp-block-post-title,
body.woocommerce-checkout .breadcrumb,
body.woocommerce-checkout #secondary,
body.woocommerce-checkout aside,
body.woocommerce-checkout .widget,
body.woocommerce-checkout .widget-area,
body.woocommerce-checkout .sidebar { display:none !important; }
body.woocommerce-checkout .mainSection,
body.woocommerce-checkout .l-site-body__main,
body.woocommerce-checkout .siteContentMain {
  width:100% !important; max-width:1180px !important; float:none !important;
  flex:1 1 100% !important; margin:0 auto !important;
  padding:32px 20px 48px !important; box-sizing:border-box !important;
}
body.woocommerce-checkout .entry-body,
body.woocommerce-checkout .entry,
body.woocommerce-checkout article.page { margin:0 !important; padding-top:0 !important; }
body.woocommerce-checkout .mainSection::before,
body.woocommerce-checkout .l-site-body__main::before,
body.woocommerce-checkout .siteContentMain::before {
  content:"ご購入手続き"; display:block; font-size:30px; line-height:1.35;
  font-weight:800; color:#111827; letter-spacing:.03em; margin:0 0 24px;
}
body.woocommerce-checkout form.checkout {
  display:grid !important;
  grid-template-columns:minmax(0,1.3fr) minmax(320px,.7fr) !important;
  gap:32px !important; align-items:start !important;
}
body.woocommerce-checkout #customer_details,
body.woocommerce-checkout #order_review {
  background:#fff !important; border:1px solid #e5e7eb !important;
  border-radius:16px !important; padding:28px !important;
  box-shadow:0 8px 24px rgba(0,0,0,.05) !important;
}
body.woocommerce-checkout h3,
body.woocommerce-checkout #order_review_heading {
  font-family:inherit !important; font-size:24px !important; font-weight:700 !important;
  color:#111827 !important; background:none !important; border:none !important;
  box-shadow:none !important; transform:none !important; text-shadow:none !important;
  padding:0 0 16px 0 !important; margin:0 0 20px 0 !important;
}
body.woocommerce-checkout h3::before,
body.woocommerce-checkout h3::after { content:none !important; display:none !important; }
body.woocommerce-checkout h3::after,
body.woocommerce-checkout #order_review_heading::after {
  content:"" !important; display:block !important; width:56px !important;
  height:3px !important; background:#111827 !important;
  border-radius:999px !important; margin-top:10px !important;
}
body.woocommerce-checkout input[type="text"],
body.woocommerce-checkout input[type="email"],
body.woocommerce-checkout input[type="tel"],
body.woocommerce-checkout input[type="password"],
body.woocommerce-checkout textarea,
body.woocommerce-checkout select {
  width:100% !important; min-height:48px !important;
  border:1px solid #d1d5db !important; border-radius:10px !important;
  background:#fff !important; box-shadow:none !important;
  padding:12px 14px !important; font-size:15px !important; color:#111827 !important;
}
body.woocommerce-checkout button,
body.woocommerce-checkout .button,
body.woocommerce-checkout #place_order {
  min-height:50px !important; border-radius:10px !important; border:none !important;
  background:#111827 !important; color:#fff !important;
  font-size:15px !important; font-weight:700 !important;
  padding:0 20px !important;
  box-shadow:none !important; transform:none !important; text-shadow:none !important;
}
@media (max-width:960px) {
  body.woocommerce-checkout form.checkout { grid-template-columns:1fr !important; }
}
.woocommerce-checkout input,
.woocommerce-checkout select,
.woocommerce-checkout textarea {
  font-size: 16px;
  line-height: 1.5;
  min-height: 52px;
  padding: 14px 16px;
  box-sizing: border-box;
}

.woocommerce-checkout label {
  display: block;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 6px;
}

.woocommerce-checkout .form-row {
  margin-bottom: 18px;
}

.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3 {
  display: block;
  width: 100%;
  padding: 10px 12px;
  margin: 24px 0 16px;
  line-height: 1.4;
  box-sizing: border-box;
}
.woocommerce-checkout input,
.woocommerce-checkout select,
.woocommerce-checkout textarea {
  font-size: 16px;
  line-height: 1.5;
  min-height: 52px;
  padding: 14px 16px;
  box-sizing: border-box;
}

.woocommerce-checkout label {
  display: block;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 6px;
}

.woocommerce-checkout .form-row {
  margin-bottom: 18px;
}

.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3 {
  display: block;
  width: 100%;
  padding: 10px 12px;
  margin: 24px 0 16px;
  line-height: 1.4;
  box-sizing: border-box;
}
/* ===== Checkout Fix Final ===== */

/* 入力欄 */
.wc-block-components-text-input input,
.wc-block-components-combobox input,
.wc-block-components-country-input input {
  height: 56px !important;
  min-height: 56px !important;
  padding: 18px 14px 6px !important;
  font-size: 16px !important;
  line-height: 1.4 !important;
  box-sizing: border-box !important;
}

/* ラベル */
.wc-block-components-text-input label,
.wc-block-components-combobox label,
.wc-block-components-country-input label {
  top: 6px !important;
  left: 14px !important;
  font-size: 11px !important;
  line-height: 1 !important;
  margin: 0 !important;
  transform: none !important;
  pointer-events: none !important;
  color: #666 !important;
}

/* 注文メモ削除 */
.wc-block-components-checkout-step--additional-information,
.wc-block-components-order-notes {
  display: none !important;
}

/* ===== Cart Page Mobile Fix ===== */
@media (max-width: 768px) {

  body.woocommerce-cart {
    background: #f5f5f7 !important;
    background-image: none !important;
  }

  body.woocommerce-cart .mainSection,
  body.woocommerce-cart .l-site-body__main,
  body.woocommerce-cart .siteContentMain {
    padding: 20px 14px 40px !important;
  }

  body.woocommerce-cart .breadcrumb {
    display: none !important;
  }

  body.woocommerce-cart .shop_table.cart,
  body.woocommerce-cart table.shop_table_responsive {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  body.woocommerce-cart table.cart tr.cart_item {
    display: grid !important;
    grid-template-columns: 82px 1fr !important;
    gap: 12px !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 16px !important;
    padding: 14px !important;
    margin-bottom: 16px !important;
    box-shadow: 0 8px 22px rgba(0,0,0,.06) !important;
  }

  body.woocommerce-cart table.cart td {
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
  }

  body.woocommerce-cart .product-thumbnail {
    grid-row: 1 / span 4 !important;
  }

  body.woocommerce-cart .product-thumbnail img {
    width: 72px !important;
    max-width: 72px !important;
    border-radius: 10px !important;
    border: 1px solid #ddd !important;
  }

  body.woocommerce-cart .product-name {
    font-size: 14px !important;
    line-height: 1.5 !important;
  }

  body.woocommerce-cart .product-name a {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #111827 !important;
  }

  body.woocommerce-cart .product-price,
  body.woocommerce-cart .product-subtotal {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #111827 !important;
  }

  body.woocommerce-cart .quantity {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
  }

  body.woocommerce-cart .quantity .qty {
    width: 70px !important;
    height: 38px !important;
    border-radius: 8px !important;
    box-shadow: none !important;
  }

  body.woocommerce-cart .product-remove {
    position: absolute !important;
    right: 16px !important;
    bottom: 16px !important;
  }

  body.woocommerce-cart .product-remove a.remove {
    background: transparent !important;
    color: #111827 !important;
    font-size: 22px !important;
  }

  body.woocommerce-cart .coupon,
  body.woocommerce-cart .actions {
    background: #fff !important;
    border-radius: 14px !important;
    padding: 14px !important;
    margin-top: 16px !important;
  }

  body.woocommerce-cart .cart_totals {
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 22px rgba(0,0,0,.06) !important;
    padding: 20px !important;
  }

  body.woocommerce-cart .wc-proceed-to-checkout a.button,
  body.woocommerce-cart .checkout-button {
    background: #111827 !important;
    color: #fff !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    border: none !important;
    font-size: 16px !important;
  }
}
/* ===== Checkout Mobile Form Final Fix ===== */
@media (max-width: 768px) {

  body.woocommerce-checkout .wc-block-components-text-input,
  body.woocommerce-checkout .wc-block-components-combobox,
  body.woocommerce-checkout .wc-block-components-country-input {
    position: relative !important;
    margin-bottom: 16px !important;
  }

  body.woocommerce-checkout .wc-block-components-text-input input,
  body.woocommerce-checkout .wc-block-components-combobox input,
  body.woocommerce-checkout .wc-block-components-country-input input,
  body.woocommerce-checkout .wc-block-components-select select {
    height: 68px !important;
    min-height: 68px !important;
    padding: 30px 14px 8px !important;
    font-size: 16px !important;
    line-height: 1.3 !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-checkout .wc-block-components-text-input label,
  body.woocommerce-checkout .wc-block-components-text-input.is-active label,
  body.woocommerce-checkout .wc-block-components-combobox label,
  body.woocommerce-checkout .wc-block-components-combobox.is-active label,
  body.woocommerce-checkout .wc-block-components-country-input label,
  body.woocommerce-checkout .wc-block-components-country-input.is-active label {
    position: absolute !important;
    top: 9px !important;
    left: 14px !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    translate: none !important;
    font-size: 12px !important;
    line-height: 1 !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #666 !important;
    pointer-events: none !important;
  }

  body.woocommerce-checkout .wc-block-components-address-form {
    display: block !important;
  }

  body.woocommerce-checkout .wc-block-components-address-form > * {
    width: 100% !important;
    max-width: 100% !important;
  }

  body.woocommerce-checkout .wc-block-components-checkout-step--additional-information,
  body.woocommerce-checkout .wc-block-components-order-notes,
  body.woocommerce-checkout .wc-block-components-checkout-step__container:has(.wc-block-components-order-notes) {
    display: none !important;
  }
}
/* ===== Checkout Mobile Form Final Fix ===== */
@media (max-width: 768px) {

  body.woocommerce-checkout .wc-block-components-text-input,
  body.woocommerce-checkout .wc-block-components-combobox,
  body.woocommerce-checkout .wc-block-components-country-input {
    position: relative !important;
    margin-bottom: 16px !important;
  }

  body.woocommerce-checkout .wc-block-components-text-input input,
  body.woocommerce-checkout .wc-block-components-combobox input,
  body.woocommerce-checkout .wc-block-components-country-input input,
  body.woocommerce-checkout .wc-block-components-select select {
    height: 68px !important;
    min-height: 68px !important;
    padding: 30px 14px 8px !important;
    font-size: 16px !important;
    line-height: 1.3 !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-checkout .wc-block-components-text-input label,
  body.woocommerce-checkout .wc-block-components-text-input.is-active label,
  body.woocommerce-checkout .wc-block-components-combobox label,
  body.woocommerce-checkout .wc-block-components-combobox.is-active label,
  body.woocommerce-checkout .wc-block-components-country-input label,
  body.woocommerce-checkout .wc-block-components-country-input.is-active label {
    position: absolute !important;
    top: 9px !important;
    left: 14px !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    translate: none !important;
    font-size: 12px !important;
    line-height: 1 !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #666 !important;
    pointer-events: none !important;
  }

  body.woocommerce-checkout .wc-block-components-address-form {
    display: block !important;
  }

  body.woocommerce-checkout .wc-block-components-address-form > * {
    width: 100% !important;
    max-width: 100% !important;
  }

  body.woocommerce-checkout .wc-block-components-checkout-step--additional-information,
  body.woocommerce-checkout .wc-block-components-order-notes,
  body.woocommerce-checkout .wc-block-components-checkout-step__container:has(.wc-block-components-order-notes) {
    display: none !important;
  }
}
/* ===== Checkout Select & Order Notes Force Fix ===== */
@media (max-width: 768px) {

  /* 国・都道府県のセレクト欄 */
  body.woocommerce-checkout .wc-block-components-combobox,
  body.woocommerce-checkout .wc-block-components-combobox-control,
  body.woocommerce-checkout .wc-block-components-country-input,
  body.woocommerce-checkout .wc-block-components-state-input,
  body.woocommerce-checkout .wc-block-components-select {
    position: relative !important;
    min-height: 68px !important;
  }

  body.woocommerce-checkout .wc-block-components-combobox input,
  body.woocommerce-checkout .wc-block-components-combobox-control input,
  body.woocommerce-checkout .wc-block-components-country-input input,
  body.woocommerce-checkout .wc-block-components-state-input input,
  body.woocommerce-checkout .wc-block-components-select select {
    height: 68px !important;
    min-height: 68px !important;
    padding: 30px 44px 8px 14px !important;
    font-size: 16px !important;
    line-height: 1.25 !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-checkout .wc-block-components-combobox label,
  body.woocommerce-checkout .wc-block-components-combobox-control label,
  body.woocommerce-checkout .wc-block-components-country-input label,
  body.woocommerce-checkout .wc-block-components-state-input label,
  body.woocommerce-checkout .wc-block-components-select label {
    position: absolute !important;
    top: 9px !important;
    left: 14px !important;
    transform: none !important;
    translate: none !important;
    font-size: 12px !important;
    line-height: 1 !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #666 !important;
    pointer-events: none !important;
    z-index: 2 !important;
  }

  /* 注文メモを強制非表示 */
  body.woocommerce-checkout .wc-block-checkout__additional-information,
  body.woocommerce-checkout .wc-block-components-checkout-step--additional-information,
  body.woocommerce-checkout .wc-block-components-order-notes,
  body.woocommerce-checkout .wc-block-components-textarea,
  body.woocommerce-checkout textarea[name="order_comments"],
  body.woocommerce-checkout [id*="order-notes"],
  body.woocommerce-checkout [class*="order-notes"],
  body.woocommerce-checkout [class*="additional-information"] {
    display: none !important;
  }
}
/* ===== Checkout Section Title Fix ===== */

body.woocommerce-checkout h3,
body.woocommerce-checkout .wc-block-components-checkout-step__heading,
body.woocommerce-checkout .wc-block-components-title {
  padding: 14px 20px !important;
  box-sizing: border-box !important;
}

/* 黒帯タイトル */
body.woocommerce-checkout h3 span,
body.woocommerce-checkout .wc-block-components-checkout-step__heading span {
  display: inline-block !important;
  padding-left: 2px !important;
}
/* ===== 国・都道府県 select 修正 ===== */

.wc-block-components-country-input,
.wc-block-components-state-input,
.wc-block-components-combobox {

  position: relative !important;
}

/* select本体 */
.wc-block-components-country-input select,
.wc-block-components-state-input select,
.wc-block-components-combobox select {

  height: 64px !important;
  min-height: 64px !important;

  padding:
    28px 42px 8px 14px !important;

  font-size: 16px !important;
  line-height: 1.2 !important;

  border-radius: 14px !important;

  appearance: none !important;
  -webkit-appearance: none !important;

  background-position:
    right 14px center !important;
}

/* ラベル */
.wc-block-components-country-input label,
.wc-block-components-state-input label,
.wc-block-components-combobox label {

  position: absolute !important;

  top: 8px !important;
  left: 14px !important;

  font-size: 12px !important;
  line-height: 1 !important;

  margin: 0 !important;

  transform: none !important;

  z-index: 2 !important;

  pointer-events: none !important;
}
/* ===== 左上ハンバーガーメニュー削除 ===== */

.menu-toggle,
.navbar-toggler,
.mobile-menu-btn,
.slide-menu-button,
.drawer-toggle,
.hamburger,
.hamburger-btn,
.vk-mobile-nav-menu-btn,
.vk-menu-btn,
.global-nav-toggle,
.offcanvas-toggle,
#mobile-menu-btn,
#menu-toggle {
  display: none !important;
}
/* Lightning モバイルメニュー削除 */

.siteHeader .menuBtn,
.site-header .menuBtn,
.vk-mobile-nav,
.vk-mobile-nav-menu-btn {
  display: none !important;
}