				/* === ID2 Hub / Kit Builder (scoped) === */
				.hbe-hub-wrapper { --hbe-bg:#0b1220; --hbe-surface:#0f1a2c; --hbe-border:rgba(255,255,255,.08); --hbe-text:#e8eefc; --hbe-muted:rgba(232,238,252,.72); --hbe-accent:#7c5cff; --hbe-accent2:#31d0aa; margin: 30px auto; }
				.hbe-hub-wrapper * { box-sizing: border-box; }
				.hbe-hub-wrapper { margin: 40px 0; }
				.hbe-hub-wrapper .hbe-hero { background: #f6f7f8; padding: 40px; border-radius: 12px; margin-bottom: 50px; }
				.hbe-hub-wrapper .hbe-hero h1 { margin-top: 0; font-size: 2.2rem; }
				.hbe-hub-wrapper .hbe-subtitle { font-size: 1.1rem; max-width: 700px; }
				.hbe-hub-wrapper .hbe-key-points { margin-top: 20px; padding-left: 18px; }
				.hbe-hub-wrapper .hbe-section { margin-bottom: 60px; }
				.hbe-hub-wrapper .hbe-section h2 { margin-bottom: 25px; font-size: 1.6rem; }

				/* Theme layout override (only when hub is present) */
			body.hbe-hub-no-sidebar #secondary,
			body.hbe-hub-no-sidebar .sidebar,
			body.hbe-hub-no-sidebar .widget-area,
			body.hbe-hub-no-sidebar .site-sidebar,
			body.hbe-hub-no-sidebar .page-sidebar,
			body.hbe-hub-no-sidebar .sidebar-container,
			body.hbe-hub-no-sidebar .ast-sidebar-container,
			body.hbe-hub-no-sidebar .et_pb_sidebar,
			body.hbe-hub-no-sidebar .fl-sidebar,
			body.hbe-hub-no-sidebar .elementor-location-sidebar {
				display: none !important;
			}

			body.hbe-hub-no-sidebar #primary,
			body.hbe-hub-no-sidebar .content-area,
			body.hbe-hub-no-sidebar .site-main,
			body.hbe-hub-no-sidebar main {
				width: 100% !important;
				max-width: 100% !important;
			}

			/* Builder product: hide native product summary/gallery so only builder + tabs remain */
			body.single-product.hbe-builder-product .woocommerce-product-gallery,
			body.single-product.hbe-builder-product .woocommerce-product-gallery__wrapper,
			body.single-product.hbe-builder-product .product .summary,
			body.single-product.hbe-builder-product .entry-summary,
			body.single-product.hbe-builder-product .woocommerce-product-details__short-description,
			body.single-product.hbe-builder-product .product_meta {
				display: none !important;
			}

			/* Builder product: force single-column product layout (some themes use grid on div.product) */
			body.single-product.hbe-builder-product div.product {
				display: block !important;
				grid-template-columns: 1fr !important;
				align-items: stretch !important;
			}
			body.single-product.hbe-builder-product .woocommerce-tabs,
			body.single-product.hbe-builder-product .woocommerce-tabs .tabs,
			body.single-product.hbe-builder-product .woocommerce-Tabs-panel {
				max-width: 100% !important;
				width: 100% !important;
			}

			/* Hide theme page title/header for this hub page */
			body.hbe-hub-no-sidebar .entry-header,
			body.hbe-hub-no-sidebar .page-header,
			body.hbe-hub-no-sidebar h1.entry-title,
			body.hbe-hub-no-sidebar .entry-title,
			body.hbe-hub-no-sidebar .page-title {
				display: none !important;
			}

			/* Hero */
			.hbe-hub-wrapper .hbe-hero { position: relative; overflow: hidden; border-radius: 18px; padding: 26px 22px; margin: 0 0 18px; background: linear-gradient(180deg, #006F77, #005c63); border: 1px solid rgba(255,255,255,.18); color: #fff; }
			.hbe-hub-wrapper .hbe-hero::after { content: ""; position: absolute; right: 200px; top: 50%; width: 520px; height: 520px; transform: translateY(-50%) rotate(0deg); transform-origin: 50% 50%; background: url('https://huvo.co.uk/wp-content/uploads/2026/02/fire-home-cat-bg-grey-bannerhead.png') center / contain no-repeat; pointer-events: none; z-index: 1; opacity: .98; animation: hbeHeroSpin 84s linear infinite; }
			.hbe-hub-wrapper .hbe-hero-inner { position: relative; z-index: 2; }
			@keyframes hbeHeroSpin {
				from { transform: translateY(-50%) rotate(0deg); }
				to { transform: translateY(-50%) rotate(360deg); }
			}
			@media (max-width: 720px) {
				.hbe-hub-wrapper .hbe-hero::after { display: none; }
			}
			@media (prefers-reduced-motion: reduce) {
				.hbe-hub-wrapper .hbe-hero::after { animation: none; }
			}
			.hbe-hub-wrapper .hbe-hero-inner { display: grid; grid-template-columns: 1fr; gap: 14px; align-items: center; }
			.hbe-hub-wrapper .hbe-hero-logo { display: block; justify-self: start; }
			.hbe-hub-wrapper .hbe-hero-logo img { display: block; width: clamp(110px, 34vw, 150px); max-width: 100%; height: auto; }
			@media (min-width: 980px) {
				.hbe-hub-wrapper .hbe-hero-inner { grid-template-columns: minmax(0, 1fr) auto; gap: 18px; }
				.hbe-hub-wrapper .hbe-hero-logo { justify-self: end; align-self: center; }
				.hbe-hub-wrapper .hbe-hero-logo img { width: clamp(120px, 18vw, 190px); }
			}
			.hbe-hub-wrapper .hbe-hero h1 { margin: 0 0 6px; font-size: 28px; line-height: 1.15; letter-spacing: -0.02em; color: #fff; }
			.hbe-hub-wrapper .hbe-subtitle { margin: 0; color: rgba(255,255,255,.85); }
			.hbe-hub-wrapper .hbe-steps { display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
			.hbe-hub-wrapper .hbe-step { display:flex; gap:8px; align-items:center; padding: 8px 10px; border:1px solid rgba(255,255,255,.24); border-radius: 999px; background: rgba(255,255,255,.10); color: rgba(255,255,255,.92); font-size: 13px; }
			.hbe-hub-wrapper .hbe-step b { color: #fff; }

			/* Section jump mini-nav */
			.hbe-hub-wrapper .hbe-jump { display:none; margin: 0 0 12px; padding: 8px; border: 1px solid rgba(11,18,32,.09); border-radius: 14px; background: rgba(255,255,255,.92); backdrop-filter: saturate(140%) blur(8px); -webkit-backdrop-filter: saturate(140%) blur(8px); overflow-x: auto; overflow-y: hidden; gap: 8px; position: sticky; top: 12px; z-index: 90; scrollbar-width: thin; }
			.hbe-hub-wrapper .hbe-jump.is-ready { display:flex; }
			.hbe-hub-wrapper .hbe-jump-btn,
			.hbe-hub-wrapper .hbe-btn,
			.hbe-hub-wrapper .hbe-top-btn,
			.hbe-hub-wrapper .hbe-basket-toggle,
			.hbe-hub-wrapper .hbe-qtypick-btn,
			.hbe-hub-wrapper .hbe-qty button,
			.hbe-hub-wrapper .hbe-info-btn {
				-webkit-appearance: none !important;
				appearance: none !important;
				font-family: inherit !important;
				text-transform: none !important;
				letter-spacing: normal !important;
				box-shadow: none !important;
				background-image: none !important;
				text-decoration: none !important;
			}
			.hbe-hub-wrapper .hbe-jump-btn { appearance:none; border:1px solid rgba(11,18,32,.14) !important; background: #fff !important; color:#0b1220 !important; border-radius: 999px !important; padding: 8px 11px !important; font-size: 12px !important; font-weight: 800 !important; line-height: 1 !important; white-space: nowrap; cursor:pointer; flex: 0 0 auto; }
			.hbe-hub-wrapper .hbe-jump-btn::after { content: none !important; display: none !important; }
			.hbe-hub-wrapper .hbe-jump-btn::before { content: none !important; display: none !important; }
			.hbe-hub-wrapper .hbe-jump-btn:hover { border-color: rgba(0,111,119,.55); }
			.hbe-hub-wrapper .hbe-jump-btn.is-active { border-color: rgba(0,111,119,.7) !important; background: rgba(0,111,119,.12) !important; color: #005c63 !important; }

			/* Layout */
			.hbe-hub-wrapper .hbe-layout { display:grid; grid-template-columns: 1fr; gap: 18px; }
			@media (max-width: 979px) {
				/* Reserve space for mobile floating kit drawer */
				.hbe-hub-wrapper { padding-bottom: 110px; }
			}
			@media (min-width: 980px) {
				.hbe-hub-wrapper .hbe-layout { grid-template-columns: minmax(0, 1fr) 360px; align-items:start; }
				.hbe-hub-wrapper .hbe-basket { position: sticky; top: 18px; }
			}

			.hbe-hub-wrapper .hbe-section { margin: 0; }
			.hbe-hub-wrapper .hbe-section h2 { margin: 0; font-size: 18px; letter-spacing: -0.01em; color: #0b1220; }

			/* Sections grid (two-up on wider screens) */
			.hbe-hub-wrapper .hbe-sections-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
			@media (min-width: 1200px) {
				.hbe-hub-wrapper .hbe-sections-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
				.hbe-hub-wrapper .hbe-section { grid-column: span var(--hbe-section-span, 2); }
				.hbe-hub-wrapper .hbe-section-wide { --hbe-section-span: 4; grid-column: span var(--hbe-section-span, 4); }
				.hbe-hub-wrapper .hbe-section .hbe-grid { grid-template-columns: repeat(var(--hbe-section-card-cols, 2), minmax(0, 1fr)); }
				.hbe-hub-wrapper .hbe-section-wide .hbe-grid { grid-template-columns: repeat(var(--hbe-section-card-cols, 4), minmax(0, 1fr)); }
			}

			/* Section card styling */
			.hbe-hub-wrapper .hbe-section { background: #fefefe; border: 4px solid rgba(11,18,32,.08); border-radius: 18px; padding: 14px; box-shadow: 0 10px 24px rgba(10,18,32,.05); }
			.hbe-hub-wrapper .hbe-section-head { display:flex; align-items:flex-start; gap: 10px; margin: 0 0 12px; padding: 10px 10px 9px; border: 1px solid rgba(11,18,32,.09); border-radius: 14px; background: linear-gradient(180deg, rgba(0,111,119,.065), rgba(0,111,119,.02)); }
			.hbe-hub-wrapper .hbe-section-head-main { min-width: 0; flex: 1 1 auto; }
			.hbe-hub-wrapper .hbe-section-kicker { display:flex; align-items:center; gap: 7px; margin-bottom: 6px; }
			.hbe-hub-wrapper .hbe-section-tag { display:inline-flex; align-items:center; justify-content:center; min-height: 21px; padding: 0 8px; border-radius: 999px; border: 1px solid rgba(0,111,119,.26); background: rgba(0,111,119,.10); color: rgba(0,91,97,.95); font-size: 11px; font-weight: 800; letter-spacing: .02em; text-transform: uppercase; white-space: nowrap; }
			.hbe-hub-wrapper .hbe-section-title-row { display:flex; align-items:center; gap: 8px; min-width: 0; }
			.hbe-hub-wrapper .hbe-section-icon { width: 11px; height: 11px; border-radius: 999px; background: #0d7c83; box-shadow: 0 0 0 3px rgba(13,124,131,.14); flex: 0 0 auto; }
			.hbe-hub-wrapper .hbe-section-head .hbe-section-note { margin: 4px 0 0; color: rgba(11,18,32,.70); font-size: 14px; line-height: 1.35; }
			@media (max-width: 740px) {
				.hbe-hub-wrapper .hbe-section-head { flex-direction: column; gap: 8px; }
			}

			/* Grid cards */
			.hbe-hub-wrapper .hbe-grid { display:grid; grid-template-columns: 1fr; gap: 14px; }
			@media (min-width: 620px) {
				.hbe-hub-wrapper .hbe-grid { grid-template-columns: 1fr 1fr; }
			}
			.hbe-hub-wrapper .hbe-card { position: relative; border:1px solid rgba(11,18,32,.10); border-radius: 16px; overflow: visible; background: #fff; box-shadow: 0 10px 25px rgba(10,18,32,.06); display:flex; flex-direction:column; min-height: 100%; }
			.hbe-hub-wrapper .hbe-card.hbe-card-info-open { z-index: 40; }
			.hbe-hub-wrapper .hbe-card-media { display:block; padding: 14px; overflow: hidden; border-radius: 12px; background: transparent !important; transition: background-color .2s ease; }
			.hbe-hub-wrapper .hbe-card-media:hover,
			.hbe-hub-wrapper .hbe-card-media:focus,
			.hbe-hub-wrapper .hbe-card-media:focus-visible { background: transparent !important; }
			.hbe-hub-wrapper .hbe-card-img { width: 100%; height: 170px; object-fit: contain; transition: transform .24s ease; transform-origin: 50% 50%; }
			.hbe-hub-wrapper .hbe-card-media:hover .hbe-card-img,
			.hbe-hub-wrapper .hbe-card-media:focus-visible .hbe-card-img { transform: scale(1.035); }
			.hbe-hub-wrapper .hbe-card-body { padding: 12px 12px 14px; display:flex; flex-direction:column; gap: 8px; position: relative; }
			.hbe-hub-wrapper .hbe-card-head { position: relative; display:flex; align-items:flex-start; justify-content:space-between; gap: 8px; }
			.hbe-hub-wrapper .hbe-card-title { font-weight: 700; font-size: 14px; line-height: 1.25; color:#0b1220; text-decoration:none; }
			.hbe-hub-wrapper .hbe-card-title:hover { text-decoration: underline; }
			.hbe-hub-wrapper .hbe-card-price { font-size: 16px; color: rgba(11,18,32,.75); }
			.hbe-hub-wrapper .hbe-card-actions { display:flex; gap: 8px; margin-top: 2px; align-items:center; flex-wrap: wrap; }
			.hbe-hub-wrapper .hbe-info { position: static; flex: 0 0 auto; }
			.hbe-hub-wrapper .hbe-info-btn { appearance:none; width: 24px !important; height: 24px !important; min-width: 24px !important; min-height: 24px !important; border-radius: 999px !important; border: 1px solid rgba(11,18,32,.18) !important; background: rgba(11,18,32,.04) !important; color: #0b1220 !important; font-size: 0 !important; display:inline-flex !important; align-items:center !important; justify-content:center !important; line-height: 1 !important; padding: 0 !important; cursor: pointer; }
			.hbe-hub-wrapper .hbe-info-btn::after { content: none !important; display: none !important; }
			.hbe-hub-wrapper .hbe-info-btn::before { content: none !important; display: none !important; }
			.hbe-hub-wrapper .hbe-info-btn svg { width: 13px; height: 13px; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; fill: none; pointer-events: none; }
			.hbe-hub-wrapper .hbe-info-btn:hover { border-color: rgba(11,18,32,.30); background: rgba(11,18,32,.08); }
			.hbe-hub-wrapper .hbe-info-btn:focus-visible { outline: 2px solid #006F77; outline-offset: 2px; }
			.hbe-hub-wrapper .hbe-info-pop { display: none; position: absolute; top: calc(100% + 8px); left: 0; right: 0; z-index: 60; width: auto; max-height: 260px; overflow: auto; background: #fff; color: #0b1220; border: 1px solid rgba(11,18,32,.12); border-radius: 12px; box-shadow: 0 14px 28px rgba(10,18,32,.16); padding: 10px 12px; font-size: 12px; line-height: 1.45; }
			.hbe-hub-wrapper .hbe-info.is-open .hbe-info-pop { display: block; }
			@media (hover: hover) {
				.hbe-hub-wrapper .hbe-info:hover .hbe-info-pop,
				.hbe-hub-wrapper .hbe-info:focus-within .hbe-info-pop { display: block; }
			}
			.hbe-hub-wrapper .hbe-info-pop ul,
			.hbe-hub-wrapper .hbe-info-pop ol { margin: 0; padding-left: 16px; }
			.hbe-hub-wrapper .hbe-info-pop li { margin: 0 0 4px; }
			.hbe-hub-wrapper .hbe-info-pop li:last-child { margin-bottom: 0; }
			.hbe-hub-wrapper .hbe-info-pop p { margin: 0 0 6px; }
			.hbe-hub-wrapper .hbe-info-pop p:last-child { margin-bottom: 0; }

			/* Card qty picker (compact) */
			.hbe-hub-wrapper .hbe-qtypick { display:inline-flex; align-items:center; gap: 6px; padding: 6px 8px; border-radius: 12px; border: 1px solid rgba(11,18,32,.10); background: rgba(11,18,32,.03); }
			.hbe-hub-wrapper .hbe-qtypick-btn { width: 28px !important; height: 28px !important; min-width: 28px !important; min-height: 28px !important; border-radius: 10px !important; border: 1px solid rgba(11,18,32,.12) !important; background: #fff !important; color:#0b1220 !important; cursor:pointer; font-weight: 900 !important; line-height: 1 !important; display:flex !important; align-items:center !important; justify-content:center !important; padding: 0 !important; }
			.hbe-hub-wrapper .hbe-qtypick-val { min-width: 16px; text-align:center; font-weight: 900; font-size: 13px; color:#0b1220; }

			/* Variable selectors */
			.hbe-hub-wrapper .hbe-var { display:flex; flex-direction:column; gap: 8px; padding: 8px 10px; border: 1px solid rgba(11,18,32,.08); border-radius: 14px; background: rgba(11,18,32,.02); }
			.hbe-hub-wrapper .hbe-var-row { display:flex; flex-direction:column; gap: 6px; }
			.hbe-hub-wrapper .hbe-var-label { font-size: 12px; font-weight: 800; color: rgba(11,18,32,.72); }
			.hbe-hub-wrapper .hbe-var-select { width: 100%; height: 38px; border-radius: 12px; border: 1px solid rgba(11,18,32,.12); padding: 0 10px; background: #fff; font-weight: 700; font-size: 13px; }
			.hbe-hub-wrapper .hbe-var-hint { font-size: 12px; color: rgba(11,18,32,.58); }

			/* Buttons */
			.hbe-hub-wrapper .hbe-btn { appearance:none; border:1px solid rgba(11,18,32,.12) !important; background:#fff !important; color:#0b1220 !important; border-radius: 12px !important; padding: 10px 10px !important; font-weight: 700 !important; font-size: 13px !important; line-height: 1 !important; cursor:pointer; text-decoration:none !important; display:inline-flex !important; align-items:center !important; justify-content:center !important; gap:8px; }
			/* Theme adds arrows via ::after on buttons — disable just for kit builder buttons */
			.hbe-hub-wrapper .hbe-btn::after,
			.hbe-hub-wrapper .hbe-qty button::after,
			.hbe-hub-wrapper .hbe-qtypick button::after { content: none !important; display: none !important; }
			.hbe-hub-wrapper .hbe-btn::before,
			.hbe-hub-wrapper .hbe-qty button::before,
			.hbe-hub-wrapper .hbe-qtypick button::before { content: none !important; display: none !important; }
			.hbe-hub-wrapper .hbe-btn:hover { border-color: rgba(11,18,32,.22); transform: translateY(-1px); }
			.hbe-hub-wrapper .hbe-btn:active { transform: translateY(0); }
			.hbe-hub-wrapper .hbe-btn-primary { border-color: rgba(0,111,119,.45) !important; background: #006F77 !important; color:#fff !important; }
			.hbe-hub-wrapper .hbe-btn-primary:hover { border-color: rgba(0,111,119,.65) !important; background: #005c63 !important; }
			.hbe-hub-wrapper .hbe-btn-primary:active { background: #004a50 !important; }
			.hbe-hub-wrapper .hbe-btn-ghost { background: rgba(11,18,32,.04) !important; border-color: rgba(11,18,32,.08) !important; color: rgba(11,18,32,.7) !important; cursor: grab; }
			.hbe-hub-wrapper .hbe-btn:disabled { opacity: .55; cursor:not-allowed; transform:none; }

			/* Basket */
			.hbe-hub-wrapper .hbe-basket { border: 1px solid var(--hbe-border); border-radius: 18px; background: linear-gradient(180deg, rgb(1 97 104), rgba(10,18,32,.98)); color: var(--hbe-text); overflow:hidden; line-height: 1.25; margin-top: 0 !important; }
			.hbe-hub-wrapper .hbe-basket { margin-top: 0 !important; }
			.hbe-hub-wrapper .hbe-basket-head { padding: 14px 14px 12px; border-bottom: 1px solid var(--hbe-border); display:flex; align-items:center; justify-content:space-between; gap: 10px; }
			.hbe-hub-wrapper .hbe-basket-head h3 { margin:0; font-size: 16px; letter-spacing: -0.01em; color: #fff; }
			.hbe-hub-wrapper .hbe-basket-sub { margin: 6px 0 0; color: var(--hbe-muted); font-size: 13px; }
			.hbe-hub-wrapper .hbe-basket-controls { display:flex; align-items:center; gap: 8px; }
			.hbe-hub-wrapper .hbe-top-btn { border: 1px solid rgba(232,238,252,.18) !important; background: rgba(255,255,255,.04) !important; color: var(--hbe-text) !important; border-radius: 12px !important; height: 34px !important; min-height: 34px !important; padding: 0 9px !important; font-weight: 900 !important; font-size: 12px !important; cursor: pointer; display:inline-flex !important; align-items:center !important; gap: 6px; line-height: 1 !important; transition: opacity .18s ease, transform .18s ease; }
			.hbe-hub-wrapper .hbe-top-btn::after { content: none !important; display:none !important; }
			.hbe-hub-wrapper .hbe-top-btn::before { content: none !important; display:none !important; }
			.hbe-hub-wrapper .hbe-top-btn.is-hidden { opacity: 0; pointer-events: none; transform: translateY(4px); }
			.hbe-hub-wrapper .hbe-top-btn .hbe-top-arrow { font-size: 14px; line-height: 1; }

			/* Basket collapse */
			.hbe-hub-wrapper .hbe-basket-toggle { border: 1px solid rgba(232,238,252,.18) !important; background: rgba(255,255,255,.04) !important; color: var(--hbe-text) !important; border-radius: 12px !important; height: 34px !important; min-height: 34px !important; padding: 0 10px !important; font-weight: 900 !important; font-size: 13px !important; cursor: pointer; display:inline-flex !important; align-items:center !important; gap: 8px; }
			.hbe-hub-wrapper .hbe-basket-toggle::after { content: none !important; display:none !important; }
			.hbe-hub-wrapper .hbe-basket-toggle::before { content: none !important; display:none !important; }
			.hbe-hub-wrapper .hbe-basket-toggle .hbe-chevron { display:inline-block; transition: transform .18s ease; }
			.hbe-hub-wrapper .hbe-basket.is-collapsed .hbe-basket-toggle .hbe-chevron { transform: rotate(-90deg); }
			.hbe-hub-wrapper .hbe-basket-mini { color: var(--hbe-muted); font-size: 12px; margin-top: 4px; }
			.hbe-hub-wrapper .hbe-basket.is-collapsed .hbe-basket-body,
			.hbe-hub-wrapper .hbe-basket.is-collapsed .hbe-basket-foot { display:none; }
			.hbe-hub-wrapper .hbe-basket.is-collapsed .hbe-basket-head { border-bottom: 0; padding-bottom: 14px; }
			/* (Dropzone removed; click-to-add is the primary UX) */
			@media (min-width: 980px) {
				.hbe-hub-wrapper .hbe-basket {
					display: flex;
					flex-direction: column;
					max-height: calc(100dvh - 24px);
				}
				.hbe-hub-wrapper .hbe-basket-body {
					flex: 1 1 auto;
					min-height: 0;
					overflow-y: auto;
					overscroll-behavior: contain;
				}
				.hbe-hub-wrapper .hbe-basket-foot {
					flex: 0 0 auto;
				}
			}
			@media (max-width: 979px) {
				.hbe-hub-wrapper .hbe-mobile-backdrop {
					position: fixed;
					inset: 0;
					background: rgba(6, 10, 18, .18);
					backdrop-filter: blur(6px);
					-webkit-backdrop-filter: blur(6px);
					opacity: 0;
					pointer-events: none;
					transition: opacity .22s ease;
					z-index: 1004;
				}
				.hbe-hub-wrapper .hbe-mobile-backdrop.is-active {
					opacity: 1;
					pointer-events: auto;
				}
				/* Mobile floating drawer */
				.hbe-hub-wrapper .hbe-basket {
					position: fixed;
					left: 12px;
					right: 12px;
					width: auto;
					bottom: max(88px, calc(env(safe-area-inset-bottom) + 76px));
					z-index: 1005;
					border-radius: 16px;
					box-shadow: 0 18px 40px rgba(8, 14, 26, .45);
					max-height: calc(100dvh - 24px);
					display: flex;
					flex-direction: column;
				}
				.hbe-hub-wrapper .hbe-basket-head {
					padding: 12px;
				}
				.hbe-hub-wrapper .hbe-basket-mini {
					font-size: 13px;
					margin-top: 2px;
				}
				.hbe-hub-wrapper .hbe-basket-body,
				.hbe-hub-wrapper .hbe-basket-foot {
					max-height: 0;
					overflow: hidden;
					padding-top: 0 !important;
					padding-bottom: 0 !important;
					border-top: 0 !important;
					transition: max-height .25s ease, padding .25s ease;
				}
				.hbe-hub-wrapper .hbe-basket.is-mobile-open .hbe-basket-body {
					max-height: calc(62dvh - 70px);
					overflow: auto;
					padding: 10px 12px 12px !important;
				}
				.hbe-hub-wrapper .hbe-basket.is-mobile-open .hbe-basket-foot {
					max-height: 240px;
					overflow: auto;
					padding: 12px 12px 14px !important;
					border-top: 1px solid var(--hbe-border) !important;
				}
				.hbe-hub-wrapper .hbe-basket.is-mobile-open .hbe-chevron { transform: rotate(180deg); }
				.hbe-hub-wrapper .hbe-basket-toggle {
					min-width: 108px;
					justify-content: center;
				}
			}

			.hbe-hub-wrapper .hbe-basket-body { padding: 10px 12px 12px; }
			.hbe-hub-wrapper .hbe-empty { margin: 10px 0; color: var(--hbe-muted); }
			.hbe-hub-wrapper .hbe-basket-items { display:flex; flex-direction:column; gap: 10px; margin-top: 10px; }
			.hbe-hub-wrapper .hbe-line { display:grid; grid-template-columns: 1fr auto; gap: 10px; padding: 10px; border: 1px solid var(--hbe-border); border-radius: 14px; background: rgba(255,255,255,.03); line-height: 1.2; }
			.hbe-hub-wrapper .hbe-line a { color: #fff; text-decoration:none; font-weight: 700; font-size: 13px; line-height: 1.25; display: inline-block; }
			.hbe-hub-wrapper .hbe-line a:hover { text-decoration: underline; }
			.hbe-hub-wrapper .hbe-line-meta { color: rgba(255,255,255,.86); font-size: 12px; margin-top: 4px; line-height: 1.2; }
			.hbe-hub-wrapper .hbe-qty { display:flex; align-items:center; gap: 6px; }
			.hbe-hub-wrapper .hbe-qty button { width: 30px !important; height: 30px !important; min-width: 30px !important; min-height: 30px !important; border-radius: 10px !important; border: 1px solid rgba(255,255,255,.24) !important; background: rgba(255,255,255,.04) !important; color: #fff !important; cursor:pointer; font-weight:700 !important; line-height: 1 !important; display:flex !important; align-items:center !important; justify-content:center !important; padding: 0 !important; }
			.hbe-hub-wrapper .hbe-qty span { min-width: 18px; text-align:center; font-weight:800; color: #fff; }

			.hbe-hub-wrapper .hbe-basket-foot { padding: 12px 12px 14px; border-top: 1px solid var(--hbe-border); display:flex; flex-direction:column; gap: 10px; }
			.hbe-hub-wrapper .hbe-basket-foot form { width: 100%; margin: 0; }
			.hbe-hub-wrapper .hbe-total { display:flex; justify-content:space-between; align-items:center; color: var(--hbe-muted); font-size: 13px; }
			.hbe-hub-wrapper .hbe-total strong { color: var(--hbe-text); font-size: 15px; }
			.hbe-hub-wrapper .hbe-total strong .hbe-total-inc { font-size: .82em; font-weight: 600; opacity: .88; }
			.hbe-hub-wrapper .hbe-btn-wide { width: 100% !important; max-width: none !important; margin: 0 !important; padding: 12px 12px !important; border-radius: 14px !important; }
			.hbe-hub-wrapper .hbe-share-wrap { border-top: 1px dotted rgba(255,255,255,.28); padding-top: 10px; display:flex; flex-direction:column; gap: 8px; }
			.hbe-hub-wrapper .hbe-share-actions { display: grid; grid-template-columns: 7fr 3fr; gap: 8px; width: 100%; }
			.hbe-hub-wrapper .hbe-share-actions .hbe-btn { background: #FF877E !important; border-color: #FF877E !important; color: #0b1220 !important; }
			.hbe-hub-wrapper .hbe-share-actions .hbe-btn:hover { background: #ff9f98 !important; border-color: #ff9f98 !important; }
			.hbe-hub-wrapper .hbe-btn-email { gap: 6px; padding-left: 10px; padding-right: 10px; }
			.hbe-hub-wrapper .hbe-btn-email svg { width: 14px; height: 14px; stroke: currentColor; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; pointer-events: none; }
			.hbe-hub-wrapper .hbe-btn-danger { border-color: rgba(255,255,255,.14) !important; background: rgba(255,255,255,.06) !important; color: var(--hbe-text) !important; }
			.hbe-hub-wrapper .hbe-basket-mini.is-pulse { animation: hbeMiniPulse .36s ease; }
			@keyframes hbeMiniPulse {
				0% { transform: scale(1); opacity: .95; }
				40% { transform: scale(1.06); opacity: 1; }
				100% { transform: scale(1); opacity: 1; }
			}
			.hbe-hub-wrapper .hbe-added-toast { position: fixed; left: 12px; top: 12px; z-index: 1100; width: min(360px, calc(100vw - 24px)); background: linear-gradient(180deg, rgb(1 97 104), rgba(10,18,32,.98)); color: #fff; border: 1px solid rgba(255,255,255,.14); border-radius: 12px; box-shadow: 0 14px 34px rgba(7,12,22,.38); padding: 10px 12px; font-size: 12px; font-weight: 700; line-height: 1.25; opacity: 0; transform: translateY(10px); pointer-events: none; transition: opacity .22s ease, transform .22s ease; }
			.hbe-hub-wrapper .hbe-added-toast.is-show { opacity: 1; transform: translateY(0); }

			/* Debug */
			.hbe-hub-wrapper .hbe-debug-panel { margin-top: 14px; padding: 12px; border: 1px dashed rgba(232,238,252,.35); border-radius: 14px; background: rgba(255,255,255,.04); color: var(--hbe-muted); font-size: 12px; }
			.hbe-hub-wrapper .hbe-debug-panel code, 
			.hbe-hub-wrapper .hbe-debug-panel pre { color: var(--hbe-text); }
			.hbe-hub-wrapper .hbe-debug-panel pre { white-space: pre-wrap; word-break: break-word; margin: 8px 0 0; }
