:root {
  --red: #e2001a; --red-dark: #c00016; --red-light: #fef2f2;
  --red-glow: rgba(226,0,26,0.08);
  --green: #16a34a; --green-light: #f0fdf4;
  --orange: #ea580c; --orange-light: #fff7ed;
  --g0: #fff; --g50: #f9fafb; --g100: #f3f4f6; --g200: #e5e7eb;
  --g300: #d1d5db; --g400: #9ca3af; --g500: #6b7280; --g600: #4b5563;
  --g700: #374151; --g800: #1f2937; --g900: #111827;
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.08), 0 2px 4px -1px rgba(0,0,0,0.04);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -2px rgba(0,0,0,0.03);
  --r: 10px; --r-lg: 14px;
  --max-w: 1400px;
  --t: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden;width:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--g50);color:var(--g900);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden;width:100%;max-width:100vw}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}

/* === TOPBAR === */
.topbar{background:var(--g900);color:var(--g400);font-size:12px;padding:7px 0}
.topbar .inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:20px}
.topbar a{color:var(--g400);transition:color var(--t)}
.topbar a:hover{color:#fff}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:16px}
.lang-sw{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border:1px solid var(--g700);border-radius:4px;font-size:11px;color:var(--g300);cursor:pointer;transition:all var(--t)}
.lang-sw:hover{border-color:var(--g500);color:#fff}

/* === HEADER === */
.header{background:var(--g0);position:sticky;top:0;z-index:100;box-shadow:0 1px 0 var(--g200);transition:box-shadow var(--t)}
.header.scrolled{box-shadow:var(--shadow-md)}
.header .inner{max-width:var(--max-w);margin:0 auto;padding:12px 24px;display:flex;align-items:center;gap:20px}
.logo-img{height:42px;cursor:pointer;transition:opacity var(--t)}
.logo-img:hover{opacity:0.85}

/* Mega Menu Trigger */
.mega-wrap{position:relative}
.mega-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;background:var(--red);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;transition:all var(--t);white-space:nowrap;height:44px;box-sizing:border-box}
.mega-btn:hover{background:var(--red-dark)}
.mega-btn .ham{display:flex;flex-direction:column;gap:3px}
.mega-btn .ham span{display:block;width:16px;height:2px;background:#fff;border-radius:1px;transition:all .3s}
.mega-btn.open .ham span:nth-child(1){transform:rotate(45deg) translate(3px,4px)}
.mega-btn.open .ham span:nth-child(2){opacity:0}
.mega-btn.open .ham span:nth-child(3){transform:rotate(-45deg) translate(3px,-4px)}
.mega-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:90;opacity:0;pointer-events:none;transition:opacity .25s}
.mega-overlay.show{opacity:1;pointer-events:auto}
.mega-dd{position:absolute;top:calc(100% + 8px);left:0;background:var(--g0);border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.05);padding:24px 28px;z-index:200;min-width:700px;opacity:0;transform:translateY(-8px);pointer-events:none;transition:all .25s cubic-bezier(.4,0,.2,1)}
.mega-dd.show{opacity:1;transform:translateY(0);pointer-events:auto}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.mega-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;cursor:pointer;transition:all var(--t);color:var(--g700)}
.mega-item:hover{background:var(--red-light);color:var(--red)}
.mi-icon{width:40px;height:40px;border-radius:10px;background:var(--g50);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--g500);transition:all var(--t);flex-shrink:0}
.mi-icon img{transition:filter var(--t)}
.mega-item:hover .mi-icon{background:var(--red)}
.mega-item:hover .mi-icon img{filter:brightness(0) invert(1)}
.mi-text h4{font-size:13px;font-weight:600;line-height:1.2;margin-bottom:1px}
.mi-text .mi-cnt{font-size:11px;color:var(--g400)}
.mega-item:hover .mi-cnt{color:var(--red);opacity:.6}

/* Search */
.search-box{flex:1;max-width:600px;position:relative;margin:0 auto}
.search-box input{width:100%;padding:11px 48px 11px 16px;border:2px solid var(--g200);border-radius:var(--r);font-size:14px;outline:none;background:var(--g50);transition:all var(--t);height:44px;box-sizing:border-box}
.search-box input:focus{border-color:var(--red);background:var(--g0);box-shadow:0 0 0 4px var(--red-glow)}
.search-box input::placeholder{color:var(--g400)}
.search-box .sbtn{position:absolute;right:6px;top:6px;bottom:6px;width:38px;border:none;background:var(--red);color:#fff;border-radius:7px;font-size:14px;transition:background var(--t)}
.search-box .sbtn:hover{background:var(--red-dark)}

/* Search suggest dropdown */
.search-suggest{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--g0);border:1.5px solid var(--g200);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:9999;max-height:480px;overflow-y:auto;overflow-x:hidden}
.ss-section{padding:8px 14px 4px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--g400);border-top:1px solid var(--g100)}
.ss-section:first-child{border-top:none}
.ss-item{display:flex;align-items:center;gap:9px;padding:7px 14px;cursor:pointer;transition:background .12s;border-radius:0}
.ss-item:hover{background:var(--g50)}
.ss-item:active{background:var(--g100)}
.ss-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--g400)}
.ss-icon img{width:16px;height:16px;object-fit:contain;opacity:.75}
.ss-thumb{width:34px;height:34px;flex-shrink:0;border-radius:6px;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;border:1px solid var(--g100)}
.ss-thumb img{width:34px;height:34px;object-fit:contain}
.ss-thumb-ph{color:var(--g300);font-size:14px}
.ss-label{flex:1;font-size:13px;color:var(--g800);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ss-sub{font-size:11px;color:var(--g400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;flex-shrink:0}
.ss-cnt{font-size:11px;color:var(--g400);flex-shrink:0;white-space:nowrap}
.ss-all{padding:9px 14px;font-size:12px;font-weight:600;color:var(--red);cursor:pointer;text-align:center;border-top:1px solid var(--g100);transition:background .12s}
.ss-all:hover{background:var(--g50)}
.ss-empty{padding:14px;text-align:center;font-size:13px;color:var(--g400)}
.ss-loading{padding:14px;text-align:center;color:var(--g400);font-size:13px}

/* Header nav & right */
.header-nav{display:flex;align-items:center;gap:2px;margin-left:8px}
.header-nav a{padding:8px 12px;font-size:13px;font-weight:500;color:var(--g600);border-radius:7px;transition:all var(--t)}
.header-nav a:hover{background:var(--g100);color:var(--g900)}
.header-right{margin-left:auto;display:flex;align-items:center;gap:6px}
.hdr-btn{display:inline-flex;align-items:center;gap:7px;padding:0 16px;height:44px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:13px;font-weight:500;color:var(--g700);background:var(--g0);transition:all var(--t);box-sizing:border-box}
.hdr-btn:hover{border-color:var(--red);color:var(--red)}
.hdr-btn i{font-size:15px}
.hdr-btn.primary{background:var(--red);color:#fff;border-color:var(--red)}
.hdr-btn.primary:hover{background:var(--red-dark);border-color:var(--red-dark)}
.cart-badge{background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;margin-left:2px;display:none}

/* === BREADCRUMB === */
.breadcrumb-bar{background:var(--g0);border-bottom:1px solid var(--g100);padding:11px 0;font-size:13px}
.breadcrumb-bar .inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.breadcrumb-bar a{color:var(--g500);transition:color var(--t)}
.breadcrumb-bar a:hover{color:var(--red)}
.breadcrumb-bar .sep{color:var(--g300);font-size:10px}
.breadcrumb-bar .cur{color:var(--g800);font-weight:500}

/* === MAIN === */
.main-layout{max-width:var(--max-w);margin:0 auto;padding:24px;display:grid;grid-template-columns:300px 1fr;gap:24px;min-height:70vh}
.content-area{min-width:0;overflow:hidden}

/* === SIDEBAR === */
.sidebar-card{background:var(--g0);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;position:sticky;top:80px}
.sidebar-title{padding:16px 18px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--g500);border-bottom:1px solid var(--g100)}
.sidebar-search{padding:12px 14px;border-bottom:1px solid var(--g100);position:relative}
.sidebar-search input{width:100%;padding:9px 12px 9px 36px;border:1.5px solid var(--g200);border-radius:8px;font-size:13px;outline:none;background:var(--g50);transition:all var(--t)}
.sidebar-search input:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow);background:var(--g0)}
.sidebar-search i{position:absolute;left:26px;top:50%;transform:translateY(-50%);color:var(--g400);font-size:13px}
.cat-list{max-height:60vh;overflow-y:auto;padding:6px 0}
.cat-list::-webkit-scrollbar{width:4px}
.cat-list::-webkit-scrollbar-thumb{background:var(--g300);border-radius:4px}
.cat-item{display:flex;align-items:center;gap:8px;padding:9px 18px;font-size:13px;color:var(--g600);cursor:pointer;transition:all var(--t);border-left:3px solid transparent}
.cat-item:hover{background:var(--g50);color:var(--g900)}
.cat-item.active{background:var(--red-light);color:var(--red);font-weight:600;border-left-color:var(--red)}
.cat-item .cnt{display:none}
.cat-item.active .cnt{display:none}
.cat-sub{border-left:2px solid var(--g150,#e5e7eb);margin-left:29px}
.cat-sub .cat-item{padding-left:16px;font-size:12.5px;border-left:none}
.cat-sub .cat-item.active{border-left:none;background:var(--red-light);color:var(--red)}
/* Level-1 (nested) subcategory in sidebar */
.cat-sub .cat-item.cat-child{padding-left:46px;font-size:12px;color:var(--g500)}
.cat-sub .cat-item.cat-child::before{content:'↳';margin-right:5px;color:var(--g300);font-size:10px}
.cat-sub .cat-item.cat-child.active::before{color:var(--red);opacity:.6}
/* Typ Produktu tree */
.typ-tree-toggle{display:flex;border-bottom:1px solid var(--g100);background:var(--g50)}
.typ-tree-toggle button{flex:1;padding:7px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:none;background:transparent;cursor:pointer;color:var(--g400);transition:all var(--t)}
.typ-tree-toggle button.active{background:var(--g0);color:var(--red);box-shadow:inset 0 -2px 0 var(--red)}
/* Level 0 — top nodes */
.typ-node{display:flex;align-items:center;gap:5px;padding:6px 10px 6px 12px;font-size:12px;font-weight:500;color:var(--g700);cursor:pointer;transition:background var(--t),color var(--t);border-left:2px solid transparent;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.typ-node-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity var(--t)}
.typ-node-icon img{width:18px;height:18px;object-fit:contain;filter:grayscale(30%);transition:filter var(--t)}
.typ-node-top{padding-left:10px;font-size:12.5px;font-weight:600}
.typ-node-top:hover .typ-node-icon,.typ-node-top.active .typ-node-icon{opacity:1}
.typ-node-top:hover .typ-node-icon img{filter:none}
.typ-node-top.active .typ-node-icon img{filter:brightness(0) saturate(100%) invert(20%) sepia(90%) saturate(700%) hue-rotate(340deg)}
.typ-node:hover{background:var(--g50);color:var(--g900)}
.typ-node.active{background:var(--red-light);color:var(--red);font-weight:600;border-left-color:var(--red)}
.typ-node .typ-lbl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.typ-node .typ-arrow{font-size:8px;color:var(--g300);flex-shrink:0;transition:transform .18s;margin-left:2px}
.typ-node.open>.typ-arrow{transform:rotate(90deg)}
/* Children container — indented line */
.typ-children{display:none}
.typ-children.open{display:block}
/* Level 1 */
.typ-children>.typ-node{font-size:11.5px;font-weight:400;color:var(--g600);padding-left:20px;border-left:none;padding-top:5px;padding-bottom:5px}
.typ-children>.typ-node::before{content:'';display:inline-block;width:10px;height:1px;background:var(--g200);margin-right:5px;flex-shrink:0;vertical-align:middle}
/* Level 2 */
.typ-children>.typ-children>.typ-node{font-size:11px;color:var(--g500);padding-left:28px;padding-top:4px;padding-bottom:4px}
.typ-children>.typ-children>.typ-node::before{width:8px;background:var(--g150)}
/* Level 3+ */
.typ-children>.typ-children>.typ-children>.typ-node{font-size:10.5px;color:var(--g400);padding-left:36px;padding-top:3px;padding-bottom:3px}
.typ-children>.typ-children>.typ-children>.typ-node::before{width:6px}

/* === CATEGORY CARDS === */
.page-title{font-size:24px;font-weight:700;margin-bottom:4px;letter-spacing:-.02em}
.page-subtitle{font-size:14px;color:var(--g500);margin-bottom:20px}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.cat-card{background:var(--g0);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-xs);border:1.5px solid var(--g100);cursor:pointer;transition:all var(--t);display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}
.cat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transition:transform .3s;transform-origin:left}
.cat-card:hover::before{transform:scaleX(1)}
.cat-card:hover{border-color:var(--red);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.cc-icon{width:40px;height:40px;border-radius:10px;background:var(--g50);display:flex;align-items:center;justify-content:center;font-size:17px;transition:all var(--t)}
.cat-card:hover .cc-icon{background:var(--red)}
.cat-card:hover .cc-icon img{filter:brightness(0) invert(1)}
.cat-card h3{font-size:14px;font-weight:600;line-height:1.3}
.cat-card .cc-count{font-size:12px;color:var(--g500)}
.cat-card .cc-arrow{position:absolute;right:18px;top:50%;transform:translateY(-50%);color:var(--g300);transition:all var(--t);font-size:14px}
.cat-card:hover .cc-arrow{color:var(--red);right:14px}
/* Nested section: level-0 parent becomes a section header spanning full width */
.cat-section{grid-column:1/-1;border:1.5px solid var(--g100);border-radius:var(--r-lg);overflow:hidden;background:var(--g0);box-shadow:var(--shadow-xs)}
.cat-section-hdr{display:flex;align-items:center;gap:12px;padding:14px 20px;cursor:pointer;background:var(--g50);border-bottom:1.5px solid var(--g100);transition:background var(--t)}
.cat-section-hdr:hover{background:var(--g100)}
.cat-section-hdr h3{font-size:14px;font-weight:700;flex:1}
.cat-section-hdr .cc-count{font-size:12px;color:var(--g500)}
.cat-section-hdr i{color:var(--g300);font-size:12px;transition:color var(--t)}
.cat-section-hdr:hover i{color:var(--red)}
.cat-section-body{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;padding:12px}
.cat-card-sm{padding:14px;min-height:auto}
.cat-card-sm h3{font-size:13px}

/* === ATTR FILTERS — 50/50 row layout === */
.attr-filters{background:var(--g0);border:1px solid var(--g200);border-bottom:none;border-radius:var(--r-lg) var(--r-lg) 0 0;overflow:hidden}
.attr-filters-hdr{display:flex;align-items:center;gap:8px;padding:10px 18px;cursor:pointer;background:var(--g50);border-bottom:1px solid var(--g200);font-size:13px;font-weight:600;color:var(--g700);user-select:none}
.attr-filters-hdr:hover{background:var(--g100)}
.attr-filters-hdr .af-badge{background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px}
.attr-filters-body{display:none;border-bottom:1px solid var(--g200)}
.attr-filters-body.open{display:block}
/* Each filter row: 50% label | 50% value */
.af-row{display:flex;align-items:flex-start;border-bottom:1px solid var(--g100);min-height:40px}
.af-row:last-child{border-bottom:none}
.af-row-label{width:50%;padding:9px 16px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--g500);display:flex;align-items:center;flex-wrap:wrap;gap:3px;border-right:1px solid var(--g100);box-sizing:border-box;flex-shrink:0}
.af-row-label.active{color:var(--red)}
.af-unit{font-size:9.5px;font-weight:400;color:var(--g400);letter-spacing:0}
.af-row-value{width:50%;padding:7px 12px;box-sizing:border-box;min-width:0}
/* Chips */
.af-chips{display:flex;flex-wrap:wrap;gap:3px}
.af-chips-wrap{overflow:hidden;max-height:56px;transition:max-height .22s ease}
.af-chips-wrap.af-expanded{max-height:600px}
.af-chip{padding:3px 10px;border-radius:20px;border:1.5px solid var(--g200);font-size:11.5px;cursor:pointer;transition:all .15s;color:var(--g600);background:var(--g0);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:inline-block}
.af-chip:hover{border-color:var(--red);color:var(--red)}
.af-chip.active{background:var(--red);border-color:var(--red);color:#fff;font-weight:600}
.af-more-btn{display:inline-block;margin-top:3px;font-size:11px;color:var(--red);cursor:pointer;border:none;background:none;padding:0;font-family:inherit;font-weight:500}
.af-more-btn:hover{text-decoration:underline}
.af-group-cnt{font-size:10px;color:var(--g400);font-weight:400;margin-left:auto}
/* Range — single input field */
.af-range-wrap{display:flex;align-items:center;gap:6px}
.af-range-input{width:100%;padding:5px 9px;border:1.5px solid var(--g200);border-radius:7px;font-size:12px;color:var(--g700);outline:none;transition:border-color .15s;font-family:inherit}
.af-range-input:focus{border-color:var(--red)}
.af-range-input.active{border-color:var(--red);background:var(--red-light)}
.af-range-hint{font-size:10px;color:var(--g300);white-space:nowrap;flex-shrink:0}
.af-reset{font-size:12px;color:var(--red);cursor:pointer;font-weight:500;white-space:nowrap;padding:2px 6px;border-radius:4px;transition:background .15s;margin-left:auto}
.af-reset:hover{background:var(--red-light)}
/* === FILTER BAR === */
.filter-bar{background:var(--g0);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:14px 20px;box-shadow:var(--shadow-xs);border:1px solid var(--g100);border-bottom:2px solid var(--red);display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.attr-filters+.filter-bar{border-radius:0;border-top:none}
.filter-bar .rc{font-size:14px;font-weight:600;color:var(--g800)}
.filter-bar .rc span{color:var(--red)}
.sort-wrap{margin-left:auto;display:flex;align-items:center;gap:8px}
.sort-wrap label{font-size:12px;color:var(--g500);white-space:nowrap}
.sort-sel{padding:7px 12px;border:1.5px solid var(--g200);border-radius:8px;font-size:13px;background:var(--g0);outline:none;color:var(--g700)}

/* === PRODUCT CARD (parent grouping) === */
.product-list{border-left:1px solid var(--g100);border-right:1px solid var(--g100);background:var(--g0)}
.product-card{padding:20px 24px;border-bottom:1px solid var(--g100);transition:background var(--t)}
.product-card:last-child{border-radius:0 0 var(--r-lg) var(--r-lg)}

/* Product header */
.pc-top{display:flex;gap:20px;align-items:flex-start}
.pc-img{width:100px;height:80px;flex-shrink:0;background:#fff;border:1px solid var(--g200);border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;transition:border-color var(--t)}
.pc-img:hover{border-color:var(--red)}
.pc-img img{max-width:90%;max-height:90%;object-fit:contain}
.pc-info{flex:1;min-width:0}
.pc-name{font-size:15px;font-weight:600;color:var(--g900);line-height:1.35;margin-bottom:6px;cursor:pointer;transition:color var(--t);display:block;text-decoration:none}
.pc-name:hover{color:var(--red)}
.pc-specs{font-size:12px;color:var(--g500);line-height:1.5}
.pc-specs strong{color:var(--g700);font-weight:500}
.pc-specs .dot{margin:0 6px;color:var(--g300)}
.pc-badge{display:inline-flex;align-items:center;gap:4px;margin-top:8px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#f0f4ff;color:#3b5bdb}

/* === VARIANT TABLE (matching the reference design) === */
.vt-section{margin-top:16px;background:var(--g0);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:16px}
.vt-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:2px solid var(--red);margin-bottom:0}
.vt-header h3{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;margin:0}
.vt-header h3::before{content:'';width:3px;height:18px;background:var(--red);border-radius:2px}
.vt-header .vt-count{font-size:13px;font-weight:400;color:var(--g500)}
.vt-filter-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--g200);border-radius:8px;background:var(--g0);font-size:12px;font-weight:500;color:var(--g600);transition:all var(--t)}
.vt-filter-btn:hover,.vt-filter-btn.active{border-color:var(--red);color:var(--red);background:var(--red-light)}
.vt-toolbar{display:flex;align-items:center;gap:10px;padding:10px 0;flex-wrap:wrap}
.vt-search{position:relative;flex:1;max-width:320px}
.vt-search input{width:100%;padding:9px 12px 9px 36px;border:1.5px solid var(--g200);border-radius:8px;font-size:13px;outline:none;transition:all var(--t)}
.vt-search input:focus{border-color:var(--red)}
.vt-search i{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--g400);font-size:12px}

/* Cart drawer */
.cart-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:500;opacity:0;pointer-events:none;transition:opacity .3s}
.cart-drawer-overlay.show{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;top:0;width:440px;height:100vh;height:100dvh;background:var(--g0);z-index:501;box-shadow:-10px 0 40px rgba(0,0,0,.15);display:flex;flex-direction:column;transition:right .35s cubic-bezier(.4,0,.2,1);right:-460px}
.cart-drawer.show{right:0}
.cd-header{padding:20px 24px;border-bottom:1px solid var(--g100);display:flex;align-items:center;justify-content:space-between}
.cd-header h2{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}
.cd-header .cd-close{width:36px;height:36px;border-radius:10px;border:none;background:var(--g100);color:var(--g600);font-size:14px;transition:all var(--t)}
.cd-header .cd-close:hover{background:var(--red);color:#fff}
.cd-items{flex:1;overflow-y:auto;padding:16px 24px}
.cd-empty{text-align:center;padding:40px 20px;color:var(--g400)}
.cd-empty i{font-size:40px;display:block;margin-bottom:12px;opacity:.3}
.cd-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--g100);align-items:center}
.cd-item .cd-info{flex:1;min-width:0}
.cd-item .cd-sku{font-size:11px;color:var(--red);font-weight:600;font-family:monospace}
.cd-item .cd-name{font-size:13px;font-weight:500;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cd-item .cd-qty{font-size:12px;color:var(--g500)}
.cd-item .cd-price{font-size:14px;font-weight:700;white-space:nowrap}
.cd-item .cd-remove{width:28px;height:28px;border-radius:6px;border:none;background:var(--g100);color:var(--g500);font-size:12px;transition:all var(--t);flex-shrink:0}
.cd-item .cd-remove:hover{background:var(--red-light);color:var(--red)}
.cd-footer{padding:20px 24px;border-top:1px solid var(--g100);background:var(--g50)}
.cd-total{display:flex;justify-content:space-between;font-size:16px;font-weight:700;margin-bottom:16px}
.cd-total .cd-total-label{color:var(--g600)}
.cd-total .cd-total-val{color:var(--g900)}
.cd-form label{display:block;font-size:12px;font-weight:600;color:var(--g600);margin-bottom:4px;margin-top:12px}
.cd-form input,.cd-form textarea{width:100%;padding:9px 12px;border:1.5px solid var(--g200);border-radius:8px;font-size:13px;outline:none;resize:vertical;transition:border-color var(--t)}
.cd-form input:focus,.cd-form textarea:focus{border-color:var(--red)}
.cd-form textarea{min-height:60px}
.cd-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.cd-submit{width:100%;padding:14px;color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:700;transition:background var(--t);display:flex;align-items:center;justify-content:center;gap:8px}
.cd-submit.order{background:var(--red)}
.cd-submit.order:hover{background:var(--red-dark)}
.cd-submit.enquiry{background:var(--g800)}
.cd-submit.enquiry:hover{background:var(--g900)}
.cd-divider{text-align:center;font-size:11px;color:var(--g400);text-transform:uppercase;letter-spacing:.1em;position:relative;margin:4px 0}
.cd-divider::before,.cd-divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:var(--g200)}
.cd-divider::before{left:0}
.cd-divider::after{right:0}
.cd-type-tag{display:inline-block;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px;margin-left:6px}
.cd-type-tag.order{background:var(--green-light);color:var(--green)}
.cd-type-tag.enquiry{background:var(--orange-light);color:var(--orange)}

.vt-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:0}
.vt-table thead th{padding:10px 12px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--red);border-bottom:1px solid var(--g200);background:var(--g50);cursor:pointer;user-select:none;white-space:nowrap;transition:color var(--t)}
.vt-table thead th .sort-ico{margin-left:3px;font-size:8px;opacity:.4}
.vt-table thead th:hover{color:var(--red-dark)}
.vt-table tbody tr{border-bottom:1px solid var(--g100);transition:background var(--t);height:44px}
.vt-table tbody tr:hover{background:var(--g50)}
.vt-table td{padding:0 8px;vertical-align:middle;white-space:nowrap}

.td-sku{font-family:'SF Mono','Fira Code',monospace;font-size:11px;color:var(--g700);font-weight:500;white-space:nowrap}
.td-name{font-size:11px;color:var(--g600);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Name column: absorbs all remaining space */
.td-sku-name{width:100%;min-width:140px}
.td-sku-code{font-family:'SF Mono','Fira Code',monospace;font-size:11px;color:var(--red);font-weight:600;display:block;white-space:nowrap}
.td-name-desc{font-size:11px;color:var(--g600);white-space:normal;word-break:break-word;line-height:1.4;max-width:360px}
/* Compact columns: collapse to content width, right-aligned */
.td-spec{width:1px;text-align:right;padding:0 6px;font-weight:600;font-size:12px;color:var(--g800);white-space:nowrap}
.td-spec small{font-weight:400;color:var(--g500);margin-left:1px}
.td-avail-cell{width:1px;padding:0 6px;text-align:right;white-space:nowrap;vertical-align:middle}
/* compact th headers */
.vt-table thead th.th-c{width:1px;text-align:left;padding-left:4px;padding-right:6px}

/* Availability badge */
.avail-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:5px;font-size:10px;font-weight:600;white-space:nowrap}
.avail-badge.in-stock{background:var(--green-light);color:var(--green)}
.avail-badge.on-request{background:var(--g100);color:var(--g500)}
.avail-badge.out-stock{background:var(--red-light);color:var(--red)}
.avail-badge .adot{width:6px;height:6px;border-radius:50%}
.avail-badge.in-stock .adot{background:var(--green)}
.avail-badge.on-request .adot{background:var(--g400)}
.avail-badge.out-stock .adot{background:var(--red)}

/* Price */
.td-price{width:1px;text-align:right;padding:0 8px;white-space:nowrap;vertical-align:middle}
.td-price .amount{font-weight:700;font-size:14px;color:var(--g900);white-space:nowrap}
.td-price .sub{font-size:9px;color:var(--g400);font-weight:400;white-space:nowrap}
.price-on-req{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:5px;font-size:10px;font-weight:600;white-space:nowrap;background:var(--g100);color:var(--g500)}
.price-on-req .adot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.td-qty{width:1px;vertical-align:middle;white-space:nowrap;padding:0 6px}

/* Qty stepper */
.qty-stepper{display:inline-flex;align-items:center;border:1.5px solid var(--g200);border-radius:6px;overflow:hidden}
.qty-stepper button{width:28px;height:30px;border:none;background:var(--g50);color:var(--g600);font-size:13px;transition:all var(--t);display:flex;align-items:center;justify-content:center}
.qty-stepper button:hover{background:var(--g200);color:var(--red)}
.qty-stepper input{width:38px;height:30px;border:none;border-left:1px solid var(--g200);border-right:1px solid var(--g200);text-align:center;font-size:12px;font-weight:500;outline:none}
.qty-stepper input:focus{background:var(--red-light)}
.qty-stepper input::-webkit-outer-spin-button,.qty-stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.qty-stepper input[type=number]{-moz-appearance:textfield}

/* Action buttons */
.td-actions{width:1px;white-space:nowrap;vertical-align:middle;text-align:right;padding:0 8px 0 4px}
.td-actions .btn-icon,.td-actions a.btn-icon{vertical-align:middle;margin-left:4px}
.td-actions .btn-cart{vertical-align:middle;margin-left:4px;width:162px}
.btn-cart{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:0 10px;height:30px;width:162px;background:var(--red);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:600;transition:all var(--t);white-space:nowrap;box-sizing:border-box}
.btn-cart:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(226,0,26,.25)}
.btn-cart.btn-cart-enq{background:transparent;color:var(--red);border:1.5px solid var(--red)}
.btn-cart.btn-cart-enq:hover{background:var(--red-light,#fff0f2);box-shadow:none;transform:none}
.btn-enq{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;background:var(--g0);color:var(--g600);border:1.5px solid var(--g200);border-radius:7px;font-size:12px;font-weight:500;transition:all var(--t);margin-left:6px}
.btn-enq:hover{border-color:var(--red);color:var(--red)}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;gap:4px;height:30px;width:30px;background:var(--g0);color:var(--g500);border:1.5px solid var(--g200);border-radius:6px;font-size:12px;transition:all var(--t);margin-left:3px;padding:0;flex-shrink:0}
.btn-icon:hover{background:var(--red-light);border-color:var(--red);color:var(--red)}
.btn-icon.pdf{color:var(--red);border-color:var(--red-light)}

/* Variant table footer */
.vt-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;font-size:12px;color:var(--g500);border-top:1px solid var(--g200);background:var(--g50);border-radius:0 0 8px 8px}
.vt-footer strong{color:var(--g700)}

/* Expand toggle */
.expand-btn{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:6px 14px;border:1.5px solid var(--g200);border-radius:8px;font-size:12px;font-weight:500;color:var(--g600);background:var(--g0);transition:all var(--t)}
.expand-btn:hover{border-color:var(--red);color:var(--red);background:var(--red-light)}
.expand-btn i{font-size:10px;transition:transform .3s}
.expand-btn.open i{transform:rotate(180deg)}
.vars-hidden{display:none}
.vars-hidden.show{display:table-row-group}

/* === PAGINATION === */
.pagination{display:flex;justify-content:center;align-items:center;gap:4px;padding:24px 0}
.pg-btn{min-width:40px;height:40px;border:1.5px solid var(--g200);border-radius:8px;background:var(--g0);font-size:13px;font-weight:500;color:var(--g700);transition:all var(--t);display:inline-flex;align-items:center;justify-content:center}
.pg-btn:hover{border-color:var(--red);color:var(--red)}
.pg-btn.active{background:var(--red);color:#fff;border-color:var(--red)}
.pg-btn:disabled{opacity:.35;cursor:not-allowed}

/* === LOADING === */
.loading{display:flex;flex-direction:column;align-items:center;padding:80px 20px;color:var(--g400)}
.spinner{width:36px;height:36px;border:3px solid var(--g200);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:14px}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:60px 20px;color:var(--g500)}
.empty-state i{font-size:40px;margin-bottom:12px;display:block;opacity:.3}

/* === MODAL === */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .25s}
.overlay.active{display:flex;opacity:1}
.modal{background:var(--g0);border-radius:16px;max-width:860px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px rgba(0,0,0,.2);position:relative;animation:modalIn .3s}
@keyframes modalIn{from{transform:translateY(20px);opacity:0}}
.modal-close{position:absolute;top:16px;right:16px;z-index:10;width:36px;height:36px;border-radius:10px;border:none;background:var(--g100);color:var(--g600);font-size:14px;transition:all var(--t)}
.modal-close:hover{background:var(--red);color:#fff}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;padding:32px}
.modal-img-wrap{background:#fff;border-radius:12px;border:1px solid var(--g200);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.modal-img-wrap img{max-width:85%;max-height:85%;object-fit:contain}
.modal-img-ph{color:var(--g300);font-size:60px}
.modal-details h1{font-size:20px;font-weight:700;line-height:1.3;margin-bottom:10px}
.modal-sku{font-size:13px;color:var(--red);font-weight:600;margin-bottom:14px;font-family:monospace}
.modal-price-tag{display:inline-block;padding:10px 18px;background:var(--red-light);border-radius:10px;margin-bottom:18px}
.modal-price-tag .amt{font-size:26px;font-weight:800;color:var(--red)}
.modal-price-tag small{font-size:13px;color:var(--g500);margin-left:4px}
.modal-meta{font-size:13px;color:var(--g600);line-height:1.7}
.modal-meta strong{color:var(--g800)}
.modal-attrs{padding:0 32px 28px;border-top:1px solid var(--g100)}
.modal-attrs h3{font-size:14px;font-weight:700;margin:20px 0 12px;padding-left:12px;border-left:3px solid var(--red)}
.attrs-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.attr-row{display:flex;justify-content:space-between;padding:8px 14px;font-size:13px;border-bottom:1px solid var(--g100)}
.attr-row:nth-child(odd){background:var(--g50)}
.attr-row .ak{font-weight:500;color:var(--g600)}
.attr-row .av{color:var(--g900);text-align:right}
.modal-actions{padding:0 32px 32px;display:flex;flex-direction:column;gap:10px}
.modal-sec-row{display:flex;gap:10px;width:100%}
.modal-sec-row .btn-enq{flex:1 1 0;min-width:0;justify-content:center;padding:12px 8px;font-size:13px;height:44px;box-sizing:border-box;margin-left:0}
.modal-btn-pdf{background:var(--g0);color:var(--g600);border:1.5px solid var(--g200)}
.modal-btn-req{background:#fff!important;color:var(--red)!important;border:1.5px solid var(--red)!important}
.modal-btn-req:hover{background:var(--red-light)!important;border-color:var(--red-dark)!important;color:var(--red-dark)!important}
.modal-atc{width:100%;height:52px;font-size:15px;font-weight:700;border-radius:8px;justify-content:center;box-sizing:border-box}

/* === FOOTER === */
.footer{background:var(--g900);color:var(--g400);padding:32px 0;margin-top:40px;font-size:13px}
.footer .inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer a{color:var(--g400);transition:color var(--t)}
.footer a:hover{color:#fff}

/* === PRODUCT DETAIL PAGE === */
.pdp-hero{display:grid;grid-template-columns:1fr 1fr;gap:32px;padding:28px;background:var(--g0);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;max-width:100%;overflow:hidden}
.pdp-img-wrap{aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;border:1px solid var(--g100);cursor:zoom-in;position:relative}
.pdp-img-wrap img{width:100%;height:100%;object-fit:contain}
.pdp-img-wrap::after{content:'\f00e';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.5);color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:opacity var(--t)}
.pdp-img-wrap:hover::after{opacity:1}
/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;cursor:zoom-out;padding:20px}
.lightbox.show{display:flex}
.lightbox img{max-width:95vw;max-height:95vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-close{position:fixed;top:16px;right:16px;background:rgba(255,255,255,.2);color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;z-index:10000;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox-close:hover{background:rgba(255,255,255,.4)}
.pdp-img-ph{font-size:64px;color:var(--g200)}
.pdp-details h1{font-size:24px;font-weight:800;line-height:1.3;margin-bottom:12px;color:var(--g900)}
.pdp-sku{display:inline-flex;align-items:center;gap:6px;font-family:monospace;font-size:13px;color:var(--red);font-weight:600;background:var(--red-light);padding:4px 12px;border-radius:6px;margin-bottom:16px}
.pdp-price{font-size:28px;font-weight:800;color:var(--g900);margin-bottom:4px}
.pdp-price-sub{font-size:13px;color:var(--g500);margin-bottom:20px}
.pdp-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;font-size:14px;color:var(--g600)}
.pdp-meta strong{color:var(--g800)}
.pdp-desc{font-size:14px;line-height:1.7;color:var(--g600);margin-bottom:20px}
.pdp-desc-toggle{display:none}
.pdp-links{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.pdp-link-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--t);text-decoration:none;border:1.5px solid var(--g200)}
.pdp-link-btn.pdf{background:var(--g0);color:var(--red);border-color:var(--red)}
.pdp-link-btn.pdf:hover{background:var(--red);color:#fff}
.pdp-link-btn.pdf i{font-size:16px}
.pdp-link-btn.info{background:var(--g0);color:var(--g700);border-color:var(--g300)}
.pdp-link-btn.info:hover{background:var(--g100);border-color:var(--g400)}
.pdp-link-btn.info i{font-size:15px;color:var(--g500)}
.pdp-actions{display:flex;gap:10px;flex-wrap:wrap}
.pdp-section{background:var(--g0);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:24px}
/* Help banner on PDP */
.help-banner{background:#fff;border-radius:var(--r-lg);border-left:5px solid var(--red);box-shadow:var(--shadow-sm);padding:22px 24px;margin-bottom:24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.help-banner-text{flex:1;min-width:0}
.help-banner-title{font-size:14px;font-weight:700;color:var(--g900);margin-bottom:5px;line-height:1.4}
.help-banner-sub{font-size:12px;color:var(--g600);line-height:1.6}
.help-banner .btn-enq-lg{display:inline-flex;align-items:center;gap:7px;padding:11px 20px;background:var(--red);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:700;white-space:nowrap;cursor:pointer;transition:all var(--t);text-decoration:none;flex-shrink:0;letter-spacing:.01em}
.help-banner .btn-enq-lg:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(226,0,26,.25)}
.pdp-section-hdr{padding:16px 20px;border-bottom:2px solid var(--red);font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}
.pdp-attrs-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0}
.pdp-attr{display:flex;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--g100);font-size:13px}
.pdp-attr:nth-child(odd){background:var(--g50)}
.pdp-attr .ak{color:var(--g500);font-weight:500}
.pdp-attr .av{color:var(--g900);font-weight:600;text-align:right}

/* === CHECKOUT LAYOUT === */
.checkout-layout{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
.checkout-main{min-width:0}
.checkout-side{min-width:0}
.checkout-side .rec-section-hdr{font-size:14px;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--red)}
.checkout-side .rec-grid{display:grid!important;grid-template-columns:1fr;gap:8px;overflow-x:visible;scroll-snap-type:none;max-height:70vh;overflow-y:auto}
.checkout-side .rec-card{min-width:0;max-width:none;flex-direction:row;gap:0;border:1px solid var(--g100);box-shadow:none}
.checkout-side .rec-card:hover{box-shadow:var(--shadow-sm);border-color:var(--g300)}
.checkout-side .rec-card-img{width:64px;min-width:64px;aspect-ratio:1;border-bottom:none;border-right:1px solid var(--g100)}
.checkout-side .rec-card-body{padding:8px 10px}
.checkout-side .rec-card-name{font-size:11px;-webkit-line-clamp:1;margin-bottom:4px}
.checkout-side .rec-card-price{font-size:13px;font-weight:700;margin-bottom:4px;margin-top:auto}
.checkout-side .rec-card-btn{padding:5px 8px;font-size:10px;border-radius:4px}
.checkout-side .rec-card-sku{font-size:9px;margin-bottom:1px}

/* === MEDIUM FINDER === */
.mf-widget{background:var(--g0);border:1.5px solid var(--g200);border-radius:14px;padding:24px 28px;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.home-section-hdr{font-size:24px;font-weight:700;margin-bottom:4px;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
.mf-header{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.mf-icon{width:36px;height:36px;background:var(--red-light);border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--red);font-size:16px;flex-shrink:0}
.mf-title{font-size:16px;font-weight:700;color:var(--g900)}
.mf-subtitle{font-size:12px;color:var(--g400);margin-top:1px}
.mf-search-row{display:flex;gap:10px;align-items:center;margin-bottom:14px}
.mf-input-wrap{flex:1;position:relative}
.mf-input{width:100%;padding:10px 40px 10px 14px;border:2px solid var(--g200);border-radius:var(--r);font-size:14px;outline:none;background:var(--g50);transition:all var(--t);height:42px;box-sizing:border-box}
.mf-input:focus{border-color:var(--red);background:var(--g0);box-shadow:0 0 0 4px var(--red-glow)}
.mf-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--g400);font-size:14px;cursor:pointer;padding:4px;display:none}
.mf-dropdown{position:fixed;background:var(--g0);border:1.5px solid var(--g200);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:99999;max-height:260px;overflow-y:auto;display:none}
.mf-opt{padding:9px 14px;cursor:pointer;font-size:13px;color:var(--g700);transition:background .1s;display:flex;align-items:center;gap:8px}
.mf-opt:hover{background:var(--g50)}
.mf-opt-sym{font-size:11px;color:var(--g400);font-family:monospace;flex-shrink:0}
.mf-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.mf-chip{padding:4px 12px;border-radius:20px;border:1.5px solid var(--g200);background:var(--g0);font-size:12px;color:var(--g600);cursor:pointer;transition:all var(--t)}
.mf-chip:hover{border-color:var(--red);color:var(--red)}
.mf-chip.active{border-color:var(--red);background:var(--red);color:#fff}
.mf-results{margin-top:4px}
.mf-cat-hdr{font-size:12px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.05em;margin:16px 0 10px;display:flex;align-items:center;gap:8px}
.mf-cat-hdr::after{content:'';flex:1;height:1px;background:var(--g200)}
.mf-empty{text-align:center;padding:24px;color:var(--g400);font-size:13px}
.mf-loading{text-align:center;padding:20px;color:var(--g400);font-size:13px}
@media(max-width:600px){.mf-widget{padding:16px;}.mf-search-row{flex-direction:column;align-items:stretch}}

/* === SEARCH GRID === */
.srch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;padding:4px 0 16px}
.srch-grid .rec-card{min-width:0;max-width:none;width:100%}

/* === RECOMMENDATIONS === */
.rec-section{margin-bottom:24px;max-width:100%;overflow:hidden}
.rec-section-hdr{font-size:15px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
/* Rec slider */
.rec-slider-wrap{position:relative;max-width:100%;overflow:hidden}
.rec-grid{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:4px 0 12px;scrollbar-width:none;max-width:100%}
.rec-grid::-webkit-scrollbar{display:none}
.rec-card{min-width:180px;max-width:180px;flex-shrink:0;scroll-snap-align:start;background:#fff;border-radius:var(--r);border:1px solid var(--g200);overflow:hidden;transition:all var(--t);display:flex;flex-direction:column}
.rec-card:hover{box-shadow:var(--shadow-md);border-color:var(--red)}
.rec-card-img{width:100%;aspect-ratio:1;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--g100);cursor:pointer}
.rec-card-img img{width:100%;height:100%;object-fit:contain}
.rec-card-body{padding:10px;flex:1;display:flex;flex-direction:column}
.rec-card-sku{font-size:10px;color:var(--red);font-weight:600;font-family:monospace;margin-bottom:2px}
.rec-card-name{font-size:12px;font-weight:500;color:var(--g800);line-height:1.3;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rec-card-price{font-size:14px;font-weight:700;margin-bottom:6px;margin-top:auto}
.rec-card-btn{width:100%;padding:7px;border:none;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all var(--t)}
.rec-card-btn.order{background:var(--red);color:#fff}.rec-card-btn.order:hover{background:var(--red-dark)}
.rec-card-btn.enquiry{background:var(--g800);color:#fff}.rec-card-btn.enquiry:hover{background:var(--g700)}
.rec-nav{position:absolute;top:50%;transform:translateY(-70%);width:32px;height:32px;border-radius:50%;background:var(--g0);border:1px solid var(--g200);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;font-size:12px;color:var(--g600);transition:all var(--t)}
.rec-nav:hover{border-color:var(--red);color:var(--red);box-shadow:var(--shadow-md)}
.rec-nav.left{left:-12px}
.rec-nav.right{right:-12px}
.rec-spinner{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--g400);gap:8px;font-size:13px}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .main-layout{grid-template-columns:220px 1fr;gap:16px}
  .header-right .hdr-btn span{display:none}
}
/* === MOBILE CATEGORY DRAWER === */
.mob-cat-btn{display:none;align-items:center;gap:8px;padding:10px 16px;background:var(--g0);border:1.5px solid var(--g200);border-radius:var(--r);font-size:13px;font-weight:600;color:var(--g700);width:100%;cursor:pointer;margin-bottom:12px}
.mob-cat-btn i{color:var(--red)}
.mob-cat-drawer{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.5)}
.mob-cat-drawer.show{display:flex}
.mob-cat-panel{width:85vw;max-width:340px;background:var(--g0);height:100%;overflow-y:auto;padding:20px;animation:slideInLeft .25s ease}
@keyframes slideInLeft{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.mob-cat-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:20px;color:var(--g500);cursor:pointer}

@media(max-width:768px){
  .topbar{display:none}

  /* Header */
  .header .inner{
    gap:8px;flex-wrap:wrap;padding:10px 12px;
    display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;
  }
  .logo-img{height:30px;grid-column:1;grid-row:1}
  .mega-wrap{grid-column:2;grid-row:1;justify-self:start}
  .mega-btn{padding:8px 12px;font-size:12px;height:38px}
  .mega-btn .ham span{width:14px}
  .header-right{grid-column:3;grid-row:1;gap:4px}
  .hdr-btn{padding:0 10px;height:38px}
  .hdr-btn span{display:none}
  .hdr-btn i{font-size:16px}
  .search-box{grid-column:1/-1;grid-row:2;max-width:100%;margin:4px 0 0}
  .search-box input{padding:10px 44px 10px 14px;font-size:13px;height:40px}
  .search-box .sbtn{top:5px;bottom:5px;right:5px;width:34px}
  .header-nav{display:none}
  /* Mega menu: fullscreen drawer on mobile */
  .mega-dd{position:fixed!important;top:0;left:0;right:0;bottom:0;min-width:100vw;width:100vw;max-height:100vh;overflow-y:auto;border-radius:0;padding:60px 16px 24px;z-index:200;transform:translateY(-100%)!important}
  .mega-dd.show{transform:translateY(0)!important}
  .mega-grid{grid-template-columns:1fr;gap:2px}
  .mega-item{padding:14px 12px;gap:12px;border-bottom:1px solid var(--g100)}
  .mega-item:last-child{border-bottom:none}
  .mi-icon{width:36px;height:36px}
  .mi-icon img{width:20px!important;height:20px!important}
  .mi-text h4{font-size:14px}
  .mi-cnt{font-size:11px;color:var(--g400)}
  .mega-close-mob{display:flex!important;position:fixed;top:0;left:0;right:0;padding:14px 16px;background:var(--g0);font-size:14px;font-weight:600;color:var(--g500);justify-content:space-between;align-items:center;z-index:201;border-bottom:1px solid var(--g100);cursor:pointer}
  .mega-close-mob span{font-size:20px}

  /* Breadcrumb */
  .breadcrumb-bar .inner{padding:0 12px;font-size:11px;overflow-x:auto;white-space:nowrap}

  /* Main layout — sidebar hidden, mobile cat button shown */
  .main-layout{grid-template-columns:1fr;padding:12px;gap:12px}
  .sidebar-card{display:none}
  .mob-cat-btn{display:flex}
  .page-title{font-size:20px}
  .page-subtitle{font-size:13px}

  /* Categories grid */
  .cat-grid{grid-template-columns:1fr 1fr;gap:8px}
  .cat-card{padding:12px}
  .cat-card h3{font-size:12px}
  .cat-card::before{display:none}
  .cc-icon{width:28px;height:28px;border-radius:6px}
  .cc-icon img{width:18px!important;height:18px!important}
  .cc-count{font-size:11px}
  .cc-arrow{display:none}

  /* Filter bar */
  .filter-bar{padding:10px 12px;font-size:12px;flex-wrap:wrap;gap:8px;border-radius:var(--r) var(--r) 0 0}
  .sort-wrap{width:100%}
  .sort-sel{width:100%}

  /* Product cards */
  .pc-top{flex-direction:column;gap:10px}
  .pc-img{width:100%;height:100px}
  .pc-name{font-size:14px}
  .pc-specs{font-size:11px}

  /* Variant table: hidden by default on mobile listing */
  .product-card .vt-toolbar,
  .product-card .vt-table,
  .product-card .vt-footer,
  .product-card .expand-btn,
  .product-card .vt-header{display:none}
  .mob-variants-btn{display:flex!important;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;margin-top:8px;background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--r);font-size:13px;font-weight:600;color:var(--g700);cursor:pointer;transition:all var(--t)}
  .mob-variants-btn:hover,.mob-variants-btn:active{border-color:var(--red);color:var(--red);background:var(--red-light)}
  .mob-variants-btn i{color:var(--red)}
  .product-card.mob-expanded .vt-toolbar,
  .product-card.mob-expanded .vt-table,
  .product-card.mob-expanded .vt-footer,
  .product-card.mob-expanded .expand-btn,
  .product-card.mob-expanded .vt-header{display:block}
  .product-card.mob-expanded .mob-variants-btn{display:none!important}

  /* Variant table card layout when expanded */
  .vt-header{flex-direction:column;align-items:flex-start;gap:6px;padding:8px 0}
  /* Toolbar: search 100% + filter always right */
  .vt-toolbar{padding:6px 0;width:100%;flex-wrap:wrap;display:flex;align-items:center}
  .vt-search{max-width:100%!important;flex:1 1 100%!important;margin-bottom:8px}
  .vt-filter-btn{margin-left:auto!important;flex-shrink:0}
  /* PDP: outer toolbar wrapper full-width so filter stays right */
  .pdp-section .vt-toolbar{flex:1 1 100%!important;padding:0!important}

  /* Variant table */
  .vt-table,.vt-table tbody{display:block;width:100%}
  .vt-table thead{display:none}
  .vt-table tbody tr{
    display:flex;flex-wrap:wrap;
    height:auto!important;min-height:0!important;
    padding:10px 12px;border-bottom:1px solid var(--g100);gap:0;
  }
  .vt-table td{padding:0;font-size:12px}
  .vt-table td::before{display:none}
  .vt-table td[data-label="Quantity"]{display:none}

  /* Line 1+2: SKU + name (combined cell) */
  .td-sku-name{flex:1 1 100%;order:1;padding-bottom:4px;max-width:100%}
  .td-sku-code{font-size:12px;font-weight:700;white-space:nowrap}
  .td-name-desc{font-size:11px;color:var(--g500);max-width:100%;white-space:normal;word-break:break-word;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  /* Line 3: specs (DN + bar) — reset desktop width:1px, display inline side by side */
  .td-spec{flex:0 0 auto;width:auto!important;order:3;font-size:12px;font-weight:600;color:var(--g800);padding:0 0 4px 0;margin-right:0;white-space:nowrap}
  .td-spec small{font-size:10px;color:var(--g500);font-weight:400;margin-left:1px;margin-right:0}
  /* Separator dot between spec cells */
  .td-spec+.td-spec::before{content:' · ';color:var(--g300);font-weight:400;font-size:12px}
  /* Line 4: availability — full width, own row */
  .td-avail{flex:1 1 100%;order:4;text-align:left;padding-top:2px;padding-bottom:4px}
  /* Line 5: price — full width, right-aligned */
  .td-price{flex:1 1 100%;order:5;text-align:right;margin-left:0;padding-bottom:4px}
  .td-price .amount{font-size:13px;font-weight:700}
  .td-price .sub{font-size:9px;color:var(--g500)}
  /* Line 6: [ℹ][PDF] left + [ATC] right */
  .td-actions{flex:1 1 100%;order:6;display:flex;gap:5px;align-items:center;padding-top:12px}
  .btn-cart{flex:none;padding:0 14px;height:36px;font-size:12px;width:162px;justify-content:center}
  .btn-icon{height:36px;font-size:12px;margin-left:0;padding:0 9px}
  .qty-stepper{display:none}

  .expand-btn{font-size:12px;padding:10px 16px}
  .vt-footer{font-size:11px;padding:8px 12px}

  /* Checkout */
  .checkout-layout{grid-template-columns:1fr}
  .checkout-side{order:2}
  .checkout-side .rec-section-hdr{font-size:13px}
  .checkout-side .rec-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}
  .checkout-side .rec-card{flex-direction:column}
  .checkout-side .rec-card-img{width:100%;min-width:0;border-right:none;border-bottom:1px solid var(--g100)}

  /* PDP mobile */
  .pdp-hero{grid-template-columns:1fr;gap:0;padding:0;margin-bottom:12px;box-shadow:none;border-radius:0;background:var(--g0)}
  .pdp-img-wrap{max-height:260px;aspect-ratio:auto;border-radius:0;border:none;border-bottom:1px solid var(--g100)}
  .pdp-img-wrap img{padding:16px;object-fit:contain}
  .pdp-details{padding:14px 16px 16px}
  .pdp-details h1{font-size:18px;font-weight:700;margin-bottom:6px;line-height:1.3}
  .pdp-sku{font-size:11px;padding:3px 8px;margin-bottom:10px}
  .pdp-price{font-size:26px;font-weight:800;margin-bottom:2px}
  .pdp-price-sub{font-size:12px;margin-bottom:12px}
  .pdp-meta{font-size:12px;gap:3px;margin-bottom:10px;flex-direction:row;flex-wrap:wrap}
  .pdp-meta span{background:var(--g50);padding:3px 8px;border-radius:4px;font-size:11px}
  .pdp-desc{font-size:12px;line-height:1.6;max-height:80px;overflow:hidden;position:relative;margin-bottom:0;color:var(--g600)}
  .pdp-desc-toggle{display:block;text-align:center;padding:6px;font-size:11px;font-weight:600;color:var(--red);cursor:pointer;background:linear-gradient(transparent,var(--g0) 50%);margin-top:-24px;position:relative;z-index:1}
  .pdp-desc.expanded{max-height:none}
  .pdp-desc.expanded+.pdp-desc-toggle{background:none;margin-top:0}
  .pdp-actions{flex-direction:row;padding:12px 16px;gap:8px;background:var(--g0);border-top:1px solid var(--g100)}
  .pdp-actions button,.pdp-actions a{flex:1;justify-content:center;padding:10px 8px;font-size:12px;min-width:0}
  .pdp-actions button i,.pdp-actions a i{margin-right:4px}

  /* PDP sections mobile */
  .pdp-section{margin-bottom:8px;border-radius:0;box-shadow:none;border-top:6px solid var(--g100)}
  .pdp-section-hdr{font-size:13px;padding:10px 16px}

  /* Specs table: single column on mobile */
  .pdp-attrs-grid{grid-template-columns:1fr;padding:0}
  .pdp-attr{padding:8px 16px;gap:8px}
  .pdp-attr .ak{font-size:12px;min-width:0;flex:1}
  .pdp-attr .av{font-size:12px;text-align:right;flex-shrink:0;max-width:50%}

  /* PDP variants: always expanded on mobile, full width */
  .pdp-mob-variants-btn{display:none!important}
  .pdp-section [style*="overflow-x"]{overflow-x:visible!important}
  .pdp-section .vt-table,.pdp-section .vt-table tbody{display:block;width:100%!important}
  /* tr uses flex layout from above — do NOT override to display:block */

  /* Recommendations mobile: horizontal scroll */
  .rec-grid{display:flex!important;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;gap:10px;padding-bottom:8px}
  .rec-grid::-webkit-scrollbar{height:3px}
  .rec-grid::-webkit-scrollbar-thumb{background:var(--g300);border-radius:3px}
  .rec-card{min-width:140px;max-width:160px;flex-shrink:0;scroll-snap-align:start}
  .rec-card-name{font-size:11px;-webkit-line-clamp:2}
  .rec-card-btn{font-size:10px;padding:6px 8px}

  /* Modal */
  .modal-grid{grid-template-columns:1fr;gap:12px;padding:16px}
  .modal-img{max-height:180px}
  .modal-details h1{font-size:16px}
  .attrs-grid{grid-template-columns:1fr}
  .modal-actions{padding:0 16px 16px}
  .modal-sec-row .btn-enq{font-size:12px;padding:10px 6px;height:40px}
  .modal-atc{font-size:14px;height:48px}

  /* Cart drawer: full width */
  .cart-drawer{width:100vw;right:-110vw}

  /* Footer */
  .footer .inner{flex-direction:column;text-align:center;gap:8px;font-size:12px}
  .footer-lang-mobile{display:flex!important}

  /* Pagination */
  .pagination{gap:3px}
  .pg-btn{min-width:32px;height:32px;font-size:12px}
}

@media(max-width:380px){
  .cat-grid{grid-template-columns:1fr}
  .mega-btn span:not(.ham){display:none}
  .hdr-btn.primary{padding:0 8px}
}
