/* Bundled critical CSS — rebuild via scripts/build-critical-css.sh */

/* === fonts.css === */
/* Self-hosted Inter font — eliminates Google Fonts round-trip */
/* latin-ext (NO, SK, LT, PL diacritics) */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* cyrillic (UK market) */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/inter-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/inter-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/inter-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin (base) */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* === base.css === */
/* === VARIABLES & RESET === */
: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: #7c8391; --g500: #5a6170; --g600: #424a57;
  --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:clip;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:clip;width:100%;max-width:100vw}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}

/* Reserve a fixed advance box for Font Awesome glyphs. fa-all.min.css and
   its woff2 load deferred, so without this every <i class="fas fa-…">
   starts at 0 width and jumps to the glyph width when the webfont swaps
   in — a ~0.23 CLS hit (confirmed CLS culprit) that also destabilised
   LCP detection on slow connections. A 1.25em inline-block box (same as
   FA's own .fa-fw) keeps the footprint constant regardless of font
   timing; the glyph just fills the reserved box. */
.fa,.fas,.far,.fab,.fa-solid,.fa-regular,.fa-brands,.fa-light,.fa-thin,.fa-duotone{display:inline-block;width:1.25em;height:1em;line-height:1;text-align:center;font-style:normal;vertical-align:-0.125em}

/* === FOCUS RINGS (accessibility) === */
:focus-visible{outline:2px solid var(--red);outline-offset:2px;border-radius:4px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--red);outline-offset:0;border-color:var(--red)!important}
button:focus-visible{outline:2px solid var(--red);outline-offset:2px}
a:focus-visible{outline:2px solid var(--red);outline-offset:2px;border-radius:4px}
.af-chip:focus-visible,.pg-btn:focus-visible,.mega-item:focus-visible,.cat-item:focus-visible,.typ-node:focus-visible{outline:2px solid var(--red);outline-offset:-2px}

/* === Z-INDEX SCALE === */
/* 100: sticky header | 200: mega-menu | 500: cart overlay | 501: cart drawer | 600: mobile drawers | 900: modal overlay | 950: modal | 990: lightbox | 999: lightbox close */


/* === header.css === */
/* === 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:55px;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:6px;padding:0 14px;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,.ss-item.ss-active{background:var(--g100)}
.ss-item:active{background:var(--g200)}
.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}


/* === homepage.css === */
/* === HOMEPAGE V2 — loaded only when goHome renders landing page === */

/* Layout override: hide sidebar, full-width content when .hp on <html> */
html.hp .sidebar-card{display:none!important}
html.hp .main-layout{display:block!important;padding:0!important;max-width:100%!important}
html.hp .breadcrumb-bar{display:none!important}
html.hp .content-area{overflow:visible!important;margin-bottom:0!important;padding-bottom:0!important}
html.hp .main-layout{margin-bottom:0!important;padding-bottom:0!important}

/* Hero */
.hp-hero{position:relative;background:#1a1a2e;overflow:hidden;min-height:440px;display:flex;align-items:center}
/* Hero bg: mobile-first. Mobile devices get a 700×240 / 30 KB variant
   sized for ~412 px viewports; desktop swaps in the 1170×400 / 68 KB
   image. Saves ~38 KB on the LCP path for the dominant traffic class. */
.hp-hero-bg{position:absolute;inset:0;background:url('/images/hero-bg-mobile.webp') center/cover no-repeat;opacity:0.5}
@media(min-width:769px){.hp-hero-bg{background-image:url('/images/hero-bg.webp')}}
.hp-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(17,24,39,0.85) 0%,rgba(17,24,39,0.5) 50%,rgba(17,24,39,0.2) 100%)}
.hp-hero-content{position:relative;z-index:1;max-width:var(--max-w);margin:0 auto;padding:70px 24px;width:100%}
.hp-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(226,0,26,0.15);color:var(--red);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:18px;border:1px solid rgba(226,0,26,0.2)}
.hp-hero h1{font-size:48px;font-weight:900;color:#fff;line-height:1.1;max-width:600px;margin-bottom:14px;letter-spacing:-0.02em}
.hp-hero h1 span{color:var(--red)}
.hp-hero p{font-size:17px;color:rgba(255,255,255,0.7);max-width:480px;line-height:1.6;margin-bottom:28px}
.hp-actions{display:flex;gap:12px;flex-wrap:wrap}
.hp-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none;text-decoration:none}
.hp-cta.primary{background:var(--red);color:#fff}
.hp-cta.primary:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 8px 24px rgba(226,0,26,0.3)}
.hp-cta.secondary{background:rgba(255,255,255,0.1);color:#fff;border:1px solid rgba(255,255,255,0.2)}
.hp-cta.secondary:hover{background:rgba(255,255,255,0.2)}
.hp-stats{display:flex;gap:36px;margin-top:40px;padding-top:28px;border-top:1px solid rgba(255,255,255,0.1)}
.hp-stat .num{font-size:26px;font-weight:800;color:#fff;line-height:1}
.hp-stat .label{font-size:11px;color:rgba(255,255,255,0.5);margin-top:3px;text-transform:uppercase;letter-spacing:.05em}

/* Sections */
.hp-section{max-width:var(--max-w);margin:0 auto;padding:48px 24px}
.hp-section-hdr{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.hp-section-hdr h2{font-size:24px;font-weight:800;color:var(--g900)}
.hp-section-hdr .ico{color:var(--red);font-size:18px}
.hp-section-sub{font-size:13px;color:var(--g500);margin-bottom:24px}

/* Medium Finder widget */
.hp-mf{background:linear-gradient(135deg,#f0f4f8,#e8edf3);border-top:1px solid var(--g200);border-bottom:1px solid var(--g200);padding:40px 0}
.hp-mf-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.hp-mf-widget{background:var(--g0);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:28px 32px;max-width:800px;margin:0 auto}
.hp-mf-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.hp-mf-flask{width:44px;height:44px;border-radius:12px;background:var(--red-light);display:flex;align-items:center;justify-content:center;color:var(--red);font-size:18px;flex-shrink:0}
.hp-mf-top h3{font-size:18px;font-weight:800;color:var(--g900)}
.hp-mf-top p{font-size:12px;color:var(--g500);margin-top:2px}
.hp-mf-search{display:flex;gap:0}
.hp-mf-search input{flex:1;min-width:0;padding:11px 16px;border:2px solid var(--g200);border-right:none;border-radius:var(--r) 0 0 var(--r);font-size:14px;outline:none;background:var(--g50)}
.hp-mf-search input:focus{border-color:var(--red);background:var(--g0);box-shadow:0 0 0 3px rgba(226,0,26,0.08)}
.hp-mf-search button{padding:0 18px;background:var(--red);color:#fff;border:2px solid var(--red);border-radius:0 var(--r) var(--r) 0;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}

/* Category grid */
.hp-cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.hp-cat-card{background:var(--g0);border:1.5px solid var(--g200);border-radius:var(--r-lg);padding:20px 16px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;color:inherit}
.hp-cat-card:hover{border-color:var(--red);box-shadow:0 6px 20px rgba(226,0,26,0.08);transform:translateY(-2px)}
.hp-cat-card .hp-cat-img{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.hp-cat-card .hp-cat-img img{width:85%;height:85%;object-fit:contain}
.hp-cat-card h3{font-size:12px;font-weight:600;color:var(--g800);margin-bottom:4px;line-height:1.3}
.hp-cat-card:hover h3{color:var(--red)}
.hp-cat-card .cnt{font-size:11px;color:var(--g400)}

/* Services */
.hp-svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.hp-svc-card{background:var(--g0);border:1.5px solid var(--g200);border-radius:var(--r-lg);overflow:hidden;transition:all .2s}
.hp-svc-card:hover{border-color:var(--red);box-shadow:0 6px 20px rgba(226,0,26,0.08);transform:translateY(-2px)}
/* height:auto is REQUIRED — the <img> tags carry HTML width/height attrs
   (500×280 vs 800×411) which otherwise leak in as a definite CSS height
   and make the browser ignore aspect-ratio, so the 800×411 card grew
   taller than the rest. */
.hp-svc-card .hp-svc-img{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover;display:block;transition:transform .4s}
.hp-svc-card:hover .hp-svc-img{transform:scale(1.03)}
.hp-svc-card .hp-svc-body{padding:18px}
.hp-svc-card h4{font-size:14px;font-weight:700;color:var(--g800);margin-bottom:8px}
.hp-svc-card:hover h4{color:var(--red)}
.hp-svc-card ul{list-style:none;padding:0;margin:0}
.hp-svc-card ul li{font-size:12px;color:var(--g500);line-height:1.4;padding:3px 0;border-bottom:1px solid var(--g100);display:flex;align-items:baseline;gap:6px}
.hp-svc-card ul li:last-child{border:none}
.hp-svc-card ul li::before{content:'\f105';font-family:'Font Awesome 6 Free';font-weight:900;font-size:9px;color:var(--red);flex-shrink:0}
.hp-svc-card ul li a{color:var(--g600);text-decoration:none;transition:color .2s}
.hp-svc-card ul li a:hover{color:var(--red)}

/* Industries */
.hp-ind{background:var(--g900);padding:56px 0}
.hp-ind-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.hp-ind .hp-section-hdr h2{color:#fff}
.hp-ind .hp-section-sub{color:rgba(255,255,255,0.5)}
.hp-ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.hp-ind-card{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:var(--r-lg);padding:18px;cursor:pointer;transition:all .2s;display:flex;align-items:flex-start;gap:12px}
.hp-ind-card:hover{background:rgba(226,0,26,0.1);border-color:rgba(226,0,26,0.3);transform:translateY(-1px)}
.hp-ind-card .ind-ico{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--red);flex-shrink:0;transition:all .2s}
.hp-ind-card:hover .ind-ico{background:var(--red);color:#fff}
.hp-ind-card h4{font-size:12px;font-weight:600;color:#fff}
.hp-ind-card p{font-size:10px;color:rgba(255,255,255,0.4);margin-top:2px;line-height:1.4}
.hp-ind-hidden{display:none}
.hp-ind-grid.expanded .hp-ind-hidden{display:flex}
.hp-ind-more{display:flex;justify-content:center;margin-top:20px}
.hp-ind-more button{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border:1px solid rgba(255,255,255,0.2);border-radius:var(--r);color:rgba(255,255,255,0.7);font-size:13px;font-weight:600;cursor:pointer;background:none;transition:all .2s}
.hp-ind-more button:hover{border-color:var(--red);color:#fff;background:rgba(226,0,26,0.15)}

/* Value props */
.hp-vp{background:var(--g50);border-top:1px solid var(--g200);border-bottom:1px solid var(--g200)}
.hp-vp-inner{max-width:var(--max-w);margin:0 auto;padding:40px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.hp-vp-item{display:flex;align-items:flex-start;gap:12px}
.hp-vp-ico{width:40px;height:40px;border-radius:10px;background:var(--red-light);display:flex;align-items:center;justify-content:center;color:var(--red);font-size:16px;flex-shrink:0}
.hp-vp-item h4{font-size:12px;font-weight:700;color:var(--g800);margin-bottom:2px}
.hp-vp-item p{font-size:11px;color:var(--g500);line-height:1.4}

/* CTA banner */
.hp-cta-banner{background:linear-gradient(135deg,#1e293b,#334155);padding:48px 0}
.hp .footer{margin-top:0}
.hp-cta-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.hp-cta-banner h2{font-size:24px;font-weight:800;color:#fff;margin-bottom:4px}
.hp-cta-banner p{font-size:14px;color:rgba(255,255,255,0.6)}
.hp-cta-banner .hp-cta-btn{padding:12px 28px;background:var(--red);color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:all .2s}
.hp-cta-banner .hp-cta-btn:hover{background:var(--red-dark)}

/* Responsive */
@media(max-width:1024px){
  .hp-cat-grid{grid-template-columns:repeat(3,1fr)}
  .hp-svc-grid{grid-template-columns:repeat(2,1fr)}
  .hp-ind-grid{grid-template-columns:repeat(2,1fr)}
  .hp-vp-inner{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .hp-hero h1{font-size:32px}
  .hp-cat-grid{grid-template-columns:repeat(2,1fr)}
  .hp-svc-grid{grid-template-columns:1fr}
  .hp-ind-grid{grid-template-columns:1fr}
  .hp-vp-inner{grid-template-columns:1fr}
  .hp-cta-inner{flex-direction:column;text-align:center}
  .hp-stats{flex-wrap:wrap;gap:20px}
}

/* HAC inquiry form — stack 4 input fields on mobile */
@media(max-width:768px){
  .hac-input-grid{grid-template-columns:1fr !important;gap:12px !important}
}


/* === sidebar.css === */
/* === 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;max-height:calc(100vh - 96px);overflow-y:auto}
.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(40%) opacity(.7);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(14%) sepia(97%) saturate(7471%) hue-rotate(349deg) brightness(94%) contrast(117%)}
.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}


/* === categories.css === */
/* === HOME STATS BAR === */
.home-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;margin-top:8px}
.home-stat{background:var(--g0);border:1.5px solid var(--g100);border-radius:var(--r-lg);padding:20px 16px;text-align:center;box-shadow:var(--shadow-xs);transition:all var(--t)}
.home-stat:hover{border-color:var(--red);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.home-stat-val{font-size:28px;font-weight:800;color:var(--red);letter-spacing:-.02em;line-height:1.2}
.home-stat-label{font-size:12px;color:var(--g500);margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}
@media(max-width:768px){.home-stats{grid-template-columns:repeat(2,1fr);gap:10px}.home-stat{padding:14px 12px}.home-stat-val{font-size:22px}}
@media(max-width:480px){.home-stats{grid-template-columns:repeat(2,1fr);gap:8px}.home-stat{padding:12px 8px}.home-stat-val{font-size:20px}.home-stat-label{font-size:10px}}

/* === 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:hover .cc-icon i{color:#fff!important}
.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}


/* === products.css === */
/* === 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:16px;align-items:flex-start}
.pc-img{width:112px;height:112px;flex-shrink:0;background:#fff;border:1px solid var(--g100);border-radius:6px;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;transition:transform .5s}
.pc-img:hover img{transform:scale(1.06)}
.pc-info{flex:1;min-width:0}
.pc-name{font-size:18px;font-weight:800;color:var(--g900);line-height:1.3;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:12px;background:var(--g0);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:16px}
.pc-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:10px}
.pc-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--g700);text-decoration:none;cursor:pointer;transition:color var(--t)}
.pc-link i{color:var(--red);font-size:12px}
.pc-link:hover{color:var(--red)}
.pc-count{font-size:11px;font-weight:600;color:var(--g400);margin-left:auto;white-space:nowrap;text-transform:lowercase}
.vt-stock-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none;font-size:13px;font-weight:600;color:var(--g700);margin-left:auto;padding:0 6px}
.vt-stock-toggle input{width:16px;height:16px;accent-color:var(--red);cursor:pointer;margin:0}
.vt-toolbar{display:flex;align-items:center;gap:14px;padding:10px 20px;flex-wrap:wrap;background:var(--g50);border-bottom:1px solid var(--g100)}
.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}
/* Cart drawer item — same structure as checkout bestilling: 3 cols × 2 rows */
.cd-item{display:grid;grid-template-columns:60px 1fr auto;grid-template-rows:auto auto;gap:6px 12px;padding:14px 0;border-bottom:1px solid var(--g100);align-items:start}
.cd-item .cd-img-box{grid-row:1/3;grid-column:1;width:60px;height:60px;border-radius:8px;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--g100)}
.cd-item .cd-img-box img{width:100%;height:100%;object-fit:contain}
.cd-item .cd-info{grid-row:1;grid-column:2;min-width:0;display:flex;flex-direction:column;gap:2px}
.cd-item .cd-sku{font-size:14px;color:var(--red);font-weight:700;font-family:monospace}
.cd-item .cd-name{font-size:13px;font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--g800);text-decoration:none;transition:color var(--t)}
.cd-item .cd-name:hover{color:var(--red)}
.cd-item .cd-price{grid-row:1;grid-column:3;text-align:right;white-space:nowrap;font-weight:600}
.cd-item .cd-price-net{font-size:14px;font-weight:700;color:var(--g900)}
.cd-item .cd-price-sub{font-size:10px;color:var(--g500);font-weight:400}
.cd-item .cd-price-unit{font-size:10px;color:var(--g400);margin-top:1px;font-weight:400}
.cd-item .cd-actions{grid-row:2;grid-column:2/-1;display:flex;flex-direction:row;align-items:center;gap:6px;margin-top:4px;justify-content:flex-end}
.cd-item .cd-unit{font-size:11px;color:var(--g500);font-weight:500}
.cd-item .cd-remove{width:36px;height:36px;border-radius:8px;border:none;background:var(--g100);color:var(--g500);font-size:13px;transition:all var(--t);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}
.cd-item .cd-remove:hover{background:var(--red-light);color:var(--red)}
/* Volume discount banner — row 3 spans full width */
.cd-item>div[style*="flex-basis:100%"]{grid-row:3;grid-column:1/-1;flex-wrap:nowrap!important;min-width:0}
.cd-item>div[style*="flex-basis:100%"]>span{min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cd-item>div[style*="flex-basis:100%"]>button{flex-shrink:0}
.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)}

/* === MULTI-CART SELECTOR === */
.mc-bar{padding:6px 24px 8px;border-bottom:1px solid var(--g100)}
.mc-selector{display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none;padding:2px 0}
.mc-selector::-webkit-scrollbar{display:none}
.mc-tab{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:6px;border:none;background:none;font-size:12px;font-weight:500;color:var(--g500);cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0;position:relative}
.mc-tab:hover{color:var(--g800);background:var(--g50)}
.mc-tab.active{color:var(--red);font-weight:600;background:var(--red-light)}
.mc-tab.active::after{content:'';position:absolute;bottom:-7px;left:12px;right:12px;height:2px;background:var(--red);border-radius:1px}
.mc-tab .mc-cnt{font-size:10px;color:var(--g400);font-weight:600}
.mc-tab.active .mc-cnt{color:var(--red)}
.mc-add{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1.5px dashed var(--g300);background:none;color:var(--g400);font-size:12px;cursor:pointer;transition:all .15s;flex-shrink:0}
.mc-add:hover{border-color:var(--red);color:var(--red);border-style:solid}
.mc-actions{display:flex;gap:4px;padding:2px 0 0;justify-content:flex-end}
.mc-act-btn{font-size:10px;color:var(--g400);cursor:pointer;border:none;background:none;padding:2px 6px;border-radius:4px;transition:all .12s;font-family:inherit;font-weight:500;display:inline-flex;align-items:center;gap:3px}
.mc-act-btn:hover{color:var(--red)}
.mc-act-btn.danger:hover{color:#dc2626}
/* mc-bar inside page content (not drawer) */
.mc-bar-page{background:var(--g0);border:1.5px solid var(--g100);border-radius:var(--r-lg);padding:10px 20px;margin-bottom:20px}

/* === ORDER HISTORY === */
.oh-panel{padding:16px 24px}
.oh-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;border:1.5px solid var(--g200);background:var(--g0);font-size:12px;font-weight:600;color:var(--g600);cursor:pointer;transition:all .15s;width:100%;margin-top:8px}
.oh-toggle:hover{border-color:var(--red);color:var(--red)}
.oh-toggle i{color:var(--red)}
.oh-list{margin-top:12px}
.oh-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r);border:1px solid var(--g100);margin-bottom:8px;transition:all .15s;background:var(--g0)}
.oh-item:hover{border-color:var(--g300);box-shadow:var(--shadow-xs)}
.oh-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.oh-icon.order{background:var(--green-light);color:var(--green)}
.oh-icon.enquiry{background:var(--orange-light);color:var(--orange)}
.oh-info{flex:1;min-width:0}
.oh-ref{font-size:12px;font-weight:600;color:var(--g800);font-family:monospace}
.oh-date{font-size:11px;color:var(--g500)}
.oh-meta{font-size:11px;color:var(--g500);display:flex;gap:8px;margin-top:2px}
.oh-right{text-align:right;flex-shrink:0}
.oh-total{font-size:13px;font-weight:700;color:var(--g900)}
.oh-count{font-size:10px;color:var(--g500)}
.oh-reorder{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:6px;border:1.5px solid var(--g200);background:var(--g0);font-size:11px;font-weight:600;color:var(--g600);cursor:pointer;transition:all .15s;margin-top:4px}
.oh-reorder:hover{border-color:var(--red);color:var(--red);background:var(--red-light)}
.oh-empty{text-align:center;padding:24px 16px;color:var(--g400);font-size:13px}
.oh-clear{font-size:11px;color:var(--g400);cursor:pointer;border:none;background:none;padding:4px 8px;margin-top:8px;font-family:inherit;transition:color .15s}
.oh-clear:hover{color:#dc2626}
.cd-type-tag.enquiry{background:var(--orange-light);color:var(--orange)}

/* Variant table */
.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 #ECECEE;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:14px;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:13px;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:left;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}
.td-price .tier{display:flex;align-items:baseline;gap:6px;line-height:1.25}
.td-price .tier + .tier{margin-top:2px}
.td-price .tier .q{font-size:10px;font-weight:700;color:var(--g400);min-width:36px}
.td-price .tier .amt{font-size:13px;font-weight:700;color:var(--g900);white-space:nowrap}
.td-price .tier .br{font-size:10px;color:var(--g400);white-space:nowrap}
.td-price .tier-wh .q{color:#16a34a}
.td-price .tier-wh .amt{color:#16a34a}
.td-price .tier-hdr{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--red);margin-bottom:2px}
.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;cursor:pointer}
.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}
/* Larger stepper for cart drawer — better tap targets on mobile */
.qty-stepper.cd-qty{border-width:1.5px;border-radius:8px}
.qty-stepper.cd-qty button{width:38px;height:38px;font-size:16px;font-weight:600}
.qty-stepper.cd-qty input{width:52px;height:38px;font-size:14px;font-weight:700}
.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}

/* Search results — same product-card layout as category page but
   with variants hidden. Keep them in DOM so we can flip the rule
   to show variants again without re-rendering. */
.search-view .vt-section,
.search-view .mob-variants-btn,
.search-view .pdp-section,
.search-view .product-card .pc-top + button,
.search-view .product-card > div[style*="padding:0 20px"]{display:none!important}

.search-view .product-card{cursor:pointer}
.search-view .product-card .pc-name{pointer-events:auto}


/* === checkout.css === */
/* === CHECKOUT LAYOUT === */
.checkout-layout{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
.checkout-main{min-width:0;padding:0 16px}
.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-grid>.rec-card,
.checkout-side .rec-card{min-width:0!important;max-width:none!important;width:100%;flex-direction:row;gap:0;border:1px solid var(--g100);box-shadow:none}
/* Hide the slider chevrons inside checkout sidebar (no horizontal scroll there) */
.checkout-side .rec-nav-btn{display:none!important}
.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%}
.rec-grid{display:flex;gap:14px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:4px 2px 12px;scrollbar-width:none;max-width:100%;scroll-snap-type:x proximity}
.rec-grid::-webkit-scrollbar{display:none}
.rec-grid>.rec-card{min-width:200px;max-width:200px;flex-shrink:0;scroll-snap-align:start}
/* Intuitive prev/next chevrons rendered into .rec-slider-wrap by JS */
.rec-nav-btn{position:absolute;top:calc(50% - 14px);transform:translateY(-50%);z-index:5;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--g200);box-shadow:0 4px 12px rgba(0,0,0,.12);color:var(--g700);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t);padding:0}
.rec-nav-btn:hover{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 4px 16px rgba(226,0,26,.3)}
.rec-nav-btn.prev{left:6px}
.rec-nav-btn.next{right:6px}
.rec-nav-btn[hidden]{display:none}
.rec-card{background:#fff;border-radius:var(--r);border:1px solid var(--g200);overflow:hidden;transition:all var(--t);display:flex;flex-direction:column;min-width:0}
.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.css === */
/* === 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:12px 16px;background:var(--g0);border:1.5px solid var(--g200);border-radius:var(--r);font-size:14px;font-weight:600;color:var(--g700);width:100%;cursor:pointer;margin-bottom:12px;min-height:48px}
.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 cubic-bezier(.4,0,.2,1)}
@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;width:44px;height:44px;display:flex;align-items:center;justify-content:center}

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

  /* Announcement bar mobile */
  #announcementBar{font-size:11px!important;padding:8px 12px!important;line-height:1.4}
  #announcementBar strong{font-size:11px}
  #announcementText{flex-wrap:wrap;justify-content:center}

  /* Header — mobile: [hamburger] [===logo===] [enquiry][cart] */
  .header .inner{
    gap:6px;flex-wrap:wrap;padding:8px 12px;
    display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto;align-items:center;
  }
  .mega-wrap{grid-column:1;grid-row:1;justify-self:start}
  .mega-btn{padding:0;width:44px;height:44px;border-radius:8px;justify-content:center;font-size:0;background:var(--g0);border:1.5px solid var(--g200);color:var(--g700)}
  .mega-btn .ham{gap:4px}
  .mega-btn .ham span{width:18px;height:2px;background:var(--g700)}
  .mega-label{display:none!important}
  .logo-img{height:48px;grid-column:2;grid-row:1;justify-self:center}
  .header-right{grid-column:3;grid-row:1;gap:6px;display:flex;align-items:center;justify-self:end}
  .hdr-btn{padding:0 10px;height:44px;font-size:12px;min-width:44px;justify-content:center}
  .hdr-btn span{display:none}
  .hdr-btn i{font-size:16px}
  .hdr-btn.primary{padding:0 12px;min-width:44px;position:relative}
  .cart-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;border-radius:10px;font-size:10px;padding:0 5px;display:flex!important;align-items:center;justify-content:center;line-height:1}
  .search-box{grid-column:1/-1;grid-row:2;max-width:100%;margin:4px 0 0}
  .search-box input{padding:10px 48px 10px 14px;font-size:14px;height:44px}
  .search-box .sbtn{top:4px;bottom:4px;right:4px;width:38px}
  .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);min-height:48px}
  .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;width:44px;height:44px;display:flex;align-items:center;justify-content:center}

  /* Breadcrumb — scroll affordance with gradient mask */
  .breadcrumb-bar .inner{padding:0 12px;font-size:12px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .breadcrumb-bar .inner::-webkit-scrollbar{display:none}
  .breadcrumb-bar{position:relative}
  .breadcrumb-bar::after{content:'';position:absolute;top:0;right:0;bottom:0;width:32px;background:linear-gradient(to right,transparent,var(--g0));pointer-events:none}

  /* 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:14px}

  /* Medium Finder button on mobile: icon only (Norwegian placeholder
     pushes the red button off-screen otherwise on iPhone Chrome) */
  .hp-mf-search .mf-btn-lbl{display:none}
  .hp-mf-search button{padding:0 14px}

  /* Categories grid */
  .cat-grid{grid-template-columns:1fr 1fr;gap:8px}
  .cat-card{padding:10px;min-height:48px}
  .cat-card h3{font-size:13px}
  .cat-card::before{display:none}
  .cat-card img{height:80px!important}
  .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:13px;flex-wrap:wrap;gap:8px;border-radius:var(--r) var(--r) 0 0}
  .sort-wrap{width:100%}
  .sort-sel{width:100%;min-height:44px;font-size:14px}

  /* Product cards — flattened żeby pasowały do .pdp-section (płaska karta,
     bez zagnieżdżonych "pudełek"). product-list traci side borders, product-card
     traci horizontal padding, vt-section traci border-radius + shadow. */
  .product-list{border-left:none;border-right:none;background:transparent}
  .product-card{padding:14px 0;border-bottom:none;background:var(--g0);border-top:6px solid var(--g100)}
  .product-card:first-child{border-top:none}
  .product-card .pc-top{padding:0 16px}
  .vt-section{border-radius:0;box-shadow:none;margin-top:0;margin-bottom:0;background:transparent}
  .product-card .mob-variants-btn{margin-left:16px;margin-right:16px;width:auto}

  .pc-top{flex-direction:column;gap:10px}
  /* Image — ten sam look co .pdp-img-wrap na mobile: bez border/radius,
     wyższy (220px ≈ pdp 260), padding wewnątrz, separator dolny. */
  .pc-img{width:100%;height:220px;border:none;border-radius:0;border-bottom:1px solid var(--g100);background:#fff}
  .pc-img img{max-width:100%;max-height:100%;padding:16px;object-fit:contain}
  .pc-name{font-size:15px}
  .pc-specs{font-size:12px}

  /* 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:14px;margin-top:8px;background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--r);font-size:14px;font-weight:600;color:var(--g700);cursor:pointer;transition:all var(--t);min-height:48px}
  .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-search input{min-height:44px;font-size:14px}
  .vt-filter-btn{margin-left:auto!important;flex-shrink:0;min-height:44px;padding:7px 16px}
  /* PDP: outer toolbar wrapper full-width — padding zgodne z listingiem (8px 0) */
  .pdp-section .vt-toolbar{flex:1 1 100%!important;padding:8px 0!important}
  .product-card .vt-toolbar{padding:8px 0}

  /* 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:12px;border-bottom:1px solid var(--g100);gap:0;
  }
  .vt-table td{padding:0;font-size:13px}
  .vt-table td::before{display:none}
  .vt-table td.td-avail-cell::before{display:inline-block!important}
  /* spec separator " · " między mm/bar — exception dla td-spec ::before */
  .vt-table td.td-spec+td.td-spec::before{display:inline!important}
  /* td-info — partner flex tytułu w pierwszej linii. align-self:stretch
     (default) sprawia, że box rozciąga się na wysokość .td-sku-name; samo
     [i] centruje się w środku przez align-items:center na td-info.
     Identycznie na listingu i PDP.
     UWAGA: JS klonuje [i] button do td-info, oryginał zostaje w td-actions.
     Tutaj ukrywamy oryginał na mobile (żeby nie było dwóch [i]). */
  .vt-table td.td-info{order:2!important;flex:0 0 44px!important;display:flex!important;align-items:center;justify-content:center;padding:0;margin:0;background:none!important}
  .vt-table td.td-info .btn-icon{width:40px;height:40px;font-size:12px;margin:0;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--g200);border-radius:8px;background:var(--g0);color:var(--g600);cursor:pointer}
  /* Mobile: ukryj ORYGINAŁ [i] w td-actions — używamy klona w td-info */
  .vt-table td.td-actions .btn-icon{display:none!important}
  /* Quantity stepper na dole, 50/50 z ATC, ta sama wysokość 44px co ATC.
     display:flex+align-items:center żeby wyrównać do td-actions, które też
     centruje btn-cart. Bez tego stepper siedzi przy padding-top, ATC w środku
     komórki — visual offset paru px.
     padding-right:8px + td-actions padding-left:8px = 16px gap między qty a ATC. */
  .vt-table td.td-qty{display:flex!important;align-items:center!important;flex:1 1 calc(50% - 8px)!important;order:7!important;padding-top:6px;padding-right:8px;border-bottom:none!important;margin-bottom:0!important}
  /* qty-stepper na mobile: 44px outer, jak ATC. flex:1 1 0 (basis 0) na inpucie
     żeby NIE zjadał miejsca dla [+] buttona. */
  .vt-table td.td-qty .qty-stepper{width:100%!important;height:44px!important;box-sizing:border-box!important;display:flex!important;border-radius:8px!important;overflow:hidden!important}
  .vt-table td.td-qty .qty-stepper button{flex:0 0 44px!important;width:44px!important;height:100%!important;font-size:18px!important;box-sizing:border-box!important;padding:0!important;line-height:1}
  .vt-table td.td-qty .qty-stepper input{flex:1 1 0!important;width:0!important;min-width:0!important;max-width:none!important;height:100%!important;text-align:center!important;font-size:14px!important;box-sizing:border-box!important;padding:0 4px!important}
  /* "On request" w td-price na mobile dubluje się z badgem w Tilgjengelighet — ukryj.
     Dodatkowo ukrywamy CAŁY td-price gdy jego jedyna zawartość to .price-on-req,
     żeby pusta komórka nie zostawiała border-bottom + padding-bottom (osierocona kreska). */
  .vt-table td.td-price .price-on-req{display:none}
  .vt-table td.td-price:has(.price-on-req){display:none!important}
  .vt-table td.td-qty .qty-stepper input::-webkit-outer-spin-button,
  .vt-table td.td-qty .qty-stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
  /* "Kun på lager" toggle na lewo na mobile (desktop ma margin-left:auto z products.css) */
  .vt-stock-toggle{margin-left:0!important}
  /* Listing 1:1 z PDP — separator lines pod każdą sekcją (PDP ma to z pdp.css 'pdp-section table td{border-bottom:...}'). td-info dzieli linię z td-sku-name, więc dostaje ten sam border żeby separator szedł przez całą szerokość. */
  .product-card .vt-table td.td-sku-name,
  .product-card .vt-table td.td-info,
  .product-card .vt-table td.td-spec,
  .product-card .vt-table td.td-avail,
  .product-card .vt-table td.td-price{border-bottom:1px solid var(--g100);padding-bottom:8px;margin-bottom:8px}
  .pdp-section .vt-table td.td-sku-name,
  .pdp-section .vt-table td.td-info,
  .pdp-section .vt-table td.td-spec,
  .pdp-section .vt-table td.td-avail,
  .pdp-section .vt-table td.td-price{padding-bottom:8px;margin-bottom:8px}
  /* spec cells inline obok siebie — auto-width (np. samo "3 mm" = ~50px).
     border-bottom na spec cell pokrywałby tylko jej szerokość (krótka linia),
     więc usuwamy go i zamiast tego polegamy na border-top td-avail (100% wide)
     który wizualnie pełni rolę separatora pod spec row. Patrz reguła td-avail
     border-top niżej. */
  .vt-table td.td-spec{border-bottom:none!important;margin-bottom:0!important;padding-bottom:8px}
  /* td-avail border-top = separator pod spec row, pełna szerokość */
  .vt-table td.td-avail{border-top:1px solid var(--g100);padding-top:8px}

  /* Line 1+2: SKU + name. flex-basis:calc(100% - 52px) + td-info flex-basis:44px
     razem wypełniają 100% szerokości tr — spec cells (order:3) wrappują się
     do drugiej linii. Bez tego specs ciskałyby się obok [i] na pierwszej linii. */
  .td-sku-name{flex:1 1 calc(100% - 52px)!important;order:1;padding-bottom:4px;min-width:0}
  .td-sku-code{font-size:13px;font-weight:700;white-space:nowrap}
  .td-name-desc{font-size:12px;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:13px;font-weight:600;color:var(--g800);padding:0 0 4px 0;margin-right:0;white-space:nowrap}
  .td-spec small{font-size:11px;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, with 50/50 label | value */
  .td-avail{flex:1 1 100%;order:4;text-align:left;padding-top:2px;padding-bottom:4px}
  .td-avail-cell{display:flex!important;align-items:center;gap:8px;width:100%!important}
  .td-avail-cell::before{content:attr(data-label);flex:0 0 50%;color:var(--g500);font-size:12px;font-weight:500;text-align:left;white-space:nowrap}
  .td-avail-cell .avail-badge{margin-left:auto}
  /* Line 5: price — full width, with "Pris [unit]" label | amount layout per tier */
  .td-price{flex:1 1 100%;order:5;text-align:right;margin-left:0;padding-bottom:4px;display:block!important}
  .td-price .amount{font-size:14px;font-weight:700}
  .td-price .sub{font-size:10px;color:var(--g500)}
  .td-price .tier{display:flex!important;align-items:baseline;gap:6px}
  .td-price .tier::before{content:attr(data-label);flex:0 0 50%;color:var(--g500);font-size:12px;font-weight:500;text-align:left;white-space:nowrap}
  /* .q jest już zawarty w data-label (np. "Pris ≥50m") — duplikat ukrywamy żeby zwolnić miejsce dla br "(NOK)" */
  .td-price .tier .q{display:none}
  .td-price .tier .amt{margin-left:auto;font-size:14px;white-space:nowrap}
  .td-price .tier .br{font-size:10px;white-space:nowrap;color:var(--g400)}
  .td-price .tier-hdr{display:none}
  /* Line 6: ATC bottom row, 50% (drugie 50% to td-qty z order:7 powyżej).
     flex basis + padding-left muszą się zgadzać z td-qty (calc(50% - 8px) + 8px),
     inaczej cells mają różne szerokości i przyciski siedzą na różnych X-ach.
     UWAGA: selektor MUSI być .vt-table td.td-actions (specificity 0,2,1), bo
     .vt-table td{padding:0} (0,1,1) by inaczej nadpisał padding-top:6 na 0,
     przez co ATC siedział 6px wyżej niż qty stepper (różnica padding-top). */
  .vt-table td.td-actions{flex:1 1 calc(50% - 8px)!important;order:8!important;display:flex;gap:6px;align-items:center;padding-top:6px;padding-left:8px;justify-content:flex-end}
  .btn-cart{flex:1 1 auto;padding:0 14px;height:44px;font-size:12px;justify-content:center;margin-left:0;width:100%}
  .btn-icon{height:44px;width:44px;font-size:13px;margin-left:0;padding:0}
  /* Stepper on mobile: compact but tappable — shown before cart button in actions row */
  .qty-stepper{display:inline-flex;flex-shrink:0}
  .qty-stepper button{width:36px;height:36px;font-size:16px}
  .qty-stepper input{width:40px;height:36px;font-size:13px}

  .expand-btn{font-size:13px;padding:12px 16px;min-height:44px}
  .vt-footer{font-size:12px;padding:10px 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:12px;padding:3px 8px;margin-bottom:10px}
  .pdp-price{font-size:26px;font-weight:800;margin-bottom:2px}
  .pdp-price-sub{font-size:13px;margin-bottom:12px}
  .pdp-meta{font-size:13px;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:12px}
  .pdp-desc{font-size:13px;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:12px;font-weight:600;color:var(--red);cursor:pointer;background:linear-gradient(transparent,var(--g0) 50%);margin-top:-24px;position:relative;z-index:1;min-height:44px;display:flex;align-items:center;justify-content:center}
  .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:12px 8px;font-size:13px;min-width:0;min-height:48px}
  .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:14px;padding:10px 16px;min-height:48px;display:flex;align-items:center}

  /* Specs table: single column on mobile */
  .pdp-attrs-grid{grid-template-columns:1fr;padding:0}
  .pdp-attr{padding:10px 16px;gap:8px;min-height:44px}
  .pdp-attr .ak{font-size:13px;min-width:0;flex:1}
  .pdp-attr .av{font-size:13px;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: tighter cards in horizontal scroller */
  .rec-grid{gap:10px}
  .rec-grid>.rec-card{min-width:160px;max-width:160px}
  .rec-nav-btn{display:none}
  .rec-card-name{font-size:12px;-webkit-line-clamp:2}
  .rec-card-btn{font-size:11px;padding:8px 10px;min-height:36px}

  /* 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:13px;padding:10px 8px;height:48px}
  .modal-atc{font-size:15px;height:52px}
  .modal-close{width:44px;height:44px}

  /* Multi-cart mobile */
  .mc-bar{padding:0 16px 8px}
  .mc-tab{font-size:11px;padding:5px 10px}
  .mc-add{width:28px;height:28px}
  .oh-item{padding:10px;gap:8px}
  .oh-icon{width:32px;height:32px;font-size:12px}
  .oh-reorder{padding:5px 10px;font-size:10px}

  /* Cart drawer: full width + mobile layout */
  .cart-drawer{width:100vw;max-width:100%;right:-110vw}
  .cd-header .cd-close{width:44px;height:44px}
  /* Cart drawer item on mobile — matches checkout bestilling 3-col layout */
  .cd-item{grid-template-columns:50px 1fr auto;padding:12px 0;gap:4px 10px}
  .cd-item .cd-img-box{width:50px!important;height:50px!important}
  .cd-item .cd-sku{font-size:11px}
  .cd-item .cd-name{font-size:12px;-webkit-line-clamp:2}
  .cd-item .cd-price-net{font-size:13px}
  .cd-item .cd-price-sub,.cd-item .cd-price-unit{font-size:9px}
  .cd-item .cd-actions{gap:8px;margin-top:2px}
  .cd-item .cd-remove{width:36px;height:36px;font-size:12px;margin-top:2px}
  /* Stepper — consistent sizing for cart drawer AND checkout on mobile */
  .qty-stepper.cd-qty button{width:36px;height:36px;font-size:15px;font-weight:700}
  .qty-stepper.cd-qty input{width:48px;height:36px;font-size:13px;font-weight:700}
  /* Volume discount hint — force single line, span full cart item width */
  .cd-item>div[style*="flex-basis:100%"]{grid-column:1/-1!important;grid-row:3;margin:0!important;padding:6px 10px!important;font-size:10px!important;line-height:1.3!important;flex-wrap:nowrap!important;justify-content:flex-start!important;gap:6px!important}
  .cd-item>div[style*="flex-basis:100%"]>span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}
  .cd-item>div[style*="flex-basis:100%"]>button{flex-shrink:0}

  /* Checkout table: hide header, card layout on mobile */
  #checkoutTable{display:block}
  #checkoutTable tr{display:grid;grid-template-columns:50px 1fr auto auto;grid-template-rows:auto auto;gap:4px 6px;padding:12px 16px;border-bottom:1px solid var(--g100);position:relative}
  thead{display:none}
  #checkoutTable td{padding:4px 0!important;border:none!important}
  /* Image (td 1) — spans both rows */
  #checkoutTable td:nth-child(1){grid-row:1/3;grid-column:1;width:50px}
  #checkoutTable td:nth-child(1) div{width:50px!important;height:50px!important}
  /* SKU + name (td 2) — TOP, left col */
  #checkoutTable td:nth-child(2){grid-row:1;grid-column:2;font-size:13px}
  /* Qty stepper (td 3) — BOTTOM row, col 3 */
  #checkoutTable td:nth-child(3){grid-row:2;grid-column:3;text-align:right!important}
  /* Price (td 4) — TOP, spans cols 3-4 (right-aligned) */
  #checkoutTable td:nth-child(4){grid-row:1;grid-column:3/-1;text-align:right!important;font-size:13px}
  /* Trash (td 5) — BOTTOM row, col 4, tight next to stepper */
  #checkoutTable td:nth-child(5){grid-row:2;grid-column:4;text-align:left!important;padding-left:0!important}
  #checkoutTable td:nth-child(5) button{min-width:36px;min-height:36px;width:36px;height:36px;font-size:12px}
  /* Totals row */
  #checkoutTable tr:last-child{display:flex;justify-content:flex-end;gap:12px}
  #checkoutTable tr:last-child td{padding:12px 0!important}
  /* Form grid */
  .co-form-grid{grid-template-columns:1fr!important}

  /* Footer */
  .footer .inner{padding:0 16px!important}
  .footer-grid{grid-template-columns:1fr!important;gap:24px!important;text-align:center}
  .footer-grid a{justify-content:center;word-break:break-all;font-size:13px;min-height:44px;display:flex;align-items:center}
  .footer-grid>div{display:flex;flex-direction:column;align-items:center}
  .footer-grid>div>div[style*="display:flex"]{justify-content:center!important}
  .footer-grid+div{flex-direction:column!important;align-items:center!important;gap:8px!important}

  /* Pagination */
  .pagination{gap:8px}
  .pg-btn{min-width:44px;height:44px;font-size:13px}
}

@media(max-width:380px){
  .cat-grid{grid-template-columns:1fr}
  /* NIE używaj `.mega-btn span:not(.ham)` — łapie spany kresek wewnątrz <div class="ham">
     i ukrywa cały hamburger. Label jest już ukryty przez .mega-label{display:none!important}
     w regule @media(max-width:768px) wyżej. */
  .hdr-btn.primary{padding:0 8px}
}

/* Desktop (>768px): ukryj klon td-info wstrzykiwany przez js/pdp-related.js.
   Klon istnieje TYLKO dla układu mobile (Tytuł|[i] górna linia). Na desktop
   oryginalny [i] siedzi w td-actions (HANDLINGER kolumna), klon byłby ósmą
   kolumną bez nagłówka i łamałby alignment tabeli. */
@media(min-width:769px){
  .vt-table td.td-info{display:none!important}
}
