/* ──────────────────────────────────────────────────────────────
 * BSM&T B2B — Theme CSS
 * Tokens + base + header + footer + front-page sections.
 * Korean-first · Flat · Functional · Navy primary (#004282).
 * ────────────────────────────────────────────────────────────── */

:root {
  --c-primary: #004282;
  --c-primary-hover: #003469;
  --c-primary-press: #002851;
  --c-primary-tint: #d6e4f2;
  --c-primary-softer: #eef4fb;

  --c-warning: #ffc107; --c-warning-bg: #fff3cd; --c-warning-text: #856404;
  --c-success: #28a745; --c-success-bg: #d4edda; --c-success-text: #155724;
  --c-danger:  #dc3545; --c-danger-bg:  #f8d7da; --c-danger-text:  #721c24;
  --c-info:    #17a2b8; --c-info-bg:    #cce5ff; --c-info-text:    #004085;

  --c-bg: #f8f9fa;
  --c-surface: #fff;
  --c-surface-alt: #f1f1f1;
  --c-border: #e5e5e5;
  --c-border-strong: #c3c4c7;
  --c-divider: #eee;

  --c-fg-1: #1d2327;
  --c-fg-2: #333;
  --c-fg-3: #666;
  --c-fg-4: #8c8f94;

  --font-sans: 'Pretendard Variable','Pretendard',-apple-system,BlinkMacSystemFont,system-ui,'Segoe UI',Roboto,'Apple SD Gothic Neo','Noto Sans KR','Malgun Gothic','맑은 고딕',sans-serif;
  --font-mono: ui-monospace,'SF Mono',Menlo,Consolas,monospace;

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-8:32px; --s-10:40px; --s-12:48px; --s-16:64px; --s-20:80px;
  --r-xs:3px; --r-sm:4px; --r-md:6px; --r-lg:8px; --r-pill:12px; --r-round:999px;
  --sh-sm: 0 1px 3px rgba(0,0,0,.08);
  --sh-md: 0 1px 4px rgba(0,0,0,.10);
  --sh-lg: 0 4px 12px rgba(0,0,0,.12);
  --container: 1200px;
}

/* Reset */
*,*::before,*::after { box-sizing: border-box; }
body { margin:0; font-family: var(--font-sans); font-size:16px; line-height:1.65; color: var(--c-fg-2); background: var(--c-surface); -webkit-font-smoothing:antialiased; word-break: keep-all; overflow-wrap: break-word; }
img,svg { max-width:100%; display:block; }
a { color: var(--c-primary); text-decoration:none; }
a:hover { color: var(--c-primary-hover); text-decoration: underline; }
h1,h2,h3,h4,h5,h6 { margin:0 0 var(--s-3); color: var(--c-fg-1); font-weight:700; line-height:1.3; text-wrap: balance; }
h1 { font-size:40px; letter-spacing:-0.02em; }
h2 { font-size:28px; letter-spacing:-0.01em; }
h3 { font-size:20px; }
p  { margin:0 0 var(--s-3); text-wrap: pretty; }
ul { padding:0; margin:0; list-style:none; }
button { font-family: inherit; cursor: pointer; }
.num, .money { font-variant-numeric: tabular-nums; font-feature-settings:'tnum' 1; }
.screen-reader-text { position:absolute !important; width:1px; height:1px; overflow:hidden; clip: rect(1px,1px,1px,1px); }
.skip-link { position:absolute; left:-9999px; top:8px; padding:8px 16px; background:var(--c-primary); color:#fff; z-index:9999; }
.skip-link:focus { left: 8px; }
:focus-visible { outline: 2px solid var(--c-primary); outline-offset: 2px; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--s-5); }

/* Lucide icons inline */
[data-lucide] { width: 18px; height: 18px; stroke-width: 1.75; vertical-align: middle; display:inline-block; }

/* ──────── Buttons ──────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 10px 18px; border-radius: var(--r-sm); border:1px solid transparent;
  font-weight:600; font-size:14px; line-height:1; cursor:pointer;
  white-space: nowrap;
  transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
  text-decoration:none;
}
.btn--primary { background: var(--c-primary); color:#fff; }
.btn--primary:hover { background: var(--c-primary-hover); color:#fff; text-decoration:none; }
.btn--primary:active { background: var(--c-primary-press); }
.btn--ghost { background:#fff; color: var(--c-fg-1); border-color: var(--c-border-strong); }
.btn--ghost:hover { background: var(--c-surface-alt); color: var(--c-fg-1); text-decoration:none; }
.btn--lg { padding: 14px 24px; font-size: 15px; }
.btn--sm { padding: 7px 12px; font-size: 13px; }

/* ──────── Status badges ──────── */
.status-badge { display:inline-flex; align-items:center; padding: 3px 10px; border-radius: var(--r-pill); font-size:12px; font-weight:600; }
.status-badge--success { background: var(--c-success-bg); color: var(--c-success-text); }
.status-badge--warning { background: var(--c-warning-bg); color: var(--c-warning-text); }
.status-badge--danger  { background: var(--c-danger-bg);  color: var(--c-danger-text); }
.status-badge--info    { background: var(--c-info-bg);    color: var(--c-info-text); }

/* Tier badge */
.tier-badge { display:inline-block; padding: 2px 8px; border-radius: var(--r-pill); font-size: 11px; font-weight:700; letter-spacing: 0.04em; background: var(--c-surface-alt); color: var(--c-fg-3); margin-right: 6px; }
.tier-badge.tier-gold     { background:#fff3cd; color:#856404; }
.tier-badge.tier-silver   { background:#e2e3e5; color:#383d41; }
.tier-badge.tier-bronze   { background:#ffe8d1; color:#8a4b1a; }
.tier-badge.tier-platinum { background:#d6e4f2; color:#004282; }
.tier-badge.tier-pending  { background:#fff3cd; color:#856404; }

/* ──────── Topbar ──────── */
.topbar { background: var(--c-fg-1); color: #cbd1d6; font-size: 13px; }
.topbar a { color: #cbd1d6; }
.topbar a:hover { color: #fff; text-decoration: none; }
.topbar-inner { display:flex; justify-content:space-between; align-items:center; height: 36px; gap: var(--s-4); }
.topbar-left, .topbar-right { display:flex; align-items:center; gap: var(--s-5); }
.topbar-item { display:inline-flex; align-items:center; gap:6px; }
.topbar-item [data-lucide] { width:14px; height:14px; }
.topbar-item--muted { color:#8a9399; }
.topbar-link { padding: 4px 0; }
.topbar-link--cta { color:#ffd166 !important; font-weight: 600; }

/* ──────── Header ──────── */
.site-header { background:#fff; border-bottom: 1px solid var(--c-border); }
.header-inner { display:grid; grid-template-columns: auto 1fr auto; gap: var(--s-8); align-items:center; padding: var(--s-5) var(--s-5); }
.header-brand { flex-shrink: 0; min-width: 160px; }
.header-brand .site-logo-link { display:inline-flex; align-items:center; gap: 10px; text-decoration: none; color: var(--c-fg-1); }
.header-brand .site-logo-name { font-size: 18px; font-weight: 700; color: var(--c-primary); letter-spacing: -0.01em; white-space: nowrap; }
.header-brand img, .header-brand .site-logo, .header-brand .custom-logo { height: 44px !important; width: auto !important; max-width: 220px !important; max-height: 44px; display: block; }
.custom-logo { height: 44px; width: auto; }

.header-search-wrap { max-width: 560px; width: 100%; justify-self: center; }
.header-search { position:relative; display:flex; align-items:center; background: #fff; border: 2px solid var(--c-primary); border-radius: var(--r-pill); overflow: hidden; }
.header-search-icon { position:absolute; left: 16px; color: var(--c-primary); pointer-events:none; }
.header-search input[type=search] { flex:1; padding: 12px 18px 12px 44px; border: 0; outline: none; font-size: 15px; background: transparent; }
.header-search-hints { display:flex; gap: var(--s-3); font-size: 12px; color: var(--c-fg-3); margin-top: 6px; padding: 0 4px; }
.header-search-hints a { color: var(--c-fg-3); }
.header-search-hints a:hover { color: var(--c-primary); text-decoration:none; }

.header-actions { display:flex; align-items:center; gap: var(--s-4); }
.header-quote, .header-cart, .header-account {
  display:inline-flex; align-items:center; gap: 6px; padding: 8px 10px;
  color: var(--c-fg-2); font-size: 13px; font-weight: 500; border-radius: var(--r-sm);
}
.header-quote:hover, .header-cart:hover, .header-account:hover { background: var(--c-surface-alt); color: var(--c-fg-1); text-decoration:none; }
.header-quote-count, .header-cart-count {
  display:inline-flex; align-items:center; justify-content:center;
  min-width: 20px; height: 20px; padding: 0 6px;
  background: var(--c-primary); color: #fff; border-radius: var(--r-round); font-size: 11px; font-weight:700;
}
.header-cart-total { color: var(--c-fg-3); font-size: 12px; margin-left: 4px; }

/* Primary nav */
.site-nav { background:#fff; border-top: 1px solid var(--c-divider); border-bottom: 2px solid var(--c-primary); }
.site-nav-inner { display:flex; align-items:stretch; gap: var(--s-4); }
.nav-categories {
  display:inline-flex; align-items:center; gap: 8px;
  background: var(--c-primary); color:#fff; padding: 0 20px; border:0;
  font-weight: 600; font-size: 14px; cursor: pointer;
}
.nav-categories:hover { background: var(--c-primary-hover); }
.primary-menu { display:flex; align-items:stretch; gap: 0; flex:1; }
.primary-menu li { display:flex; }
.primary-menu a { display:inline-flex; align-items:center; padding: 14px 20px; color: var(--c-fg-1); font-weight: 500; font-size: 15px; }
.primary-menu a:hover { background: var(--c-surface-alt); text-decoration:none; color: var(--c-primary); }
.primary-menu .current-menu-item > a, .primary-menu .current_page_item > a { color: var(--c-primary); font-weight:700; box-shadow: inset 0 -3px 0 var(--c-primary); }
.site-nav-right { display:flex; align-items:center; padding-right: 4px; }
.nav-cta { display:inline-flex; align-items:center; gap:6px; color: var(--c-primary); font-weight: 600; font-size: 14px; padding: 0 12px; }

/* ──────── Site main ──────── */
.site-main { min-height: 50vh; }

/* ──────── Hero ──────── */
.hero { background: linear-gradient(180deg, var(--c-primary-softer) 0%, #fff 100%); padding: var(--s-16) 0 var(--s-20); border-bottom: 1px solid var(--c-border); }
.hero-inner { display:grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--s-12); align-items:center; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:6px; padding: 6px 12px; background: var(--c-primary-tint); color: var(--c-primary); border-radius: var(--r-pill); font-size: 13px; font-weight: 600; margin-bottom: var(--s-5); }
.hero-title { font-size: 52px; line-height: 1.2; letter-spacing: -0.025em; margin-bottom: var(--s-5); font-weight: 700; }
.hero-title strong { color: var(--c-primary); font-weight: 900; }
.hero-sub { font-size: 18px; color: var(--c-fg-3); margin-bottom: var(--s-8); max-width: 540px; }
.hero-actions { display:flex; gap: var(--s-3); margin-bottom: var(--s-10); flex-wrap:wrap; }
.hero-trust { display:grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); padding-top: var(--s-6); border-top: 1px solid var(--c-border); }
.hero-trust li strong { display:block; font-size: 28px; font-weight: 900; color: var(--c-primary); line-height:1.1; }
.hero-trust li span { display:block; font-size: 13px; color: var(--c-fg-3); margin-top: 2px; }

.hero-visual { position:relative; min-height: 420px; }
.hero-card { background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg); box-shadow: var(--sh-lg); }
.hero-card--quote { padding: var(--s-6); border-left: 4px solid var(--c-primary); }
.hero-card-head { display:flex; justify-content: space-between; align-items:center; margin-bottom: var(--s-3); }
.hero-card-id { font-family: var(--font-mono); color: var(--c-fg-3); font-size: 13px; }
.hero-card-title { font-size: 18px; font-weight: 700; color: var(--c-fg-1); margin-bottom: var(--s-4); }
.hero-card-rows { display:grid; gap: 10px; padding: var(--s-4) 0; border-top: 1px dashed var(--c-border); border-bottom: 1px dashed var(--c-border); margin-bottom: var(--s-3); }
.hero-card-rows > div { display:flex; justify-content:space-between; font-size: 14px; }
.hero-card-rows span { color: var(--c-fg-3); }
.hero-card-rows strong { color: var(--c-fg-1); font-weight: 700; }
.hero-card-rows strong.money { color: var(--c-primary); font-size: 16px; }
.hero-card-foot { display:flex; align-items:center; gap:6px; font-size: 12px; color: var(--c-fg-3); }

.hero-card--stat { position: absolute; right: -12px; bottom: -12px; padding: var(--s-5) var(--s-6); display:flex; align-items:center; gap: var(--s-4); background: var(--c-primary); color:#fff; border: 0; }
.hero-card--stat .hero-card-icon { width: 40px; height: 40px; stroke-width: 2; }
.hero-card-stat-label { font-size: 12px; opacity: 0.85; margin-bottom: 2px; }
.hero-card-stat-value { font-size: 32px; font-weight: 900; line-height: 1; letter-spacing: -0.02em; }

/* ──────── Section shell ──────── */
section { padding: var(--s-16) 0; }
.section-head { text-align: center; margin-bottom: var(--s-10); }
.section-head--row { display:flex; justify-content: space-between; align-items: end; text-align: left; margin-bottom: var(--s-8); }
.section-title { font-size: 32px; margin-bottom: var(--s-2); }
.section-sub { color: var(--c-fg-3); font-size: 16px; margin: 0; }
.section-link { color: var(--c-primary); font-weight: 600; font-size: 14px; display:inline-flex; align-items:center; gap: 6px; }

/* ──────── Benefits ──────── */
.benefits { background: var(--c-bg); }
.benefits-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); }
.benefit-card { background:#fff; padding: var(--s-8) var(--s-6); border:1px solid var(--c-border); border-radius: var(--r-lg); border-left: 4px solid var(--c-primary); transition: background-color 150ms ease, border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease; }
.benefit-card:hover { background: var(--c-primary); color:#fff; border-color: var(--c-primary); border-left-color:#ffd166; box-shadow: var(--sh-md); }
.benefit-card:hover h3, .benefit-card:hover p, .benefit-card:hover .benefit-meta { color:#fff; }
.benefit-icon { font-size: 32px; margin-bottom: var(--s-4); }
.benefit-card h3 { font-size: 18px; margin-bottom: var(--s-2); }
.benefit-card p { font-size: 14px; color: var(--c-fg-3); margin-bottom: var(--s-4); min-height: 4.2em; }
.benefit-meta { font-size: 13px; font-weight: 600; color: var(--c-primary); display:inline-flex; align-items:center; gap:4px; }

/* ──────── Category grid ──────── */
.category-grid { display:grid; grid-template-columns: repeat(6, 1fr); gap: var(--s-4); }
.category-tile {
  background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg);
  padding: var(--s-6) var(--s-4); text-align:center;
  display:flex; flex-direction: column; align-items:center; gap: var(--s-2);
  color: var(--c-fg-1); transition: border-color 150ms, transform 150ms, box-shadow 150ms;
}
.category-tile:hover { border-color: var(--c-primary); color: var(--c-primary); text-decoration: none; box-shadow: var(--sh-md); }
.category-emoji { font-size: 36px; }
.category-tile h3 { font-size: 15px; margin: 0; }
.category-cta, .category-meta { font-size: 12px; color: var(--c-fg-3); display:inline-flex; align-items:center; gap: 4px; }

/* ──────── Product grid (placeholder) ──────── */
.product-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-5); }
.product-card { background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; transition: box-shadow 150ms; }
.product-card:hover { box-shadow: var(--sh-md); }
.product-card-image { position:relative; aspect-ratio: 1/1; background: var(--c-surface-alt); display:flex; align-items:center; justify-content:center; }
.product-card-image .image-placeholder { font-size: 48px; opacity: 0.35; }
.product-card-badge { position:absolute; top:12px; left:12px; background:#fff; color: var(--c-primary); font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: var(--r-pill); border:1px solid var(--c-primary-tint); }
.product-card-body { padding: var(--s-4); }
.product-card-title { font-size: 15px; font-weight: 600; margin-bottom: var(--s-2); color: var(--c-fg-1); }
.product-card-price { font-size: 18px; font-weight: 700; color: var(--c-primary); margin-bottom: var(--s-3); }

/* WooCommerce shortcode output — [products] */
.woocommerce ul.products { display:grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: var(--s-5); margin:0; padding:0; }
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after,
body .woocommerce ul.products::before,
body .woocommerce ul.products::after { content: none !important; display: none !important; width: 0 !important; height: 0 !important; overflow: hidden !important; }
.woocommerce ul.products li.product,
body .woocommerce ul.products li.product,
body .woocommerce-page ul.products li.product { width: 100% !important; max-width: 100% !important; min-width: 0 !important; margin: 0 !important; float:none !important; clear: none !important; background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg); padding: var(--s-4); }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 15px; color: var(--c-fg-1); padding: var(--s-3) 0 var(--s-2); }
.woocommerce ul.products li.product .price { color: var(--c-primary); font-weight:700; font-size: 17px; }
.woocommerce ul.products li.product .button { background: var(--c-primary) !important; color:#fff !important; border-radius: var(--r-sm) !important; padding: 8px 14px !important; font-size: 13px !important; font-weight: 600 !important; }
.woocommerce ul.products li.product .button:hover { background: var(--c-primary-hover) !important; }

/* ──────── Process steps ──────── */
.process { background: var(--c-bg); }
.process-steps { display:grid; grid-template-columns: repeat(5, 1fr); gap: var(--s-4); counter-reset: step; list-style: none; padding: 0; margin: 0; }
.process-steps li { background:#fff; padding: var(--s-6); border-radius: var(--r-lg); border:1px solid var(--c-border); position: relative; list-style: none; }
.process-steps li + li::before { content: ''; position: absolute; left: -10px; top: 50%; width: 12px; height: 2px; background: var(--c-border-strong); }
.process-num { display:inline-block; font-family: var(--font-mono); font-size: 13px; color: var(--c-primary); font-weight: 700; margin-bottom: var(--s-3); padding: 2px 8px; border-radius: var(--r-sm); background: var(--c-primary-tint); }
.process-steps h4 { font-size: 16px; margin-bottom: var(--s-2); }
.process-steps p { font-size: 13px; color: var(--c-fg-3); margin: 0; }

/* ──────── Clients ──────── */
.clients-stats { display:grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); padding-bottom: var(--s-10); margin-bottom: var(--s-10); border-bottom:1px solid var(--c-border); text-align:center; }
.clients-stats strong { display:block; font-size: 44px; font-weight: 900; color: var(--c-primary); letter-spacing: -0.02em; line-height:1; }
.clients-stats span { display:block; font-size: 14px; color: var(--c-fg-3); margin-top: var(--s-2); }
.clients-label { display:block; text-align:center; color: var(--c-fg-3); font-size: 13px; margin-bottom: var(--s-5); }
.clients-marquee { display:grid; grid-template-columns: repeat(8, 1fr); gap: var(--s-3); }
.client-logo { padding: var(--s-4); border: 1px solid var(--c-border); border-radius: var(--r-sm); text-align:center; font-family: var(--font-mono); color: var(--c-fg-3); font-size: 13px; letter-spacing: 0.02em; }

/* ──────── Footer ──────── */
.site-footer { background: #1d2327; color: #9aa0a6; margin-top: var(--s-20); }
.footer-cta { background: var(--c-primary); color:#fff; padding: var(--s-10) 0; }
.footer-cta-inner { display:flex; justify-content:space-between; align-items:center; gap: var(--s-6); flex-wrap: wrap; }
.footer-cta h3 { color:#fff; font-size: 24px; margin-bottom: var(--s-2); }
.footer-cta p  { color: rgba(255,255,255,0.85); margin: 0; }
.footer-cta-actions { display:flex; gap: var(--s-3); flex-wrap: wrap; }
.footer-cta .btn--primary { background:#fff; color: var(--c-primary); }
.footer-cta .btn--primary:hover { background: var(--c-primary-tint); color: var(--c-primary); }
.footer-cta .btn--ghost { background: transparent; color:#fff; border-color: rgba(255,255,255,0.4); }
.footer-cta .btn--ghost:hover { background: rgba(255,255,255,0.1); color:#fff; }

.footer-main { padding: var(--s-12) 0 var(--s-10); }
.footer-grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--s-8); }
.footer-col-title { color:#fff; font-size: 14px; margin-bottom: var(--s-4); font-weight: 700; letter-spacing: 0.02em; }
.footer-logo img { filter: brightness(0) invert(1); max-height: 40px; margin-bottom: var(--s-3); }
.footer-tagline { color:#cbd1d6; margin-bottom: var(--s-4); }
.footer-corp { font-size: 12.5px; line-height: 1.7; color:#9aa0a6; margin: 0; }
.footer-corp div { display:flex; gap:6px; }
.footer-corp dt { min-width: 108px; color: #c3c4c7; margin:0; font-weight: 500; }
.footer-corp dd { margin: 0; }
.footer-phone { font-size: 22px; font-weight: 700; color:#fff; margin-bottom: var(--s-2); display:flex; align-items:center; gap:8px; }
.footer-hours { font-size: 12.5px; margin-bottom: var(--s-3); color:#9aa0a6; }
.footer-email { font-size: 13px; margin-bottom: var(--s-4); display:flex; align-items:center; gap:8px; color:#cbd1d6; }
.footer-links li { margin-bottom: 8px; }
.footer-links a { color: #9aa0a6; font-size: 13px; }
.footer-links a:hover { color: #fff; text-decoration: none; }

.footer-bottom { border-top: 1px solid #2c3338; padding: var(--s-5) 0; }
.footer-bottom-inner { display:flex; justify-content:space-between; gap: var(--s-4); flex-wrap: wrap; font-size: 12px; color: #6d7175; }
.footer-disclaimer { color: #9aa0a6; }

/* ──────── Shop (archive-product) ──────── */
.shop-breadcrumb { padding: var(--s-4) 0 0; background: var(--c-surface); }
.breadcrumb { font-size: 13px; color: var(--c-fg-3); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.breadcrumb a { color: var(--c-fg-3); }
.breadcrumb a:hover { color: var(--c-primary); text-decoration:none; }
.breadcrumb [data-lucide] { width:14px; height:14px; color: var(--c-fg-4); }

.shop-header { padding: var(--s-6) 0 var(--s-5); background: var(--c-surface); border-bottom:1px solid var(--c-border); }
.shop-header-inner { display:flex; justify-content:space-between; align-items:flex-end; gap: var(--s-6); flex-wrap:wrap; }
.shop-title { font-size: 32px; margin:0 0 var(--s-2); }
.shop-desc { color: var(--c-fg-3); font-size: 14px; }
.shop-notice { display:inline-flex; align-items:center; gap:8px; padding: 8px 14px; border-radius: var(--r-sm); font-size: 13px; }
.shop-notice--warning { background: var(--c-warning-bg); color: var(--c-warning-text); }
.shop-notice--tier { background: var(--c-primary-tint); color: var(--c-primary); font-weight:600; }

.shop-layout { display:grid; grid-template-columns: 260px 1fr; gap: var(--s-8); padding-top: var(--s-8); padding-bottom: var(--s-16); }
.shop-sidebar { position: sticky; top: var(--s-4); align-self: start; }

.filter { background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg); padding: var(--s-5); margin-bottom: var(--s-4); }
.filter-title { display:flex; align-items:center; gap:6px; font-size: 15px; margin: 0 0 var(--s-4); padding-bottom: var(--s-3); border-bottom: 2px solid var(--c-primary); color: var(--c-fg-1); }
.filter-block { margin-bottom: var(--s-5); }
.filter-block:last-child { margin-bottom: 0; }
.filter-block-title { font-size: 13px; margin-bottom: var(--s-3); color: var(--c-fg-1); font-weight: 700; letter-spacing: 0.02em; }
.filter-list { display: flex; flex-direction: column; gap: 4px; }
.filter-list a { display:flex; justify-content:space-between; padding: 6px 8px; border-radius: var(--r-sm); font-size: 13px; color: var(--c-fg-2); }
.filter-list a:hover { background: var(--c-surface-alt); text-decoration:none; color: var(--c-primary); }
.filter-list a.is-active { background: var(--c-primary-tint); color: var(--c-primary); font-weight: 600; }
.filter-count { color: var(--c-fg-4); font-size: 12px; font-variant-numeric: tabular-nums; }
.filter-list--checks label { display:flex; align-items:center; gap:8px; padding: 5px 0; font-size: 13px; color: var(--c-fg-2); cursor:pointer; }
.filter-list--checks input { accent-color: var(--c-primary); }
.filter-actions { display:flex; gap:8px; padding-top: var(--s-4); border-top: 1px dashed var(--c-border); margin-top: var(--s-4); }

.filter-help { background: var(--c-primary-softer); border:1px solid var(--c-primary-tint); border-radius: var(--r-lg); padding: var(--s-5); display:flex; gap: var(--s-3); align-items:flex-start; }
.filter-help-icon { font-size: 28px; flex-shrink:0; }
.filter-help strong { display:block; color: var(--c-fg-1); margin-bottom: 2px; font-size: 14px; }
.filter-help p { font-size: 12.5px; color: var(--c-fg-3); margin: 0 0 var(--s-3); line-height: 1.5; }

.shop-toolbar { display:flex; justify-content:space-between; align-items:center; gap: var(--s-4); padding: var(--s-4); background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg); margin-bottom: var(--s-5); flex-wrap:wrap; }
.shop-toolbar .woocommerce-result-count { margin:0; font-size: 13px; color: var(--c-fg-3); }
.shop-toolbar-right { display:flex; align-items:center; gap: var(--s-3); }
.shop-toolbar-right select, .shop-sort select { padding: 7px 10px; border:1px solid var(--c-border-strong); border-radius: var(--r-sm); font-size: 13px; background:#fff; }
.shop-view { display:flex; border:1px solid var(--c-border-strong); border-radius: var(--r-sm); overflow:hidden; }
.shop-view button { background:#fff; border:0; padding: 7px 10px; color: var(--c-fg-3); border-right: 1px solid var(--c-border-strong); }
.shop-view button:last-child { border-right: 0; }
.shop-view button.is-active { background: var(--c-primary); color:#fff; }

ul.bsmt-product-grid,
ul.products.bsmt-product-grid,
.woocommerce ul.products.bsmt-product-grid,
.woocommerce-page ul.products.bsmt-product-grid,
body .woocommerce ul.products.bsmt-product-grid,
body .woocommerce-page ul.products.bsmt-product-grid,
.bsmt-product-grid > ul.products,
.woocommerce.bsmt-product-grid > ul.products,
body .woocommerce.bsmt-product-grid > ul.products { display:grid !important; grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: var(--s-5); margin: 0 !important; padding: 0 !important; list-style: none; width: 100% !important; }
/* Reset wrapper div that WooCommerce shortcode wraps around ul.products (do NOT make it a grid) */
.woocommerce.bsmt-product-grid { display: block !important; }
.bsmt-product-card { background:#fff; border:1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; transition: box-shadow 150ms, border-color 150ms; display:flex; flex-direction: column; width:auto !important; margin:0 !important; float:none !important; padding:0 !important; }
.bsmt-product-card:hover { box-shadow: var(--sh-md); border-color: var(--c-primary-tint); }
.bsmt-product-card .product-card-link { display:block; }
.bsmt-product-card .product-card-image { position:relative; aspect-ratio: 1/1; background: var(--c-surface-alt); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.bsmt-product-card .product-card-image .image-placeholder { font-size: 48px; opacity: 0.35; }
.bsmt-product-card .product-card-img, .bsmt-product-card .product-card-image img { width:100%; height:100%; object-fit: cover; }
.bsmt-product-card .product-card-badge { position:absolute; top:12px; left:12px; background:#fff; color: var(--c-primary); font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: var(--r-pill); border:1px solid var(--c-primary-tint); }
.product-card-flag { position:absolute; top:12px; right:12px; padding: 3px 10px; border-radius: var(--r-pill); font-size: 11px; font-weight: 700; }
.product-card-flag--sale { background: var(--c-danger); color:#fff; }
.product-card-flag--poa  { background: var(--c-primary); color:#fff; }
.product-card-flag--oos  { background: var(--c-fg-3); color:#fff; }
.bsmt-product-card .product-card-body { padding: var(--s-4); display:flex; flex-direction:column; gap: var(--s-2); flex:1; }
.product-card-sku { font-family: var(--font-mono); font-size: 11px; color: var(--c-fg-4); letter-spacing: 0.02em; }
.bsmt-product-card .product-card-title { font-size: 15px; font-weight: 600; margin: 0; }
.bsmt-product-card .product-card-title a { color: var(--c-fg-1); }
.bsmt-product-card .product-card-title a:hover { color: var(--c-primary); text-decoration: none; }
.product-card-meta { display:flex; gap: var(--s-3); font-size: 12px; color: var(--c-fg-3); }
.product-card-meta [data-lucide] { width:13px; height:13px; }
.product-card-stock--in { color: var(--c-success-text); }
.product-card-stock--back { color: var(--c-warning-text); }
.product-card-price-block { margin-top: auto; padding-top: var(--s-2); }
.product-card-price-row { display:flex; align-items:baseline; gap: var(--s-2); flex-wrap:wrap; }
.bsmt-product-card .product-card-price { font-size: 20px; font-weight: 800; color: var(--c-primary); letter-spacing: -0.01em; }
.product-card-price--poa { font-size: 18px; }
.product-card-price-strike { text-decoration: line-through; color: var(--c-fg-4); font-size: 13px; }
.product-card-price-disc { background: var(--c-danger-bg); color: var(--c-danger-text); font-size: 11px; font-weight: 700; padding: 2px 6px; border-radius: var(--r-sm); }
.product-card-price-note { font-size: 11px; color: var(--c-fg-4); margin-top: 2px; }
.product-card-actions { display:grid; grid-template-columns: 1fr 1fr; gap: 6px; padding-top: var(--s-3); }
.btn--block { grid-column: 1 / -1; }

/* List view toggle */
.bsmt-product-grid.is-list { grid-template-columns: 1fr !important; }
.bsmt-product-grid.is-list .bsmt-product-card { flex-direction: row; }
.bsmt-product-grid.is-list .product-card-link { width: 220px; flex-shrink: 0; }
.bsmt-product-grid.is-list .product-card-image { aspect-ratio: auto; height: 100%; }
.bsmt-product-grid.is-list .product-card-body { flex: 1; }
.bsmt-product-grid.is-list .product-card-actions { grid-template-columns: auto auto 1fr; justify-content: start; }

/* WooCommerce pagination */
.woocommerce-pagination { margin-top: var(--s-8); }
.woocommerce-pagination ul.page-numbers { display:flex; gap: 4px; justify-content: center; border: 0 !important; }
.woocommerce-pagination ul.page-numbers li { border: 0 !important; margin: 0; }
.woocommerce-pagination .page-numbers { display:inline-flex; align-items:center; justify-content:center; min-width: 36px; height: 36px; padding: 0 10px; border-radius: var(--r-sm); background:#fff; border:1px solid var(--c-border); color: var(--c-fg-2); font-size: 13px; font-weight: 500; }
.woocommerce-pagination .page-numbers.current { background: var(--c-primary); color:#fff; border-color: var(--c-primary); }
.woocommerce-pagination .page-numbers:hover:not(.current) { border-color: var(--c-primary); color: var(--c-primary); text-decoration:none; }

/* ──────── Responsive ──────── */
@media (max-width: 960px) {
  .header-inner { grid-template-columns: 1fr auto; }
  .header-search-wrap { grid-column: 1 / -1; order: 3; }
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { min-height: 0; margin-top: var(--s-6); }
  .hero-card--stat { position: static; margin-top: var(--s-4); }
  .benefits-grid, .category-grid, .process-steps, .product-grid, .clients-stats, .clients-marquee, .woocommerce ul.products:not(.bsmt-product-grid) { grid-template-columns: repeat(2, 1fr) !important; }
  .bsmt-product-grid, ul.bsmt-product-grid, ul.products.bsmt-product-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .shop-layout { grid-template-columns: 1fr !important; }
  .shop-sidebar { position: static !important; }
  .process-steps li + li::before { display:none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .hero-title { font-size: 36px; }
  .section-head--row { flex-direction: column; align-items: flex-start; gap: var(--s-3); }
}
@media (max-width: 560px) {
  .benefits-grid, .category-grid, .product-grid, .footer-grid, .woocommerce ul.products:not(.bsmt-product-grid) { grid-template-columns: 1fr !important; }
  .bsmt-product-grid, ul.bsmt-product-grid, ul.products.bsmt-product-grid { grid-template-columns: 1fr !important; }
  .hero-trust, .clients-stats { grid-template-columns: repeat(2, 1fr); }
  .clients-marquee { grid-template-columns: repeat(2, 1fr); }
  .topbar-left .topbar-item--muted { display: none; }
}

/* ──────────────────────────────────────────────────────────────
 * Cart Drawer (mini-cart) — 우측 슬라이드 사이드바
 * 트리거: [data-bsmt-drawer="cart"] (header cart / quote 링크)
 * body.bsmt-drawer-open 일 때 .bsmt-drawer--cart 가 in
 * ────────────────────────────────────────────────────────────── */

.bsmt-drawer-backdrop {
  position: fixed; inset: 0;
  background: rgba(29, 35, 39, 0.45);
  z-index: 1000;
  opacity: 0; transition: opacity 200ms ease;
  cursor: pointer;
}
.bsmt-drawer-backdrop.is-visible { opacity: 1; }

.bsmt-drawer {
  position: fixed; top: 0; right: 0;
  width: 100%; max-width: 440px; height: 100dvh;
  background: #fff;
  border-left: 1px solid var(--c-border);
  box-shadow: -4px 0 24px rgba(0,0,0,0.10);
  z-index: 1001;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform 260ms cubic-bezier(.22,.61,.36,1);
  -webkit-overflow-scrolling: touch;
}
.bsmt-drawer.is-open { transform: translateX(0); }

/* Drawer head */
.bsmt-drawer-head {
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--c-border);
  background: #fff;
}
.bsmt-drawer-title {
  display: inline-flex; align-items: center; gap: 10px;
  margin: 0;
  font-size: 18px; font-weight: 700;
  color: var(--c-fg-1);
}
.bsmt-drawer-title [data-lucide] { width: 20px; height: 20px; color: var(--c-primary); }
.bsmt-drawer-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 22px; padding: 0 7px;
  background: var(--c-primary); color: #fff;
  border-radius: var(--r-round);
  font-size: 12px; font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.bsmt-drawer-close {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 0;
  border-radius: var(--r-sm);
  color: var(--c-fg-3); cursor: pointer;
  transition: background 150ms ease, color 150ms ease;
}
.bsmt-drawer-close:hover { background: var(--c-surface-alt); color: var(--c-fg-1); }
.bsmt-drawer-close [data-lucide] { width: 20px; height: 20px; }

/* Drawer body — scrollable area */
.bsmt-drawer-body {
  flex: 1; min-height: 0;
  display: flex; flex-direction: column;
  overflow: hidden;
}

/* Items list — scrolls when long */
.bsmt-drawer-items {
  flex: 1; min-height: 0;
  overflow-y: auto; overflow-x: hidden;
  padding: 4px 0;
  list-style: none; margin: 0;
  scrollbar-width: thin; scrollbar-color: var(--c-border-strong) transparent;
}
.bsmt-drawer-items::-webkit-scrollbar { width: 8px; }
.bsmt-drawer-items::-webkit-scrollbar-thumb { background: var(--c-border-strong); border-radius: 8px; }

/* Single item row */
.bsmt-drawer-item {
  display: grid;
  grid-template-columns: 72px 1fr 24px;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--c-divider);
  align-items: start;
}
.bsmt-drawer-item:last-child { border-bottom: 0; }

.bsmt-drawer-item-thumb-link { display: block; width: 72px; height: 72px; }
.bsmt-drawer-item-thumb,
.bsmt-drawer-item-thumb--ph {
  width: 72px !important; height: 72px !important;
  object-fit: cover;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  background: var(--c-surface-alt);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
}

.bsmt-drawer-item-body {
  min-width: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.bsmt-drawer-item-title {
  font-size: 14px; font-weight: 600; line-height: 1.4;
  color: var(--c-fg-1);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.bsmt-drawer-item-title:hover { color: var(--c-primary); text-decoration: none; }
.bsmt-drawer-item-meta {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--c-fg-4);
  flex-wrap: wrap;
}
.bsmt-drawer-item-sku {
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}
.bsmt-drawer-item-meta .tier-badge { margin: 0; font-size: 10px; padding: 1px 6px; }

.bsmt-drawer-item-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-3); margin-top: 4px;
}

/* Qty stepper */
.bsmt-drawer-qty {
  display: inline-flex; align-items: stretch;
  border: 1px solid var(--c-border-strong);
  border-radius: var(--r-sm);
  overflow: hidden;
  background: #fff;
}
.bsmt-drawer-qty-btn {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #fff; border: 0; padding: 0;
  color: var(--c-fg-2); font-size: 16px; line-height: 1; font-weight: 600;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.bsmt-drawer-qty-btn:hover { background: var(--c-surface-alt); color: var(--c-primary); }
.bsmt-drawer-qty-btn:disabled { color: var(--c-fg-4); cursor: not-allowed; background: var(--c-surface-alt); }
.bsmt-drawer-qty-input {
  width: 40px; border: 0;
  border-left: 1px solid var(--c-border);
  border-right: 1px solid var(--c-border);
  text-align: center;
  font-size: 13px; font-weight: 600;
  color: var(--c-fg-1);
  font-variant-numeric: tabular-nums;
  background: #fff;
  -moz-appearance: textfield;
}
.bsmt-drawer-qty-input::-webkit-outer-spin-button,
.bsmt-drawer-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.bsmt-drawer-qty-input:focus { outline: none; background: var(--c-primary-softer); }

.bsmt-drawer-item-price {
  font-size: 15px; font-weight: 700;
  color: var(--c-fg-1);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.bsmt-drawer-item-price .woocommerce-Price-amount { color: var(--c-fg-1); }

.bsmt-drawer-item-remove {
  width: 24px; height: 24px; margin-top: 4px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-fg-4);
  border-radius: var(--r-sm);
  transition: background 120ms ease, color 120ms ease;
}
.bsmt-drawer-item-remove:hover { background: var(--c-danger-bg); color: var(--c-danger); text-decoration: none; }
.bsmt-drawer-item-remove [data-lucide] { width: 16px; height: 16px; }
button.bsmt-drawer-item-remove { background: transparent; border: 0; padding: 0; cursor: pointer; }

/* Quote drawer — 가격문의 라벨 */
.bsmt-drawer-item-poa {
  display: inline-block;
  padding: 2px 8px;
  background: var(--c-primary-softer);
  color: var(--c-primary);
  border-radius: var(--r-sm);
  font-size: 12px; font-weight: 700;
}

/* Quote drawer — 헤더 아이콘 살짝 다른 톤(시각적 구분) */
.bsmt-drawer--quote .bsmt-drawer-title [data-lucide] { color: var(--c-success); }
.bsmt-drawer--quote .bsmt-drawer-count { background: var(--c-success); }

/* Row being updated (AJAX in-flight) */
.bsmt-drawer-item.is-updating { opacity: 0.55; pointer-events: none; }

/* ── Notices (승인대기, MOQ 경고) ── */
.bsmt-drawer-notice {
  margin: var(--s-4) var(--s-5);
  padding: var(--s-4);
  border-radius: var(--r-md);
  border-left: 4px solid var(--c-warning);
  background: var(--c-warning-bg);
  color: var(--c-warning-text);
  font-size: 13px; line-height: 1.55;
}
.bsmt-drawer-notice strong { display: block; margin-bottom: 4px; font-size: 14px; color: var(--c-warning-text); }
.bsmt-drawer-notice p { margin: 0 0 var(--s-3); color: var(--c-warning-text); }
.bsmt-drawer-notice ul { margin: 4px 0 0; padding-left: 18px; list-style: disc; }
.bsmt-drawer-notice ul li { margin-bottom: 2px; }
.bsmt-drawer-notice--warning { border-color: var(--c-warning); background: var(--c-warning-bg); }
.bsmt-drawer-notice--warning .btn--primary { background: var(--c-primary); color: #fff; margin-top: var(--s-2); }

/* ── Empty state ── */
.bsmt-drawer-empty {
  flex: 1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  padding: var(--s-8) var(--s-5);
  gap: var(--s-3);
}
.bsmt-drawer-empty-icon {
  font-size: 48px;
  width: 96px; height: 96px;
  display: flex; align-items: center; justify-content: center;
  background: var(--c-primary-softer);
  border-radius: 50%;
  margin-bottom: var(--s-2);
}
.bsmt-drawer-empty h3 { margin: 0; font-size: 18px; color: var(--c-fg-1); }
.bsmt-drawer-empty p { margin: 0; font-size: 14px; color: var(--c-fg-3); max-width: 280px; }
.bsmt-drawer-empty-actions {
  width: 100%; max-width: 320px;
  display: flex; flex-direction: column; gap: var(--s-2);
  margin-top: var(--s-4);
}

/* ── Footer (CTA + subtotal) ── */
.bsmt-drawer-foot {
  flex-shrink: 0;
  padding: var(--s-4) var(--s-5) var(--s-5);
  border-top: 1px solid var(--c-border);
  background: #fff;
}
.bsmt-drawer-subtotal {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: var(--s-4);
  border-bottom: 1px dashed var(--c-border);
  margin-bottom: var(--s-4);
}
.bsmt-drawer-subtotal-label {
  font-size: 13px; color: var(--c-fg-3); font-weight: 500;
}
.bsmt-drawer-subtotal-label small { color: var(--c-fg-4); margin-left: 2px; font-weight: 400; }
.bsmt-drawer-subtotal-value {
  font-size: 22px; font-weight: 800;
  color: var(--c-primary);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.bsmt-drawer-subtotal-value .woocommerce-Price-amount { color: var(--c-primary); }
.bsmt-drawer-subtotal-value small {
  display: inline-block;
  margin-left: 6px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em;
  color: var(--c-fg-4); vertical-align: middle;
}

.bsmt-drawer-actions {
  display: flex; flex-direction: column; gap: var(--s-2);
}
.bsmt-drawer-actions .btn { width: 100%; }

.bsmt-drawer-hint {
  display: flex; align-items: flex-start; gap: 6px;
  margin: var(--s-3) 0 0;
  padding: 0;
  font-size: 12px; color: var(--c-fg-3); line-height: 1.55;
}
.bsmt-drawer-hint [data-lucide] { width: 13px; height: 13px; flex-shrink: 0; margin-top: 3px; color: var(--c-fg-4); }

/* ── Scroll lock ── */
body.bsmt-drawer-open { overflow: hidden; }

/* ── Flying toast when add-to-cart fires from outside drawer ── */
.bsmt-cart-toast {
  position: fixed; top: 24px; right: 24px;
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  background: var(--c-fg-1); color: #fff;
  border-radius: var(--r-md);
  box-shadow: var(--sh-lg);
  font-size: 13px; font-weight: 600;
  z-index: 1100;
  transform: translateX(120%); opacity: 0;
  transition: transform 260ms ease, opacity 200ms ease;
}
.bsmt-cart-toast.is-visible { transform: translateX(0); opacity: 1; }
.bsmt-cart-toast [data-lucide] { width: 16px; height: 16px; color: #7fcf9f; }
.bsmt-cart-toast--err [data-lucide] { color: #ff7f7f; }

/* ── Narrow screens ── */
@media (max-width: 520px) {
  .bsmt-drawer { max-width: 100%; }
  .bsmt-drawer-head { padding: var(--s-3) var(--s-4); }
  .bsmt-drawer-item { padding: var(--s-3) var(--s-4); grid-template-columns: 60px 1fr 20px; gap: var(--s-2); }
  .bsmt-drawer-item-thumb-link, .bsmt-drawer-item-thumb, .bsmt-drawer-item-thumb--ph { width: 60px !important; height: 60px !important; }
  .bsmt-drawer-foot { padding: var(--s-4); }
}

/* ──────────────────────────────────────────────────────────────
 * Korea for WooCommerce 플러그인 호환
 * 한국식 체크아웃·주문·고객지원 UI에 테마 브랜드 적용
 * ────────────────────────────────────────────────────────────── */

/* ── 우편번호 필드 (Daum Postcode) ── */
/* 플러그인은 #billing_postcode 클릭 시 우편번호 팝업/임베드 오픈 */
.woocommerce-checkout #billing_postcode,
.woocommerce-checkout #shipping_postcode,
.woocommerce-edit-address #billing_postcode,
.woocommerce-edit-address #shipping_postcode {
  cursor: pointer !important;
  background: var(--c-surface-alt) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23004282' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>") no-repeat right 12px center;
  background-size: 16px 16px;
  padding-right: 38px !important;
  font-weight: 600;
  color: var(--c-primary);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
}
.woocommerce-checkout #billing_postcode::placeholder,
.woocommerce-checkout #shipping_postcode::placeholder { color: var(--c-fg-3); font-weight: 400; }
.woocommerce-checkout #billing_postcode:hover,
.woocommerce-checkout #shipping_postcode:hover { background-color: var(--c-primary-softer); border-color: var(--c-primary-tint); }

/* 우편번호 오버레이 (display: overlay) — 전체 화면 덮는 모달 */
#billing-address-autocomplete.overlay,
#shipping-address-autocomplete.overlay {
  background: rgba(0,0,0,0.5);
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: var(--s-6);
}
/* 실제 iframe 컨테이너 내부는 플러그인이 다루지만 외곽 여백/중앙정렬은 테마가 잡아줌 */
#billing-address-autocomplete.overlay > *:not(.address-autocomplete-close),
#shipping-address-autocomplete.overlay > *:not(.address-autocomplete-close) {
  max-width: 560px;
  max-height: 640px;
  margin: auto;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh-lg);
}
.address-autocomplete-close {
  position: fixed !important;
  top: var(--s-5) !important;
  right: var(--s-5) !important;
  width: 36px;
  height: 36px;
  padding: 6px;
  background: #fff !important;
  border-radius: 50%;
  box-shadow: var(--sh-md);
}

/* 우편번호 임베드 (display: embed) */
#billing-address-autocomplete.embed,
#shipping-address-autocomplete.embed {
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-md);
  margin-top: var(--s-3);
  height: 420px !important;
}

/* ── 한국식 체크아웃 필드 간격 ── */
/* 순서는 서버사이드 priority로 처리(functions.php). 테마는 간격·폭만 담당. */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-address-fields__field-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.woocommerce-checkout #billing_postcode_field,
.woocommerce-checkout #shipping_postcode_field { max-width: 240px; }

/* ── 가상계좌(무통장입금) 주문상세 ── */
.woocommerce-vbank-details { margin: var(--s-6) 0; }
.woocommerce-vbank-details__title {
  font-size: 20px;
  font-weight: 700;
  color: var(--c-fg-1);
  margin: 0 0 var(--s-4);
  padding-left: var(--s-3);
  border-left: 4px solid var(--c-primary);
  line-height: 1.3;
}
.woocommerce-vbank-details__title::before { content: "💳 "; }
.woocommerce-table--vbank-details {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.woocommerce-table--vbank-details thead th {
  background: var(--c-primary-softer) !important;
  color: var(--c-primary) !important;
  font-size: 12px;
  font-weight: 700;
  padding: var(--s-3) var(--s-4) !important;
  letter-spacing: 0.02em;
  border-bottom: 1px solid var(--c-primary-tint);
}
.woocommerce-table--vbank-details tbody td {
  padding: var(--s-4) !important;
  font-size: 15px;
  font-weight: 600;
  color: var(--c-fg-1);
  font-variant-numeric: tabular-nums;
}

/* ── 네이버 톡톡 버튼 (#navertalktalk-button) ── */
/* 플러그인이 인라인 스타일 주입. 테마는 z-index·여백만 보강 */
#navertalktalk-button {
  z-index: 90 !important;
  border-radius: 50% !important;
  box-shadow: var(--sh-md);
  transition: box-shadow 150ms ease;
}
#navertalktalk-button:hover { box-shadow: var(--sh-lg); }

/* ── 카카오 채널 버튼 ── */
#kakao-channel-button,
#kakao-channel-badge,
.kakao-channel-badge {
  z-index: 90 !important;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.15));
}

/* 플로팅 버튼 두 개 동시 노출 시 겹침 방지 — 우측 하단 스택 */
body:has(#navertalktalk-button):has(#kakao-channel-button) #navertalktalk-button {
  bottom: 84px !important;
}

/* ── [products] 쇼트코드 / 기타 한국 플러그인 출력 공통 ── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-top: 0 !important;
  border-left: 4px solid var(--c-primary) !important;
  background: var(--c-primary-softer) !important;
  color: var(--c-fg-1) !important;
  padding: var(--s-4) var(--s-5) !important;
  border-radius: var(--r-sm);
  font-size: 14px;
  line-height: 1.6;
}
.woocommerce-error { border-left-color: var(--c-danger) !important; background: var(--c-danger-bg) !important; color: var(--c-danger-text) !important; }
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { color: var(--c-primary) !important; }
.woocommerce-error::before { color: var(--c-danger) !important; }

/* ──────────────────────────────────────────────────────────────
 * B2B Features 플러그인 호환 (자사 플러그인)
 * 플러그인이 인라인 스타일로 출력하는 요소를 BSM&T 브랜드 톤으로 오버라이드.
 * 플러그인 PHP는 수정하지 않고 CSS로만 덮어씁니다.
 * ────────────────────────────────────────────────────────────── */

/* ── 회원가입: 사업자 정보 박스 ── */
/* 플러그인: <div class="b2b-registration-fields" style="border:2px solid #0073aa;..."> */
.b2b-registration-fields {
  border: 1px solid var(--c-border) !important;
  border-top: 3px solid var(--c-primary) !important;
  border-radius: var(--r-lg) !important;
  background: #fff !important;
  padding: var(--s-6) !important;
  margin: var(--s-5) 0 !important;
  box-shadow: var(--sh-sm);
}
.b2b-registration-fields h3 {
  color: var(--c-fg-1) !important;
  font-size: 18px !important;
  margin: 0 0 var(--s-2) !important;
  padding-left: var(--s-3);
  border-left: 4px solid var(--c-primary);
  line-height: 1.3;
}
.b2b-registration-fields > p {
  color: var(--c-fg-3) !important;
  font-size: 13px !important;
  margin: 0 0 var(--s-4) !important;
}
.b2b-registration-fields .form-row { margin-bottom: var(--s-3); }
.b2b-registration-fields input {
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-size: 14px;
  width: 100%;
}
.b2b-registration-fields input:focus {
  outline: none;
  border-color: var(--c-primary);
  box-shadow: 0 0 0 2px var(--c-primary-tint);
}
.b2b-registration-fields .required { color: var(--c-danger); }

/* ── 가격 뱃지 (등급별 할인) ── */
/* 플러그인: <small class="b2b-discount-badge" style="color:#28a745;font-weight:bold;"> */
.b2b-discount-badge {
  color: var(--c-success) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  display: inline-block;
  margin-top: 4px;
  padding: 2px 8px;
  background: var(--c-success-bg, #e8f5ee);
  border-radius: var(--r-xs);
  letter-spacing: 0.02em;
}

/* ── 로그인 필요 / 가격문의 ── */
.b2b-login-to-see-price {
  color: var(--c-primary) !important;
  font-weight: 700 !important;
  text-decoration: none;
  font-size: 14px;
}
.b2b-login-to-see-price:hover { text-decoration: underline; }

.b2b-login-notice {
  background: var(--c-primary-softer) !important;
  border-left: 4px solid var(--c-primary) !important;
  border-radius: var(--r-sm) !important;
  padding: var(--s-4) var(--s-5) !important;
  margin: var(--s-4) 0 !important;
  color: var(--c-fg-1);
}
.b2b-login-notice p { margin: 0 0 8px; font-size: 14px; line-height: 1.6; }
.b2b-login-notice p:last-child { margin-bottom: 0; }
.b2b-login-notice a { color: var(--c-primary); font-weight: 600; }

/* "가격문의" 라벨/버튼 */
.b2b-price-inquiry-label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--c-primary) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: -0.01em;
}
.b2b-price-inquiry-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--c-primary) !important;
  color: #fff !important;
  border: 0 !important;
  padding: 8px 14px !important;
  border-radius: var(--r-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  transition: background 150ms ease;
}
.b2b-price-inquiry-btn:hover { background: var(--c-primary-hover) !important; }

/* ── 장바구니 "견적 요청" 버튼 + 폼 ── */
/* 플러그인: #b2b-request-quote (초록 버튼), #b2b-quote-form (회색 배경 박스) */
#b2b-request-quote {
  background: var(--c-primary-softer) !important;
  border: 1px solid var(--c-primary) !important;
  color: var(--c-primary) !important;
  font-weight: 700;
  padding: 14px !important;
  border-radius: var(--r-sm);
  width: 100%;
  cursor: pointer;
  margin-top: var(--s-3);
  transition: background 150ms ease;
}
#b2b-request-quote:hover { background: var(--c-primary-tint) !important; }

#b2b-quote-form {
  background: #fff !important;
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-md) !important;
  padding: var(--s-5) !important;
  margin-top: var(--s-3);
}
#b2b-quote-form h4 {
  margin: 0 0 var(--s-3) !important;
  font-size: 15px;
  color: var(--c-fg-1);
}
#b2b-quote-note {
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-size: 14px;
  resize: vertical;
}
#b2b-submit-quote {
  background: var(--c-primary) !important;
  color: #fff !important;
  border: 0 !important;
  padding: 10px 20px !important;
  border-radius: var(--r-sm);
  font-weight: 600;
}
#b2b-submit-quote:hover { background: var(--c-primary-hover) !important; }
#b2b-cancel-quote {
  background: transparent !important;
  color: var(--c-fg-3) !important;
  border: 1px solid var(--c-border) !important;
  padding: 10px 16px !important;
  border-radius: var(--r-sm);
}

/* ── 견적요청 숏코드 폼 (.b2b-qf-*) ── */
.b2b-qf { max-width: 960px; margin: 0 auto; }
.b2b-qf-info {
  background: var(--c-surface-alt) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-lg) !important;
  padding: var(--s-5) !important;
  gap: var(--s-4) !important;
}
.b2b-qf-info label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--c-fg-3) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.b2b-qf-info input {
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 12px !important;
  font-size: 14px !important;
  background: #fff;
  font-variant-numeric: tabular-nums;
}
.b2b-qf-info input[readonly] { background: var(--c-bg); color: var(--c-fg-2); }

.b2b-qf-search input {
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-md) !important;
  font-size: 15px !important;
  padding: 12px 15px 12px 40px !important;
}
.b2b-qf-search input:focus {
  outline: none;
  border-color: var(--c-primary) !important;
  box-shadow: 0 0 0 2px var(--c-primary-tint);
}
.b2b-qf-results {
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--sh-md) !important;
  max-height: 280px !important;
}
.b2b-qf-results .item { padding: 12px 16px !important; transition: background 120ms ease; }
.b2b-qf-results .item:hover { background: var(--c-primary-softer) !important; }
.b2b-qf-results .item .name { font-weight: 600; color: var(--c-fg-1); }
.b2b-qf-results .item .sku { font-size: 12px; color: var(--c-fg-3); font-variant-numeric: tabular-nums; }
.b2b-qf-results .item .price { color: var(--c-primary) !important; font-weight: 700 !important; font-variant-numeric: tabular-nums; }

.b2b-qf-table {
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.b2b-qf-table th {
  background: var(--c-primary-softer) !important;
  color: var(--c-primary) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em;
  padding: var(--s-3) var(--s-4) !important;
  border-bottom: 1px solid var(--c-primary-tint);
}
.b2b-qf-table td {
  padding: var(--s-3) var(--s-4) !important;
  font-size: 14px !important;
  font-variant-numeric: tabular-nums;
  color: var(--c-fg-1);
}
.b2b-qf-table tr:hover { background: var(--c-surface-alt) !important; }
.b2b-qf-table .qty-input {
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-xs) !important;
  padding: 6px 8px !important;
  font-size: 14px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.b2b-qf-table .remove-btn {
  color: var(--c-danger) !important;
  transition: background 120ms ease;
}
.b2b-qf-table .remove-btn:hover { background: var(--c-danger-bg) !important; border-radius: var(--r-xs); }

.b2b-qf-empty {
  color: var(--c-fg-3) !important;
  background: var(--c-bg);
  border-radius: var(--r-md);
}

.b2b-qf-total {
  border-top: 2px solid var(--c-primary) !important;
  padding: var(--s-4) 0 !important;
  font-size: 16px !important;
  color: var(--c-fg-1);
}
.b2b-qf-total .amount {
  color: var(--c-primary) !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums;
}

.b2b-qf-note { display: block; }
.b2b-qf-note label { display: block; font-size: 13px; font-weight: 700; color: var(--c-fg-1); margin-bottom: 6px; }
.b2b-qf-note textarea {
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  border: 1px solid var(--c-border) !important;
  border-radius: var(--r-md) !important;
  padding: 12px !important;
  font-size: 14px !important;
  font-family: inherit;
}
.b2b-qf-note textarea:focus {
  outline: none;
  border-color: var(--c-primary) !important;
  box-shadow: 0 0 0 2px var(--c-primary-tint);
}

.b2b-qf-submit { text-align: center !important; margin-top: var(--s-5) !important; }
.b2b-qf-submit button {
  background: var(--c-primary) !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  border-radius: var(--r-sm) !important;
  cursor: pointer;
  padding: 14px 50px !important;
  border-radius: var(--r-md) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  transition: background 150ms ease, transform 80ms ease;
}
.b2b-qf-submit button:hover { background: var(--c-primary-hover) !important; }
.b2b-qf-submit button:active { transform: translateY(1px); }
.b2b-qf-submit button:disabled { background: var(--c-fg-3) !important; opacity: 0.6; }

.b2b-qf-msg {
  border-radius: var(--r-md) !important;
  padding: var(--s-4) var(--s-5) !important;
  font-size: 14px !important;
  font-weight: 500;
}
.b2b-qf-msg.success { background: var(--c-success-bg) !important; color: var(--c-success-text, #155724) !important; border-left: 4px solid var(--c-success); }
.b2b-qf-msg.error   { background: var(--c-danger-bg) !important;  color: var(--c-danger-text) !important;  border-left: 4px solid var(--c-danger); }

/* "장바구니에서 가져오기" 버튼 */
#b2b-qf-import-cart {
  background: #fff !important;
  color: var(--c-primary) !important;
  border: 1px solid var(--c-primary) !important;
  border-radius: var(--r-md) !important;
  padding: 12px 20px !important;
  font-weight: 600 !important;
  transition: background 150ms ease;
}
#b2b-qf-import-cart:hover { background: var(--c-primary-softer) !important; }

/* ── 견적 상태 뱃지 (마이페이지·관리자) ── */
/* 플러그인이 인라인 스타일로 배경/글자색을 찍지만, class 있으면 덮을 수 있음.
   플러그인은 span에 클래스 없이 inline style만 주므로 status별 attr 선택자로 매칭 */
.woocommerce-MyAccount-content .woocommerce-orders-table [style*="background:#fff3cd"],
.woocommerce-MyAccount-content .woocommerce-orders-table [style*="background:#cce5ff"],
.woocommerce-MyAccount-content .woocommerce-orders-table [style*="background:#d4edda"],
.woocommerce-MyAccount-content .woocommerce-orders-table [style*="background:#f8d7da"],
.woocommerce-MyAccount-content .woocommerce-orders-table [style*="background:#e2e3e5"] {
  display: inline-block !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em;
}

/* ── 마이페이지 사업자 정보 대시보드 블록 ── */
/* 플러그인: <div style="background:#fff3cd..."> (승인 대기) / #d4edda (승인) */
.woocommerce-MyAccount-content > div[style*="background:#fff3cd"] {
  background: var(--c-warning-bg) !important;
  border-left: 4px solid var(--c-warning) !important;
  border-radius: var(--r-md) !important;
  padding: var(--s-5) !important;
}
.woocommerce-MyAccount-content > div[style*="background:#d4edda"] {
  background: var(--c-success-bg) !important;
  border-left: 4px solid var(--c-success) !important;
  border-radius: var(--r-md) !important;
  padding: var(--s-5) !important;
}
.woocommerce-MyAccount-content > div[style*="background:#fff3cd"] p,
.woocommerce-MyAccount-content > div[style*="background:#d4edda"] p {
  margin: 0 0 6px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--c-fg-1);
}


/* ──────────────────────────────────────────────────────────────
 * Product grid + cards (WooCommerce loop)
 * Overrides WC default [products] shortcode styles which use
 * float + 22.05% width.
 * ────────────────────────────────────────────────────────────── */

/* Grid — flatten WC defaults, use CSS grid (override WC columns-N width) */
.woocommerce ul.products.bsmt-product-grid,
.woocommerce-page ul.products.bsmt-product-grid,
ul.products.bsmt-product-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: var(--s-5) !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce ul.products.bsmt-product-grid::before,
.woocommerce ul.products.bsmt-product-grid::after,
ul.products.bsmt-product-grid::before,
ul.products.bsmt-product-grid::after { content: none !important; display: none !important; }
.woocommerce ul.products.bsmt-product-grid li.product,
.woocommerce-page ul.products.bsmt-product-grid li.product,
ul.products.bsmt-product-grid li.product,
ul.products.bsmt-product-grid li.product.first,
ul.products.bsmt-product-grid li.product.last {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
  padding: 0 !important;
}
@media (max-width: 1024px) {
  .woocommerce ul.products.bsmt-product-grid,
  ul.products.bsmt-product-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
}
@media (max-width: 768px) {
  .woocommerce ul.products.bsmt-product-grid,
  ul.products.bsmt-product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: var(--s-4) !important; }
}
@media (max-width: 420px) {
  .woocommerce ul.products.bsmt-product-grid,
  ul.products.bsmt-product-grid { grid-template-columns: 1fr !important; }
}

/* Card */
.bsmt-product-card {
  display: flex;
  flex-direction: column;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  position: relative;
}
.bsmt-product-card:hover {
  border-color: var(--c-primary-tint);
  box-shadow: var(--sh-md);
  transform: translateY(-1px);
}

.product-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.product-card-link:hover { text-decoration: none; color: inherit; }

/* Image */
.product-card-image {
  position: relative;
  aspect-ratio: 1 / 1;
  background: var(--c-surface-alt);
  overflow: hidden;
}
.product-card-image .product-card-img,
.product-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}
.bsmt-product-card:hover .product-card-image img { transform: scale(1.03); }
.product-card-image .image-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 48px;
  color: var(--c-fg-4);
}

/* Badges / flags on image */
.product-card-badge {
  position: absolute;
  top: var(--s-2);
  left: var(--s-2);
  background: rgba(0,0,0,.7);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: var(--r-sm);
  letter-spacing: .02em;
}
.product-card-flag {
  position: absolute;
  top: var(--s-2);
  right: var(--s-2);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: var(--r-sm);
  letter-spacing: .02em;
  color: #fff;
}
.product-card-flag--sale { background: var(--c-danger); }
.product-card-flag--oos  { background: var(--c-fg-3); }

/* Body */
.product-card-body {
  padding: var(--s-4);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  flex: 1;
}
.product-card-sku {
  font-size: 11px;
  color: var(--c-fg-4);
  font-family: var(--font-mono);
  letter-spacing: .02em;
}
.product-card-title {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--c-fg-1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(15px * 1.4 * 2);
}
.product-card-title a { color: inherit; text-decoration: none; }
.product-card-title a:hover { color: var(--c-primary); }

.product-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  font-size: 12px;
  color: var(--c-fg-3);
}
.product-card-meta > span { display: inline-flex; align-items: center; gap: 4px; }
.product-card-meta i { width: 14px; height: 14px; }
.product-card-stock--in   { color: var(--c-success-text); }
.product-card-stock--back { color: var(--c-warning-text); }

.product-card-price-block {
  margin-top: auto;
  padding-top: var(--s-2);
}
.product-card-price-row {
  display: flex;
  align-items: baseline;
  gap: var(--s-2);
  flex-wrap: wrap;
}
.product-card-price {
  font-size: 18px;
  font-weight: 700;
  color: var(--c-fg-1);
}
.product-card-price--poa {
  color: var(--c-primary);
  font-size: 16px;
}
.product-card-price-strike {
  font-size: 13px;
  color: var(--c-fg-4);
  text-decoration: line-through;
}
.product-card-price-disc {
  font-size: 12px;
  font-weight: 700;
  color: var(--c-danger);
  background: var(--c-danger-bg);
  padding: 2px 6px;
  border-radius: var(--r-sm);
}
.product-card-price-note {
  font-size: 11px;
  color: var(--c-fg-4);
  margin-top: 2px;
}

/* Actions */
.product-card-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-2);
  margin-top: var(--s-3);
}
.product-card-actions .btn--block { grid-column: 1 / -1; }
.product-card-actions .btn { justify-content: center; }

/* Out of stock dim */
.bsmt-product-card.outofstock .product-card-image img { opacity: .55; filter: grayscale(.3); }
