*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;font-size:14px;background:#f0f0f0;color:#222;overflow-x:hidden;padding-bottom:60px}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}
:root{--p:#1a1a2e;--a:#e8420a;--gold:#f5c842;--green:#25d366;--teal:#4ecdc4;--w:#fff;--b:#e5e5e5;--r:4px;--rm:6px;--rl:8px}
.g-wrap{max-width:1200px;margin:0 auto;padding:0 14px}
.g-ann{background:var(--p);color:#fff;text-align:center;font-size:12px;padding:7px 16px}
.g-header{background:var(--w);border-bottom:1px solid var(--b);position:sticky;top:0;z-index:200;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.g-top{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid #f0f0f0}
.g-logo{font-weight:700;font-size:20px;color:var(--p);white-space:nowrap;flex-shrink:0}
.g-logo em{color:var(--a);font-style:normal}
.g-logo img{height:42px;width:auto}
.g-search{flex:1;display:flex;border:2px solid var(--p);border-radius:var(--r);overflow:hidden;max-width:560px}
.g-search form{display:flex;flex:1}
.g-search input[type=search],.g-search input[type=text]{flex:1;border:none;padding:8px 12px;font-size:13px;outline:none;font-family:inherit}
.g-search button{background:var(--p);color:#fff;border:none;padding:0 16px;font-size:14px}
.g-actions{display:flex;gap:8px;margin-left:auto;flex-shrink:0}
.g-btn{display:inline-flex;align-items:center;gap:6px;border:none;padding:8px 14px;font-size:12px;font-weight:600;border-radius:var(--r);cursor:pointer;white-space:nowrap;transition:opacity .2s;text-decoration:none}
.g-btn-wa{background:var(--green);color:#fff}
.g-btn-wa:hover{opacity:.88;color:#fff}
.g-btn-quote{background:var(--a);color:#fff}
.g-btn-quote:hover{opacity:.88}
.g-bottom{display:flex;align-items:center}
.g-mega{position:relative}
.g-mega-btn{display:flex;align-items:center;gap:8px;background:var(--p);color:#fff;padding:10px 16px;font-size:13px;font-weight:500;border:none;cursor:pointer;white-space:nowrap;height:100%}
.g-mega-menu{position:absolute;top:100%;left:0;background:var(--w);border:1px solid var(--b);box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:300;display:none;min-width:240px}
.g-mega:hover .g-mega-menu{display:block}
.g-mega-menu li a{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:13px;color:#333;border-bottom:1px solid #f5f5f5}
.g-mega-menu li a:hover{background:#fff5f2;color:var(--a)}
.g-mega-menu li a span{width:26px;text-align:center;font-size:16px}
.g-nav{display:flex}
.g-nav a{padding:10px 12px;font-size:13px;font-weight:500;color:#333;border-bottom:2px solid transparent;white-space:nowrap;display:block;transition:color .15s}
.g-nav a:hover,.g-nav a.active{color:var(--a);border-bottom-color:var(--a)}
.g-nav-right{margin-left:auto;font-size:12px;color:#666;white-space:nowrap;padding:0 8px}
.g-nav-right a:hover{color:var(--a)}
.g-hero-grid{display:grid;grid-template-columns:1fr 360px;gap:12px;padding:14px 0}
.g-hero-main{border-radius:var(--rl);background:linear-gradient(135deg,#0f2027,#203a43,#2c5364);min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;padding:32px 34px;position:relative;overflow:hidden}
.g-hero-bg{position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:110px;opacity:.06;pointer-events:none}
.g-hero-badge{background:var(--a);color:#fff;font-size:10px;font-weight:700;padding:4px 9px;border-radius:2px;width:fit-content;margin-bottom:11px;letter-spacing:.06em;text-transform:uppercase}
.g-hero-main h1{font-size:28px;font-weight:700;color:#fff;line-height:1.22;margin-bottom:8px}
.g-hero-main h1 span{color:var(--gold)}
.g-hero-main p{color:rgba(255,255,255,.65);font-size:13px;margin-bottom:18px;line-height:1.6;max-width:340px}
.g-hero-btn{background:var(--a);color:#fff;border:none;padding:10px 20px;font-size:13px;font-weight:600;border-radius:var(--r);display:inline-block}
.g-hero-btn:hover{opacity:.88;color:#fff}
.g-hero-side{display:flex;flex-direction:column;gap:10px}
.g-hero-sm{border-radius:var(--rl);position:relative;flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding:18px;min-height:145px;overflow:hidden}
.g-orange{background:linear-gradient(135deg,#c95c0a,#f7931e)}
.g-teal{background:linear-gradient(135deg,#1a535c,#4ecdc4)}
.g-sm-bg{position:absolute;right:12px;bottom:10px;font-size:46px;opacity:.15;pointer-events:none}
.g-sm-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.7);margin-bottom:4px}
.g-hero-sm h3{font-size:15px;font-weight:700;color:#fff;line-height:1.25;margin-bottom:9px}
.g-sm-btn{background:rgba(255,255,255,.22);color:#fff;border:1px solid rgba(255,255,255,.4);padding:5px 12px;font-size:11px;font-weight:600;border-radius:2px;cursor:pointer;font-family:inherit}
.g-sm-btn:hover{background:rgba(255,255,255,.38)}
.g-services{background:var(--w);border:1px solid var(--b);border-radius:var(--rm);margin:0 0 12px;display:grid;grid-template-columns:repeat(4,1fr)}
.g-svc{display:flex;align-items:center;gap:10px;padding:12px 14px;border-right:1px solid #f0f0f0}
.g-svc:last-child{border-right:none}
.g-svc span{font-size:22px;flex-shrink:0}
.g-svc b{display:block;font-size:12px;font-weight:600;color:#222}
.g-svc small{font-size:11px;color:#888;display:block}
.g-sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.g-sec-hd h2{font-size:17px;font-weight:700;color:var(--p);padding-bottom:5px;position:relative}
.g-sec-hd h2::after{content:'';position:absolute;bottom:0;left:0;width:32px;height:3px;background:var(--a);border-radius:2px}
.g-sec-hd a{font-size:12px;color:var(--a);font-weight:500}
.g-cats{background:var(--w);border:1px solid var(--b);border-radius:var(--rm);padding:14px;margin-bottom:12px}
.g-cats-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:6px}
.g-cat{display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none;padding:8px 4px;border-radius:var(--rm);transition:background .15s;position:relative}
.g-cat:hover{background:#fff5f2}
.g-cat-ico{width:56px;height:56px;border-radius:50%;background:#f5f5f5;border:2px solid #eee;display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden;transition:border-color .15s}
.g-cat-ico img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.g-cat:hover .g-cat-ico{border-color:#eee}
.g-cat span{font-size:10px;font-weight:500;color:#333;text-align:center;line-height:1.3}
.g-prods{background:var(--w);border:1px solid var(--b);border-radius:var(--rm);padding:14px;margin-bottom:12px}
.g-tabs-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:0}
.g-tabs{display:flex;gap:4px;background:#f5f5f5;border-radius:8px;padding:4px}
.g-tab,.g-tab-btn{background:none;border:none;border-radius:6px;padding:8px 18px;font-size:13px;font-weight:500;color:#666;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}
.g-tab:hover,.g-tab-btn:hover{color:#1a1a2e}
.g-tab.active,.g-tab-btn.active{background:#fff;color:var(--a);font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.g-tabs-row > a{font-size:12px;color:var(--a);font-weight:600;white-space:nowrap}
.g-tab-pane{display:none;grid-template-columns:repeat(5,1fr);gap:10px}
.g-tab-pane.active{display:grid}
.g-pcard{border:1px solid #ebebeb;border-radius:var(--rm);overflow:hidden;cursor:pointer;transition:box-shadow .2s;background:var(--w);position:relative}
.g-pcard:hover{box-shadow:0 4px 16px rgba(0,0,0,.1);border-color:#ddd}
.g-pcard:hover .g-pqv{opacity:1;transform:translateY(0)}
.g-pimg{height:155px;display:flex;align-items:center;justify-content:center;background:#f8f8f8;position:relative;overflow:hidden;font-size:44px}
.g-pimg img{width:100%;height:100%;object-fit:cover}
.g-pbadge{position:absolute;top:7px;left:7px;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:2px;text-transform:uppercase}
.g-pbadge-red{background:var(--a)}
.g-pbadge-green{background:#2eb872}
.g-pqv{position:absolute;bottom:0;left:0;right:0;background:var(--p);color:#fff;text-align:center;padding:7px;font-size:11px;font-weight:600;opacity:0;transform:translateY(6px);transition:all .2s}
.g-pbody{padding:10px}
.g-psku{font-size:9px;color:#bbb;margin-bottom:2px;font-weight:500}
.g-pname{font-size:12px;font-weight:500;color:#333;line-height:1.4;margin-bottom:4px;min-height:32px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.g-pstars{color:var(--gold);font-size:10px;margin-bottom:4px}
.g-pprice{font-size:13px;font-weight:700;color:var(--a)}
.gondola-enquire-btn{display:block;width:100%;background:var(--a);color:#fff;border:none;padding:8px;font-size:12px;font-weight:600;cursor:pointer;border-radius:var(--r);margin-top:8px}
.gondola-enquire-single{background:var(--a);color:#fff;border:none;padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;border-radius:var(--r);width:100%;margin-top:14px;display:block}
.g-promos{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.g-promo{border-radius:var(--rm);position:relative;min-height:140px;display:flex;align-items:center;padding:24px 26px;overflow:hidden}
.g-promo-dark{background:linear-gradient(120deg,#0f2027 55%,#2c5364)}
.g-promo-green{background:linear-gradient(120deg,#1a3a1a 55%,#2d5a2d)}
.g-promo-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5);margin-bottom:5px}
.g-promo h3{font-size:18px;font-weight:700;color:#fff;margin-bottom:5px;line-height:1.2}
.g-promo h3 b{color:var(--gold)}
.g-promo p{font-size:11px;color:rgba(255,255,255,.6);margin-bottom:12px;line-height:1.5}
.g-promo-btn{background:var(--a);color:#fff;border:none;padding:7px 14px;font-size:11px;font-weight:600;border-radius:2px;cursor:pointer;font-family:inherit}
.g-promo-btn-teal{background:#1a535c}
.g-promo-ico{position:absolute;right:20px;bottom:10px;font-size:60px;opacity:.12;pointer-events:none}
.g-blog{background:var(--w);border:1px solid var(--b);border-radius:var(--rm);padding:14px;margin-bottom:12px}
.g-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g-blog-card{border:1px solid #ebebeb;border-radius:var(--rm);overflow:hidden;display:block;text-decoration:none;transition:box-shadow .2s;background:var(--w)}
.g-blog-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.1)}
.g-blog-img{height:155px;background:#f8f8f8;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:48px}
.g-blog-img img{width:100%;height:100%;object-fit:cover}
.g-blog-cat{position:absolute;top:8px;left:8px;background:var(--p);color:#fff;font-size:9px;font-weight:700;padding:3px 8px;border-radius:2px;text-transform:uppercase}
.g-blog-body{padding:13px}
.g-blog-meta{font-size:10px;color:#bbb;margin-bottom:7px}
.g-blog-title{font-size:13px;font-weight:700;color:var(--p);line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.g-blog-exc{font-size:11px;color:#777;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}
.g-blog-foot{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid #f5f5f5}
.g-blog-tag{font-size:10px;background:#f0f0f0;color:#666;padding:2px 8px;border-radius:20px}
.g-blog-more{font-size:11px;font-weight:600;color:var(--a)}
.g-brands{background:var(--w);border:1px solid var(--b);border-radius:var(--rm);padding:14px 18px;margin-bottom:12px}
.g-brands-row{display:grid;grid-template-columns:repeat(6,1fr)}
.g-brand{display:flex;align-items:center;justify-content:center;padding:10px;border-right:1px solid #f0f0f0;font-size:13px;font-weight:700;color:#bbb;letter-spacing:.06em}
.g-brand:last-child{border-right:none}
.g-brand:hover{color:var(--p)}
.g-footer{background:var(--p);color:#888;padding:32px 0 0}
.g-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.07)}
.g-footer-logo{font-size:18px;font-weight:700;color:#fff;margin-bottom:8px}
.g-footer-logo em{color:var(--a);font-style:normal}
.g-footer-logo img{height:38px;width:auto;margin-bottom:10px}
.g-footer p{font-size:12px;line-height:1.7;color:#777;margin-bottom:12px}
.g-footer-contact{font-size:12px;color:#777;line-height:2.2}
.g-footer-contact a{color:#bbb}
.g-footer-contact a:hover{color:var(--a)}
.g-footer h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#fff;margin-bottom:11px}
.g-footer ul li{margin-bottom:6px}
.g-footer ul a{font-size:12px;color:#777}
.g-footer ul a:hover{color:var(--a)}
.g-footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:11px;color:#555;flex-wrap:wrap;gap:6px}
.g-footer-bottom a{color:#555;margin-left:12px}
.g-footer-bottom a:hover{color:var(--a)}
.g-wa-float{position:fixed;bottom:30px;right:26px;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.g-wa-label{background:var(--p);color:#fff;font-size:11px;font-weight:600;padding:5px 11px;border-radius:20px;white-space:nowrap;opacity:0;transition:all .2s;pointer-events:none;position:absolute;right:66px;bottom:50%;transform:translateY(50%) translateX(8px)}
.g-wa-float:hover .g-wa-label{opacity:1;transform:translateY(50%) translateX(0)}
.g-wa-btn{width:56px;height:56px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.4);transition:all .2s;text-decoration:none;position:relative}
.g-wa-btn:hover{background:#1da855;transform:scale(1.06)}
.g-wa-btn::before{content:'';position:absolute;width:56px;height:56px;border-radius:50%;background:rgba(37,211,102,.3);animation:wapulse 2.2s ease-out infinite}
@keyframes wapulse{0%{transform:scale(1);opacity:.8}70%{transform:scale(1.6);opacity:0}100%{transform:scale(1.6);opacity:0}}
.g-mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:58px;background:var(--w);border-top:1px solid var(--b);z-index:500;box-shadow:0 -4px 16px rgba(0,0,0,.08);grid-template-columns:1fr 1fr 1fr}
.g-mb-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:none;background:transparent;border-right:1px solid #f0f0f0;padding:5px;text-decoration:none;transition:background .15s}
.g-mb-btn:last-child{border-right:none}
.g-mb-btn:active{background:#f8f8f8}
.g-mb-btn span{font-size:10px;font-weight:600;line-height:1}
.g-mb-call span{color:#1a4bcc}
.g-mb-email span{color:var(--a)}
.g-mb-wa span{color:#25d366}
.g-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
.g-modal-overlay.open{opacity:1;pointer-events:all}
.g-modal{background:var(--w);border-radius:var(--rl);width:92%;max-width:760px;max-height:90vh;overflow-y:auto;position:relative;transform:translateY(20px);transition:transform .25s}
.g-modal-overlay.open .g-modal{transform:translateY(0)}
.g-modal-close{position:absolute;top:13px;right:14px;background:none;border:none;font-size:20px;cursor:pointer;color:#666;z-index:2;line-height:1}
.g-modal-close:hover{color:var(--a)}
.g-modal-inner{display:grid;grid-template-columns:1fr 1fr;min-height:380px}
.g-modal-left{background:#f8f8f8;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px;gap:12px;border-right:1px solid #f0f0f0;border-radius:var(--rl) 0 0 var(--rl);text-align:center}
.g-m-sku{font-size:10px;color:#bbb;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.g-m-name{font-size:16px;font-weight:700;color:var(--p);line-height:1.3}
.g-m-price{font-size:13px;font-weight:700;color:var(--a)}
.g-m-desc{font-size:12px;color:#777;line-height:1.6;max-width:200px}
.g-m-badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}
.g-m-badge{font-size:10px;background:#f0f0f0;color:#555;padding:3px 8px;border-radius:20px}
.g-modal-right{padding:26px;display:flex;flex-direction:column}
.g-modal-right h3{font-size:15px;font-weight:700;color:var(--p);margin-bottom:4px}
.g-sub{font-size:12px;color:#888;margin-bottom:16px;line-height:1.5}
.g-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.g-fg{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}
.g-fg label{font-size:11px;font-weight:600;color:#555}
.g-fg input,.g-fg textarea{border:1px solid #ddd;border-radius:var(--r);padding:8px 10px;font-size:13px;color:#222;outline:none;font-family:inherit;width:100%;transition:border-color .15s}
.g-fg input:focus,.g-fg textarea:focus{border-color:var(--p)}
.g-fg input.err{border-color:var(--a);background:#fff8f7}
.g-fg textarea{resize:vertical;min-height:70px;line-height:1.5}
.g-fg small{font-size:10px;color:#bbb;margin-top:2px;display:block}
.g-send-btn{background:var(--a);color:#fff;border:none;padding:11px;font-size:13px;font-weight:600;border-radius:var(--r);width:100%;cursor:pointer;font-family:inherit;margin-top:auto;transition:opacity .2s}
.g-send-btn:hover{opacity:.88}
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:12px!important}
.woocommerce ul.products li.product{margin:0!important}
.woocommerce .star-rating::before,.woocommerce .star-rating span::before{color:var(--gold)!important}
@media(max-width:1024px){.g-hero-grid{grid-template-columns:1fr}.g-hero-side{flex-direction:row}.g-cats-grid{grid-template-columns:repeat(5,1fr)}.g-tab-pane.active{grid-template-columns:repeat(3,1fr)}.g-footer-grid{grid-template-columns:1fr 1fr}.g-blog-grid{grid-template-columns:1fr 1fr}.woocommerce ul.products{grid-template-columns:repeat(3,1fr)!important}}

/* ══════════════════════════════════════
   SHOP LAYOUT - LEFT SIDEBAR
══════════════════════════════════════ */
.g-wc-layout { display: grid; grid-template-columns: 220px minmax(0,1fr); gap: 20px; align-items: start; }
.g-wc-sidebar { background: #fff; border: 0.5px solid #e5e5e5; border-radius: 6px; padding: 14px; position: sticky; top: 80px; min-width: 0; }
.g-wc-sidebar .g-wc-widget { margin-bottom: 18px; padding-bottom: 18px; border-bottom: 1px solid #f0f0f0; }
.g-wc-sidebar .g-wc-widget:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.g-wc-sidebar h3 { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #1a1a2e; margin-bottom: 10px; padding-bottom: 7px; border-bottom: 2px solid #e8420a; }
.g-wc-sidebar ul { list-style: none; padding: 0; margin: 0; }
.g-wc-sidebar ul li { font-size: 12px; border-bottom: 1px solid #f5f5f5; }
.g-wc-sidebar ul li a { color: #444; text-decoration: none; display: flex; justify-content: space-between; align-items: center; padding: 6px 0; }
.g-wc-sidebar ul li a:hover { color: #e8420a; }
.g-wc-sidebar ul li .count { background: #f0f0f0; color: #888; font-size: 10px; padding: 1px 6px; border-radius: 20px; }
.g-wc-sidebar ul li.g-active-cat > a { color: #e8420a; font-weight: 600; }
.g-purpose-ico { font-size: 14px; margin-right: 6px; }
.g-clear-filter { display: block; text-align: center; margin-top: 8px; font-size: 11px; color: #e8420a; text-decoration: none; }
.g-tag-cloud { display: flex; flex-wrap: wrap; gap: 5px; }
.g-tag { font-size: 11px; background: #f0f0f0; color: #555; padding: 3px 9px; border-radius: 20px; text-decoration: none; transition: all .15s; }
.g-tag:hover { background: #e8420a; color: #fff; }
.g-sidebar-cta { display: block; text-align: center; padding: 8px; border-radius: 4px; font-size: 12px; font-weight: 600; text-decoration: none; margin-bottom: 6px; }
.g-sidebar-cta--wa { background: #25d366; color: #fff; }
.g-sidebar-cta--em { background: #f0f4ff; color: #1a1a2e; }
.g-price-filter input { width: 85px; border: 1px solid #ddd; border-radius: 4px; padding: 6px 8px; font-size: 12px; font-family: inherit; }
.g-wc-main { min-width: 0; overflow: hidden; }

/* ══════════════════════════════════════
   BLOG LAYOUT - RIGHT SIDEBAR
══════════════════════════════════════ */
.g-blog-layout { display: grid; grid-template-columns: 1fr 280px; gap: 24px; align-items: start; }
.g-blog-main { min-width: 0; }
.g-blog-sidebar { position: sticky; top: 80px; }
.g-sidebar-widget { background: #fff; border: 0.5px solid #e5e5e5; border-radius: 6px; padding: 16px; margin-bottom: 16px; }
.g-sidebar-widget h3 { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: #1a1a2e; margin-bottom: 12px; padding-bottom: 8px; border-bottom: 2px solid #e8420a; }
.g-sidebar-widget ul { list-style: none; padding: 0; margin: 0; }
.g-sidebar-widget ul li { padding: 6px 0; font-size: 13px; border-bottom: 1px solid #f5f5f5; display: flex; justify-content: space-between; align-items: center; }
.g-sidebar-widget ul li:last-child { border-bottom: none; }
.g-sidebar-widget ul li a { color: #444; text-decoration: none; }
.g-sidebar-widget ul li a:hover { color: #e8420a; }
.g-sidebar-widget ul li span { color: #bbb; font-size: 11px; }
.g-sidebar-widget .search-form { display: flex; border: 1px solid #ddd; border-radius: 4px; overflow: hidden; }
.g-sidebar-widget .search-field { flex: 1; border: none; padding: 8px 10px; font-size: 13px; outline: none; font-family: inherit; }
.g-sidebar-widget .search-submit { background: #1a1a2e; color: #fff; border: none; padding: 0 12px; font-size: 12px; cursor: pointer; font-family: inherit; }

/* ══════════════════════════════════════
   WOOCOMMERCE PRODUCT IMAGES - SQUARE
══════════════════════════════════════ */
/* All product thumbnails forced square */
.woocommerce ul.products li.product a img { width: 100% !important; aspect-ratio: 1/1 !important; object-fit: cover !important; object-position: center !important; display: block !important; border-radius: 6px 6px 0 0 !important; }
.woocommerce ul.products li.product { transition: box-shadow .2s, transform .15s; border-radius: 6px; overflow: hidden; background: #fff; }
.woocommerce ul.products li.product:hover { box-shadow: 0 4px 16px rgba(0,0,0,.10); transform: translateY(-2px); }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 12px !important; font-weight: 500 !important; padding: 8px 10px 4px !important; color: #333 !important; }
/* Hide price - enquiry only */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price { display: none !important; }
.gondola-price { display: none !important; }
/* Quick Enquire button */
.gondola-enquire-btn { display: block !important; width: calc(100% - 20px) !important; margin: 4px 10px 10px !important; background: #e8420a !important; color: #fff !important; border: none !important; padding: 8px !important; font-size: 12px !important; font-weight: 600 !important; cursor: pointer !important; border-radius: 4px !important; font-family: inherit !important; }
.gondola-enquire-btn:hover { background: #c73508 !important; }
/* Single product */
.woocommerce div.product div.images img { aspect-ratio: 1/1 !important; object-fit: cover !important; width: 100% !important; border-radius: 6px !important; }
/* Homepage product cards */
.g-pimg { height: 160px !important; overflow: hidden !important; background: #f8f8f8 !important; }
.g-pimg img { width: 100% !important; height: 100% !important; object-fit: cover !important; object-position: center !important; }

/* WC grid override */
.g-wc-main .woocommerce ul.products { display: grid !important; grid-template-columns: repeat(3,1fr) !important; gap: 12px !important; margin: 0 !important; padding: 0 !important; }
.g-wc-main .woocommerce ul.products li.product { margin: 0 !important; float: none !important; width: 100% !important; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1024px) {
    .g-wc-layout { grid-template-columns: 200px minmax(0,1fr); }
    .g-blog-layout { grid-template-columns: 1fr 240px; }
    .g-wc-main .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; }
}
@media(max-width:768px) {
    .g-top { flex-wrap: wrap; gap: 6px; padding: 8px 0; }
    .g-logo { order: 1; flex: 1; min-width: 0; }
    .g-actions { order: 2; gap: 6px; margin-left: 0; flex-shrink: 0; }
    .g-actions .g-btn { padding: 6px 10px; font-size: 11px; }
    .g-search { order: 3; width: 100%; max-width: 100%; flex: 0 0 100%; }
    /* SHOP MOBILE - hide sidebar, full width products */
    .g-wc-layout { display: block !important; }
    .g-wc-sidebar { display: none !important; }
    .g-wc-main { width: 100% !important; }
    /* BLOG MOBILE - hide sidebar */
    .g-blog-layout { display: block !important; }
    .g-blog-sidebar { display: none !important; }
    .g-blog-main { width: 100% !important; }
    /* NAV */
    .g-nav { display: none; }
    /* GRIDS */
    .g-cats-grid { grid-template-columns: repeat(3,1fr); }
    .g-tab-pane.active { grid-template-columns: repeat(2,1fr); }
    .g-promos { grid-template-columns: 1fr; }
    .g-blog-grid { grid-template-columns: 1fr; }
    .g-footer-grid { grid-template-columns: 1fr 1fr; }
    .g-modal-inner { grid-template-columns: 1fr; }
    .g-modal-left { border-radius: 8px 8px 0 0; border-right: none; border-bottom: 1px solid #f0f0f0; }
    .g-services { grid-template-columns: 1fr 1fr; }
    .g-brands-row { grid-template-columns: repeat(3,1fr); }
    .g-wa-float { display: none; }
    .g-mobile-bar { display: grid; }
    body { padding-bottom: 58px; }
    /* WC products - 2 columns on mobile */
    .woocommerce ul.products,
    .g-wc-main .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; display: grid !important; gap: 10px !important; }
    /* Hero */
    .g-hero-grid { grid-template-columns: 1fr; }
    .g-hero-side { flex-direction: column; }
}
@media(max-width:480px) {
    .g-hero-main h1 { font-size: 22px; }
    .g-footer-grid { grid-template-columns: 1fr; }
    .g-row { grid-template-columns: 1fr; }
    .g-actions .g-btn span { display: none; }
    .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; }
}

/* MOBILE FILTER BUTTON */
.g-mobile-filter-btn { display: none; width: 100%; background: #1a1a2e; color: #fff; border: none; padding: 10px 16px; font-size: 13px; font-weight: 600; border-radius: 6px; cursor: pointer; margin-bottom: 14px; font-family: inherit; text-align: left; }
.g-mobile-filter-btn::after { content: ' ▾'; }
.g-mobile-filter-panel { display: none; background: #fff; border: 0.5px solid #e5e5e5; border-radius: 6px; padding: 14px; margin-bottom: 14px; }
.g-mobile-filter-panel.open { display: block; }
@media(max-width:768px) {
    .g-mobile-filter-btn { display: block; }
    .g-cats-grid { grid-template-columns: repeat(3,1fr); }
}
@media(max-width:380px) {
    .g-cats-grid { grid-template-columns: repeat(2,1fr); }
    .woocommerce ul.products,
    .g-wc-main .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; }
    .g-services { grid-template-columns: 1fr 1fr; }
    .g-hero-main h1 { font-size: 20px; }
    .g-footer-grid { grid-template-columns: 1fr; }
    .g-row { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   NUCLEAR OVERRIDE - PRODUCT CARDS
══════════════════════════════════════ */
/* Remove WC float layout completely */
.woocommerce ul.products::after,
.woocommerce ul.products::before { display: none !important; }
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0,1fr)) !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    float: none !important;
    clear: both !important;
}
.woocommerce ul.products li.product,
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last {
    width: 100% !important;
    margin: 0 !important;
    float: none !important;
    clear: none !important;
    padding: 0 !important;
}
/* Square product image */
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
    display: block !important;
    text-decoration: none !important;
}
.woocommerce ul.products li.product a.woocommerce-loop-product__link img {
    display: block !important;
    width: 100% !important;
    height: 200px !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 6px 6px 0 0 !important;
    margin: 0 !important;
}
/* Product card styling */
.woocommerce ul.products li.product {
    background: #fff !important;
    border: 1px solid #ebebeb !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    transition: box-shadow .2s !important;
    cursor: pointer !important;
}
.woocommerce ul.products li.product:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.10) !important;
}
/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 12px !important;
    font-weight: 500 !important;
    color: #333 !important;
    padding: 8px 10px 4px !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}
/* HIDE PRICE EVERYWHERE */
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product span.price,
.woocommerce div.product p.price,
.woocommerce div.product span.price,
.gondola-price,
.woocommerce .price { display: none !important; }
/* Quick Enquire button */
.gondola-enquire-btn {
    display: block !important;
    width: calc(100% - 20px) !important;
    margin: 4px 10px 10px !important;
    background: #e8420a !important;
    color: #fff !important;
    border: none !important;
    padding: 8px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    border-radius: 4px !important;
    font-family: inherit !important;
    text-align: center !important;
}
.gondola-enquire-btn:hover { background: #c73508 !important; }
/* Mobile product grid */
@media(max-width: 768px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, minmax(0,1fr)) !important;
        gap: 10px !important;
    }
    .woocommerce ul.products li.product a.woocommerce-loop-product__link img {
        height: 150px !important;
    }
}
@media(max-width: 380px) {
    .woocommerce ul.products li.product a.woocommerce-loop-product__link img {
        height: 120px !important;
    }
}

/* FORCE PERFECT SQUARE IMAGE */
.woocommerce ul.products li.product a.woocommerce-loop-product__link img {
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    width: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
}

/* PERFECT SQUARE - ALL PRODUCT IMAGES EVERYWHERE */
/* WooCommerce loop */
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product img {
    aspect-ratio: 1 / 1 !important;
    width: 100% !important;
    height: auto !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
}
/* Homepage product tab cards */
.g-pimg {
    aspect-ratio: 1 / 1 !important;
    width: 100% !important;
    height: auto !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.g-pimg img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
}

/* HOMEPAGE PRODUCT CARDS - FORCE SQUARE */
.g-pimg {
    position: relative !important;
    width: 100% !important;
    padding-bottom: 100% !important;
    height: 0 !important;
    overflow: hidden !important;
    background: #f8f8f8 !important;
}
.g-pimg img {
    position: absolute !important;
    top: 0 !important; left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
}
.g-pimg span {
    position: absolute !important;
    top: 50% !important; left: 50% !important;
    transform: translate(-50%,-50%) !important;
    font-size: 48px !important;
}
.g-pqv {
    position: absolute !important;
    bottom: 0 !important; left: 0 !important; right: 0 !important;
}
/* HIDE PRICE EVERYWHERE */
.g-pprice,
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price { display: none !important; }

/* ══════════════════════════════════════
   SERVICES MEGA MENU
══════════════════════════════════════ */
.g-svc-trigger { position: relative; display: inline-block; }
.g-svc-btn {
    background: none;
    border: none;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    color: #1a1a2e;
    cursor: pointer;
    padding: 8px 12px;
    border-radius: 6px;
    transition: background .15s, color .15s;
    white-space: nowrap;
}
.g-svc-btn:hover,
.g-svc-trigger.open .g-svc-btn { background: #1a1a2e; color: #fff; }

/* Mega menu panel */
.g-services-mega {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    width: 1100px;
    max-width: 98vw;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 12px;
    box-shadow: 0 16px 48px rgba(0,0,0,.14);
    z-index: 9999;
    overflow: hidden;
}
.g-svc-trigger.open .g-services-mega { display: block; }
.g-services-mega-inner {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    border-bottom: 1px solid #f0f0f0;
}

/* Column */
.g-svc-col { border-right: 1px solid #f0f0f0; }
.g-svc-col:last-child { border-right: none; }

/* Column header */
.g-svc-col-head {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 14px 12px;
    border-bottom: 1px solid #f0f0f0;
    text-decoration: none;
    transition: opacity .15s;
}
.g-svc-col-head:hover { opacity: .85; }
.g-svc-col-icon { font-size: 22px; line-height: 1; }
.g-svc-col-label { font-size: 12px; font-weight: 700; line-height: 1.3; }
.g-svc-col-desc { font-size: 10px; color: #888; line-height: 1.4; margin-top: 2px; }

/* Products list */
.g-svc-col-list {
    list-style: none;
    padding: 8px 0;
    margin: 0;
}
.g-svc-col-list li { padding: 0; }
.g-svc-prod-link {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 5px 14px;
    font-size: 12px;
    color: #444;
    text-decoration: none;
    transition: background .1s, color .1s;
    line-height: 1.4;
}
.g-svc-prod-link:hover { background: #f8f8f8; color: #e8420a; }
.g-svc-prod-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    flex-shrink: 0;
    opacity: .6;
}
.g-svc-view-all {
    padding: 6px 14px 10px !important;
    border-top: 1px solid #f5f5f5;
    margin-top: 4px;
}
.g-svc-view-all a {
    font-size: 11px;
    font-weight: 700;
    text-decoration: none;
}
.g-svc-view-all a:hover { text-decoration: underline; }

/* Footer bar */
.g-svc-mega-footer {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    background: #f8f8f8;
    border-top: 1px solid #ebebeb;
}
.g-svc-mega-footer-left { display: flex; align-items: center; gap: 0; }
.g-svc-cta-wa {
    background: #25d366;
    color: #fff;
    padding: 7px 16px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
}
.g-svc-cta-all {
    background: #1a1a2e;
    color: #fff;
    padding: 7px 16px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
}

/* Hide on mobile */
@media(max-width:768px) {
    .g-svc-trigger { display: none; }
}

/* ══════════════════════════════════════
   CATEGORY CAROUSEL
══════════════════════════════════════ */
.g-cats { background:var(--w); border:1px solid var(--b); border-radius:var(--rm); padding:12px 0; margin-bottom:12px; }
.g-cats-head { display:flex; align-items:center; justify-content:space-between; padding:0 14px; margin-bottom:10px; }
.g-cats-head h2 { font-size:16px; font-weight:700; color:var(--p); margin:0; }
.g-cats-head a { font-size:12px; font-weight:600; color:var(--a); }
.g-cats-controls { display:flex; gap:6px; }
.g-cats-btn { width:28px; height:28px; border-radius:50%; border:1.5px solid #ddd; background:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:13px; color:#555; transition:all .15s; flex-shrink:0; line-height:1; }
.g-cats-btn:hover { border-color:var(--a); color:var(--a); }
/* Viewport clips overflow, shows exactly 8 icons */
.g-cats-viewport { overflow:hidden; padding:0 14px; }
.g-cats-track { display:flex; gap:8px; transition:transform .45s ease; will-change:transform; }
/* Each item width controlled by JS to fit exactly 8 */
.g-cat { display:flex; flex-direction:column; align-items:center; gap:5px; text-decoration:none; padding:8px 2px; border-radius:var(--rm); transition:background .15s; flex-shrink:0; box-sizing:border-box; }
.g-cat:hover { background:#fff5f2; }
.g-cat-ico { width:52px; height:52px; border-radius:50%; background:#f5f5f5; border:2px solid #eee; display:flex; align-items:center; justify-content:center; font-size:20px; overflow:hidden; transition:border-color .2s; flex-shrink:0; }
.g-cat-ico img { width:100%; height:100%; object-fit:cover; border-radius:50%; display:block; pointer-events:none; }
.g-cat:hover .g-cat-ico { border-color:var(--a); }
.g-cat span { font-size:10px; font-weight:500; color:#333; text-align:center; line-height:1.3; display:block; white-space:normal; }

/* ══════════════════════════════════════
   PRODUCT QUICK VIEW MODAL
══════════════════════════════════════ */


/* Image side */
.g-qv-imgs { background:#f8f8f8; display:flex; flex-direction:column; }
.g-qv-main-wrap { position:relative; flex:1; overflow:hidden; }
.g-qv-main-img { width:100%; height:340px; object-fit:cover; display:block; transition:opacity .2s; }
.g-qv-arr { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.9); border:none; border-radius:50%; width:34px; height:34px; font-size:20px; cursor:pointer; display:flex; align-items:center; justify-content:center; color:#333; transition:all .15s; box-shadow:0 2px 6px rgba(0,0,0,.1); }
.g-qv-arr:hover { background:#fff; color:var(--a); }
.g-qv-prev { left:8px; }
.g-qv-next { right:8px; }
.g-qv-counter { position:absolute; bottom:8px; right:10px; background:rgba(0,0,0,.45); color:#fff; font-size:10px; padding:2px 8px; border-radius:20px; }
.g-qv-thumbs { display:flex; gap:6px; padding:8px 10px; background:#f0f0f0; overflow-x:auto; }
.g-qv-thumb { width:54px; height:54px; border-radius:6px; object-fit:cover; cursor:pointer; border:2px solid transparent; flex-shrink:0; transition:border-color .15s; }
.g-qv-thumb:hover { border-color:#ddd; }
.g-qv-thumb.active { border-color:var(--a); }

/* Info side */
.g-qv-info { padding:24px; display:flex; flex-direction:column; gap:12px; overflow-y:auto; max-height:92vh; }
.g-qv-cat { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--a); }
.g-qv-sku-badge { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:#888; background:#f5f5f5; padding:3px 8px; border-radius:4px; width:fit-content; }
.g-qv-name { font-size:20px; font-weight:700; color:#1a1a2e; line-height:1.3; }
.g-qv-div { border:none; border-top:1px solid #f0f0f0; }
.g-qv-desc { font-size:13px; color:#555; line-height:1.8; }
.g-qv-desc p { margin:0 0 8px; }
.g-qv-desc p:last-child { margin-bottom:0; }
.g-qv-desc ul,.g-qv-desc ol { margin:0 0 8px; padding-left:18px; }
.g-qv-desc li { margin-bottom:4px; }
.g-qv-specs { display:flex; flex-direction:column; gap:5px; }
.g-qv-spec { display:flex; gap:8px; font-size:12px; }
.g-qv-spec-label { color:#888; width:100px; flex-shrink:0; }
.g-qv-spec-val { color:#333; font-weight:500; }
.g-qv-enquire-btn { background:var(--a); color:#fff; border:none; padding:13px; border-radius:6px; font-size:14px; font-weight:700; cursor:pointer; width:100%; transition:background .15s; }
.g-qv-enquire-btn:hover { background:#c73508; }
.g-qv-wa-btn { display:flex; align-items:center; justify-content:center; gap:7px; background:#25d366; color:#fff; padding:11px; border-radius:6px; font-size:13px; font-weight:600; text-decoration:none; transition:opacity .15s; }
.g-qv-wa-btn:hover { opacity:.88; color:#fff; }

/* Mobile quick view */
@media(max-width:640px) {
    .g-qv-modal { grid-template-columns:1fr; max-height:95vh; overflow-y:auto; border-radius:12px 12px 0 0; }
    .g-qv-main-img { height:260px; }
    .g-qv-thumbs { display:none; }
    .g-qv-arr { display:none; }
    .g-qv-counter { display:block; }
    .g-qv-overlay { align-items:flex-end; padding:0; }
    .g-qv-info { max-height:none; padding:16px; }
}

/* ══════════════════════════════════════
   GLOBAL SERVICE PAGE RESPONSIVE
══════════════════════════════════════ */
.g-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.g-svc-2col { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.g-svc-4col { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.g-svc-3col { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.g-svc-hero { padding:56px 0; }
.g-svc-cta  { display:grid; grid-template-columns:1fr auto; align-items:center; gap:24px; border-radius:12px; padding:36px; }
.g-svc-cta-btns { display:flex; gap:10px; flex-shrink:0; }

@media(max-width:768px) {
    .g-svc-grid { grid-template-columns:1fr 1fr !important; gap:14px !important; }
    .g-svc-2col { grid-template-columns:1fr !important; }
    .g-svc-4col { grid-template-columns:repeat(2,1fr) !important; gap:10px !important; }
    .g-svc-3col { grid-template-columns:1fr 1fr !important; gap:10px !important; }
    .g-svc-hero { padding:32px 0 !important; }
    .g-svc-cta  { grid-template-columns:1fr !important; text-align:center; padding:24px !important; }
    .g-svc-cta-btns { justify-content:center; flex-wrap:wrap; }
    /* Service hero h1 */
    .g-svc-h1 { font-size:24px !important; }
    /* Product grids on service pages */
    .g-svc-prods { grid-template-columns:repeat(2,1fr) !important; }
}
@media(max-width:480px) {
    .g-svc-grid { grid-template-columns:1fr !important; }
    .g-svc-4col { grid-template-columns:1fr 1fr !important; }
    .g-svc-3col { grid-template-columns:1fr !important; }
}

/* Quick view button order fix */
.g-qv-wa-btn { order:1; }
.g-qv-enquire-btn { order:2; background:#f8f8f8 !important; color:#1a1a2e !important; border:1.5px solid #ddd !important; }
.g-qv-enquire-btn:hover { background:#f0f0f0 !important; border-color:#bbb !important; }
@media(max-width:640px){
    .g-qvf-fields > div { grid-template-columns:1fr !important; }
}

/* ══════════════════════════════════════
   MOBILE NAV MENU
══════════════════════════════════════ */
.g-mob-menu-btn { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; margin-left:8px; flex-shrink:0; }
.g-mob-menu-btn span { display:block; width:22px; height:2px; background:#1a1a2e; border-radius:2px; transition:all .25s; }
.g-mob-menu-btn.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.g-mob-menu-btn.open span:nth-child(2) { opacity:0; }
.g-mob-menu-btn.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* Mobile nav overlay */
.g-mob-nav { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:#fff; z-index:1000; overflow-y:auto; padding:0 0 80px; }
.g-mob-nav.open { display:block; }
.g-mob-nav-head { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid #f0f0f0; }
.g-mob-nav-close { background:none; border:none; font-size:22px; cursor:pointer; color:#333; }
.g-mob-nav-links { padding:8px 0; }
.g-mob-nav-links a { display:block; padding:13px 20px; font-size:15px; font-weight:500; color:#1a1a2e; border-bottom:1px solid #f5f5f5; text-decoration:none; }
.g-mob-nav-links a:hover { color:var(--a); background:#fff5f2; }
.g-mob-nav-links a.active { color:var(--a); }
.g-mob-nav-cats { padding:8px 16px 16px; }
.g-mob-nav-cats h4 { font-size:10px; text-transform:uppercase; letter-spacing:.08em; color:#999; font-weight:700; margin-bottom:10px; padding-top:8px; }
.g-mob-nav-cats-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.g-mob-nav-cat { display:flex; align-items:center; gap:8px; padding:10px 12px; background:#f8f8f8; border-radius:8px; font-size:12px; font-weight:500; color:#333; text-decoration:none; }
.g-mob-nav-cat:hover { background:#fff5f2; color:var(--a); }
.g-mob-nav-cat span:first-child { font-size:18px; }
.g-mob-nav-cta { padding:16px; display:flex; gap:8px; }
.g-mob-nav-cta a { flex:1; text-align:center; padding:12px; border-radius:6px; font-size:13px; font-weight:700; text-decoration:none; }

@media(max-width:768px) {
    .g-mob-menu-btn { display:flex; }
    .g-bottom { display:none; }
    /* Search full width on mobile */
    .g-top { flex-wrap:wrap; gap:8px; }
    .g-logo { order:1; }
    .g-actions { order:2; margin-left:auto; gap:6px; }
    .g-actions .g-btn span { display:none; }
    .g-mob-menu-btn { order:3; }
    .g-search { order:4; width:100%; max-width:100%; }
    /* Tabs on mobile */
    .g-tabs { overflow-x:auto; }
    .g-tab,.g-tab-btn { padding:7px 12px; font-size:12px; }
    .g-tab-pane.active { grid-template-columns:repeat(2,1fr) !important; }
    /* Category carousel mobile */
    .g-cats-head h2 { font-size:14px; }
}

/* ══════════════════════════════════════
   QUICK VIEW - PROPER SIZE ON HOMEPAGE
══════════════════════════════════════ */
.g-qv-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:9000; align-items:center; justify-content:center; padding:16px; }
.g-qv-modal { background:#fff; border-radius:12px; width:100%; max-width:880px; max-height:90vh; overflow:hidden; display:grid; grid-template-columns:1fr 1fr; position:relative; box-shadow:0 20px 60px rgba(0,0,0,.25); }
@media(max-width:640px) {
    .g-qv-modal { grid-template-columns:1fr; max-height:95vh; border-radius:16px 16px 0 0; }
    .g-qv-overlay { align-items:flex-end; padding:0; }
    .g-qv-main-img { height:260px; }
    .g-qv-thumbs { display:none !important; }
    .g-qv-arr { display:none !important; }
    .g-qv-info { max-height:60vh; overflow-y:auto; padding:16px; }
}

/* ══════════════════════════════════════
   SERVICES PAGE - MOBILE 1 COLUMN
══════════════════════════════════════ */
@media(max-width:600px) {
    .g-svc-grid { grid-template-columns:1fr !important; gap:12px !important; }
    .g-svc-card-top { padding:20px 16px 14px; }
    .g-svc-card-body { padding:14px 16px; }
    .g-svc-card-ico { font-size:32px; margin-bottom:8px; }
    .g-svc-card-title { font-size:17px; }
    .g-svc-card-desc { font-size:13px; }
}

/* ══════════════════════════════════════
   CATEGORY ICONS - MOBILE FIX
══════════════════════════════════════ */
@media(max-width:768px) {
    .g-cat-ico { width:46px; height:46px; font-size:18px; }
    .g-cat span { font-size:9px; }
    .g-cat { padding:6px 2px; }
    .g-cats-head h2 { font-size:13px; }
}

/* ══════════════════════════════════════
   FINAL OVERRIDES — SERVICES + QV + MOBILE HEADER
══════════════════════════════════════ */

/* ── Services page: 1 col on mobile ── */
@media(max-width:640px) {
    .g-svc-grid,
    div[style*="grid-template-columns:1fr 1fr 1fr"],
    div[style*="grid-template-columns: 1fr 1fr 1fr"],
    div[style*="repeat(3,1fr)"],
    div[style*="repeat(3, 1fr)"] {
        display: flex !important;
        flex-direction: column !important;
    }
}

/* ── Mobile header: hide button text, show icons only ── */
@media(max-width:768px) {
    .g-actions .g-btn span { display:none !important; }
    .g-btn-wa::before { content:'💬'; font-size:16px; }
    .g-btn-quote::before { content:'📋'; font-size:16px; }
    .g-btn { padding:8px 10px !important; min-width:36px; }
}

/* ── Quick view: fix image area height on desktop ── */
.g-qv-imgs { background:#f8f8f8; display:flex; flex-direction:column; min-height:400px; }
.g-qv-main-wrap { flex:1; position:relative; overflow:hidden; min-height:320px; }
.g-qv-main-img { width:100% !important; height:100% !important; min-height:320px; object-fit:contain !important; display:block; transition:opacity .2s; background:#f8f8f8; }

/* ── Quick view mobile: image on top, info below ── */
@media(max-width:640px) {
    .g-qv-overlay { align-items:flex-end !important; padding:0 !important; }
    .g-qv-modal {
        grid-template-columns:1fr !important;
        border-radius:16px 16px 0 0 !important;
        max-height:92vh !important;
        overflow-y:auto !important;
        width:100% !important;
    }
    .g-qv-imgs { min-height:auto !important; }
    .g-qv-main-img { height:240px !important; min-height:0 !important; object-fit:cover !important; }
    .g-qv-main-wrap { min-height:0 !important; }
    .g-qv-thumbs { display:none !important; }
    .g-qv-arr { display:none !important; }
    .g-qv-info { padding:16px !important; }
}

/* Services grid responsive */
#g-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media(max-width:768px) { #g-svc-grid { grid-template-columns:repeat(2,1fr) !important; gap:12px !important; } }
@media(max-width:480px) { #g-svc-grid { grid-template-columns:1fr !important; gap:10px !important; } }

/* ══════════════════════════════════════
   SERVICE PAGE — TECHNIQUE ROWS (Gift Branding)
   Icon | Content | Badge - 3 col layout
══════════════════════════════════════ */
.g-technique-row {
    background:#fff;
    border:1px solid #ebebeb;
    border-radius:12px;
    padding:24px;
    display:grid;
    grid-template-columns:80px 1fr auto;
    gap:20px;
    align-items:start;
    margin-bottom:0;
}
@media(max-width:640px) {
    .g-technique-row {
        grid-template-columns:56px 1fr !important;
        gap:12px !important;
        padding:16px !important;
    }
    /* Hide the "best for" badge column on mobile - move below */
    .g-technique-row > div:last-child {
        grid-column:1/-1;
        text-align:left !important;
    }
    /* Service page 4-col → 2-col on mobile */
    .g-svc-4col { grid-template-columns:repeat(2,1fr) !important; gap:10px !important; }
    /* Service page 3-col → 1-col on mobile */
    .g-svc-3col { grid-template-columns:1fr !important; }
    /* Service 2-col → 1-col */
    .g-svc-2col { grid-template-columns:1fr !important; }
    /* CTA button row */
    .g-svc-cta { grid-template-columns:1fr !important; text-align:center !important; padding:20px !important; }
    .g-svc-cta-btns { justify-content:center !important; flex-wrap:wrap !important; }
    /* Hero padding */
    .g-svc-hero { padding:24px 0 !important; }
    .g-svc-h1 { font-size:22px !important; }
    /* All inline grids with 4 cols inside service pages */
    .g-wrap div[style*="repeat(4"] { grid-template-columns:repeat(2,1fr) !important; }
    .g-wrap div[style*="repeat(3"] { grid-template-columns:1fr !important; }
}

/* ══════════════════════════════════════
   QUICK VIEW MOBILE — COMPLETE FIX
══════════════════════════════════════ */
@media(max-width:768px) {
    .g-qv-overlay {
        align-items:flex-end !important;
        padding:0 !important;
    }
    .g-qv-modal {
        grid-template-columns:1fr !important;
        grid-template-rows:auto 1fr !important;
        border-radius:20px 20px 0 0 !important;
        max-height:92vh !important;
        width:100vw !important;
        max-width:100vw !important;
        overflow-y:auto !important;
        overflow-x:hidden !important;
    }
    /* Image on TOP */
    .g-qv-imgs {
        order:1 !important;
        min-height:0 !important;
        width:100% !important;
    }
    .g-qv-main-wrap {
        min-height:0 !important;
        height:260px !important;
    }
    .g-qv-main-img {
        width:100% !important;
        height:260px !important;
        min-height:0 !important;
        object-fit:cover !important;
    }
    .g-qv-thumbs { display:none !important; }
    /* Info BELOW */
    .g-qv-info {
        order:2 !important;
        max-height:none !important;
        overflow-y:visible !important;
        padding:16px !important;
        width:100% !important;
    }
    /* Close button position */
    .g-qv-close {
        top:8px !important;
        right:8px !important;
        z-index:100 !important;
    }
    /* Counter visible */
    .g-qv-counter { display:block !important; }
    /* Arrows hidden - use swipe */
    .g-qv-arr { display:none !important; }
}

/* ══════════════════════════════════════
   MOBILE HEADER BUTTONS — SHOW TEXT
══════════════════════════════════════ */
@media(max-width:768px) {
    /* Show button text on mobile */
    .g-actions .g-btn span { display:inline !important; }
    .g-btn-wa::before { content:none !important; }
    .g-btn-quote::before { content:none !important; }
    .g-btn-wa { font-size:11px !important; padding:7px 10px !important; }
    .g-btn-quote { font-size:11px !important; padding:7px 10px !important; }
    /* Keep hamburger */
    .g-mob-menu-btn { display:flex !important; }
}

/* ══════════════════════════════════════
   CATEGORY CAROUSEL — 4 ICONS ON MOBILE
══════════════════════════════════════ */
@media(max-width:768px) {
    .g-cats-viewport .g-cats-track .g-cat { min-width:0 !important; }
}

/* ══════════════════════════════════════
   QUICK VIEW — NUCLEAR MOBILE FIX
══════════════════════════════════════ */
@media(max-width:768px) {
    .g-qv-overlay {
        position:fixed !important;
        inset:0 !important;
        align-items:flex-end !important;
        justify-content:center !important;
        padding:0 !important;
        background:rgba(0,0,0,.6) !important;
        z-index:9000 !important;
    }
    .g-qv-modal {
        display:flex !important;
        flex-direction:column !important;
        width:100vw !important;
        max-width:100vw !important;
        max-height:92vh !important;
        border-radius:20px 20px 0 0 !important;
        overflow-y:auto !important;
        overflow-x:hidden !important;
        grid-template-columns:unset !important;
    }
    /* Image section on TOP */
    .g-qv-imgs {
        order:1 !important;
        width:100% !important;
        flex-shrink:0 !important;
    }
    .g-qv-main-wrap {
        position:relative !important;
        width:100% !important;
        height:280px !important;
        min-height:0 !important;
        overflow:hidden !important;
    }
    .g-qv-main-img {
        width:100% !important;
        height:280px !important;
        object-fit:cover !important;
        display:block !important;
    }
    .g-qv-thumbs { display:none !important; }
    .g-qv-arr { display:none !important; }
    .g-qv-counter { display:block !important; }
    /* Info section BELOW */
    .g-qv-info {
        order:2 !important;
        width:100% !important;
        padding:16px !important;
        flex-shrink:0 !important;
        overflow-y:visible !important;
        max-height:none !important;
    }
    /* Close button */
    .g-qv-close {
        position:fixed !important;
        top:auto !important;
        bottom:calc(92vh - 16px) !important;
        right:12px !important;
        z-index:9999 !important;
    }
}

/* ══════════════════════════════════════
   SERVICE PAGE CTA — MOBILE FIX
══════════════════════════════════════ */
@media(max-width:640px) {
    .g-svc-cta {
        display:flex !important;
        flex-direction:column !important;
        padding:20px !important;
        text-align:left !important;
    }
    .g-svc-cta-btns {
        display:flex !important;
        flex-direction:column !important;
        gap:8px !important;
        width:100% !important;
    }
    .g-svc-cta-btns a {
        text-align:center !important;
        white-space:nowrap !important;
    }
}

/* Fix close button on mobile QV - keep it inside modal */
@media(max-width:768px) {
    .g-qv-close {
        position:absolute !important;
        top:8px !important;
        right:8px !important;
        bottom:auto !important;
        background:rgba(0,0,0,.5) !important;
        z-index:9999 !important;
    }
}

/* ══════════════════════════════════════
   QUICK VIEW — COMPLETE REWRITE
   Image LEFT, Info RIGHT (desktop)
   Image TOP, Info BOTTOM (mobile)
══════════════════════════════════════ */
.g-qv-overlay {
    position:fixed !important;
    inset:0 !important;
    background:rgba(0,0,0,.6) !important;
    z-index:9000 !important;
    align-items:center !important;
    justify-content:center !important;
    padding:16px !important;
}
.g-qv-modal {
    background:#fff !important;
    border-radius:12px !important;
    width:100% !important;
    max-width:860px !important;
    max-height:90vh !important;
    overflow:hidden !important;
    /* IMAGE first (left), INFO second (right) */
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    position:relative !important;
    box-shadow:0 20px 60px rgba(0,0,0,.3) !important;
}
/* Image side — LEFT */
.g-qv-imgs {
    order:1 !important;
    background:#f8f8f8 !important;
    display:flex !important;
    flex-direction:column !important;
}
.g-qv-main-wrap {
    position:relative !important;
    flex:1 !important;
    min-height:320px !important;
    overflow:hidden !important;
}
.g-qv-main-img {
    width:100% !important;
    height:100% !important;
    min-height:320px !important;
    object-fit:contain !important;
    display:block !important;
    background:#f8f8f8 !important;
}
/* Info side — RIGHT */
.g-qv-info {
    order:2 !important;
    padding:24px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    overflow-y:auto !important;
    max-height:90vh !important;
}

/* MOBILE: stack vertically, image top */
@media(max-width:700px) {
    .g-qv-overlay {
        align-items:flex-end !important;
        padding:0 !important;
    }
    .g-qv-modal {
        grid-template-columns:unset !important;
        display:flex !important;
        flex-direction:column !important;
        width:100vw !important;
        max-width:100vw !important;
        max-height:92vh !important;
        border-radius:20px 20px 0 0 !important;
        overflow-y:auto !important;
    }
    .g-qv-imgs {
        order:1 !important;
        width:100% !important;
        flex-shrink:0 !important;
        min-height:0 !important;
    }
    .g-qv-main-wrap {
        height:260px !important;
        min-height:0 !important;
    }
    .g-qv-main-img {
        height:260px !important;
        min-height:0 !important;
        object-fit:cover !important;
    }
    .g-qv-thumbs { display:none !important; }
    .g-qv-arr { display:none !important; }
    .g-qv-info {
        order:2 !important;
        max-height:none !important;
        overflow-y:visible !important;
        padding:16px !important;
    }
    .g-qv-close {
        position:absolute !important;
        top:8px !important;
        right:8px !important;
    }
}



/* ══════════════════════════════════════
   QUICK VIEW FINAL — IMAGE LEFT, INFO RIGHT
══════════════════════════════════════ */
.g-qv-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:9000; align-items:center; justify-content:center; padding:16px; }
.g-qv-modal { background:#fff; border-radius:12px; width:100%; max-width:860px; max-height:90vh; overflow:hidden; display:grid; grid-template-columns:1fr 1fr; position:relative; box-shadow:0 20px 60px rgba(0,0,0,.3); }
#g-qv-imgs { grid-column:1 !important; background:#f8f8f8; display:flex; flex-direction:column; }
.g-qv-main-wrap { position:relative; flex:1; min-height:320px; overflow:hidden; }
.g-qv-main-img { width:100%; height:100%; min-height:320px; object-fit:contain; display:block; background:#f8f8f8; transition:opacity .2s; }
.g-qv-info { grid-column:2 !important; padding:24px; display:flex; flex-direction:column; gap:12px; overflow-y:auto; max-height:90vh; }
.g-qv-close { position:absolute; top:10px; right:10px; background:rgba(0,0,0,.4); color:#fff; border:none; border-radius:50%; width:30px; height:30px; font-size:14px; cursor:pointer; z-index:10; display:flex; align-items:center; justify-content:center; }
.g-qv-arr { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.9); border:none; border-radius:50%; width:34px; height:34px; font-size:20px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.g-qv-prev { left:8px; }
.g-qv-next { right:8px; }
.g-qv-thumbs { display:flex; gap:6px; padding:8px 10px; background:#f0f0f0; overflow-x:auto; }
.g-qv-thumb { width:54px; height:54px; border-radius:6px; object-fit:cover; cursor:pointer; border:2px solid transparent; flex-shrink:0; }
.g-qv-thumb.active { border-color:#e8420a; }
.g-qv-counter { position:absolute; bottom:8px; right:10px; background:rgba(0,0,0,.45); color:#fff; font-size:10px; padding:2px 8px; border-radius:20px; }
.g-qv-cat { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:#e8420a; }
.g-qv-sku-badge { font-size:10px; font-weight:700; color:#888; background:#f5f5f5; padding:3px 8px; border-radius:4px; width:fit-content; }
.g-qv-name { font-size:20px; font-weight:700; color:#1a1a2e; line-height:1.3; }
.g-qv-div { border:none; border-top:1px solid #f0f0f0; }
.g-qv-desc { font-size:13px; color:#555; line-height:1.8; }
.g-qv-wa-btn { display:flex; align-items:center; justify-content:center; gap:7px; background:#25d366; color:#fff; padding:12px; border-radius:6px; font-size:14px; font-weight:700; text-decoration:none; }
.g-qv-enquire-btn { background:#f5f5f5; color:#1a1a2e; border:1.5px solid #ddd; padding:11px; border-radius:6px; font-size:13px; font-weight:600; cursor:pointer; width:100%; font-family:inherit; }

/* MOBILE: stack — image top, info bottom */
@media(max-width:700px){
    .g-qv-overlay { align-items:flex-end !important; padding:0 !important; }
    .g-qv-modal { display:flex !important; flex-direction:column !important; width:100vw !important; max-width:100vw !important; max-height:83vh !important; border-radius:20px 20px 0 0 !important; overflow-y:auto !important; }
    #g-qv-imgs { grid-column:unset !important; order:1 !important; flex-shrink:0 !important; }
    .g-qv-main-wrap { height:234px !important; min-height:0 !important; }
    .g-qv-main-img { height:234px !important; min-height:0 !important; object-fit:cover !important; }
    .g-qv-thumbs { display:none !important; }
    .g-qv-arr { display:none !important; }
    .g-qv-info { grid-column:unset !important; order:2 !important; max-height:none !important; padding:14px !important; gap:10px !important; }
    .g-qv-name { font-size:18px !important; }
    .g-qv-desc { font-size:12px !important; }
    .g-qv-close { top:8px !important; right:8px !important; }
}

/* ══════════════════════════════════════
   FIX: View All tap area on mobile
══════════════════════════════════════ */
.g-cats-head { position:relative; z-index:1; }
.g-cats-head a { 
    position:relative; 
    z-index:10; 
    padding:8px 4px; 
    min-height:44px;
    display:inline-flex;
    align-items:center;
}
.g-cats-controls { position:relative; z-index:10; }
.g-cats-btn { 
    min-width:36px; 
    min-height:36px;
    touch-action:manipulation;
}

/* ══════════════════════════════════════
   FIX: Quick view image — square, no crop
   Show full product, no hiding
══════════════════════════════════════ */
.g-qv-main-img {
    width:100% !important;
    height:100% !important;
    min-height:320px !important;
    object-fit:contain !important;
    background:#f8f8f8 !important;
    display:block !important;
}
/* Make image area square on desktop */
.g-qv-main-wrap {
    position:relative !important;
    aspect-ratio:1 !important;
    min-height:0 !important;
    overflow:hidden !important;
    flex:unset !important;
}
/* Mobile image — square, full product visible */
@media(max-width:700px){
    .g-qv-main-wrap {
        aspect-ratio:1 !important;
        height:auto !important;
        width:100% !important;
    }
    .g-qv-main-img {
        width:100% !important;
        height:100% !important;
        min-height:0 !important;
        object-fit:contain !important;
    }
}

/* ══════════════════════════════════════
   MOBILE QUICK VIEW — leave 8% gap at top
══════════════════════════════════════ */
@media(max-width:700px){
    .g-qv-overlay {
        align-items:flex-end !important;
        padding:0 !important;
    }
    .g-qv-modal {
        max-height:88vh !important;
        border-radius:20px 20px 0 0 !important;
        margin-top:auto !important;
    }
}

/* ══ View All — always tappable on mobile ══ */
.g-cats-head { position:relative; }
.g-cats-head > div { position:relative; }
.g-cats-head a {
    position:relative !important;
    z-index:20 !important;
    display:inline-flex !important;
    align-items:center !important;
    min-height:44px !important;
    min-width:60px !important;
    padding:8px !important;
    cursor:pointer !important;
    -webkit-tap-highlight-color:rgba(232,66,10,.15) !important;
    touch-action:manipulation !important;
}
.g-cats-btn {
    position:relative !important;
    z-index:1 !important;
    touch-action:manipulation !important;
}
/* Ensure viewport doesn't overlap head */
.g-cats-viewport { position:relative; z-index:0; }

/* ══ Prevent auto-zoom on input focus (iOS) ══ */
@media(max-width:768px){
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="search"],
    input[type="number"],
    input[type="password"],
    textarea,
    select {
        font-size:16px !important;
    }
}

/* ══════════════════════════════════════
   SCROLLING CLIENT BRANDS
══════════════════════════════════════ */
.g-brands { background:#fff; border:1px solid #ebebeb; border-radius:var(--rm); padding:20px 0; margin-bottom:12px; overflow:hidden; }
.g-brands .g-sec-hd { padding:0 14px 14px; border-bottom:1px solid #f5f5f5; margin-bottom:14px; }
.g-brands-viewport { overflow:hidden; position:relative; width:100%; }
.g-brands-viewport::before,
.g-brands-viewport::after { content:''; position:absolute; top:0; bottom:0; width:40px; z-index:2; pointer-events:none; }
.g-brands-viewport::before { left:0; background:linear-gradient(to right,#fff,transparent); }
.g-brands-viewport::after  { right:0; background:linear-gradient(to left,#fff,transparent); }
.g-brands-track {
    display:flex;
    flex-wrap:nowrap;
    width:max-content;
    animation:g-brands-scroll 18s linear infinite;
    will-change:transform;
}
.g-brands-track:hover { animation-play-state:paused; }
.g-brand-item {
    flex:0 0 auto;
    padding:10px 28px;
    font-size:14px;
    font-weight:700;
    color:#1a1a2e;
    letter-spacing:.06em;
    border-right:1px solid #f0f0f0;
    white-space:nowrap;
    display:inline-block;
}
.g-brand-item:hover { color:var(--a); }
@keyframes g-brands-scroll {
    from { transform:translateX(0); }
    to   { transform:translateX(-50%); }
}
@media(max-width:768px){
    .g-brand-item { font-size:12px; padding:8px 18px; }
}
