/* ============================================================
   SpectraLight modern design system (.sl-*)
   Shared by the home page and product pages so the whole site
   speaks one visual language. Tokens, sections, typography,
   buttons, cards and the modern product buy box all live here.
   ============================================================ */
.sl-home{
	--o:#f68a1f;
	--o-2:#ffb15a;
	--blue:#2997ff;
	--ink:#05070d;
	--ink-2:#0a1018;
	--ink-3:#101a26;
	--line:rgba(255,255,255,.12);
	--line-dark:rgba(10,16,24,.1);
	--mut:rgba(255,255,255,.72);
	color:#0a1018;
	overflow-x:hidden;
}
.sl-home *{box-sizing:border-box;}
.sl-wrap{
	width:100%;
	max-width:1220px;
	margin:0 auto;
	padding-left:clamp(1.1rem,4vw,2.5rem);
	padding-right:clamp(1.1rem,4vw,2.5rem);
}
.sl-section{position:relative;padding:clamp(3.5rem,8vw,7rem) 0;}
.sl-section--tight{padding:clamp(2.5rem,6vw,4.5rem) 0;}

/* ---- backgrounds ---- */
.sl-dark{
	background:
		radial-gradient(120% 90% at 80% -10%, rgba(41,151,255,.16), transparent 55%),
		radial-gradient(90% 80% at 8% 0%, rgba(246,138,31,.16), transparent 50%),
		linear-gradient(180deg,var(--ink),var(--ink-2));
	color:#fff;
}
.sl-dark::before{
	content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
	background-image:
		linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
		linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
	background-size:46px 46px;
	-webkit-mask-image:radial-gradient(120% 100% at 50% 0%,#000,transparent 75%);
	mask-image:radial-gradient(120% 100% at 50% 0%,#000,transparent 75%);
}
.sl-dark > *{position:relative;z-index:1;}
.sl-tint{background:linear-gradient(180deg,#f5f9fc,#eef4fa);}
.sl-light{background:#fff;}

/* ---- typography helpers ---- */
.sl-eyebrow{
	display:inline-flex;align-items:center;gap:.55rem;
	font-size:.74rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;
	color:var(--o);margin:0 0 1.1rem;
}
.sl-eyebrow::before{
	content:"";width:8px;height:8px;border-radius:50%;background:var(--o);
	box-shadow:0 0 0 4px rgba(246,138,31,.18),0 0 14px var(--o);
}
.sl-eyebrow.is-light{color:#0a1018;}
.sl-h2{
	font-size:clamp(1.9rem,4.4vw,3.25rem);
	line-height:1.05;letter-spacing:-1.5px;font-weight:800;margin:0 0 1.1rem;
}
.sl-lead{font-size:clamp(1.02rem,1.6vw,1.2rem);line-height:1.7;color:#3a444f;max-width:46ch;}
.sl-dark .sl-lead{color:var(--mut);}
.sl-orange{color:var(--o);}

/* ---- buttons / links ---- */
.sl-btns{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.8rem;}
.sl-btn{
	display:inline-flex;align-items:center;gap:.55rem;
	padding:.9rem 1.55rem;border-radius:999px;font-weight:700;font-size:.98rem;
	text-decoration:none;border:1px solid transparent;cursor:pointer;
	transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;
}
.sl-btn svg{width:15px;height:11px;}
.sl-btn--primary{
	background:linear-gradient(135deg,var(--o),var(--o-2));color:#0a0a0a;
	box-shadow:0 10px 30px rgba(246,138,31,.35);
}
.sl-btn--primary svg path{fill:#0a0a0a;}
.sl-btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(246,138,31,.5);color:#0a0a0a;}
.sl-btn--ghost{border-color:var(--line);color:#fff;background:rgba(255,255,255,.04);}
.sl-btn--ghost svg path{fill:#fff;}
.sl-btn--ghost:hover{border-color:var(--o);color:var(--o);transform:translateY(-2px);}
.sl-btn--ghost:hover svg path{fill:var(--o);}
.sl-btn--dark{background:#0a1018;color:#fff;}
.sl-btn--dark svg path{fill:#fff;}
.sl-btn--dark:hover{background:#000;color:#fff;transform:translateY(-2px);}

.sl-link{
	display:inline-flex;align-items:center;gap:.7rem;margin-top:1.4rem;
	font-weight:700;text-decoration:none;color:inherit;
}
.sl-link .sl-arrow{
	display:flex;align-items:center;justify-content:center;
	width:2.4rem;height:2.4rem;border-radius:999px;background:var(--o);flex:0 0 auto;
	transition:transform .3s ease;
}
.sl-link .sl-arrow svg{width:15px;height:11px;}
.sl-link .sl-arrow svg path{fill:#0a0a0a;}
.sl-link:hover{color:var(--o);}
.sl-link:hover .sl-arrow{transform:translateX(4px);}

/* ---- split layout (image + text) ---- */
.sl-split{
	display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,22rem),1fr));
	gap:clamp(2rem,5vw,4.5rem);align-items:center;
}
.sl-split > *{min-width:0;}
.sl-split--rev .sl-split__media{order:2;}
.sl-split__media{position:relative;text-align:center;}
.sl-split__media img,.sl-split__media video{
	max-width:100%;height:auto;position:relative;z-index:1;border-radius:14px;
}
.sl-glow::after{
	content:"";position:absolute;z-index:0;inset:8% 8%;border-radius:50%;
	background:radial-gradient(circle,rgba(246,138,31,.42),transparent 62%);
	filter:blur(46px);
}
.sl-glow.is-blue::after{background:radial-gradient(circle,rgba(41,151,255,.4),transparent 62%);}

/* ---- hero ---- */
.sl-hero{
	position:relative;min-height:clamp(540px,86vh,860px);
	display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);
}
.sl-hero picture,.sl-hero picture img{
	position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.sl-hero__scrim{
	position:absolute;inset:0;z-index:1;
	background:
		linear-gradient(180deg,rgba(5,7,13,.62) 0%,rgba(5,7,13,.12) 26%,rgba(5,7,13,.05) 52%,rgba(5,7,13,.78) 100%),
		linear-gradient(90deg,rgba(5,7,13,.6),transparent 60%);
}
.sl-hero__content{
	position:relative;z-index:2;width:100%;
	padding-bottom:clamp(2.5rem,6vw,4.5rem);padding-top:clamp(7rem,12vw,9rem);
	color:#fff;
}
.sl-hero h1{
	font-size:clamp(2.6rem,7vw,5.4rem);line-height:.98;letter-spacing:-3px;
	font-weight:800;margin:0 0 1.2rem;color:#fff;
	text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.sl-hero .sl-lead{color:rgba(255,255,255,.9);max-width:40ch;}
.sl-hero__stats{
	display:flex;flex-wrap:wrap;gap:clamp(1.2rem,3vw,2.6rem);margin-top:2rem;
	padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.18);
}
.sl-hero__stats .n{display:block;font-size:clamp(1.4rem,3vw,2rem);font-weight:800;letter-spacing:-1px;color:#fff;}
.sl-hero__stats .l{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:.15rem;}

/* ---- intro / product showcase ---- */
.sl-showcase{text-align:center;}
.sl-showcase h2{font-size:clamp(2rem,5vw,3.4rem);line-height:1.04;letter-spacing:-1.5px;font-weight:800;margin:0 0 2rem;}
.sl-showcase__img{position:relative;display:inline-block;width:100%;max-width:1100px;}
.sl-showcase__img > img{max-width:100%;width:100%;height:auto;position:relative;z-index:2;}

/* ---- stat band ---- */
.sl-stats{
	display:grid;grid-template-columns:repeat(3,1fr);
	gap:1px;background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden;
}
.sl-stat{padding:clamp(1.4rem,3vw,2.2rem);background:rgba(255,255,255,.02);}
.sl-stat .n{font-size:clamp(2rem,5vw,3.1rem);font-weight:800;letter-spacing:-2px;
	background:linear-gradient(135deg,var(--o),var(--o-2));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;}
.sl-stat .l{margin:.6rem 0 0;font-size:.95rem;color:var(--mut);line-height:1.5;}

/* ---- feature cards ---- */
.sl-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,30rem),1fr));gap:clamp(1rem,2.5vw,1.6rem);}
.sl-grid-2 > *{min-width:0;}
.sl-feature{
	position:relative;padding:clamp(1.5rem,3vw,2.2rem);border-radius:18px;
	background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
	border:1px solid var(--line);overflow:hidden;
	transition:transform .35s ease,border-color .35s ease;
}
.sl-feature:hover{transform:translateY(-4px);border-color:rgba(246,138,31,.5);}
.sl-feature__num{font-size:.8rem;font-weight:800;letter-spacing:.2em;color:var(--o);opacity:.85;}
.sl-feature h3{font-size:clamp(1.2rem,2.2vw,1.5rem);font-weight:800;letter-spacing:-.5px;margin:.5rem 0 .6rem;color:#fff;}
.sl-feature p{margin:0;color:var(--mut);line-height:1.65;font-size:1rem;}
.sl-feature::after{
	content:"";position:absolute;right:-30%;top:-60%;width:80%;height:160%;
	background:radial-gradient(circle,rgba(41,151,255,.14),transparent 60%);opacity:0;transition:opacity .35s ease;
}
.sl-feature:hover::after{opacity:1;}

/* Light feature cards (for use on white/tint backgrounds) */
.sl-light .sl-feature,.sl-tint .sl-feature{
	background:#fff;border:1px solid var(--line-dark);box-shadow:0 1px 4px rgba(0,0,0,.05);
}
.sl-light .sl-feature h3,.sl-tint .sl-feature h3{color:#0a1018;}
.sl-light .sl-feature p,.sl-tint .sl-feature p{color:#3a444f;}
.sl-feature__num{text-transform:uppercase;}

/* CTA feature card (e.g. "Chat with a Pool Expert") */
button.sl-feature{font:inherit;text-align:left;width:100%;cursor:pointer;}
.sl-feature--cta{
	background:linear-gradient(135deg,rgba(246,138,31,.12),rgba(255,177,90,.06)) !important;
	border-color:rgba(246,138,31,.4) !important;
}
.sl-feature--cta:hover{border-color:rgba(246,138,31,.7) !important;}
.sl-feature__link{
	display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;
	font-weight:700;color:var(--o);
}
.sl-feature__link svg{width:15px;height:11px;transition:transform .3s ease;}
.sl-feature__link svg path{fill:var(--o);}
.sl-feature--cta:hover .sl-feature__link svg{transform:translateX(4px);}

/* ---- statement band ---- */
.sl-statement h2{font-size:clamp(2rem,5vw,3.6rem);line-height:1.05;letter-spacing:-1.5px;font-weight:800;margin:0 0 1.4rem;}
.sl-statement p{font-size:clamp(1.05rem,1.7vw,1.3rem);line-height:1.7;color:var(--mut);max-width:60ch;}

/* ---- pill cards (explore) ---- */
.sl-pills{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,2vw,1.2rem);}
.sl-pill{
	display:flex;align-items:center;justify-content:space-between;gap:1rem;
	padding:1.3rem 1.5rem;border-radius:14px;text-decoration:none;
	background:#fff;border:1px solid var(--line-dark);color:#0a1018;font-weight:700;
	box-shadow:0 1px 4px rgba(0,0,0,.05);
	transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.sl-pill span{font-size:clamp(1rem,1.6vw,1.18rem);letter-spacing:-.3px;}
.sl-pill .sl-arrow{width:2rem;height:2rem;}
.sl-pill:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.12);border-color:rgba(246,138,31,.5);color:#0a1018;}
.sl-pill:hover .sl-arrow{transform:translateX(3px);}

/* ---- press cards ---- */
.sl-press{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,1.6rem);}
.sl-press__card{
	display:flex;flex-direction:column;align-items:center;text-align:center;
	padding:clamp(1.8rem,3vw,2.6rem) 1.5rem;border-radius:18px;text-decoration:none;
	background:#fff;
	border:1px solid var(--line);color:var(--ink);
	transition:transform .35s ease,border-color .35s ease;
}
.sl-press__card:hover{transform:translateY(-4px);border-color:rgba(246,138,31,.5);color:var(--ink);}
.sl-press__card .k{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--o);font-weight:800;}
.sl-press__card h3{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:800;letter-spacing:-.5px;margin:.5rem 0 1.4rem;line-height:1.2;color:var(--ink);}
.sl-press__card img{height:90px;width:auto;display:block;margin:auto auto 0;}

/* ---- knowledge grid ---- */
.sl-know{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(.7rem,1.6vw,1.1rem);}
.sl-know__card{
	display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.7rem;
	padding:1.4rem .8rem;border-radius:14px;text-decoration:none;background:#fff;
	border:1px solid var(--line-dark);color:#0a1018;text-align:center;
	box-shadow:0 1px 3px rgba(0,0,0,.05);
	transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.sl-know__card img{width:auto;height:56px;display:block;}
.sl-know__card h3{font-size:.92rem;font-weight:700;margin:0;letter-spacing:-.2px;line-height:1.25;}
.sl-know__card:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(0,0,0,.12);border-color:rgba(246,138,31,.5);color:#0a1018;}

/* ---- reveal ---- */
.sl-anim .sl-reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1);}
.sl-anim .sl-reveal.is-visible{opacity:1;transform:none;}

/* ---- responsive ---- */
@media (max-width:900px){
	.sl-split{grid-template-columns:1fr;gap:2rem;}
	.sl-split--rev .sl-split__media{order:0;}
	.sl-stats{grid-template-columns:repeat(3,1fr);}
	.sl-press{grid-template-columns:1fr;}
	.sl-know{grid-template-columns:repeat(3,1fr);}
	.sl-pills{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:640px){
	.sl-grid-2{grid-template-columns:1fr;}
	.sl-stats{grid-template-columns:repeat(2,1fr);}
	.sl-know{grid-template-columns:repeat(2,1fr);}
	.sl-pills{grid-template-columns:1fr;}
	.sl-hero{min-height:78vh;}
	.sl-hero__stats{gap:1.2rem 1.6rem;}
}
@media (prefers-reduced-motion:reduce){
	.sl-anim .sl-reveal{opacity:1;transform:none;transition:none;}
	.sl-btn,.sl-feature,.sl-pill,.sl-press__card,.sl-know__card,.sl-link .sl-arrow{transition:none;}
}

/* ============================================================
   MODERN PRODUCT PAGE
   Restyles the existing (Foundation-era) product markup so it
   matches the home page's modern language. Scoped tightly to
   product regions so other templates are unaffected.
   ============================================================ */

/* --- Breadcrumbs --- */
#breadcrumbs-container{
	max-width:1220px;margin:0 auto;
	padding:1.1rem clamp(1.1rem,4vw,2.5rem) .2rem;
}
.breadcrumbs{
	margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;align-items:center;
	font-size:.82rem;letter-spacing:.01em;font-weight:500;
}
.breadcrumbs::before,.breadcrumbs::after{content:none;display:none;}
.breadcrumbs li{display:inline-flex;align-items:center;color:#1d1d1f;text-transform:none;}
.breadcrumbs li:last-child{color:#1d1d1f;font-weight:600;}
.breadcrumbs li:not(:last-child)::after{
	content:"";display:inline-block;width:.42rem;height:.42rem;margin:0 .6rem;
	border-right:1.5px solid #c2c7cf;border-top:1.5px solid #c2c7cf;transform:rotate(45deg);
}
.breadcrumbs a{color:#86868b;text-decoration:none;font-weight:500;transition:color .2s ease;}
.breadcrumbs a:hover{color:#1a73e8;}

/* --- Sticky product nav --- */
#stickynav{
	background:#fff;
	border-bottom:1px solid rgba(10,16,24,.08);
	box-shadow:0 6px 16px -14px rgba(10,16,24,.4);
}
/* Align the sticky-nav content to the same 1220 column + padding as the
   breadcrumbs so breadcrumbs, product name and tabs share one left edge. */
#stickynav .grid-x.align-center{justify-content:center;margin-left:0;margin-right:0;}
#stickynav .grid-x.align-center > .cell{
	flex:0 0 auto;width:100%;max-width:1220px;
	padding-left:clamp(1.1rem,4vw,2.5rem);padding-right:clamp(1.1rem,4vw,2.5rem);
}
#stickynav .productnav{max-width:none;}
#stickynav .productname{padding-left:0;}
#stickynav .productname h1{
	font-size:1.1rem;font-weight:700;letter-spacing:-.3px;color:#0a1018;margin:.7rem 0 .5rem;
}
/* Pill tabs — back to the original rounded "circle" pill style, refreshed */
.leftnav{padding-bottom:.9rem;margin-left:0;display:flex;flex-wrap:wrap;gap:.5rem;}
.leftnav button{
	background:#f2f3f5;color:#3a444f;border:0;border-radius:999px;
	padding:.5rem 1.15rem;font-weight:600;font-size:.9rem;max-height:none;line-height:1.1;
	transition:background .2s ease,color .2s ease,box-shadow .2s ease;cursor:pointer;
}
.leftnav button:hover{background:#e6e8ec;color:#0a1018;}
.leftnav button.active{
	background:#1a73e8;color:#fff;box-shadow:0 6px 16px -7px rgba(26,115,232,.55);
}

/* Sticky-nav compact offer — single, vertically-centered row */
#topoffer{align-items:center;margin-top:0;}
#topoffer .offer,#bottomoffer .offer{display:flex;align-items:center;gap:.55rem;}
#topoffer .price,#bottomoffer .price{
	display:inline-flex;align-items:center;
	font-size:1.15rem;font-weight:700;letter-spacing:-.4px;color:#0a1018;margin:0;line-height:1;white-space:nowrap;
}
#topoffer .below-price,#bottomoffer .below-price{
	display:flex;align-items:center;gap:.55rem;margin:0;
}
#topoffer .save,#bottomoffer .save{
	display:inline-flex;align-items:center;
	background:#eaf7f0;color:#0f7a4f;border:1px solid rgba(15,122,79,.18);
	border-radius:999px;padding:.2rem .6rem;font-weight:700;font-size:.72rem;line-height:1;margin:0;
}
#topoffer .freeship,#bottomoffer .freeship{float:none;margin:0;color:#6e6e73;font-size:.85rem;line-height:1;}
#topoffer .regprice,#bottomoffer .regprice{
	margin-left:.3rem;color:#9aa0a6;font-weight:600;font-size:.82rem;
	text-decoration-line:line-through;text-decoration-thickness:1.5px;
}
/* Compact buy button inside the sticky bar */
#topoffer .bigbuy{margin:0;}
#topoffer .bigbuy button,#topoffer .bigbuy a{
	height:40px;min-width:0;padding:0 1.3rem;font-size:.9rem;border-radius:9px;
	box-shadow:none;
}

/* --- Buy box (main column) --- */
#overview{padding-top:clamp(1.5rem,4vw,2.5rem);}
#mainproduct{padding-top:.25rem;}
#mainproduct .product-name{
	font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:800;letter-spacing:-1px;line-height:1.07;
	color:#0a1018;margin:.1rem 0 .55rem;
}
#mainproduct .overall-reviews{display:flex;align-items:center;gap:.55rem;margin:0 0 1rem;flex-wrap:wrap;}
#mainproduct .overall-reviews button{
	background:none;border:0;padding:0;color:#6e6e73;font-size:.9rem;text-decoration:underline;cursor:pointer;
}

/* Price block — single row, all items on one clean centerline */
#mainproduct .offer{display:flex;align-items:center;flex-wrap:wrap;gap:.55rem .8rem;margin:.2rem 0 1.3rem;}
#mainproduct .offer .price{
	display:inline-flex;align-items:center;
	font-size:clamp(1.7rem,2.8vw,2.15rem);font-weight:800;letter-spacing:-.8px;color:#0a1018;margin:0;line-height:1;
}
#mainproduct .offer span.regprice{
	margin-left:.45rem;font-size:1.02rem;font-weight:600;color:#9aa0a6;
	text-decoration-line:line-through;text-decoration-thickness:1.5px;
}
#mainproduct .below-price{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin:0 0 .5rem;}
#mainproduct .save{
	display:inline-flex;align-items:center;background:#eaf7f0;color:#0f7a4f;
	border:1px solid rgba(15,122,79,.2);border-radius:999px;
	padding:.3rem .8rem;font-weight:700;font-size:.8rem;letter-spacing:.01em;margin:0;line-height:1;
}
#mainproduct .freeship{
	float:none;margin:0;padding:0;color:#6e6e73;font-size:.9rem;font-weight:500;line-height:1;
}
#mainproduct .freeship .sup-cross{color:#9aa0a6;}

/* Pre-order / availability notice (build-time + live shopify-live.js states) */
.preorder-note,.pb-preorder,.pb-soldout{
	display:inline-flex;align-items:center;border-radius:999px;
	padding:.3rem .8rem;font-weight:700;font-size:.8rem;letter-spacing:.01em;line-height:1;
}
.preorder-note,.pb-preorder{background:#e8f1fe;color:#1d4ed8;border:1px solid rgba(29,78,216,.2);}
.pb-soldout{background:#fdecec;color:#c0392b;border:1px solid rgba(192,57,43,.2);}
#topoffer .preorder-note,#bottomoffer .preorder-note,
#topoffer .pb-preorder,#bottomoffer .pb-preorder,
#topoffer .pb-soldout,#bottomoffer .pb-soldout{padding:.2rem .6rem;font-size:.72rem;}

/* Keep the buy-box content flush-left and full width so the price,
   buttons, selector and features all line up with the product title
   (the legacy .small-10 sub-cell was centered + narrow, causing the
   misalignment, especially on mobile). */
#mainproduct .grid-x.align-center{justify-content:flex-start;margin-left:0;margin-right:0;}
#mainproduct .grid-x.align-center > div{width:100%;max-width:100%;flex:0 0 100%;padding-left:0;padding-right:0;}

/* When a variant selector + dedicated "Add to Cart" exists, hide the
   default offer-section "Buy" button to avoid a confusing duplicate CTA.
   The Add to Cart button is the one that respects the chosen variant. */
#mainproduct:has(#refurb-selector) .offer + .bigbuy{display:none;}

/* Primary buy button — original brand blue, compact. */
.bigbuy{margin:.2rem 0 0;}
.bigbuy button,.bigbuy a{
	display:inline-flex;align-items:center;justify-content:center;
	width:auto;min-width:140px;height:46px;line-height:1;
	padding:0 1.8rem;border:1px solid transparent;border-radius:10px;cursor:pointer;
	font-size:.95rem;font-weight:600;letter-spacing:.01em;
	background:#1a73e8;color:#fff;
	box-shadow:0 6px 16px -8px rgba(26,115,232,.6);
	transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.bigbuy a{text-decoration:none;}
.bigbuy a button{min-width:0;box-shadow:none;height:auto;padding:0;background:none;}
.bigbuy button:hover,.bigbuy a:hover{background:#1666d0;transform:translateY(-1px);box-shadow:0 10px 22px -8px rgba(26,115,232,.6);color:#fff;}
.bigbuy button.sold-out-button{
	background:#eceef1;color:#80868b;box-shadow:none;cursor:default;
}
.bigbuy button.sold-out-button:hover{background:#eceef1;transform:none;box-shadow:none;}
/* Main column: confident but compact CTA */
#mainproduct .bigbuy{margin-top:.5rem;}
#mainproduct .bigbuy button,#mainproduct .bigbuy a{width:auto;min-width:200px;max-width:100%;height:48px;}
.landing-page-category .bigbuy button{background:#1a73e8;color:#fff;}

/* Voltage / variant selector */
#refurb-selector{margin:1.3rem 0 .5rem;}
#refurb-selector h3{font-size:.9rem;font-weight:700;color:#0a1018;letter-spacing:-.1px;margin:0 0 .6rem;}
#refurb-selector.pill-div button{
	background:#fff;color:#0a1018;border:1.5px solid rgba(10,16,24,.16);border-radius:10px;
	padding:.5rem 1.2rem;font-weight:600;font-size:.95rem;max-height:none;margin:0 .5rem .25rem 0;
	transition:border-color .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease;cursor:pointer;
}
#refurb-selector.pill-div button:hover{border-color:rgba(26,115,232,.6);}
/* Override the legacy global .highlight (blue tint, uses !important) */
#refurb-selector.pill-div button.highlight{
	background:#1a73e8 !important;color:#fff !important;
	border-color:#1a73e8 !important;box-shadow:0 6px 16px -6px rgba(26,115,232,.45) !important;
}

/* Feature list with check marks */
#mainproduct .feature-list{list-style:none;margin:1.3rem 0 0;padding:0;font-size:1rem;}
#mainproduct .feature-list li{
	position:relative;padding-left:2rem;margin:.75rem 0;line-height:1.55;color:#3a444f;
}
#mainproduct .feature-list li::before{
	content:"";position:absolute;left:0;top:.1rem;width:1.3rem;height:1.3rem;border-radius:50%;
	background:rgba(246,138,31,.16) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f68a1f' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / .8rem no-repeat;
}

/* Coupon box — clean light card with a subtle orange accent edge */
.coupon-box{
	margin-top:1.5rem;padding:1.1rem 1.3rem;border-radius:14px;text-align:left;
	background:#f7f9fc;border:1px solid rgba(10,16,24,.08);border-left:3px solid #f68a1f;color:#0a1018;
}
.coupon-box h2{font-size:1rem;font-weight:700;letter-spacing:-.2px;margin:0 0 .3rem;color:#0a1018;}
.coupon-box p{margin:.12rem 0;color:#6e6e73;font-size:.9rem;}
.coupon-box .white-box{
	display:inline-block;background:#0a1018;color:#fff;
	font-weight:700;border-radius:6px;padding:.12rem .55rem;margin:0 .15rem;letter-spacing:.08em;font-size:.85rem;
}

/* --- Section headings shared by product sub-sections --- */
#product-description .h1-title,
#specs .h1-title,
#reviews .h1-title,
#write-review .h1-title{
	font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:800;letter-spacing:-1px;line-height:1.1;
}
.h1-title .grey{color:#9aa0a6;font-weight:800;}

/* Product description body copy */
#product-description{color:#3a444f;}
#product-description h2{font-size:clamp(1.3rem,2.4vw,1.7rem);font-weight:800;letter-spacing:-.5px;color:#0a1018;margin:1.6rem 0 .8rem;}
#product-description h3{font-size:1.2rem;font-weight:700;color:#0a1018;margin:1.4rem 0 .6rem;}
#product-description p{line-height:1.75;font-size:1.02rem;margin:0 0 1.1rem;}
#product-description ul{line-height:1.7;}

/* --- Specs table --- */
#specs #product-specifications table{
	border:1px solid #eef2f6;border-radius:16px;overflow:hidden;letter-spacing:normal;
	box-shadow:0 1px 4px rgba(0,0,0,.05);
}
#specs #product-specifications th[scope="row"]{
	background:#f5f9fc;color:#0a1018;font-weight:700;text-align:left;vertical-align:top;
	width:34%;border:0;border-bottom:1px solid #eef2f6;padding:1rem 1.1rem;
}
#specs #product-specifications td{
	color:#3a444f;border:0;border-bottom:1px solid #eef2f6;padding:1rem 1.1rem;line-height:1.6;
}
#specs #product-specifications tr:last-child th,
#specs #product-specifications tr:last-child td{border-bottom:0;}
#specs #product-specifications tr:nth-child(2n){background:transparent;}
#specs #product-specifications tr:nth-child(2n) td{background:#fbfcfe;}

/* --- Reviews --- */
#reviews .reviewContainer{
	background:#fff;border:1px solid rgba(10,16,24,.08);border-radius:18px;
	padding:1.5rem 1.75rem;box-shadow:0 1px 4px rgba(0,0,0,.05);
}
#reviews .reviewContainer > h2{font-size:1.2rem;font-weight:800;letter-spacing:-.3px;color:#0a1018;margin:0 0 1rem;}
#reviews .reviewContainer > div{padding:1.1rem 0;border-bottom:1px solid #eef2f6;}
#reviews .reviewContainer > div:last-child{border-bottom:0;}
#reviews .reviewContainer h4{font-size:1.05rem;font-weight:700;color:#0a1018;margin:0 0 .35rem;}
#reviews .reviewContainer p{color:#3a444f;line-height:1.6;margin:.5rem 0 0;}

/* Pill action buttons (Load more / Share thoughts) */
#reviews .pillButton,#write-review .pillButton{
	margin-top:1.2rem;background:#0a1018;color:#fff;padding:.7rem 1.6rem;font-size:.95rem;border-radius:999px;
}
#reviews .pillButton:hover,#write-review .pillButton:hover{background:#1b2433;color:#fff;}

@media (max-width:640px){
	#specs #product-specifications th[scope="row"]{width:42%;}
	#mainproduct{padding-top:1.1rem;}
	#mainproduct .product-name{font-size:1.6rem;}
	/* Full-width the CTA for easy tapping on mobile */
	#mainproduct .bigbuy button,#mainproduct .bigbuy a{width:100%;min-width:0;max-width:none;height:50px;}
	#mainproduct .offer{gap:.5rem;}
	#mainproduct .below-price{margin:.5rem 0 1rem;}
	.coupon-box{margin-top:1.2rem;padding:1rem 1.1rem;}
}

/* ============================================================
   Product image gallery (custom, no slider library)
   ============================================================ */
.pgallery{display:flex;flex-direction:column;align-items:stretch;gap:.9rem;width:100%;}
.pgallery *{box-sizing:border-box;}

.pgallery__stage{
	position:relative;width:100%;border:none;border-radius:20px;
	background:#fff;overflow:hidden;box-shadow:none;
}
/* Shorter, wider frame so the image is easy to see and the thumbnails
   stay visible without scrolling far down the page. */
.pgallery__viewport{position:relative;width:100%;aspect-ratio:4/3;touch-action:pan-y;}

.pgallery__slide{display:none;margin:0;width:100%;height:100%;}
.pgallery__slide.is-active{display:block;animation:pgFade .4s cubic-bezier(.22,.61,.36,1);}
.pgallery__slide picture{display:block;width:100%;height:100%;}
.pgallery__slide img{width:100%;height:100%;object-fit:contain;padding:5%;}

@keyframes pgFade{from{opacity:0;transform:scale(.99)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.pgallery__slide.is-active{animation:none;}}

/* Always-visible arrows for clear, easy navigation */
.pgallery__nav{
	position:absolute;top:50%;transform:translateY(-50%);z-index:3;
	width:2.6rem;height:2.6rem;padding:0;border-radius:999px;
	border:1px solid rgba(10,16,24,.1);background:rgba(255,255,255,.92);
	-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);
	display:flex;align-items:center;justify-content:center;cursor:pointer;
	color:#1d1d1f;box-shadow:0 4px 14px -4px rgba(10,16,24,.25);
	opacity:1;transition:background .2s,transform .2s,box-shadow .2s,color .2s;
}
.pgallery__nav:hover{background:#1a73e8;color:#fff;border-color:#1a73e8;box-shadow:0 8px 20px -6px rgba(26,115,232,.5);}
.pgallery__nav:active{transform:translateY(-50%) scale(.92);}
.pgallery__nav--prev{left:.9rem;}
.pgallery__nav--next{right:.9rem;}
.pgallery__nav svg{width:1.15rem;height:1.15rem;display:block;}

/* Thumbnail grid: equal-width tiles per line, left-aligned, wraps cleanly */
.pgallery__thumbs{
	display:grid;grid-template-columns:repeat(auto-fill,minmax(3.6rem,1fr));
	gap:.55rem;max-width:100%;padding:.15rem .1rem .35rem;justify-items:stretch;
	scrollbar-width:none;
}
.pgallery__thumbs::-webkit-scrollbar{display:none;}
.pgallery__thumb{
	width:100%;aspect-ratio:1;padding:0;overflow:hidden;cursor:pointer;
	border-radius:12px;background:#fff;border:none;
	transition:box-shadow .18s ease,transform .18s ease;
}
.pgallery__thumb picture{display:block;width:100%;height:100%;}
.pgallery__thumb img{width:100%;height:100%;object-fit:contain;padding:8%;}
.pgallery__thumb:hover{transform:translateY(-2px);}
.pgallery__thumb.is-active{
	box-shadow:0 0 0 2px #1a73e8;transform:none;
}

@media (max-width:640px){
	.pgallery__stage{border-radius:16px;}
	.pgallery__viewport{aspect-ratio:1/1;}
	.pgallery__thumbs{grid-template-columns:repeat(auto-fill,minmax(3rem,1fr));}
	.pgallery__thumb{border-radius:10px;}
	.pgallery__nav{width:2.3rem;height:2.3rem;}
}
