/* ============================================================
   KAZENA Marketplace — cs.money 風 ダークUI
   対象: Astra + WooCommerce
   v0.1.0
   ============================================================ */

:root {
	/* 背景・面 */
	--kz-bg:            #15161f;   /* ページ背景 */
	--kz-bg-2:         #1b1d29;   /* セクション背景 */
	--kz-surface:      #23252f;   /* カード面 */
	--kz-surface-2:    #2b2e3b;   /* カード面(ホバー/入力) */
	--kz-border:       #34384a;   /* 罫線 */

	/* 文字 */
	--kz-text:         #e7e9f0;   /* 主要文字 */
	--kz-text-dim:     #9aa0b4;   /* 補助文字 */
	--kz-text-faint:   #6b7088;   /* 薄い文字 */

	/* アクセント */
	--kz-accent:       #ffc83d;   /* ブランド黄(価格/CTA) */
	--kz-accent-2:     #4b8bff;   /* リンク/フォーカス青 */
	--kz-success:      #36c98f;   /* 値下げ/成功 */
	--kz-danger:       #eb4b4b;   /* 警告/赤レア */

	/* CS2 レア度カラー（標準色） */
	--rarity-consumer:    #b0c3d9; /* Consumer Grade */
	--rarity-industrial:  #5e98d9; /* Industrial Grade */
	--rarity-milspec:     #4b69ff; /* Mil-Spec */
	--rarity-restricted:  #8847ff; /* Restricted */
	--rarity-classified:  #d32ce6; /* Classified */
	--rarity-covert:      #eb4b4b; /* Covert */
	--rarity-special:     #e4ae39; /* ★ Knife/Gloves (Contraband) */

	--kz-radius:       14px;
	--kz-radius-sm:    10px;
}

/* ---------- 全体のダーク化 ---------- */
body.kazena-dark,
body.kazena-dark #page,
body.kazena-dark .site-content,
body.kazena-dark .ast-container {
	background-color: var(--kz-bg);
	color: var(--kz-text);
}

body.kazena-dark h1,
body.kazena-dark h2,
body.kazena-dark h3,
body.kazena-dark h4,
body.kazena-dark h5,
body.kazena-dark h6,
body.kazena-dark p,
body.kazena-dark li,
body.kazena-dark span,
body.kazena-dark label,
body.kazena-dark .entry-title,
body.kazena-dark .entry-content,
body.kazena-dark .ast-container,
body.kazena-dark .widget {
	color: var(--kz-text);
}
body.kazena-dark h1,
body.kazena-dark h2,
body.kazena-dark h3,
body.kazena-dark .entry-title {
	color: #fff;
}

/* サイトタイトル/ロゴ・キャッチフレーズ（最重要：暗背景で見えない問題の修正） */
body.kazena-dark .site-title,
body.kazena-dark .site-title a,
body.kazena-dark .ast-site-identity .site-title a,
body.kazena-dark header .site-title a {
	color: #fff !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, .5);
}
body.kazena-dark .site-description,
body.kazena-dark .ast-site-identity .site-description {
	color: var(--kz-text-dim) !important;
}
/* パンくず・ページタイトル帯・アーカイブ説明 */
body.kazena-dark .ast-breadcrumbs,
body.kazena-dark .ast-breadcrumbs a,
body.kazena-dark .page-title,
body.kazena-dark .woocommerce-products-header__title,
body.kazena-dark .term-description {
	color: var(--kz-text) !important;
}
/* フッタの文字も明るく */
body.kazena-dark .site-footer,
body.kazena-dark .site-footer p,
body.kazena-dark .site-footer a,
body.kazena-dark .ast-footer-overlay * {
	color: var(--kz-text-dim) !important;
}

/* ロゴ横のサイトタイトル文字を非表示（ロゴ画像は残す） */
.site-title,
.ast-site-title-wrap .site-title,
.site-header .site-title,
.ast-site-identity .site-title {
	display: none !important;
}

/* ---------- スマホ ハンバーガーメニュー（白背景＋黒文字＝確実に読める） ---------- */
.ast-mobile-popup-drawer .ast-mobile-popup-content,
.ast-mobile-popup-drawer .ast-mobile-popup-inner,
#ast-hf-mobile-menu,
.ast-mobile-popup-content {
	background-color: #ffffff !important;
}
.ast-mobile-popup-drawer a,
.ast-mobile-popup-drawer .menu-link,
.ast-mobile-popup-drawer .menu-item > a,
.ast-mobile-popup-drawer .sub-menu a,
.ast-mobile-popup-drawer li a,
#ast-hf-mobile-menu a,
#ast-hf-mobile-menu .menu-link,
.ast-mobile-popup-content a {
	color: #15161f !important;
}
.ast-mobile-popup-drawer a:hover,
#ast-hf-mobile-menu a:hover {
	color: var(--kz-accent-2) !important;
}
.ast-mobile-popup-drawer .menu-item,
#ast-hf-mobile-menu .menu-item {
	border-bottom: 1px solid #e7e7ec !important;
}
.ast-mobile-popup-drawer .current-menu-item > a {
	color: var(--kz-accent-2) !important;
	font-weight: 700;
}
/* 閉じる(×)・サブメニュー矢印を濃色に */
.ast-mobile-popup-drawer .menu-toggle-close,
.ast-mobile-popup-drawer .ast-close-svg path,
.ast-mobile-popup-drawer .ast-menu-toggle {
	color: #15161f !important;
	fill: #15161f !important;
}
.ast-mobile-popup-drawer .ast-search-menu-icon .search-field {
	background: #f1f1f4 !important;
	color: #15161f !important;
}

body.kazena-dark a {
	color: var(--kz-accent-2);
}
body.kazena-dark a:hover {
	color: #7aa9ff;
}

/* ヘッダ/フッタもダークに寄せる */
body.kazena-dark .site-header,
body.kazena-dark .ast-primary-header-bar,
body.kazena-dark .site-footer,
body.kazena-dark .ast-footer-overlay {
	background-color: var(--kz-bg-2) !important;
	border-color: var(--kz-border);
}
body.kazena-dark .main-header-menu a,
body.kazena-dark .site-header .ast-builder-menu a {
	color: var(--kz-text) !important;
}
body.kazena-dark .main-header-menu a:hover {
	color: var(--kz-accent) !important;
}

/* ---------- WooCommerce 商品グリッド（cs.money風カード） ---------- */
body.kazena-dark .woocommerce ul.products,
body.kazena-dark .woocommerce-page ul.products {
	gap: 18px;
}

body.kazena-dark .woocommerce ul.products li.product,
body.kazena-dark .woocommerce-page ul.products li.product {
	background: var(--kz-surface);
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius);
	padding: 12px 12px 16px;
	margin: 0 0 18px;
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	position: relative;
	overflow: hidden;
}

body.kazena-dark .woocommerce ul.products li.product:hover {
	transform: translateY(-3px);
	border-color: var(--kz-surface-2);
	box-shadow: 0 10px 26px rgba(0, 0, 0, .45);
}

/* レア度の上部カラーバー（li.product に rarity-* クラスを付与して使う） */
body.kazena-dark li.product::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: var(--kz-border);
	opacity: .9;
}
body.kazena-dark li.product.rarity-consumer::before   { background: var(--rarity-consumer); }
body.kazena-dark li.product.rarity-industrial::before { background: var(--rarity-industrial); }
body.kazena-dark li.product.rarity-milspec::before    { background: var(--rarity-milspec); }
body.kazena-dark li.product.rarity-restricted::before { background: var(--rarity-restricted); }
body.kazena-dark li.product.rarity-classified::before { background: var(--rarity-classified); }
body.kazena-dark li.product.rarity-covert::before     { background: var(--rarity-covert); }
body.kazena-dark li.product.rarity-special::before    { background: var(--rarity-special); }

body.kazena-dark .woocommerce ul.products li.product img {
	border-radius: var(--kz-radius-sm);
	background: radial-gradient(circle at 50% 40%, rgba(255,255,255,.05), transparent 70%);
}

body.kazena-dark .woocommerce ul.products li.product .woocommerce-loop-product__title {
	color: var(--kz-text);
	font-size: 14px;
	line-height: 1.35;
	padding: 10px 2px 2px;
}

/* 価格 */
body.kazena-dark .woocommerce ul.products li.product .price,
body.kazena-dark .woocommerce div.product p.price {
	color: var(--kz-accent);
	font-weight: 700;
}
body.kazena-dark .woocommerce ul.products li.product .price del {
	color: var(--kz-text-faint);
	font-weight: 400;
	opacity: .8;
}
body.kazena-dark .woocommerce ul.products li.product .price ins {
	text-decoration: none;
	color: var(--kz-success);
}

/* カート/ボタン */
body.kazena-dark .woocommerce a.button,
body.kazena-dark .woocommerce button.button,
body.kazena-dark .woocommerce .button.add_to_cart_button,
body.kazena-dark .woocommerce #respond input#submit {
	background: var(--kz-accent);
	color: #1a1408;
	border-radius: 999px;
	font-weight: 700;
	border: none;
	transition: filter .15s ease;
}
body.kazena-dark .woocommerce a.button:hover,
body.kazena-dark .woocommerce button.button:hover {
	filter: brightness(1.08);
}

/* ---------- WOOF（商品フィルタ）サイドバー ---------- */
body.kazena-dark .woof_container,
body.kazena-dark .woof_sid_auto_shortcode,
body.kazena-dark .widget_woof_widget {
	background: var(--kz-surface);
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius);
	padding: 14px 16px;
	color: var(--kz-text);
}
body.kazena-dark .woof_container .woof_block_html_items label,
body.kazena-dark .woof_container .woof_redraw_zone {
	color: var(--kz-text-dim);
}
body.kazena-dark .woof_submit_search_form_button,
body.kazena-dark .woof_reset_search_form {
	background: var(--kz-accent-2) !important;
	color: #fff !important;
	border-radius: 999px !important;
	border: none !important;
}

/* ---------- 検索（FiboSearch）ダーク調整 ---------- */
body.kazena-dark .dgwt-wcas-search-wrapp input.dgwt-wcas-search-input {
	background: var(--kz-surface-2);
	color: var(--kz-text);
	border: 1px solid var(--kz-border);
	border-radius: 999px;
}

/* ---------- 入力フォーム全般 ---------- */
body.kazena-dark input[type="text"],
body.kazena-dark input[type="email"],
body.kazena-dark input[type="password"],
body.kazena-dark input[type="search"],
body.kazena-dark input[type="number"],
body.kazena-dark select,
body.kazena-dark textarea {
	background: var(--kz-surface-2);
	color: var(--kz-text);
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius-sm);
}
body.kazena-dark input::placeholder,
body.kazena-dark textarea::placeholder {
	color: var(--kz-text-faint);
}
body.kazena-dark input:focus,
body.kazena-dark select:focus,
body.kazena-dark textarea:focus {
	outline: none;
	border-color: var(--kz-accent-2);
	box-shadow: 0 0 0 2px rgba(75, 139, 255, .25);
}

/* ---------- バッジ（外観/StatTrak/Souvenir 用ユーティリティ） ---------- */
.kz-badge {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
	padding: 4px 8px;
	border-radius: 999px;
	background: var(--kz-surface-2);
	color: var(--kz-text-dim);
	border: 1px solid var(--kz-border);
}
.kz-badge--stattrak { color: #cf6a32; border-color: #cf6a32; }
.kz-badge--souvenir { color: #ffd700; border-color: #ffd700; }
.kz-badge--float    { color: var(--kz-text); }

/* カード内バッジ行 */
.kz-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin: 6px 2px 2px;
}
.kz-single-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	margin: 10px 0;
}
.kz-stickers,
.kz-inspect {
	flex-basis: 100%;
	font-size: 13px;
	color: var(--kz-text-dim);
	margin-top: 6px;
}

/* ---------- マイアカウント/Dokan の面もダークに ---------- */
body.kazena-dark .woocommerce-MyAccount-navigation ul li,
body.kazena-dark .dokan-dashboard .dokan-dash-sidebar {
	background: var(--kz-surface);
	border-color: var(--kz-border);
}

/* ---------- トップ ヒーロースライダー ---------- */
.kz-hero {
	position: relative;
	overflow: hidden;
	border-radius: 16px;
	margin: 0 0 30px;
	background: var(--kz-bg-2);
	box-shadow: 0 10px 30px rgba(0, 0, 0, .35);
}
.kz-hero__track {
	display: flex;
	transition: transform .55s cubic-bezier(.4, 0, .2, 1);
	will-change: transform;
}
.kz-hero__slide {
	flex: 0 0 100%;
	display: block;
	aspect-ratio: 1600 / 520;
	background-size: cover;
	background-position: center;
	text-decoration: none;
}
.kz-hero__dots {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 16px;
	display: flex;
	gap: 8px;
	justify-content: center;
}
.kz-hero__dot {
	width: 10px;
	height: 10px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: rgba(255, 255, 255, .45);
	cursor: pointer;
	transition: width .2s ease, background .2s ease;
}
.kz-hero__dot.is-active {
	width: 24px;
	border-radius: 6px;
	background: var(--kz-accent);
}
.kz-hero__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 42px;
	height: 42px;
	border: none;
	border-radius: 50%;
	background: rgba(0, 0, 0, .35);
	color: #fff;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	opacity: 0;
	transition: opacity .2s ease, background .2s ease;
}
.kz-hero:hover .kz-hero__nav { opacity: 1; }
.kz-hero__nav:hover { background: var(--kz-accent); color: #1a1408; }
.kz-hero__prev { left: 14px; }
.kz-hero__next { right: 14px; }

@media (max-width: 768px) {
	.kz-hero { border-radius: 12px; }
	.kz-hero__nav { display: none; }
}

/* ---------- 通貨スイッチャー（IDR / USD） ---------- */
.kz-currency-switch {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 3px;
	background: var(--kz-surface-2);
	border: 1px solid var(--kz-border);
	border-radius: 999px;
}
.kz-currency-switch button {
	appearance: none;
	border: none;
	cursor: pointer;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	padding: 6px 12px;
	border-radius: 999px;
	background: transparent;
	color: var(--kz-text-dim);
	transition: background .15s ease, color .15s ease;
}
.kz-currency-switch button:hover {
	color: var(--kz-text);
}
.kz-currency-switch button.is-active {
	background: var(--kz-accent);
	color: #1a1408;
}

/* フッタ右下のフローティング版（統合トグル） */
.kz-float-controls {
	position: fixed;
	right: 16px;
	bottom: 16px;
	z-index: 9999;
}
.kz-float-controls .kz-locale-switch {
	box-shadow: 0 8px 22px rgba(0, 0, 0, .45);
}

/* 統合スイッチャー（言語＋通貨） */
.kz-locale-switch {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 3px;
	background: var(--kz-surface-2);
	border: 1px solid var(--kz-border);
	border-radius: 999px;
}
.kz-locale-switch button {
	appearance: none;
	border: none;
	cursor: pointer;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	padding: 7px 13px;
	border-radius: 999px;
	background: transparent;
	color: var(--kz-text-dim);
	white-space: nowrap;
	transition: background .15s ease, color .15s ease;
}
.kz-locale-switch button:hover { color: var(--kz-text); }
.kz-locale-switch button.is-active {
	background: var(--kz-accent);
	color: #1a1408;
}

/* 言語スイッチャー（通貨と同デザイン） */
.kz-lang-switch {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 3px;
	background: var(--kz-surface-2);
	border: 1px solid var(--kz-border);
	border-radius: 999px;
}
.kz-lang-switch button {
	appearance: none;
	border: none;
	cursor: pointer;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	padding: 6px 12px;
	border-radius: 999px;
	background: transparent;
	color: var(--kz-text-dim);
	transition: background .15s ease, color .15s ease;
}
.kz-lang-switch button:hover { color: var(--kz-text); }
.kz-lang-switch button.is-active {
	background: var(--kz-accent-2);
	color: #fff;
}

/* Google翻訳の既定UI（バナー/ツールチップ）を隠す */
.goog-te-banner-frame.skiptranslate,
.goog-te-gadget-icon,
#goog-gt-tt,
.goog-te-balloon-frame { display: none !important; }
.goog-text-highlight { background: none !important; box-shadow: none !important; }
body { top: 0 !important; }
.skiptranslate iframe { visibility: hidden !important; height: 0 !important; }

/* USD換算中の価格はわずかに区別（任意） */
body.kazena-dark .woocommerce-Price-amount.kz-usd {
	color: var(--kz-accent);
}

/* ============================================================
   KAZENA Market（cs.money風 左フィルタ＋グリッド）
   ============================================================ */
.kz-market {
	display: flex;
	gap: 22px;
	align-items: flex-start;
	max-width: 1480px;
	margin: 0 auto;
}

/* 左フィルタ */
.kz-market__filters {
	flex: 0 0 270px;
	width: 270px;
	background: var(--kz-surface);
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius);
	padding: 16px 16px 20px;
	position: sticky;
	top: 16px;
	max-height: calc(100vh - 32px);
	overflow-y: auto;
}
.kz-filter-head {
	font-size: 16px;
	font-weight: 800;
	color: #fff;
	margin-bottom: 12px;
}
.kz-filter-group {
	padding: 12px 0;
	border-top: 1px solid var(--kz-border);
}
.kz-filter-title {
	display: block;
	font-size: 13px;
	font-weight: 700;
	color: var(--kz-text);
	margin-bottom: 8px;
	text-transform: uppercase;
	letter-spacing: .03em;
}
.kz-filter-options { display: flex; flex-direction: column; gap: 7px; }
.kz-check {
	display: flex;
	align-items: center;
	gap: 7px;
	font-size: 13px;
	color: var(--kz-text-dim);
	cursor: pointer;
}
.kz-check input { accent-color: var(--kz-accent); }
.kz-check:hover { color: var(--kz-text); }
.kz-cnt { margin-left: auto; font-size: 11px; color: var(--kz-text-faint); }
.kz-dot { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.kz-search,
.kz-price {
	width: 100%;
	background: var(--kz-surface-2);
	color: var(--kz-text);
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius-sm);
	padding: 9px 10px;
	font-size: 13px;
}
.kz-price-row { display: flex; align-items: center; gap: 6px; }
.kz-price-row span { color: var(--kz-text-faint); }
.kz-reset {
	width: 100%;
	margin-top: 14px;
	padding: 9px;
	border: 1px solid var(--kz-border);
	background: transparent;
	color: var(--kz-text-dim);
	border-radius: 999px;
	font-weight: 600;
	cursor: pointer;
}
.kz-reset:hover { color: #fff; border-color: var(--kz-accent-2); }

/* 右メイン */
.kz-market__main { flex: 1 1 auto; min-width: 0; }
.kz-market__bar {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}
.kz-count { font-size: 14px; color: var(--kz-text-dim); font-weight: 600; }
.kz-sort-wrap { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.kz-sort-wrap label { font-size: 13px; color: var(--kz-text-faint); }
.kz-sort {
	background: var(--kz-surface-2);
	color: var(--kz-text);
	border: 1px solid var(--kz-border);
	border-radius: 999px;
	padding: 8px 12px;
	font-size: 13px;
}
.kz-filter-toggle {
	display: none;
	background: var(--kz-accent);
	color: #1a1408;
	border: none;
	border-radius: 999px;
	padding: 9px 16px;
	font-weight: 700;
	cursor: pointer;
}

/* グリッド（4列→画面幅で可変） */
.kz-market__grid ul.products,
.kz-market__grid .products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 18px;
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
}
.kz-market__grid ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
}
.kz-market__grid.is-loading { opacity: .5; transition: opacity .15s; }
.kz-noresult { color: var(--kz-text-dim); padding: 40px 0; text-align: center; }
.kz-market__loading { color: var(--kz-text-dim); padding: 16px 0; text-align: center; }

/* ---------- レスポンシブ：マーケット ---------- */
@media (max-width: 1200px) {
	.kz-market__grid ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 992px) {
	.kz-market__grid ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 782px) {
	.kz-market { gap: 0; }
	.kz-filter-toggle { display: inline-block; }
	/* サイドバーをオフキャンバス（ドロワー） */
	.kz-market__filters {
		position: fixed;
		top: 0;
		left: 0;
		bottom: 0;
		z-index: 99990;
		width: 84vw;
		max-width: 320px;
		max-height: none;
		border-radius: 0;
		transform: translateX(-105%);
		transition: transform .25s ease;
	}
	.kz-market.filters-open .kz-market__filters { transform: translateX(0); }
	.kz-market.filters-open::before {
		content: "";
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, .55);
		z-index: 99980;
	}
	.kz-market__main { width: 100%; }
}
@media (max-width: 560px) {
	.kz-market__grid ul.products { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}
@media (max-width: 380px) {
	.kz-market__grid ul.products { grid-template-columns: 1fr; }
}

/* ============================================================
   商品詳細（cs.money風）
   ============================================================ */
body.kazena-dark.single-product div.product {
	display: flex;
	flex-wrap: wrap;
	gap: 36px;
	align-items: flex-start;
}
body.kazena-dark.single-product div.product .woocommerce-product-gallery {
	flex: 1 1 44%;
	max-width: 48%;
	background: var(--kz-surface);
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius);
	padding: 20px;
}
body.kazena-dark.single-product div.product .summary {
	flex: 1 1 48%;
	margin: 0;
}
body.kazena-dark .product_title {
	font-size: 30px;
	line-height: 1.2;
}
body.kazena-dark.single-product .summary .price {
	font-size: 30px;
	margin: 14px 0;
}
body.kazena-dark .single_add_to_cart_button {
	font-size: 16px !important;
	padding: 14px 28px !important;
}
.kz-escrow-badge {
	margin: 16px 0;
	padding: 12px 14px;
	background: rgba(54, 201, 143, .10);
	border: 1px solid rgba(54, 201, 143, .35);
	border-radius: var(--kz-radius-sm);
	color: var(--kz-text);
	font-size: 13px;
	line-height: 1.5;
}
.kz-escrow-badge strong { color: var(--kz-success); }
.kz-escrow-note {
	margin-top: 10px;
	font-size: 12px;
	color: var(--kz-text-dim);
	text-align: center;
}

/* ============================================================
   ウォレット（マイアカウント）
   ============================================================ */
.kz-wallet__balance {
	display: flex;
	flex-direction: column;
	gap: 4px;
	background: linear-gradient(135deg, var(--kz-bg-2), var(--kz-surface));
	border: 1px solid var(--kz-border);
	border-radius: var(--kz-radius);
	padding: 22px 24px;
	margin-bottom: 20px;
}
.kz-wallet__balance span { color: var(--kz-text-dim); font-size: 13px; }
.kz-wallet__balance strong { color: var(--kz-accent); font-size: 34px; font-weight: 800; }
.kz-wallet__deposit { margin-bottom: 24px; }
.kz-wallet__deposit label { display: block; font-size: 13px; color: var(--kz-text-dim); margin-bottom: 6px; }
.kz-wallet__row { display: flex; gap: 10px; max-width: 420px; }
.kz-wallet__row input { flex: 1; }
.kz-hint { font-size: 12px; color: var(--kz-text-faint); margin-top: 6px; }
.kz-wallet__log { width: 100%; border-collapse: collapse; }
.kz-wallet__log th, .kz-wallet__log td { padding: 9px 10px; border-bottom: 1px solid var(--kz-border); font-size: 13px; text-align: left; }
.kz-wallet__log .kz-in { color: var(--kz-success); }
.kz-wallet__log .kz-out { color: var(--kz-danger); }
.kz-notice { padding: 10px 14px; background: rgba(54,201,143,.12); border: 1px solid rgba(54,201,143,.35); border-radius: 8px; color: var(--kz-text); margin-bottom: 14px; }
.kz-balance-chip {
	display: inline-block;
	background: var(--kz-surface-2);
	border: 1px solid var(--kz-border);
	border-radius: 999px;
	padding: 6px 14px;
	font-weight: 700;
	color: var(--kz-accent) !important;
}
.kz-balance-line { color: var(--kz-text-dim); }

/* ============================================================
   エスクロー（注文詳細）
   ============================================================ */
.kz-escrow-box {
	margin: 22px 0;
	padding: 18px 20px;
	background: var(--kz-surface);
	border: 1px solid var(--kz-border);
	border-left: 4px solid var(--kz-success);
	border-radius: var(--kz-radius-sm);
}
.kz-escrow-box__title { font-weight: 800; color: #fff; margin-bottom: 6px; }
.kz-escrow-box p { color: var(--kz-text-dim); font-size: 14px; margin: 0 0 12px; }
.kz-escrow-box__actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.kz-escrow-box .kz-confirm { background: var(--kz-success); color: #0a1a12; }
.kz-escrow-box .kz-link { color: var(--kz-text-faint); font-size: 13px; text-decoration: underline; }

/* ---------- レスポンシブ：商品詳細/ウォレット ---------- */
@media (max-width: 782px) {
	body.kazena-dark.single-product div.product { flex-direction: column; gap: 20px; }
	body.kazena-dark.single-product div.product .woocommerce-product-gallery,
	body.kazena-dark.single-product div.product .summary {
		max-width: 100%;
		flex-basis: 100%;
		width: 100%;
	}
	.kz-product_title, body.kazena-dark .product_title { font-size: 24px; }
	.kz-wallet__row { flex-wrap: wrap; }
}

/* ---------- スマホ全般 ---------- */
@media (max-width: 768px) {
	body.kazena-dark .woocommerce ul.products li.product {
		padding: 10px 10px 14px;
	}
	.kz-float-controls {
		right: 12px;
		bottom: 12px;
	}
	.kz-float-controls .kz-locale-switch button {
		padding: 6px 10px;
		font-size: 11px;
	}
}
