/* ==========================================================================
   Single product — ported from prototype product.html, adapted to native
   WooCommerce variation form + plugin output (Flycart, Box Addons, gallery).
   ========================================================================== */

/* breadcrumb shares .crumb from category.css; redeclare minimally here */
.crumb{padding:15px 0}
.crumb ol{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.crumb a{color:var(--muted);transition:.15s}
.crumb a:hover{color:var(--brand)}
.crumb .sep{opacity:.5}
.crumb li:last-child{color:var(--ink);font-weight:600}

.pdp{padding:26px 0 60px}
.pdp-main{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}

/* gallery — thumbnail column on the left + large main image on the right.
   The flexslider container must stay a normal block (it measures its own width
   to size slides), so the thumbnail strip is absolutely positioned into a
   reserved left gutter rather than using flex on the gallery root. */
.gallery{position:sticky;top:150px;min-width:0}
/* Both PDP grid columns must allow shrinking, else wide buy-box content (pack
   prices / discount table that appears once a variation is chosen) forces the
   column past the viewport on mobile. */
.summary,.buybox{min-width:0}
.gallery .woocommerce-product-gallery{position:relative;margin:0}
.gallery .woocommerce-product-gallery:has(.flex-control-thumbs){padding-left:78px}
.gallery img{border-radius:var(--r-l)}
/* The rounded white frame lives on the STATIC box. With flexslider active that's
   .flex-viewport — the __wrapper is the strip of slides that animates sideways,
   so a border/radius on it travels with the animation (stray curved corners
   appearing at the frame edge). Without flexslider the wrapper IS the static box. */
.gallery .woocommerce-product-gallery__wrapper{margin:0;border:1px solid var(--line);border-radius:var(--r-l);overflow:hidden;background:#fff}
.gallery .flex-viewport{border:1px solid var(--line);border-radius:var(--r-l);overflow:hidden;background:#fff}
.gallery .flex-viewport .woocommerce-product-gallery__wrapper{border:0;border-radius:0;background:#fff}
/* let the white frame wrap each image's own shape (no square letterboxing) —
   some photos (e.g. postal box variations) aren't square. No radius on the image
   itself — the static frame clips the corners. */
.gallery .woocommerce-product-gallery__wrapper img{width:100%;height:auto;object-fit:contain;background:#fff;border-radius:0}
/* Thumbnail rail capped to the main-image height and scrollable, so a product
   with many photos (7–8, Amazon-style) keeps a tidy column instead of running
   far below the main image. ~54px thumbs let up to ~8 fit before any scroll. */
.gallery .woocommerce-product-gallery .flex-control-thumbs{position:absolute!important;left:0;top:0;bottom:0;width:66px;box-sizing:border-box;display:flex;flex-direction:column;gap:8px;margin:0!important;padding:0 6px 0 0;list-style:none;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin}
.gallery .woocommerce-product-gallery .flex-control-thumbs li{width:54px!important;height:54px;float:none!important;margin:0!important}
.gallery .woocommerce-product-gallery .flex-control-thumbs img{width:100%!important;height:100%;object-fit:contain;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:6px;box-sizing:border-box;cursor:pointer;opacity:1;transition:.15s}
.gallery .woocommerce-product-gallery .flex-control-thumbs img.flex-active,.gallery .woocommerce-product-gallery .flex-control-thumbs img:hover{border-color:var(--brand)}
.gbadge{position:absolute;top:14px;left:14px;z-index:2;background:var(--ink);color:#fff;font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:12px;padding:6px 12px;border-radius:8px}

/* The .deliv postcode estimator styles now live in style.css (shared by the
   single product page and the cart). */

/* summary */
.summary .peyebrow{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand)}
.summary h1{font-size:clamp(26px,3vw,38px);font-weight:900;letter-spacing:-.02em;margin:10px 0 12px;line-height:1.08}
.prow{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.prow .stars .icn{width:16px;height:16px;fill:var(--amber);stroke:none}
.prow .rev-link{font-size:13.5px;color:var(--muted)}
.prow .rev-link b{color:var(--ink);font-family:"Archivo","Archivo Fallback"}
.prow .rev-link a{text-decoration:underline}
.prow .sku{font-size:13px;color:var(--muted);border-left:1px solid var(--line);padding-left:14px}

/* short description → psub + feature bullets */
.woocommerce-product-details__short-description{color:var(--ink-2);font-size:16px;line-height:1.6;margin-bottom:22px;max-width:52ch}
.woocommerce-product-details__short-description ul{list-style:none;display:grid;gap:9px;margin:14px 0 0;padding:0}
.woocommerce-product-details__short-description ul li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-2);position:relative;padding-left:28px}
.woocommerce-product-details__short-description ul li::before{content:"";position:absolute;left:0;top:1px;width:18px;height:18px;background:no-repeat center/contain url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%231c8a5b" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5"/></svg>')}

/* buy box card */
.buybox{border:1px solid var(--line);border-radius:var(--r-l);background:#fff;padding:22px;box-shadow:var(--shadow)}
.buybox .price-now{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.buybox .price-now .big{font-family:"Archivo","Archivo Fallback";font-weight:900;font-size:34px;letter-spacing:-.02em}
.buybox .price-now .big .from{font-family:"Hanken Grotesk","Hanken Fallback";font-weight:500;font-size:14px;color:var(--muted)}
.buybox .price-now .vatlab{font-size:13px;color:var(--muted);font-weight:600}
.buybox .price-now .incl{font-size:14px;color:var(--ink-2);font-weight:600}
.buybox .price-now .unit{font-size:14px;color:var(--ink-2);font-weight:600;margin-left:auto}
.buybox .price-now .amount{font-family:inherit}

/* option labels + pack cards (custom display layer) */
.optlabel{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin:18px 0 10px;display:flex;justify-content:space-between;align-items:center}
.optlabel .hint{font-family:"Hanken Grotesk","Hanken Fallback";font-weight:600;text-transform:none;letter-spacing:0;font-size:12.5px;color:var(--brand)}
.packs{display:grid;gap:10px}
.packs-empty{font-size:13.5px;color:var(--muted);border:1px dashed var(--line);border-radius:12px;padding:14px 15px}
.packs-empty.packs-oos{color:#9c2a2a;background:#fdecec;border:1px solid #f3c6c6;font-weight:700;display:flex;align-items:center;gap:8px}
.packs-empty.packs-oos::before{content:"\2715";font-weight:900}
.pack{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:13px;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;cursor:pointer;transition:.15s;background:#fff;position:relative}
.pack:hover{border-color:#c2cdda}
.pack.on{border-color:var(--brand);background:var(--brand-soft)}
.pack .radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;transition:.15s}
.pack.on .radio{border-color:var(--brand)}
.pack.on .radio::after{content:"";width:10px;height:10px;border-radius:50%;background:var(--brand)}
.pack .pk-name{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:15px}
.pack .pk-unit{font-size:12.5px;color:var(--muted);margin-top:2px}
.pack .pk-right{text-align:right}
.pack .pk-price{font-family:"Archivo","Archivo Fallback";font-weight:800;font-size:16px}
.pack .pk-save{font-size:11.5px;font-weight:700;color:var(--green);font-family:"Archivo","Archivo Fallback"}
/* Badge holder pinned to the card's top-right; lets a card show e.g. "Full Box"
   next to "Best value". */
.pack .pk-tags{position:absolute;top:-9px;right:14px;display:flex;gap:5px}
.pack .pk-tag{background:var(--green);color:#fff;font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:10.5px;letter-spacing:.04em;padding:3px 9px;border-radius:6px;white-space:nowrap}
/* "Sample" tag on the pack-of-1 card — slate, to read as informational not a deal. */
.pack .pk-tag.pk-sample{background:#64748b}
/* Full-case tag ("Full Box" / "Outer Box" / "Full Pack") — brand blue. */
.pack .pk-tag.pk-box{background:var(--brand)}
/* Sale banner shown above the size selector. */
.bagit-flags{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 12px}
.bagit-flags:empty{display:none;margin:0}
.bagit-flag{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:6px;background:var(--brand-soft);color:var(--brand-d)}
.bagit-flag.flag-sale{background:#e11d48;color:#fff}

/* native variation form */
.buybox form.cart{margin:0}
.buybox .variations{width:100%;border-collapse:collapse;margin:6px 0 0}
.buybox .variations tr{display:block;margin-top:16px}
.buybox .variations th.label{display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left;font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);padding:0 0 10px}
.buybox .variations th.label .hint{font-family:"Hanken Grotesk","Hanken Fallback";font-weight:600;text-transform:none;letter-spacing:0;font-size:12.5px;color:var(--brand);white-space:nowrap}
.buybox .variations td.value{display:block;position:relative}
.buybox .variations td.value select{width:100%;appearance:none;-webkit-appearance:none;border:1.5px solid var(--line);border-radius:12px;background:#fff;font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:15px;color:var(--ink);padding:14px 44px 14px 15px;cursor:pointer;outline:none}
.buybox .variations td.value select:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
.buybox .variations td.value::after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;width:18px;height:18px;background:no-repeat center/contain url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%236b7280" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="m6 9 6 6 6-6"/></svg>')}
.buybox .reset_variations{font-size:12.5px;color:var(--brand);display:inline-block;margin-top:8px}
/* hide the variation's own price/availability — our price-now is the source of truth */
.buybox .woocommerce-variation-price{display:none}
/* hide everything WC/plugins put in the variation-availability slot (we show our
   own stock line + delivery estimator), but keep the back-order notice visible */
.buybox .woocommerce-variation-availability>*:not(.available-on-backorder):not(.out-of-stock){display:none}
/* WooCommerce stock notices, styled to the theme (simple + variation) */
.buybox p.stock.available-on-backorder,
.buybox p.stock.out-of-stock{display:flex;align-items:flex-start;gap:8px;margin:14px 0 0;padding:11px 14px;border-radius:10px;font-size:13.5px;font-weight:700;line-height:1.4}
.buybox p.stock.available-on-backorder{background:#fff7e6;border:1px solid #f3d79a;color:#8a5a00}
.buybox p.stock.out-of-stock{background:#fdecec;border:1px solid #f3c6c6;color:#9c2a2a}
.buybox p.stock.available-on-backorder::before{content:"\26A0";font-size:15px;line-height:1.3}
.buybox p.stock.out-of-stock::before{content:"\2715";font-size:14px;line-height:1.4;font-weight:900}
.buybox .woocommerce-variation.single_variation{margin-top:6px}

/* quantity stepper (native .quantity, enhanced by product.js) */
.buybox .addrow,.buybox .woocommerce-variation-add-to-cart{display:flex;gap:12px;margin-top:18px;align-items:stretch;flex-wrap:nowrap}
.buybox .quantity{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:12px;overflow:hidden;flex:none}
.buybox .quantity .bagit-step{width:46px;height:54px;border:0;background:#fff;font-size:20px;cursor:pointer;color:var(--ink);display:grid;place-items:center}
.buybox .quantity .bagit-step:hover{background:var(--bg-2)}
.buybox .quantity input.qty{width:50px;height:54px;border:0;text-align:center;font-family:"Archivo","Archivo Fallback";font-weight:800;font-size:17px;outline:none;-moz-appearance:textfield}
.buybox .quantity input.qty::-webkit-outer-spin-button,.buybox .quantity input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.buybox .single_add_to_cart_button.button{flex:1;min-width:0;border:0;border-radius:12px;background:var(--brand);color:#fff;font-family:"Archivo","Archivo Fallback";font-weight:800;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:.16s;padding:0 20px;white-space:nowrap;height:54px}
.buybox .single_add_to_cart_button.button::before{content:"";width:20px;height:20px;flex:none;background:no-repeat center/contain url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M6 2 3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4z"/><path d="M3 6h18"/><path d="M16 10a4 4 0 0 1-8 0"/></svg>')}
.buybox .single_add_to_cart_button.button:hover{background:var(--brand-d)}
.buybox .single_add_to_cart_button.button.added{background:var(--green)}
.buybox .single_add_to_cart_button.button.disabled{opacity:.5;cursor:not-allowed}

/* Flycart bulk discount table (style its output to the .disc design) */
.buybox .wdr_table_wrapper,.buybox .advanced-woo-discount-rules-onsale-product,#discTable .disc,.buybox table.wdr_bulk_table{margin-top:14px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.buybox table.wdr_bulk_table,.buybox .wdr_table_wrapper table{width:100%;border-collapse:collapse}
.buybox .wdr_table_wrapper th,.buybox table.wdr_bulk_table th{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:11.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);text-align:left;padding:10px 14px;border-bottom:1px solid var(--line-2);background:var(--brand-soft)}
.buybox .wdr_table_wrapper td,.buybox table.wdr_bulk_table td{padding:11px 14px;font-size:14px;border-bottom:1px solid var(--line-2)}
.buybox .wdr_table_wrapper td:last-child,.buybox table.wdr_bulk_table td:last-child{text-align:right;font-family:"Archivo","Archivo Fallback";font-weight:800}

/* The buybox shows the theme's own branded bulk table (#discTable, below). Hide
   the discount plugin's native bulk table (Flycart "Advanced Woo Discount Rules",
   .awdr-* output) so it doesn't render a second, duplicate table — it was showing
   above the size selector on mobile because the styling above only covered the
   plugin's older .wdr_* markup, not the current .awdr-* markup. #discTable builds
   its own rows from the stored rules, so hiding this does not affect it. */
.awdr-bulk-customizable-table,.awdr-product-table-wrapper,.advanced-woo-discount-rules-product-table,.buybox .awdr-table{display:none !important}

/* custom bulk discount table (#discTable) */
#discTable .disc{margin-top:14px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.disc-h{background:var(--brand-soft);color:var(--brand-d);font-family:"Archivo","Archivo Fallback";font-weight:800;font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:10px 14px;display:flex;align-items:center;gap:8px}
.disc-h .icn{stroke:var(--brand-d);width:16px;height:16px;fill:none}
.disc table{width:100%;border-collapse:collapse}
.disc th{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:11.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);text-align:left;padding:10px 14px;border-bottom:1px solid var(--line-2)}
.disc td{padding:11px 14px;font-size:14px;border-bottom:1px solid var(--line-2)}
.disc tr:last-child td{border-bottom:0}
.disc th:last-child,.disc td:last-child{text-align:right;font-family:"Archivo","Archivo Fallback";font-weight:800}
.disc tr.cur td{background:var(--brand-soft)}

/* trust list */
.buy-meta{display:grid;gap:9px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.buy-meta div{display:flex;gap:10px;align-items:center;font-size:13.5px;color:var(--ink-2)}
.buy-meta .icn{stroke:var(--brand);width:17px;height:17px;flex:none}
.buy-meta b{color:var(--ink);font-weight:700}

/* custom-size callout */
.tradecta{display:flex;align-items:center;flex-wrap:wrap;gap:13px;margin-top:16px;background:var(--ink);color:#fff;border-radius:14px;padding:16px}
.tradecta .tc-ic{width:40px;height:40px;border-radius:10px;background:rgba(157,180,255,.16);display:grid;place-items:center;flex:none}
.tradecta .tc-ic .icn{stroke:#9db4ff;width:21px;height:21px}
.tradecta .tc-txt{flex:1;min-width:130px}
.tradecta p{font-size:12.5px;color:#c2c9d4;margin-top:2px}
.tradecta b{color:#fff;font-family:"Archivo","Archivo Fallback";display:block;font-size:14.5px}
.tradecta a{margin-left:auto;white-space:nowrap;font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:13px;color:#fff;background:var(--brand);border-radius:999px;padding:10px 16px;transition:.15s}
.tradecta a:hover{background:var(--brand-d)}

/* WebToffee delivery estimate slot (style whatever it outputs) */
.buybox .wf-edd-wrapper,.buybox .wf_edd_estimated_delivery{margin-top:16px;border:1px solid var(--line);border-radius:14px;padding:13px 15px;font-size:14px;color:var(--ink-2)}

/* info strip */
.usp2{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.usp2 .wrap{display:grid;grid-template-columns:1fr 1fr 1fr 1.5fr;gap:0;align-items:stretch}
.usp2 .item{display:flex;align-items:center;gap:11px;padding:22px 20px;border-right:1px solid var(--line)}
.usp2 .item .ic{width:44px;height:44px;border-radius:11px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;flex:none}
.usp2 .item .ic .icn{stroke:var(--brand);width:22px;height:22px}
.usp2 .item b{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:14px;display:block}
.usp2 .item span{font-size:12.5px;color:var(--muted)}
.usp2 .contact{display:flex;align-items:center;gap:12px;padding:16px 20px;margin:10px;border-radius:14px;background:var(--ink);color:#fff;border-left:1px solid var(--line)}
.usp2 .contact .c-ic{width:40px;height:40px;border-radius:10px;background:rgba(157,180,255,.16);display:grid;place-items:center;flex:none}
.usp2 .contact .c-ic .icn{stroke:#9db4ff;width:21px;height:21px}
.usp2 .contact p{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:13.5px;max-width:20ch;line-height:1.3}
.usp2 .contact a{white-space:nowrap;background:var(--brand);color:#fff;font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:14px;padding:11px 18px;border-radius:999px;transition:.15s;margin-left:auto}
.usp2 .contact a:hover{background:var(--brand-d)}

/* sizes table (box_addon_table styled) */
.sizeguide-block{padding-bottom:34px;margin-bottom:10px;border-bottom:1px solid var(--line)}
.sizeguide-title{font-family:"Archivo","Archivo Fallback";font-weight:800;font-size:22px;letter-spacing:-.01em;margin-bottom:8px}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -2px}
.sizes-table table{width:100%;min-width:560px;border-collapse:collapse;font-size:14px}
.sizes-table th{font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:11.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);text-align:left;padding:11px 12px;border-bottom:2px solid var(--line)}
.sizes-table td{padding:12px;border-bottom:1px solid var(--line-2)}
.sizes-table tr:hover td{background:var(--bg-2)}
/* Small screens: stack each size into a labelled card (data-label set by product.js) */
@media(max-width:600px){
  .table-scroll{overflow-x:visible;margin:0}
  .sizes-table table{min-width:0}
  .sizes-table thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
  .sizes-table tbody tr{display:block;border:1px solid var(--line);border-radius:12px;padding:4px 14px;margin-bottom:12px}
  .sizes-table tbody tr:hover td{background:transparent}
  .sizes-table td{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:10px 0;border-bottom:1px solid var(--line-2);text-align:right}
  .sizes-table td:last-child{border-bottom:0}
  .sizes-table td::before{content:attr(data-label);font-family:"Archivo","Archivo Fallback";font-weight:700;font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);text-align:left;flex:none}
  .sizes-table td:empty{display:none}
}

/* accordions */
.pdetails{margin-top:8px}
.acc{border-bottom:1px solid var(--line)}
.acc summary{display:flex;justify-content:space-between;align-items:center;cursor:pointer;list-style:none;font-family:"Archivo","Archivo Fallback";font-weight:800;font-size:18px;padding:22px 0}
.acc summary::-webkit-details-marker{display:none}
.acc .pm{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;flex:none;transition:.2s}
.acc[open] .pm{background:var(--brand);border-color:var(--brand);transform:rotate(45deg)}
.acc[open] .pm .icn{stroke:#fff}
.acc .pm .icn{width:16px;height:16px}
.acc .acc-body{padding:0 0 24px;color:var(--ink-2);font-size:15.5px;line-height:1.7;max-width:74ch}
.acc .acc-body p{margin-bottom:12px}
.spec-wrap table,.shop_attributes{width:100%;border-collapse:collapse;max-width:560px}
.spec-wrap th,.spec-wrap td,.shop_attributes th,.shop_attributes td{padding:11px 0;border-bottom:1px solid var(--line-2);font-size:14.5px;text-align:left}
.shop_attributes th{color:var(--muted);width:45%;font-weight:600}

/* native reviews inside the Reviews accordion */
#reviews .commentlist{list-style:none;display:grid;gap:20px;margin:0;padding:0}
#reviews .comment-text{display:grid;gap:6px}
#reviews .star-rating{color:var(--amber)}
#reviews .comment-form{display:grid;gap:12px;margin-top:18px}
#reviews .comment-form input,#reviews .comment-form textarea{border:1.5px solid var(--line);border-radius:10px;padding:12px;font:inherit;outline:none}
#reviews .comment-form .submit{justify-self:start;background:var(--brand);color:#fff;border:0;border-radius:999px;padding:12px 24px;font-family:"Archivo","Archivo Fallback";font-weight:700;cursor:pointer}

/* related products grid */
.related-products ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;margin:0;padding:0}
.related-products ul.products::before,.related-products ul.products::after{display:none}
.related-products ul.products li.product{width:auto;margin:0;float:none}

/* responsive */
@media(max-width:1080px){
  .related-products ul.products{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .related-products ul.products{grid-template-columns:1fr 1fr;gap:12px}
}
@media(max-width:980px){
  .pdp-main{grid-template-columns:1fr;gap:30px}
  .gallery{position:static}
  /* stack: main image on top, thumbnails in a row beneath */
  .gallery .woocommerce-product-gallery:has(.flex-control-thumbs){padding-left:0}
  .gallery .woocommerce-product-gallery .flex-control-thumbs{position:static!important;width:auto;height:auto;flex-direction:row;flex-wrap:wrap;overflow:visible;padding:0;margin-top:12px!important}
  .gallery .woocommerce-product-gallery .flex-control-thumbs li{width:60px!important;height:60px}
  .usp2 .wrap{grid-template-columns:1fr 1fr}
  .usp2 .item:nth-child(2){border-right:0}
  .usp2 .contact{grid-column:1 / -1;justify-content:space-between}
}
@media(max-width:760px){
  .pdp{padding:18px 0 50px}
  .summary h1{font-size:24px}
  .buybox{padding:18px;border-radius:16px}
  .buybox .price-now .big{font-size:30px}
  .buybox .price-now .unit{width:100%;margin-left:0;margin-top:2px}
  .acc summary{font-size:16px;padding:18px 0}
  /* stack the add-to-cart row: stepper full-width, button full-width below, so
     "Add to basket — £xx.xx" never overflows */
  .buybox .addrow,.buybox .woocommerce-variation-add-to-cart{flex-wrap:wrap}
  .buybox .quantity{width:100%}
  .buybox .quantity input.qty{flex:1;width:auto}
  .buybox .single_add_to_cart_button.button{flex:1 0 100%}
}
@media(max-width:600px){
  .usp2 .wrap{grid-template-columns:1fr}
  .usp2 .item{border-right:0;border-bottom:1px solid var(--line)}
  .usp2 .contact{align-items:center;gap:13px;padding:16px 18px;margin:14px;border-radius:14px}
  .usp2 .contact p{flex:1;max-width:none;font-size:14px}
  .usp2 .contact a{margin-left:0}
}

/* note disclosing the Amazon rating baseline in the reviews accordion */
.rev-source-note{font-size:13px;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:10px 14px;margin:0 0 16px}
