/* =========================================================
   FORGE THEME — Ingrid CMS Commerce Theme  v1
   ========================================================= */

/* ── Variables ─────────────────────────────────────────── */
:root {
  --forge-accent:    var(--accent, #e85d04);
  --forge-bg:        #f4f5f7;
  --forge-card:      #ffffff;
  --forge-text:      #1a1a2e;
  --forge-muted:     #6b7280;
  --forge-dim:       #9ca3af;
  --forge-border:    #e5e7eb;
  --forge-shadow:    0 2px 12px rgba(0,0,0,.07);
  --forge-shadow-lg: 0 8px 32px rgba(0,0,0,.12);
  --forge-radius:    10px;
  --forge-radius-sm: 6px;
  --forge-radius-lg: 16px;
  --forge-transition: .18s ease;

  /* Layout */
  --forge-sidebar-w: 260px;
  --forge-ann-h:     38px;
  --forge-header-h:  72px;
  --forge-nav-h:     48px;

  /* ── Standard module var contract (maps --forge-* to shared names) ── */
  --forge-bg-alt:  #eef0f3;
  --accent-text:   #ffffff;
  --bg:            var(--forge-bg);
  --bg-alt:        var(--forge-bg-alt);
  --surface:       var(--forge-card);
  --border:        var(--forge-border);
  --text:          var(--forge-text);
  --muted:         var(--forge-muted);
  --dim:           var(--forge-dim);
  --radius:        var(--forge-radius);
  --shadow:        var(--forge-shadow);
  --max-w:         1280px;
  --nav-h:         var(--forge-nav-h);
}

/* ── Reset / Base ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--forge-bg);
  color: var(--forge-text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; font-family: inherit; }

/* ── Container ─────────────────────────────────────────── */
.forge-container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.forge-container-wide { max-width: 1440px; }

/* ── Announcement Bar ──────────────────────────────────── */
.forge-ann {
  background: var(--forge-accent);
  color: #fff;
  height: var(--forge-ann-h);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .01em;
  gap: 8px;
}
.forge-ann a { color: #fff; text-decoration: underline; opacity: .85; }
.forge-ann a:hover { opacity: 1; }

/* ── Header ────────────────────────────────────────────── */
.forge-header {
  background: #fff;
  border-bottom: 1px solid var(--forge-border);
  height: var(--forge-header-h);
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 1px 0 var(--forge-border);
}
.forge-header-inner {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 24px;
}
.forge-logo { flex-shrink: 0; }
.forge-logo img { height: 36px; width: auto; }
.forge-logo-text { font-size: 22px; font-weight: 800; color: var(--forge-text); letter-spacing: -.02em; }
.forge-logo-text em { color: var(--forge-accent); font-style: normal; }

/* Search */
.forge-search { flex: 1; max-width: 520px; position: relative; }
.forge-search input {
  width: 100%;
  height: 42px;
  border: 1.5px solid var(--forge-border);
  border-radius: 8px;
  padding: 0 44px 0 16px;
  font-size: 14px;
  background: var(--forge-bg);
  color: var(--forge-text);
  transition: border-color var(--forge-transition), box-shadow var(--forge-transition);
  outline: none;
}
.forge-search input:focus { border-color: var(--forge-accent); box-shadow: 0 0 0 3px rgba(var(--forge-accent-rgb),.1); background: #fff; }
.forge-search-btn {
  position: absolute; right: 0; top: 0; height: 42px; width: 44px;
  border: none; background: none; display: flex; align-items: center; justify-content: center;
  color: var(--forge-muted);
}
.forge-search-btn:hover { color: var(--forge-accent); }

/* Header actions */
.forge-header-actions { display: flex; align-items: center; gap: 6px; margin-left: auto; }
.forge-header-action {
  width: 40px; height: 40px;
  border-radius: 8px;
  border: none;
  background: none;
  display: flex; align-items: center; justify-content: center;
  color: var(--forge-text);
  transition: background var(--forge-transition), color var(--forge-transition);
  position: relative;
}
.forge-header-action:hover { background: var(--forge-bg); color: var(--forge-accent); }
.forge-header-action-badge {
  position: absolute; top: 4px; right: 4px;
  width: 16px; height: 16px;
  background: var(--forge-accent); color: #fff;
  border-radius: 50%; font-size: 9px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

/* ── Navigation Bar ────────────────────────────────────── */
.forge-nav {
  background: #fff;
  border-bottom: 1px solid var(--forge-border);
  height: var(--forge-nav-h);
  position: sticky;
  top: var(--forge-header-h);
  z-index: 190;
}
.forge-nav-inner { display: flex; align-items: center; height: 100%; gap: 4px; }
.forge-nav-item {
  height: 100%;
  padding: 0 14px;
  display: flex; align-items: center;
  font-size: 14px; font-weight: 500;
  color: var(--forge-text);
  border-bottom: 2px solid transparent;
  transition: color var(--forge-transition), border-color var(--forge-transition);
  white-space: nowrap;
  position: relative;
}
.forge-nav-item:hover, .forge-nav-item.active { color: var(--forge-accent); border-bottom-color: var(--forge-accent); }
.forge-nav-item svg { margin-right: 5px; }

/* Mega menu */
.forge-mega { position: absolute; left: 0; top: 100%; width: 600px; background: #fff; border: 1px solid var(--forge-border); border-radius: 0 0 var(--forge-radius-lg) var(--forge-radius-lg); box-shadow: var(--forge-shadow-lg); padding: 20px; display: none; z-index: 300; }
.forge-nav-item:hover .forge-mega { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.forge-mega-item { padding: 10px 12px; border-radius: var(--forge-radius-sm); font-size: 13px; font-weight: 500; transition: background var(--forge-transition), color var(--forge-transition); }
.forge-mega-item:hover { background: var(--forge-bg); color: var(--forge-accent); }

/* ── Breadcrumb ────────────────────────────────────────── */
.forge-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--forge-muted); padding: 16px 0; }
.forge-breadcrumb a:hover { color: var(--forge-accent); }
.forge-breadcrumb-sep { opacity: .4; }

/* ── Page Layout ───────────────────────────────────────── */
.forge-page { padding: 32px 0 64px; }
.forge-layout { display: grid; grid-template-columns: var(--forge-sidebar-w) 1fr; gap: 28px; align-items: start; }
.forge-sidebar { position: sticky; top: calc(var(--forge-header-h) + var(--forge-nav-h) + 16px); }
.forge-content { min-width: 0; }

/* ── Cards ─────────────────────────────────────────────── */
.forge-card { background: var(--forge-card); border: 1px solid var(--forge-border); border-radius: var(--forge-radius); overflow: hidden; }
.forge-card-body { padding: 20px; }

/* ── Product Grid ──────────────────────────────────────── */
.forge-product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.forge-product-card {
  background: var(--forge-card);
  border: 1px solid var(--forge-border);
  border-radius: var(--forge-radius);
  overflow: hidden;
  transition: transform var(--forge-transition), box-shadow var(--forge-transition), border-color var(--forge-transition);
  position: relative;
}
.forge-product-card:hover { transform: translateY(-2px); box-shadow: var(--forge-shadow-lg); border-color: #d1d5db; }
.forge-product-img { aspect-ratio: 4/3; background: #f9fafb; display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
.forge-product-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.forge-product-card:hover .forge-product-img img { transform: scale(1.04); }
.forge-product-badges { position: absolute; top: 10px; left: 10px; display: flex; flex-direction: column; gap: 4px; z-index: 2; }
.forge-badge { font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 4px; text-transform: uppercase; letter-spacing: .05em; }
.forge-badge-sale { position:absolute; top:10px; z-index:3; font-size:10px; font-weight:700; padding:3px 8px; border-radius:4px; text-transform:uppercase; letter-spacing:.05em; line-height:1.5; left:10px; background: #ef4444; color: #fff; }
.forge-badge-new  { position:absolute; top:10px; z-index:3; font-size:10px; font-weight:700; padding:3px 8px; border-radius:4px; text-transform:uppercase; letter-spacing:.05em; line-height:1.5; left:10px; background: #3b82f6; color: #fff; }
.forge-badge-out  { position:absolute; top:10px; z-index:3; font-size:10px; font-weight:700; padding:3px 8px; border-radius:4px; text-transform:uppercase; letter-spacing:.05em; line-height:1.5; left:10px; background: #6b7280; color: #fff; }
.forge-quick-view {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  background: rgba(255,255,255,.95); border: 1px solid var(--forge-border);
  border-radius: 6px; padding: 6px 14px; font-size: 12px; font-weight: 600;
  white-space: nowrap; opacity: 0; transition: opacity var(--forge-transition);
  pointer-events: none;
}
.forge-product-card:hover .forge-quick-view { opacity: 1; pointer-events: auto; }
.forge-product-info { padding: 14px; }
.forge-product-brand { font-size: 11px; font-weight: 600; color: var(--forge-muted); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 4px; }
.forge-product-name { font-size: 14px; font-weight: 600; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 8px; }
.forge-product-sku  { font-size: 11px; color: var(--forge-dim); margin-bottom: 8px; }
.forge-product-price { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.forge-price        { font-size: 17px; font-weight: 700; color: var(--forge-accent); }
.forge-price-old    { font-size: 13px; color: var(--forge-muted); text-decoration: line-through; }
.forge-product-stock { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--forge-muted); margin-bottom: 10px; }
.forge-stock-dot    { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.forge-stock-in     { background: #22c55e; }
.forge-stock-out    { background: #ef4444; }
.forge-stock-back   { background: #f59e0b; }
.forge-btn-inquiry {
  width: 100%; padding: 9px; border-radius: 7px; border: none;
  background: var(--forge-accent); color: #fff;
  font-size: 13px; font-weight: 600; letter-spacing: .01em;
  transition: opacity var(--forge-transition), transform var(--forge-transition);
}
.forge-btn-inquiry:hover { opacity: .88; }

/* ── Sidebar Filters ───────────────────────────────────── */
.forge-filter-card { background: var(--forge-card); border: 1px solid var(--forge-border); border-radius: var(--forge-radius); overflow: hidden; margin-bottom: 12px; }
.forge-filter-head { padding: 14px 16px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--forge-muted); border-bottom: 1px solid var(--forge-border); display: flex; justify-content: space-between; align-items: center; cursor: pointer; }
.forge-filter-body { padding: 12px 16px; display: flex; flex-direction: column; gap: 8px; }
.forge-filter-option { display: flex; align-items: center; gap: 9px; font-size: 13px; cursor: pointer; }
.forge-filter-option input { width: 15px; height: 15px; accent-color: var(--forge-accent); cursor: pointer; }
.forge-filter-option:hover { color: var(--forge-accent); }
.forge-filter-count { color: var(--forge-dim); font-size: 12px; margin-left: auto; }

/* Active filters */
.forge-active-filters { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.forge-filter-tag { display: flex; align-items: center; gap: 5px; background: rgba(var(--forge-accent-rgb),.08); color: var(--forge-accent); border: 1px solid rgba(var(--forge-accent-rgb),.25); border-radius: 20px; padding: 3px 10px 3px 12px; font-size: 12px; font-weight: 500; }
.forge-filter-tag button { background: none; border: none; color: inherit; opacity: .6; line-height: 1; padding: 0; font-size: 14px; }
.forge-filter-tag button:hover { opacity: 1; }

/* ── Sort bar ──────────────────────────────────────────── */
.forge-sort-bar { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.forge-result-count { font-size: 13px; color: var(--forge-muted); flex: 1; }
.forge-sort-select { padding: 6px 12px; border: 1px solid var(--forge-border); border-radius: var(--forge-radius-sm); font-size: 13px; background: #fff; color: var(--forge-text); outline: none; cursor: pointer; }
.forge-sort-select:focus { border-color: var(--forge-accent); }
.forge-view-toggle { display: flex; border: 1px solid var(--forge-border); border-radius: var(--forge-radius-sm); overflow: hidden; }
.forge-view-btn { padding: 6px 10px; border: none; background: #fff; color: var(--forge-muted); transition: background var(--forge-transition), color var(--forge-transition); }
.forge-view-btn.active, .forge-view-btn:hover { background: var(--forge-accent); color: #fff; }

/* ── Category header banner ────────────────────────────── */
.forge-cat-banner { background: linear-gradient(135deg, var(--forge-text) 0%, #2d3748 100%); color: #fff; padding: 40px 0; margin-bottom: 32px; }
.forge-cat-banner h1 { font-size: 28px; font-weight: 800; margin-bottom: 4px; }
.forge-cat-banner p { opacity: .7; font-size: 14px; }

/* ── Pagination ────────────────────────────────────────── */
.forge-pagination { display: flex; justify-content: center; gap: 6px; margin-top: 32px; }
.forge-page-btn { min-width: 36px; padding: 8px 14px; box-sizing: border-box; border-radius: var(--forge-radius-sm); border: 1px solid var(--forge-border); background: #fff; color: var(--forge-text); font-size: 14px; display: inline-flex; align-items: center; justify-content: center; white-space: nowrap; transition: all var(--forge-transition); }
.forge-page-btn:hover, .forge-page-btn.active { background: var(--forge-accent); border-color: var(--forge-accent); color: #fff; }

/* ── Single product ────────────────────────────────────── */
.forge-product-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; margin-bottom: 56px; }
.forge-gallery { position: sticky; top: calc(var(--forge-header-h) + var(--forge-nav-h) + 24px); }
.forge-gallery-main { background: var(--forge-card); border: 1px solid var(--forge-border); border-radius: var(--forge-radius-lg); overflow: hidden; aspect-ratio: 1; display: flex; align-items: center; justify-content: center; margin-bottom: 12px; cursor: zoom-in; }
.forge-gallery-main img { width: 100%; height: 100%; object-fit: contain; padding: 24px; }
.forge-gallery-thumbs { display: flex; gap: 8px; flex-wrap: wrap; }
.forge-gallery-thumb { width: 70px; height: 70px; border: 2px solid var(--forge-border); border-radius: var(--forge-radius-sm); overflow: hidden; cursor: pointer; flex-shrink: 0; background: var(--forge-card); transition: border-color var(--forge-transition); }
.forge-gallery-thumb.active, .forge-gallery-thumb:hover { border-color: var(--forge-accent); }
.forge-gallery-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }

/* Product detail panel */
.forge-product-detail {}
.forge-product-detail-brand { font-size: 12px; font-weight: 700; color: var(--forge-muted); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px; }
.forge-product-detail h1 { font-size: 26px; font-weight: 800; line-height: 1.25; margin-bottom: 12px; letter-spacing: -.01em; }
.forge-product-detail-sku  { font-size: 12px; color: var(--forge-dim); margin-bottom: 12px; }
.forge-product-detail-price { font-size: 32px; font-weight: 800; color: var(--forge-accent); margin-bottom: 4px; }
.forge-product-detail-price-old { font-size: 16px; color: var(--forge-muted); text-decoration: line-through; margin-bottom: 16px; }
.forge-product-detail-short { font-size: 15px; line-height: 1.65; color: var(--forge-muted); margin-bottom: 20px; }
.forge-product-key-attrs { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 24px; }
.forge-attr-pill { background: var(--forge-bg); border: 1px solid var(--forge-border); border-radius: var(--forge-radius-sm); padding: 8px 12px; font-size: 12px; }
.forge-attr-pill-label { color: var(--forge-muted); margin-bottom: 2px; }
.forge-attr-pill-value { font-weight: 700; font-size: 13px; }
.forge-add-to-inquiry { width: 100%; padding: 15px; border-radius: var(--forge-radius); border: none; background: var(--forge-accent); color: #fff; font-size: 16px; font-weight: 700; letter-spacing: .01em; margin-bottom: 12px; transition: opacity var(--forge-transition); display: flex; align-items: center; justify-content: center; gap: 10px; }
.forge-add-to-inquiry:hover { opacity: .88; }
.forge-trust-badges { display: flex; gap: 16px; padding: 16px 0; border-top: 1px solid var(--forge-border); border-bottom: 1px solid var(--forge-border); margin-bottom: 20px; }
.forge-trust-badge { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--forge-muted); }
.forge-trust-badge svg { color: var(--forge-accent); flex-shrink: 0; }

/* Product tabs */
.forge-tabs { margin-bottom: 48px; }
.forge-tab-nav { display: flex; border-bottom: 2px solid var(--forge-border); margin-bottom: 24px; gap: 0; }
.forge-tab-btn { padding: 12px 20px; font-size: 14px; font-weight: 600; color: var(--forge-muted); border: none; background: none; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: color var(--forge-transition), border-color var(--forge-transition); cursor: pointer; }
.forge-tab-btn.active { color: var(--forge-accent); border-bottom-color: var(--forge-accent); }
.forge-tab-pane { display: none; }
.forge-tab-pane.active { display: block; }

/* Specs table */
.forge-specs-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.forge-specs-table tr:nth-child(even) { background: var(--forge-bg); }
.forge-specs-table td { padding: 10px 16px; border-bottom: 1px solid var(--forge-border); }
.forge-specs-table td:first-child { font-weight: 600; width: 40%; color: var(--forge-muted); }

/* Review stars */
.forge-stars { display: flex; gap: 2px; }
.forge-star  { color: #f59e0b; font-size: 16px; }
.forge-star.empty { color: var(--forge-border); }

/* ── Trust bar (homepage) ──────────────────────────────── */
.forge-trust-bar { background: #fff; border-top: 1px solid var(--forge-border); border-bottom: 1px solid var(--forge-border); padding: 28px 0; }
.forge-trust-bar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.forge-trust-icon { width: 44px; height: 44px; border-radius: 50%; background: rgba(var(--forge-accent-rgb),.08); display: flex; align-items: center; justify-content: center; margin: 0 auto 10px; color: var(--forge-accent); }
.forge-trust-title { font-size: 14px; font-weight: 700; margin-bottom: 3px; }
.forge-trust-text  { font-size: 12px; color: var(--forge-muted); }

/* ── Footer ────────────────────────────────────────────── */
.forge-footer { background: var(--forge-text); color: rgba(255,255,255,.7); padding: 56px 0 24px; margin-top: 56px; }
.forge-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.forge-footer h4 { color: #fff; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 16px; }
.forge-footer ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.forge-footer ul li a { font-size: 13px; opacity: .7; transition: opacity .15s; }
.forge-footer ul li a:hover { opacity: 1; }
.forge-footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 20px; display: flex; justify-content: space-between; align-items: center; font-size: 12px; opacity: .5; }

/* ── Quick View Modal ──────────────────────────────────── */
.forge-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity .2s ease; }
.forge-modal-overlay.open { opacity: 1; pointer-events: auto; }
.forge-modal { background: #fff; border-radius: var(--forge-radius-lg); width: 100%; max-width: 780px; max-height: 90vh; overflow-y: auto; box-shadow: var(--forge-shadow-lg); transform: translateY(16px); transition: transform .2s ease; }
.forge-modal-overlay.open .forge-modal { transform: translateY(0); }
.forge-modal-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; padding: 32px; }
.forge-modal-close { position: absolute; top: 16px; right: 16px; width: 32px; height: 32px; border-radius: 50%; background: var(--forge-bg); border: none; display: flex; align-items: center; justify-content: center; color: var(--forge-muted); }
.forge-modal-close:hover { background: var(--forge-border); color: var(--forge-text); }

/* ── Helpers ───────────────────────────────────────────── */
.forge-section { padding: 56px 0; }
.forge-section-title { font-size: 24px; font-weight: 800; margin-bottom: 24px; letter-spacing: -.01em; }
.forge-section-title span { color: var(--forge-accent); }

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 1024px) {
  .forge-layout { grid-template-columns: 220px 1fr; gap: 20px; }
  .forge-product-layout { grid-template-columns: 1fr; gap: 32px; }
  .forge-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .forge-layout { grid-template-columns: 1fr; }
  .forge-sidebar { position: static; }
  .forge-trust-bar-grid { grid-template-columns: repeat(2, 1fr); }
  .forge-product-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .forge-modal-inner { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .forge-container { padding: 0 16px; }
  .forge-product-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .forge-footer-grid { grid-template-columns: 1fr; }
  .forge-product-key-attrs { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   PHASE 2 — Listing, Product, Search, Inquiry
   ═══════════════════════════════════════════════════════════════ */

/* ── Listing page ────────────────────────────────────────────── */
.forge-listing-wrap { max-width:1280px; margin:0 auto; padding:0 24px 60px; }
.forge-listing-header { padding:32px 0 20px; }
.forge-listing-header h1 { font-size:28px; font-weight:700; color:var(--forge-text); }

.forge-cat-banner { background:var(--forge-accent) center/cover no-repeat; border-radius:var(--forge-radius); padding:60px 40px; margin-bottom:28px; position:relative; overflow:hidden; }
.forge-cat-banner::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(0,0,0,.55),rgba(0,0,0,.2)); }
.forge-cat-banner-inner { position:relative; color:#fff; }
.forge-cat-banner-inner h1 { font-size:32px; font-weight:800; margin-bottom:8px; }
.forge-cat-banner-inner p { opacity:.85; font-size:15px; }

.forge-brand-banner { display:flex; align-items:center; gap:20px; padding:28px 0 20px; }
.forge-brand-banner-logo { height:56px; object-fit:contain; }
.forge-brand-banner h1 { font-size:28px; font-weight:700; }
.forge-brand-banner p { color:var(--forge-muted); margin-top:4px; font-size:14px; }

.forge-listing-layout { display:grid; grid-template-columns:240px 1fr; gap:28px; align-items:start; }

/* Sidebar */
.forge-filter-sidebar { background:var(--forge-card); border-radius:var(--forge-radius); padding:20px; border:1px solid var(--forge-border); position:sticky; top:90px; }
.forge-filter-group { margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid var(--forge-border); }
.forge-filter-group:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }
.forge-filter-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--forge-muted); margin-bottom:10px; }
.forge-check-label { display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--forge-text); cursor:pointer; padding:4px 0; }
.forge-check-label input[type=checkbox] { accent-color:var(--forge-accent); width:15px; height:15px; cursor:pointer; }
.forge-cat-parent { font-weight:500; }
.forge-cat-child { padding-left:20px; color:var(--forge-muted); }
.forge-filter-count { margin-left:auto; font-size:11px; color:var(--forge-muted); background:var(--forge-bg); padding:1px 6px; border-radius:20px; }

.forge-price-range { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.forge-price-input { width:70px; padding:6px 8px; border:1px solid var(--forge-border); border-radius:6px; font-size:13px; background:var(--forge-bg); color:var(--forge-text); }
.forge-btn-sm { padding:6px 12px; background:var(--forge-accent); color:#fff; border:none; border-radius:6px; font-size:13px; cursor:pointer; }

.forge-active-filters { margin-bottom:20px; padding-bottom:20px; border-bottom:1px solid var(--forge-border); }
.forge-chip-row { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.forge-chip { display:flex; align-items:center; gap:4px; background:var(--forge-accent); color:#fff; font-size:12px; padding:4px 10px; border-radius:20px; }
.forge-chip-remove { background:none; border:none; color:#fff; cursor:pointer; font-size:14px; line-height:1; padding:0; }
.forge-chip-clear { background:var(--forge-bg); color:var(--forge-muted); border:1px solid var(--forge-border); text-decoration:none; }

/* Sort bar */
.forge-listing-main {}
.forge-sort-bar { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; padding:12px 16px; background:var(--forge-card); border-radius:var(--forge-radius); border:1px solid var(--forge-border); }
.forge-result-count { font-size:13.5px; color:var(--forge-muted); }
.forge-sort-right { display:flex; align-items:center; gap:10px; }
.forge-sort-select { padding:6px 10px; border:1px solid var(--forge-border); border-radius:6px; font-size:13.5px; background:var(--forge-bg); color:var(--forge-text); cursor:pointer; }
.forge-filter-toggle { display:none; align-items:center; gap:6px; padding:6px 12px; background:var(--forge-bg); border:1px solid var(--forge-border); border-radius:6px; font-size:13px; cursor:pointer; color:var(--forge-text); }

/* Pagination */
.forge-pagination { display:flex; gap:6px; justify-content:center; margin-top:32px; }
.forge-page-btn { padding:8px 14px; border:1px solid var(--forge-border); border-radius:6px; text-decoration:none; color:var(--forge-text); font-size:14px; transition:background .15s; }
.forge-page-btn:hover { background:var(--forge-accent); color:#fff; border-color:var(--forge-accent); }
.forge-page-active { background:var(--forge-accent); color:#fff !important; border-color:var(--forge-accent); }

.forge-empty-state { text-align:center; padding:60px 20px; color:var(--forge-muted); }
.forge-empty-state p { margin:16px 0 24px; }
.forge-btn-primary { display:inline-flex; align-items:center; gap:8px; padding:12px 24px; background:var(--forge-accent); color:#fff; border:none; border-radius:8px; font-size:15px; font-weight:600; cursor:pointer; text-decoration:none; transition:opacity .2s; }
.forge-btn-primary:hover { opacity:.88; }

/* ── Breadcrumb ───────────────────────────────────────────────── */
.forge-breadcrumb { max-width:1280px; margin:0 auto; padding:16px 24px 8px; display:flex; align-items:center; flex-wrap:wrap; gap:6px; font-size:13px; color:var(--forge-muted); }
.forge-breadcrumb a { color:var(--forge-muted); text-decoration:none; }
.forge-breadcrumb a:hover { color:var(--forge-accent); }
.forge-breadcrumb span { color:var(--forge-muted); }
.forge-breadcrumb span:last-child { color:var(--forge-text); font-weight:500; }

/* ── Product hero ────────────────────────────────────────────── */
.forge-product-hero { max-width:1280px; margin:0 auto; padding:24px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }

/* Gallery */
.forge-gallery { display:flex; flex-direction:column; gap:12px; position:sticky; top:90px; }
.forge-gallery-main { position:relative; background:var(--forge-card); border-radius:var(--forge-radius); border:1px solid var(--forge-border); overflow:hidden; aspect-ratio:1; display:flex; align-items:center; justify-content:center; }
.forge-gallery-main img { width:100%; height:100%; object-fit:contain; }
.forge-gallery-placeholder { display:flex; align-items:center; justify-content:center; width:100%; height:100%; }
.forge-gallery-badge { position:absolute; top:12px; left:12px; }
.forge-gallery-thumbs { display:flex; gap:8px; flex-wrap:wrap; }
.forge-thumb { width:72px; height:72px; object-fit:cover; border-radius:8px; border:2px solid var(--forge-border); cursor:pointer; transition:border-color .15s; }
.forge-thumb.active, .forge-thumb:hover { border-color:var(--forge-accent); }

/* Detail panel */
.forge-product-detail {}
.forge-product-brand-link { font-size:12.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--forge-accent); font-weight:600; text-decoration:none; }
.forge-product-title { font-size:26px; font-weight:800; color:var(--forge-text); margin:8px 0 6px; line-height:1.25; }
.forge-product-sku { font-size:12.5px; color:var(--forge-muted); margin-bottom:12px; }
.forge-rating-summary { display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.forge-stars { color:#f59e0b; font-size:18px; letter-spacing:1px; }
.forge-rating-num { font-weight:700; }
.forge-rating-link { font-size:13px; color:var(--forge-accent); text-decoration:none; }
.forge-detail-price { display:flex; align-items:baseline; gap:12px; margin:16px 0 12px; }
.forge-detail-price-main { font-size:32px; font-weight:800; color:var(--forge-accent); }
.forge-detail-price-old { font-size:18px; color:var(--forge-muted); text-decoration:line-through; }
.forge-stock-label { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:600; padding:5px 12px; border-radius:20px; margin-bottom:16px; }
.forge-stock-label-in  { background:#dcfce7; color:#166534; }
.forge-stock-label-out { background:#fee2e2; color:#991b1b; }
.forge-stock-label-back { background:#fef3c7; color:#92400e; }
.forge-stock-dot-lg { width:8px; height:8px; border-radius:50%; background:currentColor; }
.forge-short-desc { font-size:14.5px; color:var(--forge-muted); line-height:1.65; margin-bottom:18px; }
.forge-spec-preview { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; }
.forge-spec-chip { background:var(--forge-bg); border:1px solid var(--forge-border); border-radius:6px; padding:6px 12px; font-size:13px; }
.forge-spec-name { color:var(--forge-muted); margin-right:4px; }
.forge-spec-val { font-weight:600; }
.forge-add-actions { display:flex; gap:12px; margin-bottom:20px; align-items:center; }
.forge-qty-stepper { display:flex; border:1px solid var(--forge-border); border-radius:8px; overflow:hidden; }
.forge-qty-stepper button { width:36px; height:44px; background:var(--forge-bg); border:none; font-size:18px; cursor:pointer; color:var(--forge-text); transition:background .15s; }
.forge-qty-stepper button:hover { background:var(--forge-border); }
.forge-qty-stepper input { width:52px; height:44px; border:none; border-left:1px solid var(--forge-border); border-right:1px solid var(--forge-border); text-align:center; font-size:15px; font-weight:600; background:#fff; color:var(--forge-text); }
.forge-add-inquiry-lg { flex:1; display:flex; align-items:center; justify-content:center; gap:8px; padding:12px 20px; background:var(--forge-accent); color:#fff; border:none; border-radius:8px; font-size:15px; font-weight:700; cursor:pointer; transition:opacity .2s; }
.forge-add-inquiry-lg:hover { opacity:.88; }
.forge-share-row { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--forge-muted); }
.forge-share-btn { padding:5px 12px; border:1px solid var(--forge-border); border-radius:6px; font-size:13px; text-decoration:none; color:var(--forge-text); transition:background .15s; }
.forge-share-btn:hover { background:var(--forge-accent); color:#fff; border-color:var(--forge-accent); }

/* ── Product tabs ────────────────────────────────────────────── */
.forge-product-tabs-wrap { max-width:1280px; margin:0 auto; padding:40px 24px 56px; }
.forge-tabs-nav { display:flex; gap:0; border-bottom:2px solid var(--forge-border); margin-bottom:28px; overflow-x:auto; }
.forge-tab-btn { padding:12px 20px; background:none; border:none; font-size:14.5px; font-weight:500; color:var(--forge-muted); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; white-space:nowrap; transition:color .15s; }
.forge-tab-btn.active { color:var(--forge-accent); border-bottom-color:var(--forge-accent); }
.forge-tab-panel { display:none; }
.forge-tab-panel.active { display:block; }
.forge-tab-empty { color:var(--forge-muted); font-style:italic; }
.forge-desc-body { font-size:15px; line-height:1.7; color:var(--forge-text); }
.forge-compat-body { font-size:14px; line-height:1.7; color:var(--forge-text); white-space:pre-line; }

/* Specs table */
.forge-specs-table { width:100%; border-collapse:collapse; font-size:14px; }
.forge-specs-table tr { border-bottom:1px solid var(--forge-border); }
.forge-specs-table tr:last-child { border-bottom:none; }
.forge-specs-table th { text-align:left; padding:10px 16px 10px 0; color:var(--forge-muted); font-weight:500; width:35%; vertical-align:top; }
.forge-specs-table td { padding:10px 0; font-weight:500; }

/* Reviews */
.forge-reviews-list { display:flex; flex-direction:column; gap:20px; margin-bottom:36px; }
.forge-review-item { padding:20px; background:var(--forge-bg); border-radius:var(--forge-radius); }
.forge-review-header { display:flex; align-items:center; gap:12px; margin-bottom:8px; flex-wrap:wrap; }
.forge-review-name { font-weight:700; }
.forge-review-stars { color:#f59e0b; }
.forge-review-date { font-size:12px; color:var(--forge-muted); margin-left:auto; }
.forge-review-title { font-weight:600; margin-bottom:4px; }
.forge-review-body { font-size:14px; color:var(--forge-muted); line-height:1.6; }
.forge-review-form-wrap { padding-top:28px; border-top:1px solid var(--forge-border); }
.forge-review-form-wrap h3 { font-size:18px; font-weight:700; margin-bottom:20px; }
.forge-review-form { display:flex; flex-direction:column; gap:16px; }
.forge-form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.forge-form-group { display:flex; flex-direction:column; gap:6px; }
.forge-form-group label { font-size:13px; font-weight:600; color:var(--forge-text); }
.forge-form-group input, .forge-form-group textarea { padding:10px 12px; border:1px solid var(--forge-border); border-radius:8px; font-size:14px; background:#fff; color:var(--forge-text); font-family:inherit; transition:border-color .15s; }
.forge-form-group input:focus, .forge-form-group textarea:focus { outline:none; border-color:var(--forge-accent); }
.forge-star-picker { display:flex; gap:6px; cursor:pointer; }
.forge-star-pick { font-size:26px; color:#d1d5db; transition:color .1s; user-select:none; }
.forge-star-pick:hover, .forge-star-pick.selected { color:#f59e0b; }

/* Alerts */
.forge-alert { padding:14px 18px; border-radius:8px; font-size:14px; margin-bottom:16px; }
.forge-alert-success { background:#dcfce7; color:#166534; border:1px solid #86efac; }
.forge-alert-error { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }

/* Related products */
.forge-related { max-width:1280px; margin:0 auto; padding:48px 24px 60px; }
.forge-related h2 { font-size:22px; font-weight:700; margin-bottom:24px; }

/* ── Search page ─────────────────────────────────────────────── */
.forge-search-hero { text-align:center; padding:48px 24px 32px; max-width:700px; margin:0 auto; }
.forge-search-hero h1 { font-size:32px; font-weight:800; margin-bottom:20px; }
.forge-search-form-lg { display:flex; gap:0; border:2px solid var(--forge-border); border-radius:10px; overflow:hidden; background:#fff; }
.forge-search-form-lg input { flex:1; padding:14px 18px; border:none; font-size:16px; outline:none; background:transparent; }
.forge-search-form-lg button { padding:14px 24px; background:var(--forge-accent); color:#fff; border:none; font-size:15px; font-weight:600; cursor:pointer; }
.forge-search-sub { margin-top:16px; color:var(--forge-muted); font-size:14px; }

/* ── Inquiry page ────────────────────────────────────────────── */
.forge-inquiry-page { max-width:1100px; margin:0 auto; padding:40px 24px 60px; }
.forge-inquiry-page h1 { font-size:28px; font-weight:800; margin-bottom:28px; }
.forge-inquiry-layout { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
.forge-inquiry-basket { background:var(--forge-card); border-radius:var(--forge-radius); border:1px solid var(--forge-border); padding:24px; }
.forge-inquiry-basket h2 { font-size:18px; font-weight:700; margin-bottom:16px; }
.forge-basket-empty { color:var(--forge-muted); font-size:14px; }
.forge-basket-row { display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--forge-border); }
.forge-basket-row:last-child { border-bottom:none; }
.forge-basket-name { flex:1; font-size:14px; font-weight:500; }
.forge-basket-qty { display:flex; align-items:center; gap:8px; font-size:14px; }
.forge-basket-qty button { width:26px; height:26px; border:1px solid var(--forge-border); border-radius:4px; background:var(--forge-bg); cursor:pointer; font-size:14px; }
.forge-basket-remove { background:none; border:none; color:var(--forge-muted); cursor:pointer; font-size:18px; line-height:1; }
.forge-basket-total { margin-top:16px; padding-top:16px; border-top:1px solid var(--forge-border); font-size:14px; }
.forge-inquiry-form-wrap h2 { font-size:18px; font-weight:700; margin-bottom:16px; }
.forge-btn-full { width:100%; justify-content:center; }
.forge-form-note { font-size:12px; color:var(--forge-muted); margin-top:6px; text-align:center; }

/* ── Mobile responsive ───────────────────────────────────────── */
@media (max-width:1024px) {
  .forge-listing-layout { grid-template-columns:1fr; }
  .forge-filter-sidebar { display:none; position:fixed; inset:0; z-index:200; overflow-y:auto; border-radius:0; }
  .forge-filter-sidebar.forge-sidebar-open { display:block; }
  .forge-filter-toggle { display:flex !important; }
  .forge-product-hero { grid-template-columns:1fr; gap:24px; }
  .forge-gallery { position:static; }
  .forge-inquiry-layout { grid-template-columns:1fr; }
}
@media (max-width:640px) {
  .forge-product-grid { grid-template-columns:repeat(2,1fr); }
  .forge-form-row { grid-template-columns:1fr; }
  .forge-product-title { font-size:22px; }
  .forge-detail-price-main { font-size:26px; }
  .forge-add-actions { flex-direction:column; }
  .forge-add-inquiry-lg { width:100%; }
}

/* ═══════════════════════════════════════════════════════════════
   PHASE 4 — Quick View, Inline Toggles, Polish
   ═══════════════════════════════════════════════════════════════ */

/* ── Quick view modal content ────────────────────────────────── */
.forge-modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:1000; align-items:center; justify-content:center; padding:20px; }
.forge-modal-overlay.open { display:flex; }
.forge-modal-box { background:var(--forge-card); border-radius:var(--forge-radius); max-width:820px; width:100%; max-height:90vh; overflow-y:auto; position:relative; box-shadow:0 20px 60px rgba(0,0,0,.2); }
.forge-modal-close { position:absolute; top:14px; right:16px; background:none; border:none; font-size:24px; cursor:pointer; color:var(--forge-muted); z-index:2; line-height:1; padding:4px 8px; border-radius:6px; }
.forge-modal-close:hover { background:var(--forge-bg); }
.forge-modal-loading { padding:60px; text-align:center; color:var(--forge-muted); font-size:15px; }
.forge-qv-inner { display:grid; grid-template-columns:1fr 1fr; gap:0; }
.forge-qv-img { background:var(--forge-bg); border-radius:var(--forge-radius) 0 0 var(--forge-radius); overflow:hidden; aspect-ratio:1; display:flex; align-items:center; justify-content:center; }
.forge-qv-img img { width:100%; height:100%; object-fit:contain; }
.forge-qv-info { padding:28px 24px; display:flex; flex-direction:column; gap:0; }
.forge-qv-title { font-size:20px; font-weight:700; color:var(--forge-text); margin:6px 0 12px; line-height:1.3; }
@media (max-width:640px) {
  .forge-qv-inner { grid-template-columns:1fr; }
  .forge-qv-img { border-radius:var(--forge-radius) var(--forge-radius) 0 0; aspect-ratio:4/3; }
}

/* ── Inline toggle switches (product list) ───────────────────── */
.forge-toggle { position:relative; display:inline-flex; width:36px; height:20px; cursor:pointer; }
.forge-toggle input { opacity:0; width:0; height:0; position:absolute; }
.forge-toggle-track { position:absolute; inset:0; background:#d1d5db; border-radius:20px; transition:background .2s; }
.forge-toggle input:checked + .forge-toggle-track { background:var(--forge-accent); }
.forge-toggle-thumb { position:absolute; top:3px; left:3px; width:14px; height:14px; background:#fff; border-radius:50%; transition:transform .2s; box-shadow:0 1px 3px rgba(0,0,0,.2); }
.forge-toggle input:checked ~ .forge-toggle-thumb { transform:translateX(16px); }

/* ── Product list inline actions ─────────────────────────────── */
.forge-inline-actions { display:flex; align-items:center; gap:10px; }
.forge-inline-label { font-size:11px; color:var(--forge-muted); font-weight:500; }

/* ── Stock status badge ──────────────────────────────────────── */
.stock-badge-in   { background:#dcfce7; color:#166534; }
.stock-badge-out  { background:#fee2e2; color:#991b1b; }
.stock-badge-back { background:#fef3c7; color:#92400e; }

/* ── Variant Buttons ── */
.forge-var-btn{transition:border-color .15s,background .15s,opacity .15s}
.forge-var-btn:hover{border-color:var(--forge-accent)!important}
.forge-var-btn.active{border-color:var(--forge-accent)!important;background:rgba(var(--forge-accent-rgb),.06)!important}
.forge-variants{margin-bottom:16px}

/* ═══════════════════════════════════════════════════════════════
   PHASE 5 — Homepage Sections, Hero, Category Grid, Brand Strip
   ═══════════════════════════════════════════════════════════════ */

/* ── Section container alias ────────────────────────────────── */
.forge-section-inner { max-width:1280px; margin:0 auto; padding:0 24px; }

/* ── Section header with "View all" link ───────────────────── */
.forge-section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; flex-wrap:wrap; gap:12px; }
.forge-section-header .forge-section-title { margin-bottom:0; }
.forge-section-link { font-size:13px; font-weight:600; color:var(--forge-accent); text-decoration:none; display:inline-flex; align-items:center; gap:3px; }
.forge-section-link:hover { opacity:.75; }

/* ── Hero Banner ────────────────────────────────────────────── */
.forge-hero-section { display:block; }
.forge-hero-bg {
  min-height:540px;
  display:flex; align-items:stretch;
  background:#1a1a2e center/cover no-repeat;
  position:relative;
}
.forge-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.82) 0%, rgba(0,0,0,.55) 55%, rgba(0,0,0,.15) 100%);
  display:flex; align-items:center; width:100%;
}
.forge-hero-content { width:100%; max-width:1280px; margin:0 auto; padding:60px 24px; }
.forge-hero-inner { max-width:580px; }
.forge-hero-sub {
  font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.14em;
  color:var(--forge-accent); margin-bottom:18px;
  display:inline-flex; align-items:center; gap:8px;
}
.forge-hero-sub::before { content:''; display:inline-block; width:24px; height:2px; background:var(--forge-accent); }
.forge-hero-title {
  font-size:54px; font-weight:900; color:#fff;
  line-height:1.08; letter-spacing:-.025em;
  margin-bottom:22px;
}
.forge-hero-text { font-size:16px; color:rgba(255,255,255,.72); line-height:1.7; margin-bottom:36px; max-width:460px; }
.forge-hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.forge-hero-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 32px; border-radius:8px;
  font-size:15px; font-weight:700; letter-spacing:.01em;
  transition:all .2s; text-decoration:none; border:2px solid transparent;
}
.forge-hero-btn-primary {
  background:var(--forge-accent); color:#fff; border-color:var(--forge-accent);
}
.forge-hero-btn-primary:hover { opacity:.88; }
.forge-hero-btn-ghost {
  background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.35);
}
.forge-hero-btn-ghost:hover { background:rgba(255,255,255,.16); border-color:#fff; }
@media (max-width:900px) {
  .forge-hero-bg { min-height:420px; }
  .forge-hero-title { font-size:38px; }
}
@media (max-width:600px) {
  .forge-hero-bg { min-height:360px; }
  .forge-hero-title { font-size:30px; }
  .forge-hero-text { font-size:14px; }
  .forge-hero-btn { padding:12px 22px; font-size:14px; }
}

/* ── Category Grid ──────────────────────────────────────────── */
.forge-section-cats { background:var(--forge-bg); }
.forge-cat-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}
.forge-cat-card {
  position:relative; border-radius:var(--forge-radius-lg);
  overflow:hidden; display:block;
  aspect-ratio:16/10; background:#1a1a2e;
  transition:transform .22s ease, box-shadow .22s ease;
  box-shadow:var(--forge-shadow);
  text-decoration:none;
}
.forge-cat-card:hover { transform:translateY(-5px); box-shadow:var(--forge-shadow-lg); }
.forge-cat-card-img {
  position:absolute; inset:0;
  overflow:hidden;
}
.forge-cat-card-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s ease;
}
.forge-cat-card:hover .forge-cat-card-img img { transform:scale(1.06); }
.forge-cat-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,.3) 45%, rgba(0,0,0,.05) 100%);
  transition:opacity .22s;
}
.forge-cat-card:hover::after { opacity:.85; }
.forge-cat-card-info {
  position:absolute; bottom:0; left:0; right:0;
  padding:22px 20px; z-index:2;
}
.forge-cat-name {
  display:block; color:#fff;
  font-size:17px; font-weight:700;
  margin-bottom:5px; line-height:1.3;
  transition:color .18s;
}
.forge-cat-count { display:block; color:rgba(255,255,255,.6); font-size:12px; font-weight:500; }
.forge-cat-card:hover .forge-cat-name { color:var(--forge-accent); }
@media (max-width:1150px) {
  .forge-cat-grid { grid-template-columns:repeat(3, 1fr); }
}
@media (max-width:900px) {
  .forge-cat-grid { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width:480px) {
  .forge-cat-grid { grid-template-columns:1fr 1fr; gap:12px; }
  .forge-cat-card { aspect-ratio:4/3; }
  .forge-cat-name { font-size:14px; }
}

/* ── Brand Strip ────────────────────────────────────────────── */
.forge-section-brands { background:#fff; }
.forge-brand-strip {
  display:flex; flex-wrap:wrap;
  gap:14px; align-items:center; justify-content:center;
}
.forge-brand-item {
  display:flex; align-items:center; justify-content:center;
  padding:18px 28px;
  border:1.5px solid var(--forge-border);
  border-radius:var(--forge-radius);
  background:#fff;
  min-width:130px; min-height:80px;
  transition:border-color .2s, box-shadow .2s, transform .2s;
  text-decoration:none;
}
.forge-brand-item:hover {
  border-color:var(--forge-accent);
  box-shadow:0 4px 16px rgba(var(--forge-accent-rgb),.12);
  transform:translateY(-2px);
}
.forge-brand-item img {
  max-height:44px; max-width:110px;
  object-fit:contain;
  filter:grayscale(1) opacity(.55);
  transition:filter .22s;
}
.forge-brand-item:hover img { filter:grayscale(0) opacity(1); }
.forge-brand-item-text {
  font-size:16px; font-weight:800;
  color:var(--forge-muted);
  letter-spacing:-.01em;
  transition:color .18s;
}
.forge-brand-item:hover .forge-brand-item-text { color:var(--forge-accent); }

/* ── Product Section Class Aliases ─────────────────────────── */
/* (section PHP files use these; CSS existing classes differ)  */
.forge-product-price-row {
  display:flex; align-items:center; gap:8px;
  margin-bottom:10px; flex-wrap:wrap;
}
.forge-product-price { font-size:17px; font-weight:700; color:var(--forge-accent); }
.forge-product-old-price { font-size:13px; color:var(--forge-muted); text-decoration:line-through; }
.forge-add-inquiry-btn {
  width:100%; padding:10px 16px;
  border-radius:7px; border:none;
  background:var(--forge-accent); color:#fff;
  font-size:13px; font-weight:600; cursor:pointer;
  transition:opacity .2s, background .2s;
  letter-spacing:.01em;
}
.forge-add-inquiry-btn:hover { opacity:.88; }
.forge-add-cart-lg {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 28px; background:var(--forge-accent); color:#fff;
  border:none; border-radius:8px; font-size:16px; font-weight:700;
  cursor:pointer; transition:opacity .2s; width:100%;
  letter-spacing:.01em;
}
.forge-add-cart-lg:hover { opacity:.88; }
.forge-add-cart-lg:disabled { opacity:.45; cursor:not-allowed; }

.forge-quick-view-btn {
  position:absolute; bottom:10px; left:50%;
  transform:translateX(-50%);
  background:rgba(255,255,255,.96);
  border:1px solid var(--forge-border);
  border-radius:6px; padding:6px 16px;
  font-size:12px; font-weight:600;
  white-space:nowrap; cursor:pointer;
  opacity:0; transition:opacity .18s;
  color:var(--forge-text);
}
.forge-product-card:hover .forge-quick-view-btn { opacity:1; }

/* ── Trust Bar Fixes ────────────────────────────────────────── */
.forge-trust-bar-section { background:#fff; }
.forge-trust-item { display:flex; flex-direction:column; align-items:center; text-align:center; gap:2px; }
.forge-trust-icon {
  width:52px; height:52px; border-radius:50%;
  background:rgba(var(--forge-accent-rgb),.08);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 12px;
  color:var(--forge-accent);
}

/* ── Product grid improvements ──────────────────────────────── */
.forge-product-img { aspect-ratio:1; }
.forge-product-badges { position:absolute; top:10px; left:10px; z-index:2; display:flex; flex-direction:column; gap:4px; }

/* ── Footer logo color fix ──────────────────────────────────── */
.forge-footer-logo { font-size:20px; font-weight:800; color:#fff; letter-spacing:-.02em; margin-bottom:12px; }
.forge-footer-logo em { color:var(--forge-accent); font-style:normal; }

/* ══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Header, Nav, Cart, Checkout, Footer
   ══════════════════════════════════════════════════════════════ */

/* ── Nav bar: horizontal scroll on mobile ─────────────────── */
.forge-nav-inner {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  flex-wrap: nowrap;
}
.forge-nav-inner::-webkit-scrollbar { display: none; }

/* ── Header: 2-row layout on mobile ───────────────────────── */
@media (max-width: 768px) {
  .forge-header { height: auto; padding: 10px 0; }
  .forge-header-inner { flex-wrap: wrap; gap: 8px 12px; }
  /* Search drops to a full-width second row */
  .forge-search { order: 3; flex-basis: 100%; max-width: 100%; }
  /* Nav no longer sticky (header height is dynamic on mobile) */
  .forge-nav { position: relative; top: 0; }
  /* Gallery not sticky on mobile */
  .forge-gallery { position: static !important; }
}
@media (max-width: 480px) {
  .forge-logo-text { font-size: 18px; }
  .forge-search input { font-size: 16px; } /* prevent iOS zoom */
}

/* ── Cart page layout ──────────────────────────────────────── */
.forge-cart-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 32px;
  align-items: start;
}
.forge-cart-row-inner {
  display: grid;
  grid-template-columns: 80px 1fr auto auto;
  gap: 16px;
  align-items: center;
}
@media (max-width: 768px) {
  .forge-cart-layout { grid-template-columns: 1fr; }
  .forge-cart-row-inner { grid-template-columns: 72px 1fr; gap: 12px; }
  /* Line total and qty controls stack below name on mobile */
  .forge-cart-row-inner .forge-cart-qty,
  .forge-cart-row-inner .forge-cart-total { grid-column: 2; }
}

/* ── Checkout page layout ──────────────────────────────────── */
.forge-checkout-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 32px;
  align-items: start;
}
@media (max-width: 900px) {
  .forge-checkout-layout { grid-template-columns: 1fr; }
}

/* ── Order confirm summary grid ────────────────────────────── */
.forge-order-summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  font-size: 14px;
}
@media (max-width: 480px) {
  .forge-order-summary-grid { grid-template-columns: 1fr; }
}

/* ── Footer bottom row ─────────────────────────────────────── */
@media (max-width: 480px) {
  .forge-footer-bottom {
    flex-direction: column;
    gap: 6px;
    text-align: center;
  }
}

/* ── Prevent body overflow from any edge ──────────────────── */
body { overflow-x: hidden; }


/* ── Cookie Consent Banner ──────────────────────────────────── */
.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:2000;background:var(--forge-card);border:1px solid var(--forge-border);border-radius:var(--forge-radius);box-shadow:0 4px 24px rgba(0,0,0,.12);padding:16px 20px;max-width:min(640px,calc(100vw - 32px));width:100%}
.cookie-banner.hidden{display:none}
.cookie-banner-text{font-size:13px;color:var(--forge-muted);line-height:1.6;margin-bottom:12px}
.cookie-banner-btns{display:flex;flex-wrap:wrap;gap:8px}
.cookie-btn{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:background .15s,color .15s;font-family:inherit}
.cookie-btn-prefs{background:var(--forge-bg);color:var(--forge-muted);border-color:var(--forge-border)}
.cookie-btn-reject{background:var(--forge-bg);color:var(--forge-text);border-color:var(--forge-border)}
.cookie-btn-accept{background:var(--forge-accent);color:#fff;border-color:var(--forge-accent)}
.cookie-modal-backdrop{position:fixed;inset:0;z-index:2100;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px}
.cookie-modal-backdrop.hidden{display:none}
.cookie-modal{background:var(--forge-card);border-radius:12px;padding:28px;max-width:480px;width:100%;box-shadow:0 8px 32px rgba(0,0,0,.15)}
.cookie-modal h2{font-size:18px;font-weight:700;color:var(--forge-text);margin-bottom:8px}
.modal-sub{font-size:13px;color:var(--forge-muted);line-height:1.6;margin-bottom:4px}
.cookie-modal-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--forge-border)}
.cookie-modal-label{font-size:14px;font-weight:700;color:var(--forge-text);margin-bottom:4px}
.cookie-modal-desc{font-size:12px;color:var(--forge-muted);line-height:1.5}
.cookie-modal-footer{display:flex;gap:10px;margin-top:20px;justify-content:flex-end;flex-wrap:wrap}
.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--forge-border);border-radius:22px;transition:background .2s}
.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}
.toggle-switch input:checked+.toggle-slider{background:var(--forge-accent)}
.toggle-switch input:checked+.toggle-slider:before{transform:translateX(18px)}
.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}

/* ── Article body (news module fallback view) ── */
.article-body{font-size:16px;line-height:1.75;color:var(--forge-text)}
.article-body h2{font-size:26px;font-weight:800;margin:32px 0 12px;color:var(--forge-text)}
.article-body h3{font-size:21px;font-weight:700;margin:24px 0 10px;color:var(--forge-text)}
.article-body p{margin-bottom:18px}
.article-body ul,.article-body ol{margin:0 0 18px 22px}
.article-body li{margin-bottom:6px}
.article-body blockquote{border-left:4px solid var(--forge-accent);margin:24px 0;padding:14px 18px;background:var(--forge-bg-alt);border-radius:0 var(--forge-radius-sm) var(--forge-radius-sm) 0;font-style:italic;color:var(--forge-muted)}
.article-body img{width:100%;border-radius:var(--forge-radius);margin:20px 0}
.article-body table{width:100%;border-collapse:collapse;margin-bottom:20px;font-size:14px}
.article-body th{background:var(--forge-bg-alt);font-weight:700;text-align:left;padding:10px 12px;border:1px solid var(--forge-border)}
.article-body td{padding:9px 12px;border:1px solid var(--forge-border)}
.article-body tr:nth-child(even) td{background:var(--forge-bg-alt)}
.article-body a{color:var(--forge-accent);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{opacity:.8}

/* ── Newsletter strip widget (above_footer zone) ── */
.newsletter-section{background:var(--forge-text);padding:48px 0;margin:48px 0 0}
.newsletter-section .forge-container,.newsletter-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.newsletter-inner{display:flex;align-items:center;justify-content:space-between;gap:40px}
.newsletter-copy{flex:1;min-width:0}
.newsletter-heading{font-size:26px;font-weight:800;color:#fff;margin:0 0 6px}
.newsletter-sub{font-size:14px;color:rgba(255,255,255,.65);line-height:1.6;margin:0}
.newsletter-form{flex-shrink:0;width:360px}
.newsletter-field-wrap{display:flex;gap:8px}
.newsletter-field-wrap input{flex:1;padding:11px 14px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:var(--forge-radius-sm);color:#fff;font-size:14px;font-family:inherit;outline:none;min-width:0}
.newsletter-field-wrap input::placeholder{color:rgba(255,255,255,.4)}
.newsletter-field-wrap input:focus{border-color:var(--forge-accent)}
.newsletter-field-wrap button,.newsletter-btn{background:var(--forge-accent);color:#fff;border:none;border-radius:var(--forge-radius-sm);padding:11px 22px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}
.newsletter-field-wrap button:hover,.newsletter-btn:hover{opacity:.88}
.newsletter-msg{margin-top:8px;font-size:12px;color:rgba(255,255,255,.7)}
@media (max-width:720px){.newsletter-inner{flex-direction:column;align-items:flex-start}.newsletter-form{width:100%}}

.forge-brand-card{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.forge-brand-card:hover{transform:translateY(-4px);box-shadow:0 8px 22px rgba(0,0,0,.10);border-color:var(--forge-accent)}
.forge-brand-card:hover img{opacity:1 !important}
.forge-brand-card:active{transform:translateY(-1px)}

.forge-action-wrap{position:relative}
.forge-mini{position:absolute;top:100%;right:0;margin-top:10px;width:330px;background:var(--forge-card,#fff);border:1px solid var(--forge-border);border-radius:14px;box-shadow:0 18px 48px rgba(0,0,0,.16);padding:14px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:300}
.forge-action-wrap:hover .forge-mini{opacity:1;visibility:visible;transform:translateY(0)}
.forge-mini::before{content:'';position:absolute;bottom:100%;left:0;right:0;height:12px}
.forge-mini-title{font-size:13px;font-weight:600;color:var(--forge-text);margin-bottom:10px}
.forge-mini-items{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto}
.forge-mini-item{display:flex;gap:10px;align-items:center;text-decoration:none;padding:6px;border-radius:9px;transition:background .15s}
.forge-mini-item:hover{background:var(--forge-bg)}
.forge-mini-item img{width:46px;height:46px;object-fit:cover;border-radius:8px;border:1px solid var(--forge-border);background:#fff;flex-shrink:0}
.forge-mini-item-info{min-width:0;flex:1}
.forge-mini-item-name{font-size:13px;color:var(--forge-text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.forge-mini-item-meta{font-size:12px;color:var(--forge-muted);margin-top:2px}
.forge-mini-empty{font-size:13px;color:var(--forge-muted);text-align:center;padding:18px 0}
.forge-mini-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--forge-border);font-size:13px;color:var(--forge-muted)}
.forge-mini-foot strong{color:var(--forge-text);font-size:16px}
.forge-mini-actions{display:flex;gap:8px;margin-top:12px}
.forge-mini-btn{flex:1;text-align:center;padding:10px;border-radius:9px;font-size:13px;font-weight:600;text-decoration:none;border:1px solid var(--forge-border);color:var(--forge-text);transition:all .15s}
.forge-mini-btn:hover{background:var(--forge-bg)}
.forge-mini-btn-primary{background:var(--forge-accent);color:#fff;border-color:var(--forge-accent)}
.forge-mini-btn-primary:hover{background:var(--forge-accent);color:#fff;filter:brightness(1.08)}
@media (max-width:900px){.forge-mini{display:none !important}}

/* cart layout + mobile (image-left, qty+total on one row) */
.forge-cart-grid{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start}
.forge-cart-row{display:grid;grid-template-columns:80px 1fr auto auto;gap:16px;align-items:center;padding:20px 0;border-bottom:1px solid var(--forge-border)}
@media (max-width:760px){
  .forge-cart-grid{grid-template-columns:1fr;gap:24px}
  .forge-cart-grid > div:last-child{position:static !important}
}
@media (max-width:520px){
  .forge-page-wrap{padding:0 14px !important}
  .forge-cart-row{grid-template-columns:80px 1fr;grid-template-areas:"img info" "img controls";column-gap:14px;row-gap:10px;align-items:start;padding:16px 0}
  .forge-cart-row > *:nth-child(1){grid-area:img}
  .forge-cart-row > *:nth-child(2){grid-area:info;min-width:0}
  .forge-cart-row > *:nth-child(3){grid-area:controls;justify-self:start;align-self:center}
  .forge-cart-row > *:nth-child(4){grid-area:controls;justify-self:end;align-self:center}
}

@media (max-width:640px){.forge-brand-strip{grid-template-columns:repeat(2,1fr) !important}}

/* Stretched-link product cards: whole card is one valid <a>; action buttons layered above */
.forge-product-card{position:relative}
.forge-card-link{position:absolute;inset:0;z-index:1;font-size:0;text-decoration:none}
.forge-product-card .forge-quick-view-btn,.forge-product-card .forge-wishlist-btn{z-index:2}
.forge-product-card .forge-add-inquiry-btn,.forge-product-card .forge-compare-btn{position:relative;z-index:2}

/* Hide Quick View on touch/mobile — tap navigates straight to the product */
@media (hover: none), (max-width: 768px){.forge-quick-view-btn{display:none !important}}

/* Subcategory drill-down links in the category filter sidebar */
.forge-subcat-link{display:block;padding:6px 0;color:var(--forge-text);text-decoration:none;font-size:14px;transition:color .15s}
.forge-subcat-link:hover{color:var(--forge-accent)}

/* Category cards — Option A: clean image + caption below (no gradient overlay) */
.forge-cat-card{position:relative;aspect-ratio:auto;background:var(--forge-card);border:1px solid var(--forge-border);border-radius:var(--forge-radius-lg);overflow:hidden;display:block;box-shadow:none;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.forge-cat-card:hover{transform:translateY(-4px);box-shadow:var(--forge-shadow-lg)}
.forge-cat-card-img{position:relative;inset:auto;aspect-ratio:4/3;background:#f1efe8;overflow:hidden;display:flex;align-items:center;justify-content:center}
.forge-cat-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.forge-cat-card:hover .forge-cat-card-img img{transform:scale(1.05)}
.forge-cat-card::after{display:none !important;content:none !important}
.forge-cat-card-info{position:static;inset:auto;padding:13px 16px;display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.forge-cat-name{font-size:15px;font-weight:600;color:var(--forge-text);transition:color .15s}
.forge-cat-card:hover .forge-cat-name{color:var(--forge-accent)}
.forge-cat-count{display:inline;color:var(--forge-muted);font-size:12px;font-weight:500;flex-shrink:0}

/* Cart/wishlist mini action buttons — fit longer (Macedonian) labels on one line */
.forge-mini-actions{align-items:stretch}
.forge-mini-btn{white-space:nowrap;font-size:12px;padding:10px 6px;display:flex;align-items:center;justify-content:center}

/* TASK1 mobile category cards: stack name+count centered */
@media (max-width:600px){.forge-cat-card-info{flex-direction:column;align-items:center;text-align:center;gap:2px}.forge-cat-count{flex-shrink:1}}
/* TASK2 mobile filter close button */
.forge-filter-close{display:none;position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;border:1px solid var(--forge-border);background:var(--forge-card);color:var(--forge-text);font-size:24px;line-height:1;align-items:center;justify-content:center;cursor:pointer;z-index:6;padding:0}
.forge-sidebar-open .forge-filter-close{display:flex}

/* Listing/category/brand pages: proper container + overflow guard (was edge-to-edge -> mobile horizontal overflow) */
.forge-listing-wrap{max-width:1280px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px;overflow-x:clip}
@media (max-width:480px){.forge-listing-wrap{padding-left:16px;padding-right:16px}}

/* OVERFLOW FIX v2 (sort-bar/select min-width): listing main is a grid 1fr track
   (min-width:auto) and could not shrink below the sort-bar's longest <select>
   option, pushing the whole column past the mobile viewport. Break the
   min-width:auto chain + let the toolbar reflow. */
.forge-listing-main{min-width:0}
.forge-product-grid{min-width:0}
.forge-product-card{min-width:0}
@media (max-width:1024px){
  .forge-sort-bar{flex-wrap:wrap}
  .forge-sort-right{flex-wrap:wrap;justify-content:flex-end}
  .forge-sort-select{max-width:100%;min-width:0;text-overflow:ellipsis}
}
