/*
Theme Name: Storm Labs
Theme URI: https://stormbiolabs.com
Author: Rankwyre
Author URI: https://rankwyre.com
Description: Premium dark + brushed-chrome WooCommerce theme for Storm Labs research-grade peptides. For Research Use Only. Built by Rankwyre.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: storm-labs
WC requires at least: 7.0
WC tested up to: 11.0
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  /* Surfaces (near-black, layered — neutral charcoal, no navy/blue cast) */
  --sl-bg:        #08080a;
  --sl-bg-elev:   #0e0e11;
  --sl-surface:   #161619;
  --sl-surface-2: #1c1c20;
  --sl-line:      rgba(255,255,255,.085);
  --sl-line-2:    rgba(255,255,255,.14);

  /* Text */
  --sl-text:      #e9ebef;
  --sl-text-mut:  #9aa0aa;
  --sl-text-dim:  #6b7079;

  /* Silver / chrome */
  --sl-silver:    #c8cdd4;
  --sl-silver-hi: #f5f7f9;
  --sl-silver-lo: #868c95;
  --sl-chrome: linear-gradient(180deg,#f7f8fa 0%,#d2d7dd 24%,#9aa1a9 50%,#e7eaee 73%,#aab0b9 100%);
  --sl-chrome-soft: linear-gradient(180deg,#eceef1 0%,#c2c8cf 50%,#9da3ab 100%);

  /* Electric glow (kept silver-white, faint cool tint) */
  --sl-glow: rgba(200,214,235,.5);

  /* Typography */
  --sl-font-display: "Sora", system-ui, sans-serif;
  --sl-font-body: "Hanken Grotesk", system-ui, sans-serif;

  /* Spacing / layout */
  --sl-container: 1240px;
  --sl-radius: 14px;
  --sl-radius-sm: 9px;
  --sl-radius-pill: 999px;
  --sl-section-y: clamp(64px, 9vw, 132px);

  /* Motion */
  --sl-ease: cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--sl-bg);
  color: var(--sl-text);
  font-family: var(--sl-font-body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .25s var(--sl-ease); }
a:hover { color: var(--sl-silver-hi); }
button { font-family: inherit; cursor: pointer; }
h1,h2,h3,h4 { font-family: var(--sl-font-display); font-weight: 600; line-height: 1.08; letter-spacing: -.01em; margin: 0 0 .5em; }
p { margin: 0 0 1em; color: var(--sl-text-mut); }
ul { margin: 0; padding: 0; list-style: none; }

::selection { background: rgba(200,210,225,.25); color: #fff; }

/* Focus visibility for a11y */
a:focus-visible, button:focus-visible, input:focus-visible {
  outline: 2px solid var(--sl-silver); outline-offset: 2px;
}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.sl-container { width: 100%; max-width: var(--sl-container); margin: 0 auto; padding: 0 24px; }
.sl-section { padding: var(--sl-section-y) 0; position: relative; }
.sl-center { text-align: center; }

.sl-eyebrow {
  font-family: var(--sl-font-display);
  font-size: 12px; font-weight: 600;
  letter-spacing: .32em; text-transform: uppercase;
  color: var(--sl-text-dim);
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 18px;
}
.sl-eyebrow::before { content:""; width: 26px; height: 1px; background: var(--sl-line-2); }

.sl-h2 { font-size: clamp(30px, 4.4vw, 54px); }
.sl-h2 .chrome { display: inline-block; }
.sl-lead { font-size: clamp(16px,1.4vw,19px); color: var(--sl-text-mut); max-width: 56ch; }

/* Brushed-chrome text */
.chrome {
  background: var(--sl-chrome);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* Hairline divider */
.sl-hr { height: 1px; background: linear-gradient(90deg,transparent,var(--sl-line-2),transparent); border: 0; }

/* ============================================================
   BUTTONS
   ============================================================ */
.sl-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--sl-font-display); font-weight: 600; font-size: 14px;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 15px 28px; border-radius: var(--sl-radius-pill);
  border: 1px solid transparent; transition: all .3s var(--sl-ease);
  white-space: nowrap; text-decoration: none;
}
.sl-prose a.sl-btn { text-decoration: none; }
.sl-btn svg { width: 16px; height: 16px; transition: transform .3s var(--sl-ease); }
.sl-btn:hover svg { transform: translateX(4px); }

/* Primary — brushed chrome */
.sl-btn--primary {
  background: var(--sl-chrome); color: #0a0b0e;
  box-shadow: 0 1px 0 rgba(255,255,255,.5) inset, 0 10px 30px -12px rgba(210,220,235,.5);
}
.sl-btn--primary:hover { color: #0a0b0e; filter: brightness(1.06); transform: translateY(-2px); box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 16px 40px -12px rgba(210,220,235,.65); }

/* Ghost — steel outline */
.sl-btn--ghost {
  background: rgba(255,255,255,.02); color: var(--sl-silver);
  border-color: var(--sl-line-2); backdrop-filter: blur(6px);
}
.sl-btn--ghost:hover { color: var(--sl-silver-hi); border-color: rgba(255,255,255,.32); background: rgba(255,255,255,.05); transform: translateY(-2px); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.sl-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  transition: background .4s var(--sl-ease), border-color .4s var(--sl-ease), backdrop-filter .4s;
  border-bottom: 1px solid transparent;
}
.sl-header.is-scrolled {
  background: rgba(8,9,12,.72); backdrop-filter: blur(16px) saturate(140%);
  border-bottom-color: var(--sl-line);
}
.sl-header__inner { display: flex; align-items: center; justify-content: space-between; height: 78px; gap: 24px; }
.sl-brand { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.sl-brand img { height: 56px; width: auto; }
.sl-nav { display: flex; align-items: center; gap: 8px; }
.sl-nav__list { display: flex; align-items: center; gap: 6px; list-style: none; margin: 0; padding: 0; }
.sl-nav__list li { list-style: none; margin: 0; }
.sl-nav a {
  font-family: var(--sl-font-display); font-size: 13px; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase; color: var(--sl-text-mut);
  padding: 10px 16px; border-radius: var(--sl-radius-pill); transition: all .25s var(--sl-ease); white-space: nowrap;
}
.sl-nav a:hover { color: var(--sl-silver-hi); background: rgba(255,255,255,.05); }
.sl-header__actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }

/* Icon buttons (search / account / cart) */
.sl-iconbtn { position: relative; width: 42px; height: 42px; display: grid; place-items: center; color: var(--sl-text-mut); background: transparent; border: 0; border-radius: 50%; cursor: pointer; transition: color .25s var(--sl-ease), background .25s var(--sl-ease); }
.sl-iconbtn:hover { color: var(--sl-silver-hi); background: rgba(255,255,255,.06); }
.sl-iconbtn svg { width: 20px; height: 20px; }
.sl-cart__count { position: absolute; top: 1px; right: -1px; min-width: 17px; height: 17px; padding: 0 4px; background: var(--sl-chrome); color: #0a0b0e; border-radius: 999px; font-size: 10px; font-weight: 700; display: grid; place-items: center; font-family: var(--sl-font-display); }
.sl-header__shop { margin-left: 10px; padding: 13px 28px !important; font-size: 13px; gap: 11px; }

/* Animated hamburger */
.sl-burger { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 42px; height: 42px; background: transparent; border: 0; padding: 11px; border-radius: 50%; cursor: pointer; transition: background .25s var(--sl-ease); }
.sl-burger:hover { background: rgba(255,255,255,.06); }
.sl-burger span { display: block; height: 1.5px; width: 100%; background: var(--sl-silver-hi); border-radius: 2px; transition: transform .3s var(--sl-ease), opacity .25s var(--sl-ease); }
body.sl-drawer-open .sl-burger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
body.sl-drawer-open .sl-burger span:nth-child(2) { opacity: 0; }
body.sl-drawer-open .sl-burger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ---- Search overlay ---- */
.sl-search { position: fixed; top: 0; left: 0; right: 0; z-index: 300; transform: translateY(-100%); transition: transform .45s var(--sl-ease); }
.sl-search.is-open { transform: translateY(0); }
.sl-search__panel { position: relative; display: flex; align-items: center; gap: 16px; max-width: var(--sl-container); margin: 0 auto; padding: 24px; background: rgba(10,12,16,.94); backdrop-filter: blur(20px) saturate(140%); border-bottom: 1px solid var(--sl-line-2); }
/* Live search results dropdown */
.sl-search__results { position: absolute; top: 100%; left: 0; right: 0; background: rgba(9,11,15,.98); backdrop-filter: blur(20px) saturate(140%); border-bottom: 1px solid var(--sl-line-2); max-height: 64vh; overflow-y: auto; display: none; }
.sl-search__results.is-visible { display: block; }
.sl-search__result { display: flex; align-items: center; gap: 16px; padding: 13px clamp(20px,3vw,40px); border-bottom: 1px solid var(--sl-line); color: var(--sl-text); text-decoration: none; transition: background .2s var(--sl-ease); }
.sl-search__result:last-child { border-bottom: 0; }
.sl-search__result:hover { background: rgba(255,255,255,.04); }
.sl-search__result-img { width: 48px; height: 48px; object-fit: contain; background: var(--sl-surface); border: 1px solid var(--sl-line); border-radius: 8px; flex-shrink: 0; padding: 3px; }
.sl-search__result-name { flex: 1; min-width: 0; font-family: var(--sl-font-display); font-size: 15px; font-weight: 500; color: var(--sl-text); }
.sl-search__result-price { font-family: var(--sl-font-display); font-size: 15px; font-weight: 600; color: var(--sl-silver-hi); flex-shrink: 0; }
.sl-search__hint { padding: 18px clamp(20px,3vw,40px); color: var(--sl-text-dim); font-size: 14px; font-family: var(--sl-font-display); letter-spacing: .02em; }
/* mobile: compact the search bar so the placeholder/input isn't squeezed */
@media (max-width: 600px) {
  .sl-search__panel { padding: 16px 16px; gap: 10px; }
  .sl-search__form { gap: 10px; }
  .sl-search__icon { width: 18px; height: 18px; }
  .sl-search__form input[type=search] { font-size: 18px; }
  .sl-search__submit { padding: 10px 16px; font-size: 11px; letter-spacing: .04em; }
  .sl-search__close { padding: 6px; }
  .sl-search__close svg { width: 20px; height: 20px; }
}
.sl-search__form { flex: 1; display: flex; align-items: center; gap: 14px; min-width: 0; }
.sl-search__icon { width: 22px; height: 22px; color: var(--sl-text-dim); flex-shrink: 0; }
.sl-search__form input[type=search] { flex: 1; min-width: 0; background: transparent; border: 0; outline: 0; color: var(--sl-text); font-family: var(--sl-font-display); font-size: clamp(19px,3vw,30px); font-weight: 300; letter-spacing: -.01em; }
.sl-search__form input[type=search]::placeholder { color: var(--sl-text-dim); }
/* recolor the native clear (X) button silver instead of the browser's blue */
.sl-search__form input[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none; appearance: none; height: 18px; width: 18px; margin-left: 10px; cursor: pointer;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cpath d='M5 5 13 13M13 5 5 13' stroke='%23c8cdd6' stroke-width='1.7' stroke-linecap='round'/%3E%3C/svg%3E") center / contain no-repeat;
  opacity: .75; transition: opacity .2s var(--sl-ease);
}
.sl-search__form input[type=search]::-webkit-search-cancel-button:hover { opacity: 1; }
.sl-search__submit { flex-shrink: 0; background: var(--sl-chrome); color: #0a0b0e; border: 0; border-radius: var(--sl-radius-pill); font-family: var(--sl-font-display); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; font-size: 13px; padding: 13px 26px; cursor: pointer; transition: filter .25s; }
.sl-search__submit:hover { filter: brightness(1.06); }
.sl-search__close { flex-shrink: 0; background: transparent; border: 0; color: var(--sl-text-mut); padding: 8px; display: grid; place-items: center; cursor: pointer; }
.sl-search__close:hover { color: var(--sl-silver-hi); }
.sl-search__close svg { width: 22px; height: 22px; }

/* ---- Premium mobile drawer ---- */
.sl-drawer { position: fixed; inset: 0; z-index: 250; display: flex; flex-direction: column; padding: 20px 24px calc(env(safe-area-inset-bottom) + 26px); background: linear-gradient(180deg, #0b0d12 0%, #070809 100%); opacity: 0; pointer-events: none; transform: translateY(-8px); transition: opacity .4s var(--sl-ease), transform .4s var(--sl-ease); }
.sl-drawer.is-open { opacity: 1; pointer-events: auto; transform: none; }
.sl-drawer__top { display: flex; align-items: center; justify-content: space-between; padding-bottom: 16px; border-bottom: 1px solid var(--sl-line); }
.sl-drawer__logolink { display: inline-flex; align-items: center; flex-shrink: 0; }
.sl-drawer__logo { height: 56px !important; width: auto !important; max-height: 56px !important; max-width: none !important; object-fit: contain; display: block; }
.sl-drawer__close { background: rgba(255,255,255,.04); border: 1px solid var(--sl-line); color: var(--sl-text); width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; cursor: pointer; }
.sl-drawer__close svg { width: 20px; height: 20px; }
.sl-drawer__nav { display: flex; flex-direction: column; margin-top: 8px; flex: 1; overflow-y: auto; }
.sl-drawer__nav a { display: flex; align-items: center; justify-content: space-between; padding: 21px 4px; border-bottom: 1px solid var(--sl-line); font-family: var(--sl-font-display); font-size: 25px; font-weight: 500; letter-spacing: -.01em; color: var(--sl-text); opacity: 0; transform: translateX(-12px); transition: color .25s var(--sl-ease); }
.sl-drawer.is-open .sl-drawer__nav a { opacity: 1; transform: none; transition: opacity .5s var(--sl-ease) calc(.07s * var(--i) + .12s), transform .5s var(--sl-ease) calc(.07s * var(--i) + .12s), color .25s var(--sl-ease); }
.sl-drawer__nav a span { display: inline-block; transition: transform .3s var(--sl-ease); }
.sl-drawer__nav a svg { width: 20px; height: 20px; color: var(--sl-text-dim); transition: transform .3s var(--sl-ease), color .25s var(--sl-ease); }
.sl-drawer__nav a:hover, .sl-drawer__nav a:active { color: var(--sl-silver-hi); }
.sl-drawer__nav a:hover span, .sl-drawer__nav a:active span { transform: translateX(10px); }
.sl-drawer__nav a:hover svg { color: var(--sl-silver-hi); transform: translateX(4px); }
.sl-drawer__foot { margin-top: 18px; }
.sl-drawer__icons { display: flex; gap: 10px; margin-bottom: 16px; }
.sl-drawer__icons .sl-iconbtn { width: 54px; height: 52px; border: 1px solid var(--sl-line); border-radius: var(--sl-radius-sm); }
.sl-drawer__icons .sl-iconbtn:hover { border-color: var(--sl-line-2); }
.sl-drawer__ruo { text-align: center; font-family: var(--sl-font-display); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--sl-text-dim); margin: 16px 0 0; }

/* ============================================================
   HERO (WebGL lightning)
   ============================================================ */
.sl-hero { position: relative; min-height: 100svh; display: flex; align-items: center; overflow: hidden; background: var(--sl-bg); }
.sl-hero__canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; opacity: .9; }
.sl-hero__veil {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(120% 80% at 50% 8%, transparent 40%, rgba(8,9,12,.55) 78%, var(--sl-bg) 100%),
    linear-gradient(180deg, rgba(8,9,12,.35) 0%, transparent 30%, transparent 60%, var(--sl-bg) 100%);
}
.sl-hero__inner { position: relative; z-index: 3; width: 100%; text-align: center; padding-top: 78px; }
.sl-hero__pill {
  display: inline-flex; align-items: center; gap: 10px; margin-bottom: 28px;
  padding: 9px 18px; border-radius: 999px; border: 1px solid var(--sl-line-2);
  background: rgba(255,255,255,.03); backdrop-filter: blur(8px);
  font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--sl-silver);
}
.sl-hero__pill .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--sl-silver-hi); box-shadow: 0 0 12px 2px var(--sl-glow); animation: sl-pulse 2.4s var(--sl-ease) infinite; }
@keyframes sl-pulse { 0%,100%{opacity:1} 50%{opacity:.35} }
.sl-hero h1 {
  font-size: clamp(42px, 8vw, 104px); font-weight: 600; line-height: .98; letter-spacing: -.02em;
  margin: 0 0 22px;
}
.sl-hero h1 .line2 { font-weight: 300; }
.sl-hero__sub { font-size: clamp(16px,1.6vw,21px); color: var(--sl-text-mut); max-width: 60ch; margin: 0 auto 14px; }
.sl-hero__ruo { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--sl-text-dim); margin-bottom: 38px; }
.sl-hero__cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.sl-hero__stats { display: flex; gap: clamp(24px,5vw,72px); justify-content: center; flex-wrap: wrap; margin-top: 64px; }
.sl-stat__num { font-family: var(--sl-font-display); font-size: clamp(26px,3vw,38px); font-weight: 600; }
.sl-stat__label { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--sl-text-dim); }

/* ============================================================
   PRODUCT CARDS / CATALOG
   ============================================================ */
.sl-sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 48px; flex-wrap: wrap; }
.sl-grid { display: grid; gap: 22px; }
.sl-grid--4 { grid-template-columns: repeat(4, 1fr); }
.sl-grid--3 { grid-template-columns: repeat(3, 1fr); }

/* Borderless / seamless product card — vial floats on black with a soft silver glow */
ul.products li.product { display: flex; }
.sl-card { position: relative; display: flex; flex-direction: column; width: 100%; height: 100%; border: 0; background: transparent; transition: transform .45s var(--sl-ease); }
.sl-card:hover { transform: translateY(-4px); }
.sl-card__media { position: relative; aspect-ratio: 1/1; display: grid; place-items: center; padding: 8px; background: transparent; overflow: visible; }
.sl-card__media::before {
  content: ""; position: absolute; left: 50%; top: 53%; width: 80%; height: 72%; transform: translate(-50%, -50%);
  background: radial-gradient(ellipse at center, rgba(178,194,220,.18) 0%, rgba(178,194,220,.05) 42%, transparent 72%);
  filter: blur(8px); opacity: .5; z-index: 0;
  transition: opacity .55s var(--sl-ease), transform .55s var(--sl-ease);
}
.sl-card:hover .sl-card__media::before { opacity: 1; transform: translate(-50%, -54%) scale(1.14); }
.sl-card__media img { position: relative; z-index: 1; max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; filter: drop-shadow(0 26px 40px rgba(0,0,0,.6)); transition: transform .5s var(--sl-ease); }
.sl-card:hover .sl-card__media img { transform: translateY(-8px) scale(1.045); }
.sl-card__body { padding: 6px 2px 0; display: flex; flex-direction: column; flex: 1 1 auto; }
.sl-card__name { font-family: var(--sl-font-display); font-size: 19px; font-weight: 600; margin: 0 0 5px; color: var(--sl-text); letter-spacing: -.01em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.4em; }
.sl-card__meta { font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--sl-text-dim); margin-bottom: 16px; }
.sl-card__row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.sl-card__price { font-family: var(--sl-font-display); font-size: 22px; font-weight: 600; color: var(--sl-silver-hi); }
.sl-card__price .chrome { font-size: inherit; }
.sl-card__tag { font-family: var(--sl-font-display); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--sl-text-dim); border: 1px solid var(--sl-line); padding: 6px 11px; border-radius: 7px; white-space: nowrap; transition: color .3s var(--sl-ease), border-color .3s var(--sl-ease); }
.sl-card:hover .sl-card__tag { color: var(--sl-silver); border-color: var(--sl-line-2); }
.sl-card__cta { margin-top: auto; display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; text-align: center; font-family: var(--sl-font-display); font-size: 11px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--sl-silver); padding: 13px 16px; border: 1px solid var(--sl-line); border-radius: var(--sl-radius-pill); transition: color .3s var(--sl-ease), background .3s var(--sl-ease), border-color .3s var(--sl-ease), box-shadow .3s var(--sl-ease); }
.sl-card:hover .sl-card__cta { color: #15171c; background: var(--sl-flat); border-color: transparent; box-shadow: var(--sl-flat-shadow); }

/* ============================================================
   FEATURE / TRUST STRIP
   ============================================================ */
.sl-trust { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--sl-line); border: 1px solid var(--sl-line); border-radius: var(--sl-radius); overflow: hidden; }
.sl-trust__item { background: var(--sl-bg); padding: 34px 28px; }
.sl-trust__item h4 { font-size: 16px; margin: 14px 0 6px; }
.sl-trust__item p { font-size: 14px; margin: 0; }
.sl-trust__icon { width: 26px; height: 26px; color: var(--sl-silver); }

/* ============================================================
   COA / SPLIT SECTION
   ============================================================ */
.sl-split { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.sl-panel { border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: linear-gradient(180deg,var(--sl-surface),var(--sl-bg-elev)); padding: 40px; }
.sl-panel__row { display: flex; align-items: center; justify-content: space-between; padding: 16px 0; border-bottom: 1px solid var(--sl-line); }
.sl-panel__row:last-child { border-bottom: 0; }
.sl-panel__row span:first-child { color: var(--sl-text-mut); font-size: 14px; }
.sl-panel__row span:last-child { font-family: var(--sl-font-display); font-weight: 600; color: var(--sl-silver-hi); }

/* ============================================================
   FOOTER
   ============================================================ */
.sl-footer { border-top: 1px solid var(--sl-line); background: var(--sl-bg-elev); padding-top: 72px; }
.sl-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 56px; }
.sl-footer__brand img { height: 66px; margin-bottom: 20px; }
.sl-footer h5 { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--sl-text-dim); margin: 0 0 18px; }
.sl-footer li { margin-bottom: 11px; }
.sl-footer li a { color: var(--sl-text-mut); font-size: 15px; }
.sl-footer li a:hover { color: var(--sl-silver-hi); }
.sl-footer__ruo {
  border: 1px solid var(--sl-line); border-radius: var(--sl-radius-sm); padding: 18px 22px; margin-bottom: 40px;
  background: rgba(255,255,255,.015); font-size: 13px; line-height: 1.7; color: var(--sl-text-dim);
}
.sl-footer__ruo strong { color: var(--sl-silver); font-weight: 600; }
.sl-footer__bar { display: flex; align-items: center; justify-content: space-between; padding: 26px 0; border-top: 1px solid var(--sl-line); font-size: 13px; color: var(--sl-text-dim); flex-wrap: wrap; gap: 12px; }

/* ============================================================
   AGE GATE
   ============================================================ */
.sl-agegate { position: fixed; inset: 0; z-index: 9999; background: rgba(6,7,10,.66); backdrop-filter: blur(6px); display: none; align-items: center; justify-content: center; padding: 24px; }
.sl-agegate.is-open { display: flex; }
.sl-agegate__box { max-width: 380px; width: 100%; text-align: center; border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius); background: linear-gradient(180deg,var(--sl-surface),var(--sl-bg)); padding: 30px 28px; box-shadow: 0 40px 90px -30px rgba(0,0,0,.85); }
.sl-agegate__box img { height: 44px; margin: 0 auto 16px; }
.sl-agegate__box h3 { font-size: 21px; margin-bottom: 10px; }
.sl-agegate__box p { font-size: 14px; line-height: 1.7; }
.sl-agegate__actions { display: flex; gap: 12px; margin-top: 26px; }
.sl-agegate__actions .sl-btn { flex: 1; }
.sl-agegate__deny { background: none; border: 1px solid var(--sl-line-2); color: var(--sl-text-mut); border-radius: var(--sl-radius-pill); padding: 15px 28px; font-family: var(--sl-font-display); font-size: 14px; text-transform: uppercase; letter-spacing: .04em; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.sl-reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--sl-ease), transform .7s var(--sl-ease); }
.sl-reveal.is-in { opacity: 1; transform: none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .sl-grid--4 { grid-template-columns: repeat(2,1fr); }
  .sl-trust { grid-template-columns: repeat(2,1fr); }
  .sl-split { grid-template-columns: 1fr; gap: 36px; }
  .sl-footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
/* Mid breakpoint: collapse to hamburger before the nav crowds/wraps */
@media (max-width: 1100px) {
  .sl-nav, .sl-header__shop, .sl-hide-mobile { display: none; }
  .sl-burger { display: flex; }
  /* related/up-sell products go 2x2 on tablet instead of a cramped 4x1 */
  .related.products ul.products, .up-sells ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 44px 24px; }
}
@media (max-width: 760px) {
  body { font-size: 16px; }
  .sl-grid--4, .sl-grid--3 { grid-template-columns: 1fr 1fr; }
  .sl-sec-head { flex-direction: column; align-items: flex-start; }
  .sl-footer__grid { grid-template-columns: 1fr; }
  .sl-hero__stats { gap: 28px; }
  /* breathing room between the hero stats (COA per batch) and the trust grid */
  .sl-trust { margin-top: 40px; }
}
@media (max-width: 460px) {
  /* keep featured catalog 2x2 on mobile (like the shop); only the 3-col grid collapses */
  .sl-grid--3 { grid-template-columns: 1fr; }
  .sl-trust { grid-template-columns: 1fr; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .sl-reveal { opacity: 1; transform: none; transition: none; }
  .sl-hero__canvas { display: none; }
  * { animation: none !important; }
}

/* ============================================================
   GENERIC PAGES + PROSE
   ============================================================ */
.sl-page, .sl-shop { padding-top: calc(78px + clamp(40px,6vw,80px)); padding-bottom: var(--sl-section-y); min-height: 60vh; }
html { scroll-padding-top: 92px; }
.sl-page__head { margin-bottom: 40px; }
.sl-prose { max-width: 760px; }
.sl-prose h2 { font-size: 30px; margin: 1.4em 0 .5em; }
.sl-prose h3 { font-size: 22px; margin: 1.3em 0 .5em; color: var(--sl-text); }
.sl-prose p, .sl-prose li { color: var(--sl-text-mut); }
.sl-prose ul { list-style: none; padding: 0; margin: 0 0 1.2em; }
.sl-prose ul li { position: relative; padding-left: 24px; margin-bottom: 10px; }
.sl-prose ul li::before { content:""; position: absolute; left: 4px; top: 11px; width: 6px; height: 6px; background: var(--sl-silver); border-radius: 50%; }
.sl-prose a { color: var(--sl-silver-hi); text-decoration: underline; text-underline-offset: 3px; }
.sl-prose strong { color: var(--sl-text); }

/* ============================================================
   INFO PAGES (Contact, Affiliates) — 2-column with sticky card
   ============================================================ */
.sl-prose:has(.sl-info-page) { max-width: none !important; }
.sl-info-page { display: grid; grid-template-columns: 1fr 380px; gap: 56px; align-items: start; }
.sl-info-main > :first-child { margin-top: 0; }
.sl-info-main p { font-size: 16px; line-height: 1.75; margin: 0 0 18px; max-width: 60ch; }
.sl-info-main h2 { font-family: var(--sl-font-display); font-size: 22px; font-weight: 600; margin: 34px 0 16px; color: var(--sl-text); }
.sl-info-main ul { margin: 0 0 18px; }
.sl-info-card { position: sticky; top: 100px; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: linear-gradient(180deg, var(--sl-surface), var(--sl-bg-elev)); padding: 28px; }
.sl-info-card__label { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--sl-text-dim); margin: 0 0 18px; }
.sl-info-card dl { margin: 0; }
.sl-info-row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; padding: 14px 0; border-top: 1px solid var(--sl-line); font-size: 14px; }
.sl-info-row:first-child { border-top: 0; padding-top: 0; }
.sl-info-row dt { color: var(--sl-text-dim); margin: 0; }
.sl-info-row dd { margin: 0; color: var(--sl-text); text-align: right; font-family: var(--sl-font-display); }
.sl-prose .sl-info-card .sl-btn { width: 100%; margin-top: 22px; text-decoration: none; color: var(--sl-flat-fg); }
.sl-info-card__note { font-size: 12px; line-height: 1.65; color: var(--sl-text-dim); margin: 18px 0 0; }
@media (max-width: 860px) { .sl-info-page { grid-template-columns: 1fr; gap: 32px; } .sl-info-card { position: static; } }

/* Compliance lines */
.sl-ruo-inline { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--sl-text-dim); margin: 0 0 16px; }
.sl-ruo-checkout { border: 1px solid var(--sl-line); border-radius: var(--sl-radius-sm); background: rgba(255,255,255,.015); padding: 14px 16px; font-size: 13px; line-height: 1.6; color: var(--sl-text-dim); margin: 0 0 18px; }
.sl-ruo-checkout strong { color: var(--sl-silver); }
.sl-insurance { margin: 6px 0 18px; padding: 14px 16px; border: 1px solid var(--sl-line); border-radius: var(--sl-radius-sm); background: rgba(255,255,255,.015); }
.sl-insurance .form-row { margin: 0; padding: 0; }
.sl-insurance label { color: var(--sl-text-mut); font-size: 14px; display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.sl-insurance input[type=checkbox] { margin-top: 3px; accent-color: var(--sl-silver); width: auto; }

/* ============================================================
   WOOCOMMERCE — shop loop
   ============================================================ */
.woocommerce .sl-shop, .sl-shop { }
.woocommerce-products-header__title, .sl-shop h1 { font-family: var(--sl-font-display); font-size: clamp(30px,4vw,48px); margin-bottom: 8px; }
.woocommerce-products-header { margin-bottom: 36px; }
.term-description { color: var(--sl-text-dim); }
/* Shop toolbar: result count (left) + sort (right) on a clean divider bar */
.woocommerce-result-count { color: var(--sl-text-mut); font-size: 12px; font-family: var(--sl-font-display); letter-spacing: .1em; text-transform: uppercase; margin: 0 0 26px; padding: 14px 0; }
.woocommerce-ordering { margin: 0 0 26px; padding: 6px 0; }
.woocommerce-ordering select {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%230a0b0e' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 16px center, var(--sl-flat);
  background-size: 12px 8px, auto;
  color: var(--sl-flat-fg); border: 1px solid var(--sl-flat-border); border-radius: var(--sl-radius-pill);
  box-shadow: var(--sl-flat-shadow);
  padding: 12px 42px 12px 20px; font-family: var(--sl-font-display); font-weight: 600; font-size: 13px; letter-spacing: .03em; cursor: pointer;
  transition: filter .25s var(--sl-ease), box-shadow .25s var(--sl-ease);
}
.woocommerce-ordering select:hover, .woocommerce-ordering select:focus { background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%230a0b0e' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 16px center, var(--sl-flat-hover); background-size: 12px 8px, auto; outline: none; box-shadow: var(--sl-flat-shadow), 0 12px 28px -12px rgba(150,162,182,.7); }
.woocommerce-ordering select option { background: var(--sl-bg-elev); color: var(--sl-text); }
/* divider between the toolbar and the product grid (shop + category archives) */
.woocommerce-shop ul.products, .tax-product_cat ul.products, .post-type-archive-product ul.products { border-top: 1px solid var(--sl-line); padding-top: 40px !important; }

/* Pagination — clean circles */
.woocommerce-pagination, nav.woocommerce-pagination { margin-top: 64px; text-align: center; border: 0; }
.woocommerce-pagination ul, .woocommerce-pagination ul.page-numbers,
.woocommerce nav.woocommerce-pagination ul { display: inline-flex !important; align-items: center; gap: 14px !important; border: 0 !important; margin: 0; padding: 0; list-style: none; }
.woocommerce-pagination ul li { border: 0 !important; margin: 0 !important; padding: 0; overflow: visible; display: block; }
.woocommerce-pagination ul li a.page-numbers, .woocommerce-pagination ul li span.page-numbers {
  display: flex !important; align-items: center; justify-content: center; flex-shrink: 0;
  width: 50px !important; height: 50px !important; min-width: 50px; padding: 0 !important; margin: 0 !important;
  border: 1px solid var(--sl-line) !important; border-radius: 50% !important; background: var(--sl-surface);
  color: var(--sl-text-mut); font-family: var(--sl-font-display); font-size: 15px; line-height: 1; text-decoration: none;
  transition: color .25s var(--sl-ease), border-color .25s var(--sl-ease), background .25s var(--sl-ease), box-shadow .25s var(--sl-ease);
}
.woocommerce-pagination ul li a.page-numbers:hover { border-color: var(--sl-silver) !important; color: var(--sl-text); background: var(--sl-bg-elev); }
.woocommerce-pagination ul li span.current {
  background: var(--sl-flat) !important; color: var(--sl-flat-fg) !important; border-color: transparent !important; box-shadow: var(--sl-flat-shadow);
}
.woocommerce-pagination ul li .next, .woocommerce-pagination ul li .prev { font-size: 18px; }

ul.products { display: grid !important; grid-template-columns: repeat(3,1fr); gap: 56px 30px; margin: 0 !important; padding: 0 !important; list-style: none; }
ul.products::before, ul.products::after { display: none !important; }
ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; border: 0; background: transparent; padding: 0; }
/* Related / up-sell products: tighter row of 4 */
.related.products ul.products, .up-sells ul.products { grid-template-columns: repeat(4,1fr); gap: 30px 22px; }
.single-product .related.products, .single-product .up-sells { grid-column: 1 / -1; margin-top: 72px; padding-top: 56px; border-top: 1px solid var(--sl-line); }
.single-product .related.products > h2, .single-product .up-sells > h2 { font-family: var(--sl-font-display); font-size: clamp(22px,2.4vw,30px); font-weight: 600; letter-spacing: -.01em; margin: 0 0 32px; color: var(--sl-text); }
/* seamless card markup (.sl-card) handles the rest */
.woocommerce ul.products li.product .onsale.sl-onsale, .sl-card__media .onsale {
  position: absolute; top: 12px; right: 12px; left: auto; bottom: auto; z-index: 3; margin: 0;
  display: inline-flex; align-items: center; width: auto; height: auto; min-width: 0; min-height: 0;
  background: rgba(200,205,212,.12); border: 1px solid var(--sl-silver); color: var(--sl-silver-hi);
  font-family: var(--sl-font-display); font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  padding: 6px 11px; border-radius: var(--sl-radius-pill); line-height: 1; box-shadow: none; text-shadow: none;
}

/* ============================================================
   WOOCOMMERCE — single product
   ============================================================ */
.single-product .sl-shop { padding-top: calc(78px + 56px); }
.single-product div.product { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
.single-product div.product .woocommerce-product-gallery { margin: 0 !important; width: auto !important; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: radial-gradient(circle at 50% 35%, #1b1f2a 0%, #0a0c10 72%); padding: 24px; }
.single-product div.product .product_title { font-family: var(--sl-font-display); font-size: clamp(28px,3.4vw,44px); margin-bottom: 10px; }
.single-product div.product p.price, .single-product div.product span.price { color: var(--sl-silver-hi); font-family: var(--sl-font-display); font-size: 28px; font-weight: 600; }
.single-product .woocommerce-product-details__short-description { color: var(--sl-text-mut); margin: 18px 0; }
.single-product .quantity input { background: var(--sl-surface); border: 1px solid var(--sl-line); color: var(--sl-text); border-radius: 8px; padding: 12px; }
.single-product .single_add_to_cart_button {
  background: var(--sl-chrome) !important; color: #0a0b0e !important; border: 0 !important;
  font-family: var(--sl-font-display); font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  padding: 16px 32px !important; border-radius: var(--sl-radius-pill) !important; transition: filter .25s, transform .25s;
}
.single-product .single_add_to_cart_button:hover { filter: brightness(1.06); transform: translateY(-2px); }
.single-product .product_meta { color: var(--sl-text-dim); font-size: 13px; margin-top: 22px; border-top: 1px solid var(--sl-line); padding-top: 18px; }
.woocommerce-tabs { grid-column: 1 / -1; margin-top: 24px; }
.woocommerce-tabs ul.tabs { border-bottom: 1px solid var(--sl-line); padding: 0 !important; }
.woocommerce-tabs ul.tabs li { background: none !important; border: 0 !important; }
.woocommerce-tabs ul.tabs li a { color: var(--sl-text-mut) !important; font-family: var(--sl-font-display); text-transform: uppercase; letter-spacing: .08em; font-size: 13px; }
.woocommerce-tabs ul.tabs li.active a { color: var(--sl-silver-hi) !important; }
.woocommerce-tabs .panel { color: var(--sl-text-mut); }

/* Notices / buttons across woo */
.woocommerce-message, .woocommerce-info, .woocommerce-error { background: var(--sl-surface); border: 1px solid var(--sl-line-2); color: var(--sl-text); border-radius: 10px; padding: 14px 18px; }
/* hide WooCommerce's default notice pseudo-icon (overlaps text in dark theme) */
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before { display: none !important; content: none !important; }
.woocommerce-message { padding-left: 18px !important; }
.woocommerce-message a, .woocommerce-info a { color: var(--sl-silver-hi); }
/* Errors get a clear (but restrained) red accent so they read as errors, not generic notices */
.woocommerce-error { list-style: none; background: rgba(224,86,78,.09); border: 1px solid rgba(224,86,78,.3); border-left: 3px solid #e0564e; margin: 0 0 22px; }
.woocommerce-error li { list-style: none; margin: 0; padding: 0; }
.woocommerce-error strong { color: var(--sl-silver-hi); }
.woocommerce-error a { color: var(--sl-silver-hi); text-decoration: underline; text-underline-offset: 3px; }
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
  background: var(--sl-chrome); color: #0a0b0e; border-radius: var(--sl-radius-pill);
  font-family: var(--sl-font-display); text-transform: uppercase; letter-spacing: .04em; font-weight: 600;
}
.woocommerce a.button.alt, .woocommerce button.button.alt { background: var(--sl-chrome); color: #0a0b0e; }

/* Cart / checkout tables */
.woocommerce table.shop_table { border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: var(--sl-bg-elev); }
.woocommerce table.shop_table th { color: var(--sl-text); font-family: var(--sl-font-display); }
.woocommerce table.shop_table td { border-top: 1px solid var(--sl-line); color: var(--sl-text-mut); }
.woocommerce-checkout #payment { background: var(--sl-surface); border: 1px solid var(--sl-line); border-radius: var(--sl-radius); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .select2-container .select2-selection {
  background: var(--sl-bg) !important; border: 1px solid var(--sl-line) !important; color: var(--sl-text) !important; border-radius: 8px; padding: 12px 14px;
}
#add_payment_method #payment, .woocommerce-cart #payment, .woocommerce-checkout #payment { background: var(--sl-surface); }

@media (max-width: 900px) {
  ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .single-product div.product { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 540px) {
  /* 2 products side by side, but cleaner + more readable: bigger vial, larger text, less clutter */
  ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 30px 14px !important; }
  .related.products ul.products, .up-sells ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .sl-grid--4 { grid-template-columns: repeat(2,1fr); gap: 30px 14px; }   /* homepage featured catalog matches shop */
  .sl-card__media { aspect-ratio: 4/5; padding: 0; overflow: hidden; }  /* taller frame = more prominent vial */
  .sl-card__media img { transform: scale(1.32); }                /* vials are square cutouts w/ padding — scale up so they read bigger */
  .sl-card:hover .sl-card__media img { transform: scale(1.36) translateY(-4px); }
  .sl-card__body { padding: 10px 2px 0; }
  .sl-card__name { font-size: 15px; min-height: 2.5em; margin-bottom: 4px; }
  .sl-card__meta { font-size: 10px; letter-spacing: .12em; margin-bottom: 10px; }
  .sl-card__price { font-size: 18px; }
  .sl-card__tag { display: none; }                              /* declutter — RUO is site-wide already */
  .sl-card__row { margin-bottom: 12px; }
  /* silver-filled CTA on mobile (no hover state to reveal it) so it's clearly visible */
  .sl-card__cta { font-size: 10px; letter-spacing: .1em; padding: 13px 8px; background: var(--sl-flat); color: var(--sl-flat-fg); border: 1px solid var(--sl-flat-border); box-shadow: var(--sl-flat-shadow); }
}

/* ============================================================
   SINGLE PRODUCT — reference layout (image left, info right)
   ============================================================ */
.single-product div.product { gap: 56px; align-items: start; }
.single-product div.product .woocommerce-product-gallery {
  position: relative; border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius);
  background: radial-gradient(ellipse 72% 64% at 50% 42%, #15181f 0%, #0a0b0e 72%); padding: 28px; overflow: hidden;
}
.single-product .woocommerce-product-gallery__trigger { top: 16px; right: 16px; background: rgba(8,9,12,.55) !important; border: 1px solid var(--sl-line); }
.single-product .woocommerce-product-gallery__image img { border-radius: 8px; }
.single-product div.product .summary { padding-top: 2px; }
.single-product div.product .product_title { font-size: clamp(28px,3.2vw,40px); margin-bottom: 12px; }
.single-product div.product p.price, .single-product .summary .price { font-family: var(--sl-font-display); font-size: 30px; font-weight: 700; color: var(--sl-silver-hi); margin: 0 0 4px; display: block; }
.single-product .summary .price del { color: var(--sl-text-dim); font-weight: 400; font-size: 22px; margin-left: 10px; }
.single-product .summary .price ins { text-decoration: none; }
.sl-points { font-size: 15px; color: var(--sl-text-mut); margin: 0 0 18px; }
.sl-points strong { color: var(--sl-silver-hi); font-weight: 600; }
.sl-pills { display: flex; flex-wrap: wrap; gap: 9px; margin: 0 0 18px; }
.sl-pill { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .05em; color: var(--sl-silver); border: 1px solid var(--sl-line-2); background: rgba(255,255,255,.025); padding: 8px 14px; border-radius: 999px; white-space: nowrap; }
.single-product .woocommerce-product-details__short-description { color: var(--sl-text-mut); font-size: 16px; line-height: 1.65; margin: 0 0 20px; }
.single-product .woocommerce-product-details__short-description p { margin: 0; }
.single-product form.cart { margin: 4px 0 10px; display: flex; flex-direction: column; gap: 12px; }
/* Premium quantity stepper:  [ −  | qty |  + ]  hairline pill */
.single-product form.cart .quantity {
  display: inline-flex !important; align-self: flex-start; align-items: center; height: 52px;
  border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius-pill); background: var(--sl-surface); overflow: hidden;
}
.single-product form.cart .quantity input.qty {
  width: 54px; height: 100%; border: 0 !important; background: transparent !important; color: var(--sl-text) !important;
  text-align: center; font-family: var(--sl-font-display); font-size: 15px; font-weight: 600; padding: 0 !important;
  -moz-appearance: textfield; box-shadow: none !important;
}
.single-product form.cart .quantity input.qty::-webkit-outer-spin-button,
.single-product form.cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sl-qty__btn {
  width: 44px; height: 100%; border: 0; background: transparent; color: var(--sl-silver); font-size: 19px; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: color .18s var(--sl-ease), background .18s var(--sl-ease);
}
.sl-qty__btn:hover { color: var(--sl-silver-hi); background: rgba(255,255,255,.05); }
.sl-qty__minus { border-right: 1px solid var(--sl-line); }
.sl-qty__plus { border-left: 1px solid var(--sl-line); }
.single-product .single_add_to_cart_button { width: 100% !important; margin: 0 !important; padding: 17px 28px !important; font-size: 14px !important; line-height: 1.2 !important; min-height: 56px; display: flex; align-items: center; justify-content: center; }
.single-product table.variations { width: 100%; margin: 0 0 16px; border: 0; background: transparent; }
.single-product table.variations tr { display: block; }
.single-product table.variations td, .single-product table.variations th { display: block; width: 100%; border: 0; padding: 0; }
.single-product table.variations th.label { color: var(--sl-text-mut); font-family: var(--sl-font-display); text-transform: uppercase; letter-spacing: .12em; font-size: 12px; margin: 0 0 8px; }
.single-product table.variations select { width: 100%; background: var(--sl-surface); border: 1px solid var(--sl-line-2); color: var(--sl-text); border-radius: 10px; padding: 14px 16px; font-family: var(--sl-font-body); font-size: 15px; margin-bottom: 6px; }
.single-product .woocommerce-variation-price .price { font-size: 24px; }
.single-product .reset_variations { color: var(--sl-text-dim); font-size: 13px; }

/* Description accordion (built from Woo tabs by site.js) */
.single-product .woocommerce-tabs { margin-top: 30px; }
.single-product .woocommerce-tabs ul.tabs { display: none !important; }
.sl-acc__head { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; background: transparent; border: 0; border-top: 1px solid var(--sl-line); padding: 22px 2px; cursor: pointer; font-family: var(--sl-font-display); font-size: 18px; font-weight: 600; color: var(--sl-text); text-align: left; }
.sl-acc__icon { color: var(--sl-text-mut); font-size: 24px; line-height: 1; flex-shrink: 0; }
.sl-acc__panel { padding: 0 2px 24px; color: var(--sl-text-mut); line-height: 1.7; }
.sl-acc__panel > h2 { display: none; }
.sl-acc__panel:not(.is-open) { display: none !important; }
.sl-acc__panel.is-open { display: block !important; }

@media (max-width: 760px) {
  .single-product div.product .woocommerce-product-gallery { padding: 18px; }
  .sl-pill { font-size: 11px; padding: 7px 11px; }
}

/* ============================================================
   SINGLE PRODUCT — square gallery + one-row pills (refinement)
   ============================================================ */
.single-product div.product { grid-template-columns: minmax(0, 460px) 1fr !important; }
/* WooCommerce floats .summary (48%) and the gallery — kill it so each fills its grid cell */
.single-product div.product .summary { float: none !important; width: 100% !important; max-width: 560px; margin: 0 !important; }
.single-product div.product .woocommerce-product-gallery { float: none !important; width: 100% !important; }
.single-product div.product .woocommerce-product-gallery { aspect-ratio: 1 / 1; display: flex; align-items: center; justify-content: center; padding: 22px; overflow: hidden; }
.single-product .woocommerce-product-gallery__wrapper { margin: 0 !important; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; transform: none !important; }
.single-product .woocommerce-product-gallery__image { width: 100%; height: 100%; margin: 0 !important; display: flex; align-items: center; justify-content: center; }
.single-product .woocommerce-product-gallery__image a { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.single-product .woocommerce-product-gallery__image img { width: auto !important; height: auto !important; max-width: 100%; max-height: 100%; object-fit: contain; }
.sl-pills { flex-direction: row; align-items: center; flex-wrap: wrap; gap: 10px; margin: 0 0 22px; }
.sl-pill { padding: 9px 15px; font-size: 12px; }
@media (max-width: 900px) {
  .single-product div.product { grid-template-columns: 1fr !important; justify-items: center; text-align: left; }
  .single-product div.product .woocommerce-product-gallery { max-width: 460px; width: 100%; margin-left: auto; margin-right: auto; }
  .single-product div.product .summary { max-width: 540px; width: 100%; margin-left: auto !important; margin-right: auto !important; }
}

/* ============================================================
   SIDE CART DRAWER
   ============================================================ */
.sl-cart-overlay { position: fixed; inset: 0; background: rgba(4,5,7,.6); backdrop-filter: blur(3px); opacity: 0; pointer-events: none; transition: opacity .35s var(--sl-ease); z-index: 320; }
.sl-cart-overlay.is-open { opacity: 1; pointer-events: auto; }
.sl-cart-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 420px; max-width: 92vw; z-index: 330; background: linear-gradient(180deg,#0c0e13,#08090c); border-left: 1px solid var(--sl-line-2); transform: translateX(102%); transition: transform .4s var(--sl-ease); display: flex; flex-direction: column; }
.sl-cart-drawer.is-open { transform: none; }
.sl-cart-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid var(--sl-line); flex-shrink: 0; }
.sl-cart-drawer__head h3 { margin: 0; font-family: var(--sl-font-display); font-size: 15px; letter-spacing: .16em; text-transform: uppercase; color: var(--sl-text); }
.sl-cart-close { background: rgba(255,255,255,.04); border: 1px solid var(--sl-line); color: var(--sl-text); width: 38px; height: 38px; border-radius: 50%; cursor: pointer; display: grid; place-items: center; }
.sl-cart-close svg { width: 18px; height: 18px; }
.sl-cart-drawer__body { flex: 1; overflow-y: auto; padding: 18px 24px 24px; }
.sl-cart-drawer .woocommerce-mini-cart { list-style: none; margin: 0; padding: 0; }
/* Consistent line items: [thumb] [name] on row 1, "qty × price" on row 2 indented to align
   under the name — identical for every product regardless of name length. */
.sl-cart-drawer .woocommerce-mini-cart-item { display: flex; flex-wrap: wrap; align-items: center; column-gap: 14px; row-gap: 5px; padding: 16px 26px 16px 0; border-bottom: 1px solid var(--sl-line); position: relative; }
.sl-cart-drawer .woocommerce-mini-cart-item a:not(.remove) { flex: 1 1 100%; display: flex; align-items: center; gap: 14px; min-width: 0; color: var(--sl-text) !important; font-family: var(--sl-font-display); font-size: 14px; font-weight: 600; text-decoration: none; line-height: 1.3; }
.sl-cart-drawer .woocommerce-mini-cart-item img { width: 56px !important; height: 56px; object-fit: contain; margin: 0 !important; background: var(--sl-surface); border-radius: 8px; float: none !important; flex-shrink: 0; }
.sl-cart-drawer .woocommerce-mini-cart-item .quantity,
.sl-cart-drawer .woocommerce-mini-cart-item .variation { flex: 1 1 100%; padding-left: 70px; margin: 0; color: var(--sl-text-mut); font-size: 13px; }
.sl-cart-drawer .woocommerce-mini-cart-item .variation { font-size: 12px; line-height: 1.4; }
/* make the price stand out from the muted "qty ×" text */
.sl-cart-drawer .woocommerce-mini-cart-item .quantity .woocommerce-Price-amount { color: var(--sl-text); font-weight: 600; }
.sl-cart-drawer .woocommerce-mini-cart__total .woocommerce-Price-amount { color: var(--sl-silver-hi); font-weight: 700; }
.sl-cart-drawer .woocommerce-mini-cart-item a.remove { position: absolute; top: 14px; right: 0; color: var(--sl-text-dim) !important; font-size: 20px; line-height: 1; }
.sl-cart-drawer .woocommerce-mini-cart-item a.remove:hover { color: var(--sl-silver-hi) !important; background: none !important; }
.sl-cart-drawer .woocommerce-mini-cart__total { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; font-family: var(--sl-font-display); font-size: 15px; color: var(--sl-text); border-bottom: 1px solid var(--sl-line); margin-bottom: 16px; }
.sl-cart-drawer .woocommerce-mini-cart__total strong { color: var(--sl-silver-hi); font-size: 18px; }
.sl-cart-drawer .woocommerce-mini-cart__empty-message { color: var(--sl-text-mut); text-align: center; padding: 48px 0; }
.sl-cart-drawer .woocommerce-mini-cart__buttons { display: flex; flex-direction: column; gap: 10px; margin: 0; padding: 0; }
.sl-cart-drawer .woocommerce-mini-cart__buttons a { display: block; text-align: center; padding: 15px; border-radius: var(--sl-radius-pill); font-family: var(--sl-font-display); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; font-size: 13px; margin: 0; }
.sl-cart-drawer .woocommerce-mini-cart__buttons a.button { border: 1px solid var(--sl-line-2); color: var(--sl-silver); background: transparent; }
.sl-cart-drawer .woocommerce-mini-cart__buttons a.checkout { background: var(--sl-chrome); color: #0a0b0e; border: 0; }
.sl-cart-drawer .woocommerce-mini-cart__buttons a.checkout:hover { filter: brightness(1.06); }
/* View Cart = ghost/outline (secondary), Checkout stays silver (primary) — distinct hierarchy */
.sl-cart-drawer .woocommerce-mini-cart__buttons a.button:not(.checkout) {
  background: transparent !important; background-image: none !important; color: var(--sl-silver) !important;
  border: 1px solid var(--sl-line-2) !important; box-shadow: none !important; text-shadow: none !important;
}
.sl-cart-drawer .woocommerce-mini-cart__buttons a.button:not(.checkout):hover {
  background: rgba(255,255,255,.05) !important; color: var(--sl-silver-hi) !important; border-color: var(--sl-silver) !important; transform: none;
}
@media (max-width: 760px) { .sl-cart-drawer { width: 100%; } }

/* No gallery zoom/lightbox trigger */
.single-product .woocommerce-product-gallery__trigger { display: none !important; }
.single-product .woocommerce-product-gallery__image img { cursor: default; }

/* Buy Now button (secondary, under Add to Cart) */
.single-product form.cart .sl-buy-now {
  display: flex; align-items: center; justify-content: center; width: 100%; margin: 0; padding: 17px 28px; min-height: 56px; line-height: 1.2;
  border-radius: var(--sl-radius-pill); border: 1px solid var(--sl-line-2);
  background: transparent; color: var(--sl-text-mut);
  font-family: var(--sl-font-display); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; font-size: 14px;
  cursor: pointer; transition: color .24s var(--sl-ease), background .24s var(--sl-ease), border-color .24s var(--sl-ease), transform .24s var(--sl-ease);
}
/* quiet, smooth ghost hover — subtle lift + tint (all properties animatable; no chrome-fill snap) */
.single-product form.cart .sl-buy-now:hover {
  transform: translateY(-1px); background: rgba(255,255,255,.05); color: var(--sl-silver-hi); border-color: rgba(255,255,255,.3);
}
/* Hide WooCommerce's default inline "View cart" link — the side cart drawer opens on add
   (site.js: added_to_cart → openCart) and carries the View Cart / Checkout actions. */
.woocommerce a.added_to_cart,
a.added_to_cart.wc-forward { display: none !important; }
/* tactile press feedback on both product CTAs */
.single-product .single_add_to_cart_button:active, .single-product form.cart .sl-buy-now:active { transform: translateY(1px); }

/* ============================================================
   FLAT PREMIUM BUTTONS — kill the glossy chrome-gradient look
   (the brushed-metal .chrome TEXT for headings/prices stays)
   ============================================================ */
/* Polished chrome: diagonal silver gradient with a bright sheen band (matches client reference).
   Darker silver at the corners, a white highlight streak across the middle. */
:root {
  --sl-flat: linear-gradient(180deg, #edeff2 0%, #dadee2 100%);
  --sl-flat-hover: linear-gradient(180deg, #f4f6f8 0%, #e4e7eb 100%);
  --sl-flat-fg: #14161a;
  --sl-flat-border: rgba(20,22,26,.12);
  --sl-flat-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 1px 2px rgba(0,0,0,.22);
}
.sl-btn--primary,
.sl-search__submit,
.sl-card:hover .sl-card__cta,
.single-product .single_add_to_cart_button,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce a.button.alt, .woocommerce button.button.alt,
.woocommerce #place_order,
.woocommerce-mini-cart__buttons a.checkout,
.sl-cart-drawer .woocommerce-mini-cart__buttons a.checkout {
  background: var(--sl-flat) !important;
  color: var(--sl-flat-fg) !important;
  border: 1px solid var(--sl-flat-border) !important;
  box-shadow: var(--sl-flat-shadow) !important;
  text-shadow: none !important;
  filter: none !important;
  transition: transform .22s cubic-bezier(.22,.61,.36,1), box-shadow .22s cubic-bezier(.22,.61,.36,1), background .22s cubic-bezier(.22,.61,.36,1) !important;
}
.sl-btn--primary:hover,
.sl-search__submit:hover,
.sl-card:hover .sl-card__cta,
.single-product .single_add_to_cart_button:hover,
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover,
.woocommerce #place_order:hover,
.sl-cart-drawer .woocommerce-mini-cart__buttons a.checkout:hover {
  background: var(--sl-flat-hover) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 5px 14px -8px rgba(0,0,0,.45) !important;
  filter: none !important;
  transform: translateY(-1px);
}
/* small chrome accent badge -> silver */
.sl-cart__count { background: var(--sl-flat) !important; color: var(--sl-flat-fg) !important; border: 1px solid var(--sl-flat-border); }

/* ============================================================
   CART — 2-column (items left, totals right), real thumbnails
   ============================================================ */
/* Cart/checkout/account render in page.php — release the narrow prose column */
.woocommerce-cart .sl-prose, .woocommerce-checkout .sl-prose, .woocommerce-account .sl-prose { max-width: none !important; }
.sl-cart-layout { display: grid; grid-template-columns: 1fr 360px; gap: 40px; align-items: start; }
.sl-cart-main { min-width: 0; }
.woocommerce-cart .shop_table { width: 100%; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); border-collapse: separate; border-spacing: 0; overflow: hidden; background: var(--sl-bg-elev); margin: 0; }
.woocommerce-cart .shop_table thead th { background: transparent; color: var(--sl-text-mut); font-family: var(--sl-font-display); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; padding: 16px 14px; border-bottom: 1px solid var(--sl-line); text-align: left; }
.woocommerce-cart .shop_table td { padding: 16px 14px; border-top: 1px solid var(--sl-line); vertical-align: middle; color: var(--sl-text-mut); background: transparent; }
.sl-cart-main td.product-thumbnail img { width: 62px !important; height: 62px !important; max-width: 62px !important; min-width: 62px; object-fit: contain; background: var(--sl-surface); border-radius: 10px; padding: 4px; display: block; }
.woocommerce-cart .product-name a { color: var(--sl-text); font-family: var(--sl-font-display); font-weight: 600; text-decoration: none; }
.woocommerce-cart .product-name a:hover { color: var(--sl-silver-hi); }
.woocommerce-cart td.product-subtotal { color: var(--sl-silver-hi); font-family: var(--sl-font-display); font-weight: 600; }
.woocommerce-cart a.remove { color: var(--sl-text-dim) !important; font-size: 22px; line-height: 1; width: auto; height: auto; border-radius: 0; background: none !important; }
.woocommerce-cart a.remove:hover { color: var(--sl-silver-hi) !important; background: none !important; }
.woocommerce-cart .product-quantity .quantity { display: inline-flex !important; align-items: center; height: 44px; border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius-pill); background: var(--sl-bg); overflow: hidden; }
.woocommerce-cart .quantity input.qty { width: 42px; height: 100%; border: 0 !important; background: transparent !important; color: var(--sl-text) !important; text-align: center; font-family: var(--sl-font-display); font-size: 14px; font-weight: 600; padding: 0 !important; border-radius: 0; -moz-appearance: textfield; box-shadow: none !important; }
.woocommerce-cart .quantity input.qty::-webkit-outer-spin-button,
.woocommerce-cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.woocommerce-cart .product-quantity .sl-qty__btn { width: 36px; font-size: 17px; }
.woocommerce-cart td.actions { padding: 20px 16px; overflow: hidden; }
.woocommerce-cart td.actions .coupon { display: inline-flex; gap: 10px; align-items: center; float: left; margin: 0; }
/* dark-themed coupon input (was a plain white box) */
.woocommerce-cart td.actions .coupon input#coupon_code {
  width: 200px; min-width: 150px; margin: 0; height: 48px; padding: 0 16px;
  background: var(--sl-bg) !important; border: 1px solid var(--sl-line-2) !important; color: var(--sl-text) !important;
  border-radius: 10px !important; font-family: var(--sl-font-body); font-size: 14px;
}
.woocommerce-cart td.actions .coupon input#coupon_code::placeholder { color: var(--sl-text-dim); }
.woocommerce-cart td.actions .coupon input#coupon_code:focus { border-color: var(--sl-silver) !important; outline: none; }
/* cart action buttons: moderate height, tame radius + glow */
.woocommerce-cart td.actions button[name="apply_coupon"],
.woocommerce-cart td.actions button[name="update_cart"] {
  height: 48px; padding: 0 22px !important; border-radius: 10px !important; font-size: 13px !important;
  box-shadow: var(--sl-flat-shadow) !important;
}
.woocommerce-cart td.actions button[name="update_cart"] { float: right; }
.sl-cart-side .cart-collaterals { width: 100% !important; float: none !important; margin: 0 !important; }
.sl-cart-side .cart_totals { width: 100% !important; float: none !important; position: sticky; top: 100px; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: var(--sl-bg-elev); padding: 26px; }
.sl-cart-side .cart_totals h2 { font-family: var(--sl-font-display); font-size: 16px; letter-spacing: .16em; text-transform: uppercase; margin: 0 0 14px; color: var(--sl-text); }
.sl-cart-side .cart_totals table { width: 100%; border: 0; margin: 0; background: transparent; }
.sl-cart-side .cart_totals th, .sl-cart-side .cart_totals td { padding: 12px 0; border-top: 1px solid var(--sl-line); color: var(--sl-text-mut); text-align: left; font-size: 14px; }
.sl-cart-side .cart_totals tr:first-child th, .sl-cart-side .cart_totals tr:first-child td { border-top: 0; }
.sl-cart-side .cart_totals .order-total th, .sl-cart-side .cart_totals .order-total td { color: var(--sl-silver-hi); font-family: var(--sl-font-display); font-size: 17px; }
.sl-cart-side .wc-proceed-to-checkout { padding: 18px 0 0; width: 100%; }
.sl-cart-side .wc-proceed-to-checkout a.checkout-button {
  display: flex !important; align-items: center; justify-content: center; width: 100% !important;
  text-align: center; white-space: nowrap; min-height: 0; padding: 16px 24px !important;
  font-size: 14px !important; line-height: 1.2 !important; border-radius: 12px !important;
  box-shadow: var(--sl-flat-shadow) !important;
}
/* notices — kill the default blue focus ring */
.woocommerce-message, .woocommerce-info, .woocommerce-error { outline: none !important; }
.woocommerce-message:focus, .woocommerce-info:focus, .woocommerce-error:focus { outline: none !important; }
@media (max-width: 900px) { .sl-cart-layout { grid-template-columns: 1fr; } .sl-cart-side .cart_totals { position: static; } }
@media (max-width: 560px) { .woocommerce-cart td.actions .coupon, .woocommerce-cart td.actions .coupon input#coupon_code { width: 100%; float: none; margin-bottom: 10px; } .woocommerce-cart td.actions button[name="update_cart"] { float: none; width: 100%; } }

/* ============================================================
   COAs & TESTING — full-bleed COA grid (dark/silver brand)
   ============================================================ */
.sl-prose:has(.sl-coa-page) { max-width: none !important; }
.sl-container:has(.sl-coa-page) { max-width: none !important; padding: 0 !important; }
.sl-page:has(.sl-coa-page) { padding: 78px 0 0 !important; }
.sl-page:has(.sl-coa-page) .sl-page__head { display: none !important; }

.sl-coa-page { background: var(--sl-bg); color: var(--sl-text); padding: 0 0 90px; }
.sl-coa-hero { text-align: center; padding: 84px 24px 60px; background: linear-gradient(180deg, var(--sl-bg-elev) 0%, var(--sl-bg) 100%); border-bottom: 1px solid var(--sl-line); }
.sl-coa-hero__label { font-family: var(--sl-font-display); font-size: 12px; font-weight: 600; letter-spacing: .28em; text-transform: uppercase; color: var(--sl-text-dim); margin: 0 0 16px; }
.sl-coa-hero__title { font-family: var(--sl-font-display); font-size: clamp(40px,6vw,72px); font-weight: 600; line-height: 1.02; letter-spacing: -.01em; margin: 0 0 18px; color: var(--sl-text); }
.sl-coa-hero__sub { font-size: 16px; line-height: 1.7; color: var(--sl-text-mut); max-width: 540px; margin: 0 auto 26px; }
.sl-coa-hero__badge { display: inline-flex; align-items: center; gap: 10px; background: rgba(255,255,255,.03); border: 1px solid var(--sl-line-2); border-radius: 999px; padding: 10px 20px; font-family: var(--sl-font-display); font-size: 13px; font-weight: 500; color: var(--sl-silver); letter-spacing: .04em; }
.sl-coa-hero__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sl-silver-hi); box-shadow: 0 0 12px 2px var(--sl-glow); animation: sl-pulse 2.4s var(--sl-ease) infinite; flex-shrink: 0; }
.sl-coa-list { max-width: 1100px; margin: 0 auto; padding: 60px 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 44px 26px; }
.sl-coa-section__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.sl-coa-page .sl-coa-section__name { font-family: var(--sl-font-display); font-size: 20px; font-weight: 600; letter-spacing: -.01em; color: var(--sl-text); margin: 0 0 4px; }
.sl-coa-section__meta { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--sl-text-dim); margin: 0; }
.sl-coa-section__badge { font-family: var(--sl-font-display); font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--sl-silver); border: 1px solid var(--sl-line-2); background: rgba(255,255,255,.025); padding: 6px 11px; border-radius: 999px; white-space: nowrap; }
.sl-coa-card__image-wrap { display: block; width: 100%; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); overflow: hidden; background: #fff; transition: transform .35s var(--sl-ease), border-color .35s var(--sl-ease), box-shadow .35s var(--sl-ease); }
.sl-coa-card__image-wrap:hover { border-color: var(--sl-line-2); transform: translateY(-4px); box-shadow: 0 30px 60px -30px rgba(0,0,0,.85); }
.sl-coa-card__coa-img { display: block; width: 100%; height: auto; }
.sl-coa-request { max-width: 680px; margin: 0 auto; padding: 48px 24px 0; text-align: center; border-top: 1px solid var(--sl-line); }
.sl-coa-request__title { font-family: var(--sl-font-display); font-size: 20px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--sl-text); margin: 0 0 12px; }
.sl-coa-request__text { font-size: 15px; line-height: 1.7; color: var(--sl-text-mut); margin: 0; }
.sl-coa-request__link { color: var(--sl-silver-hi); text-decoration: underline; text-underline-offset: 3px; }
.sl-coa-disclaimer { max-width: 700px; margin: 22px auto 0; padding: 0 24px; font-family: var(--sl-font-display); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; line-height: 1.8; color: var(--sl-text-dim); text-align: center; }
@media (max-width: 600px) {
  .sl-coa-hero { padding: 56px 20px 40px; }
  .sl-coa-list { padding: 36px 22px; gap: 26px 14px; }
  .sl-coa-section__header { flex-direction: column; align-items: flex-start; gap: 6px; margin-bottom: 12px; }
  .sl-coa-page .sl-coa-section__name { font-size: 15px; line-height: 1.25; word-break: break-word; }
  .sl-coa-section__meta { font-size: 10px; letter-spacing: .04em; }
  .sl-coa-section__badge { font-size: 9px; padding: 4px 8px; }
}
.sl-coa-card__image-wrap { cursor: zoom-in; }

/* COA / image lightbox */
.sl-lightbox { position: fixed; inset: 0; z-index: 9998; background: rgba(4,5,7,.93); backdrop-filter: blur(8px); display: none; align-items: center; justify-content: center; padding: 32px; cursor: zoom-out; }
.sl-lightbox.is-open { display: flex; }
.sl-lightbox__img { max-width: 900px; width: 100%; max-height: 92vh; object-fit: contain; border-radius: 10px; background: #fff; box-shadow: 0 40px 100px -20px rgba(0,0,0,.9); cursor: default; }
.sl-lightbox__close { position: absolute; top: 24px; right: 28px; background: rgba(255,255,255,.06); border: 1px solid var(--sl-line-2); color: var(--sl-text); width: 46px; height: 46px; border-radius: 50%; font-size: 26px; line-height: 1; cursor: pointer; display: grid; place-items: center; }
.sl-lightbox__close:hover { color: var(--sl-silver-hi); }

/* ============================================================
   LANDING IMAGERY — hero poster, shop hero, lab band, about
   ============================================================ */
.sl-hero__poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; opacity: 0; }
@media (prefers-reduced-motion: reduce) { .sl-hero__poster { opacity: .55; } }

.sl-shop-hero { position: relative; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); overflow: hidden; background-size: cover; background-position: center; padding: clamp(52px,7vw,96px) 24px; margin-bottom: 48px; text-align: center; }
.sl-shop-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,9,12,.7), rgba(8,9,12,.92)); }
.sl-shop-hero__inner { position: relative; z-index: 1; max-width: 640px; margin: 0 auto; }
.sl-shop-hero__title { font-family: var(--sl-font-display); font-size: clamp(32px,4.6vw,56px); font-weight: 600; letter-spacing: -.01em; margin: 6px 0 14px; }
.sl-shop-hero__sub { color: var(--sl-text-mut); font-size: 16px; line-height: 1.65; margin: 0 auto; max-width: 54ch; }

.sl-labband { position: relative; background-size: cover; background-position: center; padding: clamp(80px,12vw,150px) 0; border-top: 1px solid var(--sl-line); border-bottom: 1px solid var(--sl-line); margin: var(--sl-section-y) 0; }
.sl-labband::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8,9,12,.94) 0%, rgba(8,9,12,.72) 58%, rgba(8,9,12,.45) 100%); }
.sl-labband__inner { position: relative; z-index: 1; max-width: 560px; }

.sl-prose:has(.sl-about-page) { max-width: none !important; }
.sl-container:has(.sl-about-page) { max-width: none !important; padding: 0 !important; }
.sl-page:has(.sl-about-page) { padding: 78px 0 0 !important; }
.sl-page:has(.sl-about-page) .sl-page__head { display: none !important; }
.sl-about-page { background: var(--sl-bg); color: var(--sl-text); padding: 0 0 90px; }
.sl-about-hero { position: relative; background: var(--sl-bg); padding: clamp(96px,13vw,150px) 24px; text-align: center; border-bottom: 1px solid var(--sl-line); }
.sl-about-hero__inner { max-width: 720px; margin: 0 auto; }
.sl-about-hero__inner .sl-eyebrow { color: var(--sl-silver); justify-content: center; }
.sl-about-hero__inner h1 { font-family: var(--sl-font-display); font-size: clamp(40px,6vw,68px); font-weight: 600; margin: 8px 0 18px; }
.sl-about-hero__inner p { color: var(--sl-text-mut); font-size: 17px; line-height: 1.65; margin: 0 auto; max-width: 56ch; }
.sl-about-split { max-width: 1140px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; padding: clamp(56px,8vw,100px) 24px; }
.sl-about-split--rev .sl-about-split__media { order: -1; }
.sl-about-split__media { aspect-ratio: 4/3; border-radius: var(--sl-radius); border: 1px solid var(--sl-line); background-size: cover; background-position: center; }
.sl-about-split__text h2 { font-family: var(--sl-font-display); font-size: clamp(26px,3.4vw,40px); font-weight: 600; margin: 0 0 16px; }
.sl-about-split__text p { color: var(--sl-text-mut); font-size: 16px; line-height: 1.75; }
.sl-about-split__text ul { list-style: none; padding: 0; margin: 0; }
.sl-about-split__text li { position: relative; padding-left: 24px; margin-bottom: 12px; color: var(--sl-text-mut); }
.sl-about-split__text li::before { content: ""; position: absolute; left: 4px; top: 10px; width: 6px; height: 6px; border-radius: 50%; background: var(--sl-silver); }
.sl-about-ruo { max-width: 760px; margin: 20px auto 0; padding: 0 24px; text-align: center; font-family: var(--sl-font-display); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--sl-text-dim); }
@media (max-width: 820px) { .sl-about-split { grid-template-columns: 1fr; gap: 28px; } .sl-about-split--rev .sl-about-split__media { order: 0; } }
.sl-about-split__text .sl-eyebrow { margin-bottom: 14px; }
.sl-about-split__text .sl-about-note { color: var(--sl-text-dim); font-style: italic; font-size: 15px; margin: 18px 0 0; }
.sl-about-split__text .sl-btn { margin-top: 26px; }
.sl-about-split__text p + p { margin-top: 14px; }
.sl-about-split__text .sl-about-checks li { padding-left: 30px; margin-bottom: 14px; color: var(--sl-text); }
.sl-about-split__text .sl-about-checks li::before { content: ""; left: 2px; top: 5px; width: 13px; height: 8px; border: 0; border-left: 1.8px solid var(--sl-silver); border-bottom: 1.8px solid var(--sl-silver); border-radius: 0; background: none; transform: rotate(-45deg); }
/* stats band */
.sl-about-stats { max-width: 1140px; margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); gap: 40px; padding: clamp(44px,6vw,76px) 24px; border-top: 1px solid var(--sl-line); text-align: center; }
.sl-about-stat__num { display: block; font-family: var(--sl-font-display); font-size: clamp(34px,4vw,52px); font-weight: 700; color: var(--sl-silver-hi); line-height: 1; letter-spacing: -.01em; }
.sl-about-stat__label { display: block; font-family: var(--sl-font-display); font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: var(--sl-text); margin: 13px 0 8px; }
.sl-about-stat__desc { display: block; color: var(--sl-text-mut); font-size: 14px; line-height: 1.6; max-width: 32ch; margin: 0 auto; }
@media (max-width: 820px) { .sl-about-stats { grid-template-columns: 1fr; gap: 30px; } }

/* ============================================================
   CHECKOUT — two-column premium layout (form left, sticky summary right)
   ============================================================ */
.sl-checkout-layout { display: grid; grid-template-columns: 1fr 400px; gap: 44px; align-items: start; }
.sl-checkout-main { min-width: 0; }
/* Stack billing over shipping — kill WooCommerce's col2-set floats */
.sl-checkout-main #customer_details { display: block; }
.sl-checkout-main #customer_details .col-1,
.sl-checkout-main #customer_details .col-2 { width: 100% !important; float: none !important; margin: 0 0 14px !important; }
.sl-checkout-main .woocommerce-billing-fields h3,
.sl-checkout-main .woocommerce-shipping-fields h3,
.sl-checkout-main .woocommerce-additional-fields h3 { font-family: var(--sl-font-display); font-size: 13px; letter-spacing: .16em; text-transform: uppercase; color: var(--sl-text); margin: 0 0 18px; padding-bottom: 14px; border-bottom: 1px solid var(--sl-line); }
.sl-checkout-main .form-row { margin: 0 0 16px; }
.sl-checkout-main .form-row label { display: block; font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--sl-text-dim); margin: 0 0 8px; }
.sl-checkout-main .form-row .required { color: var(--sl-silver); text-decoration: none; }
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 { float: none; width: 100%; }

/* Right column sticky summary card */
.sl-checkout-side { min-width: 0; }
.sl-checkout-summary { position: sticky; top: 100px; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: var(--sl-bg-elev); padding: 28px; }
.sl-checkout-summary > #order_review_heading { font-family: var(--sl-font-display); font-size: 16px; letter-spacing: .16em; text-transform: uppercase; margin: 0 0 18px; color: var(--sl-text); }
.sl-checkout-summary #order_review { width: 100%; }
.sl-checkout-summary .shop_table { width: 100%; border: 0; background: transparent; margin: 0 0 4px; }
.sl-checkout-summary .shop_table thead th { background: transparent; border: 0; padding: 0 0 10px; font-size: 11px; letter-spacing: .12em; }
.sl-checkout-summary .shop_table td, .sl-checkout-summary .shop_table th { padding: 12px 0; border-top: 1px solid var(--sl-line); color: var(--sl-text-mut); font-size: 14px; background: transparent; text-align: left; }
.sl-checkout-summary .shop_table .product-total, .sl-checkout-summary .shop_table td.product-total { text-align: right; color: var(--sl-text); }
.sl-checkout-summary .shop_table .product-name { color: var(--sl-text); }
.sl-checkout-summary .cart_item .product-name .product-quantity { color: var(--sl-text-dim); }
.sl-checkout-summary .shop_table tfoot th, .sl-checkout-summary .shop_table tfoot td { font-family: var(--sl-font-display); }
.sl-checkout-summary .shop_table tfoot .order-total th, .sl-checkout-summary .shop_table tfoot .order-total td { color: var(--sl-silver-hi); font-size: 17px; padding-top: 16px; }
.sl-checkout-summary .shop_table tfoot td { text-align: right; }
.sl-checkout-summary .shop_table tfoot .amount { color: var(--sl-text); }
.sl-checkout-summary .shop_table tfoot .order-total .amount { color: var(--sl-silver-hi); }
/* Kill stray list bullets inside cart/checkout (the .sl-prose li::before silver dot leaks in) */
.woocommerce-checkout .sl-prose ul, .woocommerce-cart .sl-prose ul { list-style: none !important; margin: 0; padding-left: 0; }
.woocommerce-checkout .sl-prose ul li, .woocommerce-cart .sl-prose ul li { padding-left: 0 !important; }
.woocommerce-checkout .sl-prose ul li::before, .woocommerce-cart .sl-prose ul li::before { content: none !important; display: none !important; }
/* Shipping method radios */
.sl-checkout-summary #shipping_method { margin: 0; padding: 0; }
.sl-checkout-summary #shipping_method li { margin: 0 0 6px; color: var(--sl-text-mut); font-size: 14px; }
.sl-checkout-summary #shipping_method input[type=radio] { accent-color: var(--sl-silver); }
/* Payment box flush inside the card */
.sl-checkout-summary #payment { background: transparent !important; border: 0 !important; border-radius: 0; padding: 0; margin-top: 18px; }
.sl-checkout-summary #payment .woocommerce-info { background: rgba(255,255,255,.02); border: 1px solid var(--sl-line); border-radius: var(--sl-radius-sm); color: var(--sl-text-mut); font-size: 13px; padding: 14px 16px; }
.sl-checkout-summary .woocommerce-info::before, .sl-checkout-summary #payment .woocommerce-info::before { display: none !important; content: none !important; }
.sl-checkout-summary .woocommerce-info { padding-left: 16px !important; }
.sl-checkout-summary #place_order { width: 100% !important; margin-top: 8px; padding: 16px 24px !important; font-size: 14px !important; border-radius: 12px !important; box-shadow: var(--sl-flat-shadow) !important; }
.sl-checkout-summary .sl-ruo-checkout { margin: 16px 0 0; }
.sl-checkout-summary .sl-insurance { margin: 0 0 16px; }

@media (max-width: 980px) {
  .sl-checkout-layout { grid-template-columns: 1fr; gap: 28px; }
  .sl-checkout-summary { position: static; }
}

/* ============================================================
   PRODUCT BUNDLES — "Build your 5-vial bundle" picker
   Styles WooCommerce Product Bundles to match the Storm Labs look.
   Scoped to .product-type-bundle so normal products are untouched.
   ============================================================ */
/* Two-column: 5-vial montage left, picker right (matches Signal Labs) */
.single-product .product-type-bundle.product { grid-template-columns: 1fr 1fr !important; gap: clamp(30px,4vw,54px) !important; align-items: start; }
.single-product .product-type-bundle .summary { width: 100% !important; max-width: none !important; float: none !important; padding-top: 0; }
.single-product .product-type-bundle .woocommerce-product-gallery { position: sticky; top: 100px; }

/* Header price (From: ...) stays on brand; badges row already styled */
.single-product .product-type-bundle .summary > .price { margin-bottom: 6px; }

/* Picker grid (override PB's float-based columns-3) */
.single-product .bundle_form .bundled_products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(228px, 1fr)) !important;
  gap: 16px !important;
  margin: 6px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  width: 100%;
}
/* Section heading injected before the grid */
.single-product .bundle_form .bundled_products::before {
  content: "Choose any 5 vials — 10% off each";
  grid-column: 1 / -1;
  font-family: var(--sl-font-display);
  font-size: 12px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--sl-text-dim);
  padding: 8px 0 14px; margin: 0;
  border-bottom: 1px solid var(--sl-line);
}

/* Each vial = a card */
.single-product .bundle_form .bundled_product {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--sl-surface);
  border: 1px solid var(--sl-line);
  border-radius: var(--sl-radius);
  padding: 18px 16px 16px;
  margin: 0 !important;
  width: auto !important; float: none !important; clear: none !important;
  transition: border-color .16s var(--sl-ease), transform .16s var(--sl-ease), background .16s var(--sl-ease);
}
.single-product .bundle_form .bundled_product:hover {
  transform: translateY(-2px);
  border-color: var(--sl-line-2);
  background: var(--sl-surface-2);
}
/* Selected state (its optional checkbox is checked) */
.single-product .bundle_form .bundled_product:has(.bundled_product_optional_checkbox input:checked) {
  border-color: var(--sl-silver);
  background: linear-gradient(180deg, rgba(200,205,212,.07), rgba(200,205,212,.02));
}

/* Image */
.single-product .bundle_form .bundled_product_images {
  width: 100% !important; margin: 0 0 12px !important; float: none !important;
  display: flex; align-items: center; justify-content: center;
}
.single-product .bundle_form .bundled_product_images img {
  width: auto !important; max-height: 148px; object-fit: contain; border-radius: 8px; margin: 0 !important; box-shadow: none;
}

/* Title + external link */
.single-product .bundle_form .bundled_product_title {
  font-family: var(--sl-font-display); font-size: 15.5px; font-weight: 600;
  color: var(--sl-text); margin: 0 0 6px; line-height: 1.22;
}
.single-product .bundle_form .bundled_product_title_link { color: inherit; }
.single-product .bundle_form .bundled_product_title_link:hover { color: var(--sl-silver-hi); }
.single-product .bundle_form .bundled_product_permalink { opacity: .4; font-size: 12px; }
.single-product .bundle_form .bundled_product_permalink:hover { opacity: .8; }

/* Excerpt — clamp for density */
.single-product .bundle_form .bundled_product_excerpt {
  color: var(--sl-text-dim); font-size: 12.5px; line-height: 1.5; margin: 0 0 10px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.single-product .bundle_form .bundled_product_excerpt p { margin: 0; color: inherit; }

/* Push the controls to the bottom of the card */
.single-product .bundle_form .bundled_item_cart_content,
.single-product .bundle_form .bundled_item_wrap { margin-top: auto; }

/* Per-item price + the 10%-off sale formatting */
.single-product .bundle_form .bundled_product .price {
  font-family: var(--sl-font-display); color: var(--sl-silver-hi); font-size: 15px; font-weight: 600; margin: 0;
}
.single-product .bundle_form .bundled_product .price del { color: var(--sl-text-dim); font-weight: 400; font-size: 12.5px; margin-right: 6px; }
.single-product .bundle_form .bundled_product .price ins { text-decoration: none; }

/* "Add for ... each" optional toggle */
.single-product .bundle_form .bundled_product_optional_checkbox {
  display: flex; align-items: center; gap: 9px; margin: 12px 0 0;
  font-family: var(--sl-font-display); font-size: 11.5px; font-weight: 600;
  letter-spacing: .04em; text-transform: uppercase; color: var(--sl-text-mut); cursor: pointer;
}
.single-product .bundle_form .bundled_product_optional_checkbox input {
  width: 18px; height: 18px; accent-color: var(--sl-silver); cursor: pointer; flex: 0 0 auto;
}

/* Quantity stepper */
.single-product .bundle_form input.bundled_qty {
  width: 58px; background: var(--sl-surface-2); border: 1px solid var(--sl-line-2);
  color: var(--sl-text); border-radius: 8px; padding: 9px; text-align: center; margin-top: 10px;
}

/* Variation selects (Size / mg) inside a card */
.single-product .bundle_form .bundled_product select {
  width: 100%; background: var(--sl-surface-2); border: 1px solid var(--sl-line-2); color: var(--sl-text);
  border-radius: 9px; padding: 10px 12px; font-family: var(--sl-font-body); font-size: 14px; margin: 8px 0 0;
}
.single-product .bundle_form .bundled_product .label,
.single-product .bundle_form .bundled_product_attributes_title {
  color: var(--sl-text-mut); font-family: var(--sl-font-display); text-transform: uppercase;
  letter-spacing: .1em; font-size: 11px; margin: 8px 0 4px;
}
.single-product .bundle_form .bundled_product .reset_variations { color: var(--sl-text-dim); font-size: 12px; }

/* Total + availability + add-to-cart */
.single-product .bundle_wrap { margin-top: 24px; padding-top: 22px; padding-bottom: 12px; border-top: 1px solid var(--sl-line); }
.single-product .bundle_price {
  font-family: var(--sl-font-display); color: var(--sl-silver-hi); font-size: 30px; font-weight: 700; margin: 0 0 6px;
}
.single-product .bundle_price del { color: var(--sl-text-dim); font-weight: 400; font-size: 20px; margin-right: 10px; }
.single-product .bundle_price ins { text-decoration: none; }
.single-product .bundle_error, .single-product .bundle_availability {
  background: var(--sl-surface); border: 1px solid var(--sl-line-2); color: var(--sl-text-mut);
  border-radius: var(--sl-radius-sm); padding: 12px 16px; font-size: 13px; margin: 14px 0; list-style: none;
}
.single-product .bundle_error::before, .single-product .bundle_availability::before { display: none !important; content: none !important; }

@media (max-width: 600px) {
  .single-product .bundle_form .bundled_products { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important; gap: 12px !important; }
  .single-product .bundle_form .bundled_product { padding: 14px 12px; }
}

/* ============================================================
   CUSTOM BUNDLE PICKER (slots + modal) — recreates Easy Product
   Bundles UX on top of WooCommerce Product Bundles.
   ============================================================ */
/* Hide PB's native inline list + duplicate price; our UI replaces them. */
/* Hide PB's native bundled products from first paint (the picker reads them via JS, hidden or not)
   so the old default-bundle styling never flashes before the custom slot UI builds. */
.single-product .bundle_form .bundled_products { display: none !important; }
.single-product .bundle_price { display: none !important; }
/* No "Sale!" flash on the build-your-own bundle */
.single-product .product-type-bundle .onsale,
.single-product .product-type-bundle .woocommerce-product-gallery .onsale { display: none !important; }

.sl-bundle { margin: 4px 0 0; }
.sl-bundle__lead { color: var(--sl-text-mut); font-size: 15px; margin: 0 0 18px; }

/* --- Slots --- */
.sl-slots {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
}
.sl-slot {
  position: relative; aspect-ratio: 3 / 4; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  background: transparent; border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius);
  color: var(--sl-text-dim); text-align: center; padding: 12px;
  transition: border-color .16s var(--sl-ease), background .16s var(--sl-ease), transform .16s var(--sl-ease);
}
.sl-slot:hover { border-color: var(--sl-silver); color: var(--sl-text-mut); transform: translateY(-2px); }
.sl-slot__plus { font-size: 30px; font-weight: 300; line-height: 1; color: var(--sl-text-mut); }
.sl-slot__hint { font-family: var(--sl-font-display); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.sl-slot.is-filled { border-style: solid; border-color: var(--sl-line); background: var(--sl-bg-elev); cursor: pointer; padding: 12px 10px 14px; justify-content: flex-start; }
.sl-slot__img { flex: 1; display: flex; align-items: center; justify-content: center; min-height: 0; width: 100%; overflow: hidden; background: radial-gradient(120% 95% at 50% 28%, #232831 0%, #0c0e12 78%); border-radius: var(--sl-radius-sm); padding: 2px; }
.sl-slot__img img { max-height: 116%; max-width: 100%; width: auto; object-fit: contain; }
.sl-slot__name { font-family: var(--sl-font-display); font-size: 14px; font-weight: 600; color: var(--sl-text); line-height: 1.2; }
.sl-slot__name span { display: block; color: var(--sl-text-dim); font-weight: 400; font-size: 12px; margin-top: 3px; }
.sl-slot__remove {
  position: absolute; top: 6px; right: 6px; z-index: 2; width: 24px; height: 24px; border-radius: 50%;
  background: rgba(8,9,12,.7); border: 1px solid var(--sl-line-2); color: var(--sl-text-mut);
  font-size: 16px; line-height: 1; display: flex; align-items: center; justify-content: center;
  transition: color .15s, border-color .15s;
}
.sl-slot__remove:hover { color: var(--sl-silver-hi); border-color: var(--sl-silver); }

/* --- Status bar --- */
/* Summary list (Signal-style rows under the slots) */
.sl-summary { margin: 18px 0 0; }
.sl-sum-row { display: grid; grid-template-columns: 1fr auto 74px 92px; align-items: center; gap: 12px; padding: 13px 2px; border-bottom: 1px solid var(--sl-line); }
.sl-sum-row:first-child { border-top: 1px solid var(--sl-line); }
.sl-sum-row__name { font-size: 15.5px; color: var(--sl-text); line-height: 1.3; }
.sl-sum-row__name.is-empty { color: var(--sl-text-dim); }
.sl-sum-row__edit { background: none; border: 0; color: var(--sl-text-dim); padding: 2px; cursor: pointer; display: inline-flex; align-items: center; transition: color .18s var(--sl-ease); }
.sl-sum-row__edit:hover { color: var(--sl-silver-hi); }
.sl-sum-row__mg { font-family: var(--sl-font-display); font-size: 13.5px; letter-spacing: .03em; color: var(--sl-text-mut); text-align: right; }
.sl-sum-row__price { font-family: var(--sl-font-display); font-size: 15px; font-weight: 600; color: var(--sl-silver-hi); text-align: right; }
.sl-sum-row:not(.is-filled) .sl-sum-row__mg,
.sl-sum-row:not(.is-filled) .sl-sum-row__price { color: var(--sl-text-dim); font-weight: 400; }

.sl-bundle__bar { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin: 20px 0 4px; padding-top: 18px; border-top: 1px solid var(--sl-line); }
.sl-bundle__count { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--sl-text-dim); }
.sl-bundle.is-complete .sl-bundle__count { color: var(--sl-silver-hi); }
.sl-bundle__total { font-family: var(--sl-font-display); font-size: 30px; font-weight: 700; color: var(--sl-silver-hi); }
.sl-bundle__total del { color: var(--sl-text-dim); font-weight: 400; font-size: 19px; margin-right: 9px; }
.sl-bundle__total ins { text-decoration: none; }

/* --- Modal --- */
body.sl-modal-open { overflow: hidden; }
.sl-modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 24px; }
.sl-modal[hidden] { display: none; }
.sl-modal__backdrop { position: absolute; inset: 0; background: rgba(4,5,7,.78); backdrop-filter: blur(2px); }
.sl-modal__panel {
  position: relative; z-index: 1; width: min(960px, 100%); max-height: 88vh; overflow-y: auto;
  background: var(--sl-bg-elev); border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius);
  padding: 28px clamp(18px, 3vw, 34px) 30px; box-shadow: 0 30px 80px -20px rgba(0,0,0,.7);
}
.sl-modal__x { position: absolute; top: 16px; right: 18px; background: none; border: 0; color: var(--sl-text-mut); font-size: 26px; line-height: 1; padding: 4px; }
.sl-modal__x:hover { color: var(--sl-silver-hi); }
.sl-modal__title { font-family: var(--sl-font-display); font-size: 22px; font-weight: 600; text-align: center; color: var(--sl-text); margin: 0 0 18px; }
.sl-modal__search { margin: 0 0 20px; }
.sl-modal__input {
  width: 100%; background: var(--sl-surface); border: 1px solid var(--sl-line-2); color: var(--sl-text);
  border-radius: var(--sl-radius-pill); padding: 13px 20px; font-family: var(--sl-font-body); font-size: 15px;
}
.sl-modal__input:focus { outline: none; border-color: var(--sl-silver); }
.sl-modal__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }

/* product card in modal (renamed from .sl-card to avoid colliding with shop cards) */
.sl-pcard {
  display: flex; flex-direction: column; background: var(--sl-surface); border: 1px solid var(--sl-line);
  border-radius: var(--sl-radius-sm); padding: 12px; transition: border-color .15s var(--sl-ease), transform .15s var(--sl-ease);
}
.sl-pcard:hover { border-color: var(--sl-line-2); transform: translateY(-2px); }
.sl-pcard.is-oos { opacity: .55; }
.sl-pcard.is-picked { opacity: .5; }
.sl-pcard__img { position: relative; display: flex; align-items: center; justify-content: center; height: 150px; margin-bottom: 10px; overflow: hidden; background: radial-gradient(120% 95% at 50% 28%, #232831 0%, #0c0e12 78%); border-radius: var(--sl-radius-sm); padding: 2px; }
.sl-pcard__img img { max-height: 116%; max-width: 92%; width: auto; object-fit: contain; }
.sl-pcard__oos { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%) rotate(-12deg); background: rgba(180,40,40,.92); color: #fff; font-family: var(--sl-font-display); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; }
.sl-pcard__name { font-family: var(--sl-font-display); font-size: 13.5px; font-weight: 600; color: var(--sl-text); line-height: 1.2; margin-bottom: 4px; min-height: 2.4em; }
.sl-pcard__name .sl-pcard__mg { color: var(--sl-text-dim); font-weight: 400; }
.sl-pcard__price { font-family: var(--sl-font-display); font-size: 14px; color: var(--sl-silver-hi); margin-bottom: 10px; }
.sl-pcard__price del { color: var(--sl-text-dim); font-weight: 400; font-size: 12px; margin-right: 5px; }
.sl-pcard__price ins { text-decoration: none; }
.sl-pcard__var {
  width: 100%; background: var(--sl-surface-2); border: 1px solid var(--sl-line-2); color: var(--sl-text);
  border-radius: 8px; padding: 8px 10px; font-family: var(--sl-font-body); font-size: 13px; margin-bottom: 10px;
}
.sl-pcard__add {
  margin-top: auto; width: 100%; background: var(--sl-flat); color: #15171c; border: 0;
  border-radius: var(--sl-radius-pill); padding: 11px; font-family: var(--sl-font-display); font-weight: 600;
  font-size: 12px; letter-spacing: .06em; text-transform: uppercase; transition: filter .15s, transform .15s;
}
.sl-pcard__add:hover:not(:disabled) { filter: brightness(1.06); transform: translateY(-1px); }
.sl-pcard__add:disabled { background: var(--sl-surface-2); color: var(--sl-text-dim); cursor: not-allowed; }

/* pager */
.sl-modal__pager { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 8px; margin-top: 22px; }
.sl-pgbtn { flex: 0 0 auto; align-self: center; min-width: 36px; width: auto; height: 36px; min-height: 0; padding: 0 10px; background: var(--sl-surface); border: 1px solid var(--sl-line-2); color: var(--sl-text-mut); border-radius: 8px; font-family: var(--sl-font-display); font-size: 13px; line-height: 1; }
.sl-pgbtn:hover { border-color: var(--sl-silver); color: var(--sl-text); }
.sl-pgbtn.is-active { background: var(--sl-flat); color: #15171c; border-color: transparent; }

@media (max-width: 900px) { .sl-modal__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) {
  .sl-slots { grid-template-columns: repeat(3, 1fr); }
  .sl-modal__grid { grid-template-columns: repeat(2, 1fr); }
  .sl-bundle__total { font-size: 24px; }
}

/* Our UI owns validation — hide PB's client-side messaging. */
.single-product .bundle_error, .single-product .bundle_availability { display: none !important; }
.sl-pgbtn--next { width: auto; padding: 0 14px; }
/* Locked cart buttons until 5 chosen */
.single-product .single_add_to_cart_button.sl-locked,
.single-product .sl-buy-now.sl-locked { opacity: .45; filter: grayscale(.35); cursor: not-allowed; }
@keyframes sl-shake { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-6px)} 40%,80%{transform:translateX(6px)} }
.sl-bundle.sl-shake .sl-slots { animation: sl-shake .45s var(--sl-ease); }

/* ============================================================
   Refined bundle CTAs — premium + restrained.
   Overrides the site-wide glossy chrome look for the bundle page only:
   even brushed silver (no fake white sheen streak), no glow bloom on
   hover, slower smooth motion per the anti-slop rules.
   ============================================================ */
.single-product .product-type-bundle .single_add_to_cart_button,
.single-product .product-type-bundle .sl-buy-now {
  border-radius: 13px !important;
  font-size: 13px !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  min-height: 58px !important;
  transition: transform .22s cubic-bezier(.22,.61,.36,1),
              box-shadow .22s cubic-bezier(.22,.61,.36,1),
              background .22s cubic-bezier(.22,.61,.36,1),
              color .22s cubic-bezier(.22,.61,.36,1),
              border-color .22s cubic-bezier(.22,.61,.36,1) !important;
}

/* Add to Cart — clean brushed silver, soft inner light, tight shadow (no halo) */
.single-product .product-type-bundle .single_add_to_cart_button {
  background: linear-gradient(180deg, #e7eaee 0%, #cfd4da 50%, #b7bcc4 100%) !important;
  color: #15171c !important;
  border: 1px solid rgba(255,255,255,.4) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7),
              inset 0 -1px 0 rgba(96,104,118,.28),
              0 2px 6px -3px rgba(0,0,0,.4) !important;
  filter: none !important;
}
.single-product .product-type-bundle .single_add_to_cart_button:hover {
  transform: translateY(-1px) !important;
  background: linear-gradient(180deg, #eef1f4 0%, #d8dde2 50%, #c0c5cd 100%) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85),
              inset 0 -1px 0 rgba(96,104,118,.28),
              0 7px 16px -10px rgba(0,0,0,.5) !important;
  filter: none !important;
}
.single-product .product-type-bundle .single_add_to_cart_button:active {
  transform: translateY(0) !important;
  box-shadow: inset 0 1px 2px rgba(96,104,118,.4) !important;
}

/* Buy Now — quiet ghost, hairline; subtle lift on hover (no chrome-fill flip) */
.single-product .product-type-bundle .sl-buy-now {
  background: transparent !important;
  color: var(--sl-text-mut) !important;
  border: 1px solid var(--sl-line-2) !important;
  box-shadow: none !important;
}
.single-product .product-type-bundle .sl-buy-now:hover {
  transform: translateY(-1px) !important;
  background: rgba(255,255,255,.04) !important;
  color: var(--sl-silver-hi) !important;
  border-color: rgba(255,255,255,.28) !important;
  box-shadow: none !important;
}
.single-product .product-type-bundle .sl-buy-now:active { transform: translateY(0) !important; }

/* CTA spacing: qty stepper → ADD TO CART, and ADD TO CART → BUY NOW (they sit in nested PB
   containers, so margins collapse to 0 — force the gaps explicitly). */
.single-product .product-type-bundle form.cart { gap: 10px; }
.single-product .product-type-bundle .bundle_button { display: flex; flex-direction: column; gap: 18px; }
.single-product .product-type-bundle .single_add_to_cart_button { margin-top: 4px !important; }
.single-product .product-type-bundle .sl-buy-now { margin-top: 16px !important; }

/* Safety net: never show the junk "Additional information" attribute table on the
   bundle (the PHP filter removes it; this also covers any stale page cache). */
.single-product .product-type-bundle .woocommerce-Tabs-panel--additional_information,
.single-product .product-type-bundle #tab-additional_information { display: none !important; }

/* ============================================================
   My Account — login / register / dashboard polish
   ============================================================ */
.woocommerce-account .sl-prose { max-width: 1080px !important; }
.woocommerce-account #customer_login { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; }
/* WooCommerce's .col2-set clearfix ::before/::after become phantom grid items and shove Login into col 2 / Register onto row 2. Remove them. */
.woocommerce-account #customer_login::before,
.woocommerce-account #customer_login::after { content: none !important; display: none !important; }
.woocommerce-account #customer_login > .col-1,
.woocommerce-account #customer_login > .col-2,
.woocommerce-account #customer_login > div {
  width: 100% !important; float: none !important; margin: 0 !important;
  background: var(--sl-bg-elev); border: 1px solid var(--sl-line); border-radius: var(--sl-radius); padding: 30px 28px;
}
.woocommerce-account h2 { font-family: var(--sl-font-display); font-size: 19px; font-weight: 600; letter-spacing: .01em; margin: 0 0 22px; color: var(--sl-text); }
.woocommerce-account .woocommerce-form-row label,
.woocommerce-account .woocommerce-form__label { display: block; font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--sl-text-mut); margin: 0 0 8px; }
.woocommerce-account form .form-row { margin: 0 0 18px; }
.woocommerce-account input.input-text,
.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"] {
  width: 100%; background: var(--sl-surface); border: 1px solid rgba(255,255,255,.18); color: var(--sl-text);
  border-radius: 10px; padding: 13px 14px; font-family: var(--sl-font-body); font-size: 15px;
}
.woocommerce-account input.input-text:focus,
.woocommerce-account input[type="password"]:focus { border-color: var(--sl-silver); outline: none; }
/* password-visibility toggle (was rendering as a stray glyph) */
.woocommerce-account .password-input,
.woocommerce-account .woocommerce-password-hint { position: relative; display: block; }
.woocommerce-account .show-password-input { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); cursor: pointer; color: var(--sl-text-dim); }
.woocommerce-account .show-password-input::after { content: "Show"; font-family: var(--sl-font-display); font-size: 11px; letter-spacing: .04em; text-transform: uppercase; }
.woocommerce-account .show-password-input.display-password::after { content: "Hide"; }
.woocommerce-account .woocommerce-form-login__rememberme,
.woocommerce-account .woocommerce-form-register__rememberme { display: inline-flex; align-items: center; gap: 8px; color: var(--sl-text-mut); font-size: 14px; margin: 4px 0 20px; }
.woocommerce-account .woocommerce-form-login__rememberme input,
.woocommerce-account form .form-row input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--sl-silver); }
.woocommerce-account .woocommerce-form-login__submit,
.woocommerce-account .woocommerce-form-register__submit,
.woocommerce-account .woocommerce-Button { width: 100%; margin: 6px 0 0 !important; padding: 14px 22px !important; }
.woocommerce-account .woocommerce-LostPassword { margin: 16px 0 0; }
.woocommerce-account .woocommerce-LostPassword a { color: var(--sl-text-mut); font-size: 14px; }
.woocommerce-account .woocommerce-LostPassword a:hover { color: var(--sl-silver-hi); }
.woocommerce-account em { color: var(--sl-text-dim); font-size: 13px; font-style: normal; }

/* Logged-in account: Signal-style layout — bordered nav card (plain links + left-accent active)
   and a bordered content card, in Storm's dark palette. */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) { display: grid; grid-template-columns: 248px 1fr; gap: 28px; align-items: start; }
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content { width: auto !important; float: none !important; margin: 0 !important; }
/* this theme outputs content before nav — pin nav to the narrow left column, content to the wide right */
.woocommerce-account .woocommerce-MyAccount-navigation { grid-column: 1; grid-row: 1; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: var(--sl-bg-elev); padding: 8px 0; }
.woocommerce-account .woocommerce-MyAccount-content { grid-column: 2; grid-row: 1; border: 1px solid var(--sl-line); border-radius: var(--sl-radius); background: var(--sl-bg-elev); padding: clamp(24px,3vw,38px); color: var(--sl-text-mut); }
.woocommerce-account .woocommerce-MyAccount-content a { color: var(--sl-silver-hi); }
/* Account utility "buttons" (Browse products, Add/Edit address) → plain underlined links, not boxy pills */
.woocommerce-account .woocommerce-MyAccount-content a.button {
  background: transparent !important; border: 0 !important; box-shadow: none !important; filter: none !important;
  color: var(--sl-silver-hi) !important; padding: 0 !important; min-height: 0 !important; width: auto !important;
  font-family: var(--sl-font-display); font-size: 15px; font-weight: 500; letter-spacing: 0; text-transform: none;
  text-decoration: underline; text-underline-offset: 3px;
}
.woocommerce-account .woocommerce-MyAccount-content a.button:hover { background: transparent !important; color: var(--sl-silver) !important; transform: none !important; }
/* "No downloads available yet." style notice — clean row, no heavy box */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-info { display: flex; align-items: center; justify-content: space-between; gap: 18px; background: transparent; border: 0; border-bottom: 1px solid var(--sl-line); border-radius: 0; padding: 0 0 18px; color: var(--sl-text); font-size: 15px; }
/* Addresses — left-aligned, clean two columns (Signal-style) */
.woocommerce-account .woocommerce-Addresses { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin: 6px 0 0; }
.woocommerce-account .woocommerce-Addresses::before, .woocommerce-account .woocommerce-Addresses::after { content: none !important; display: none !important; }
.woocommerce-account .woocommerce-Address { text-align: left; float: none; width: auto; }
.woocommerce-account .woocommerce-Address .woocommerce-Address-title { display: flex; flex-direction: column; align-items: flex-start; gap: 8px; margin: 0 0 12px; border: 0; }
.woocommerce-account .woocommerce-Address-title h3 { font-family: var(--sl-font-display); font-size: 19px; font-weight: 600; color: var(--sl-text); margin: 0; }
.woocommerce-account .woocommerce-Address-title a.edit { color: var(--sl-silver-hi); text-decoration: underline; text-underline-offset: 3px; font-size: 14px; float: none; }
.woocommerce-account .woocommerce-Address address { color: var(--sl-text-mut); font-style: normal; line-height: 1.7; font-size: 15px; margin: 0; }
@media (max-width: 700px) { .woocommerce-account .woocommerce-Addresses { grid-template-columns: 1fr; gap: 28px; } }

.woocommerce-account .woocommerce-MyAccount-navigation ul { display: flex; flex-direction: column; gap: 1px; list-style: none; margin: 0; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li { padding: 0 !important; margin: 0 !important; }
.woocommerce-account .woocommerce-MyAccount-navigation li::before { content: none !important; display: none !important; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 12px 22px; border-left: 2px solid transparent; color: var(--sl-text-mut); font-family: var(--sl-font-display); font-size: 15px; font-weight: 500; letter-spacing: 0; text-transform: none; transition: color .18s var(--sl-ease), border-color .18s var(--sl-ease), background .18s var(--sl-ease); }
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover { color: var(--sl-silver-hi); background: rgba(255,255,255,.03); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { color: var(--sl-silver-hi); font-weight: 600; border-left-color: var(--sl-silver); }
@media (max-width: 820px) { .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) { grid-template-columns: 1fr; gap: 20px; } .woocommerce-account .woocommerce-MyAccount-navigation, .woocommerce-account .woocommerce-MyAccount-content { grid-column: 1; } .woocommerce-account .woocommerce-MyAccount-content { grid-row: 2; } }

/* Password strength meter — readable + on-brand (replaces the unreadable peach default) */
.woocommerce-password-strength { margin-top: 8px; padding: 10px 14px; border-radius: 8px; border: 1px solid; font-family: var(--sl-font-display); font-size: 13px; font-weight: 600; }
.woocommerce-password-strength.short, .woocommerce-password-strength.bad { background: rgba(224,86,78,.1); border-color: rgba(224,86,78,.4); color: #f0a59f; }
.woocommerce-password-strength.good { background: rgba(216,176,96,.1); border-color: rgba(216,176,96,.42); color: #e7cd92; }
.woocommerce-password-strength.strong { background: rgba(96,200,140,.1); border-color: rgba(96,200,140,.42); color: #92ddb0; }
.woocommerce-password-hint { display: block; margin-top: 8px; color: var(--sl-text-mut); font-size: 13px; line-height: 1.6; }

/* Password-change fieldset — clean hairline section, not a raw browser box */
.woocommerce-account fieldset { border: 1px solid var(--sl-line); border-radius: var(--sl-radius); padding: 20px 22px 6px; margin: 26px 0 0; min-width: 0; }
.woocommerce-account fieldset legend { font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--sl-text); padding: 0 8px; margin: 0; }

/* keep account inputs clearly visible */
.woocommerce-account input.input-text,
.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"] { background: var(--sl-surface) !important; border-color: rgba(255,255,255,.2) !important; }

@media (max-width: 720px) {
  .woocommerce-account #customer_login { grid-template-columns: 1fr; }
}

/* ============================================================
   AffiliateWP — registration / login forms + affiliate dashboard
   (was rendering as bare, inconsistent gray/white default inputs)
   ============================================================ */
/* ----- Two-column affiliate page: value panel + form ----- */
/* let the affiliate pages use the full content width (prose is capped for reading) */
.sl-prose:has(.sl-aff-layout) { max-width: none !important; }
.sl-aff-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 460px;
  gap: clamp(40px, 6vw, 88px);
  align-items: start;
}
.affwp-form { max-width: none; width: 100%; }
.sl-aff-register { margin: 22px 0 0; padding-top: 20px; border-top: 1px solid var(--sl-line); text-align: center; color: var(--sl-text-mut); font-size: 14px; }
.sl-aff-register a { color: var(--sl-silver-hi); text-decoration: underline; text-underline-offset: 3px; }
.sl-aff-register a:hover { color: var(--sl-silver); }
.sl-aff-aside { position: sticky; top: 110px; max-width: 520px; }
.sl-aff-aside__title { font-family: var(--sl-font-display); font-size: clamp(28px, 3.2vw, 42px); font-weight: 600; line-height: 1.05; letter-spacing: -.02em; color: var(--sl-text); margin: 0 0 16px; text-wrap: balance; }
.sl-aff-aside__lead { color: var(--sl-text-mut); font-size: 16px; line-height: 1.65; max-width: 46ch; margin: 0 0 28px; }
.sl-aff-benefits { list-style: none; margin: 0 0 30px; padding: 0; }
.sl-aff-benefits li { position: relative; padding: 13px 0 13px 32px; border-bottom: 1px solid var(--sl-line); color: var(--sl-text); font-size: 15px; }
.sl-aff-benefits li:first-child { border-top: 1px solid var(--sl-line); }
.sl-aff-benefits li::before { content: ""; position: absolute; left: 2px; top: 17px; width: 13px; height: 8px; border-left: 1.8px solid var(--sl-silver); border-bottom: 1.8px solid var(--sl-silver); transform: rotate(-45deg); }
/* Beat the global .sl-prose ul li::before round dot (higher specificity) and vertically center the marker on each row. */
.sl-prose ul.sl-aff-benefits li::before {
  left: 2px; top: 50%; width: 12px; height: 7px;
  background: none; border-radius: 0;
  border-left: 1.8px solid var(--sl-silver); border-bottom: 1.8px solid var(--sl-silver);
  transform: translateY(-72%) rotate(-45deg);
}
.sl-aff-tiers { display: grid; grid-template-columns: repeat(3, 1fr); border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius); overflow: hidden; }
.sl-aff-tier { padding: 18px 12px; text-align: center; }
.sl-aff-tier + .sl-aff-tier { border-left: 1px solid var(--sl-line); }
.sl-aff-tier__rate { display: block; font-family: var(--sl-font-display); font-size: 26px; font-weight: 700; color: var(--sl-silver-hi); line-height: 1; }
.sl-aff-tier__label { display: block; font-size: 11px; color: var(--sl-text-dim); text-transform: uppercase; letter-spacing: .07em; margin-top: 7px; line-height: 1.3; }

@media (max-width: 860px) {
  .sl-aff-layout { grid-template-columns: 1fr; gap: 40px; }
  .sl-aff-aside { position: static; }
}

.affwp-form { max-width: 480px; }
.affwp-form .affwp-wrap, .affwp-form p { margin: 0 0 20px; }
.affwp-form .affwp-wrap:last-of-type { margin-bottom: 0; }
.affwp-field-label,
.affwp-form label { display: block; font-family: var(--sl-font-display); font-size: 13px; font-weight: 500; letter-spacing: .03em; text-transform: uppercase; color: var(--sl-text); margin: 0 0 9px; }

.affwp-form input[type="text"],
.affwp-form input[type="email"],
.affwp-form input[type="password"],
.affwp-form input[type="url"],
.affwp-form input[type="number"],
.affwp-form input[type="tel"],
.affwp-form select,
.affwp-form textarea,
.affwp-field {
  width: 100%; box-sizing: border-box;
  background: var(--sl-surface) !important;
  border: 1px solid var(--sl-line-2) !important;
  color: var(--sl-text) !important;
  border-radius: 11px; padding: 0 16px; min-height: 52px;
  font-family: var(--sl-font-body); font-size: 16px;
  box-shadow: none !important;
  transition: border-color .2s var(--sl-ease), box-shadow .2s var(--sl-ease);
}
.affwp-form textarea { min-height: 130px; padding: 14px 16px; resize: vertical; line-height: 1.6; }
.affwp-form input:hover, .affwp-form textarea:hover, .affwp-form select:hover { border-color: rgba(255,255,255,.26) !important; }
.affwp-form input:focus, .affwp-form textarea:focus, .affwp-form select:focus { border-color: var(--sl-silver) !important; box-shadow: 0 0 0 3px rgba(200,205,212,.12) !important; outline: none; }
.affwp-form input::placeholder, .affwp-form textarea::placeholder { color: var(--sl-text-dim); }
/* prefilled read-only fields (name / username / email) — clearly readable, marked inactive */
.affwp-form input[readonly], .affwp-form input:disabled {
  background: rgba(255,255,255,.03) !important; color: var(--sl-text-mut) !important; cursor: not-allowed; border-style: dashed !important;
}
.affwp-form .description, .affwp-form .affwp-description, .affwp-form .affwp-field-desc { color: var(--sl-text-dim); font-size: 13px; margin: 6px 0 0; }

/* submit button -> full-width, refined brushed silver */
.affwp-form input.button[type="submit"],
.affwp-form input[type="submit"],
.affwp-form button[type="submit"],
.affwp-form .button {
  display: flex; align-items: center; justify-content: center; width: 100%; min-height: 54px;
  background: var(--sl-flat) !important; color: var(--sl-flat-fg) !important;
  border: 1px solid var(--sl-flat-border) !important; box-shadow: var(--sl-flat-shadow) !important;
  border-radius: 12px; padding: 0 28px !important; margin: 26px 0 0;
  font-family: var(--sl-font-display); font-weight: 600; font-size: 13px; letter-spacing: .14em; text-transform: uppercase;
  cursor: pointer; -webkit-appearance: none; appearance: none;
  transition: transform .22s var(--sl-ease), box-shadow .22s var(--sl-ease), background .22s var(--sl-ease);
}
.affwp-form input[type="submit"]:hover, .affwp-form .button:hover { transform: translateY(-1px); background: var(--sl-flat-hover) !important; box-shadow: inset 0 1px 0 rgba(255,255,255,.85), inset 0 -1px 0 rgba(96,104,118,.28), 0 7px 16px -10px rgba(0,0,0,.5) !important; }
.affwp-form input[type="submit"]:active, .affwp-form .button:active { transform: translateY(0); }

/* remember-me / checkboxes */
.affwp-form input[type="checkbox"], .affwp-form input[type="radio"] { width: 16px; height: 16px; accent-color: var(--sl-silver); margin-right: 8px; }

/* notices / errors */
#affwp-notification, .affwp-notice, .affwp-notices, .affwp-errors, p.affwp-message {
  background: var(--sl-surface); border: 1px solid var(--sl-line-2); border-radius: 10px;
  padding: 14px 18px; color: var(--sl-text-mut); margin: 0 0 18px; font-size: 14px;
}
.affwp-errors { border-color: rgba(190,70,70,.5); color: #e9b7b7; }

/* "Log in to manage your affiliate account" / register links */
.affwp-form a, .affiliate-area a, .affwp-login-form a { color: var(--sl-silver-hi); }

/* ---- Affiliate dashboard / area (tabs + tables) ---- */
ul.affwp-tab-nav { display: flex; flex-wrap: wrap; gap: 8px; list-style: none; margin: 0 0 28px; padding: 0 0 18px; border-bottom: 1px solid var(--sl-line); }
ul.affwp-tab-nav li { margin: 0; }
ul.affwp-tab-nav li a { display: inline-block; padding: 9px 16px; border: 1px solid var(--sl-line-2); border-radius: var(--sl-radius-pill); color: var(--sl-text-mut); font-family: var(--sl-font-display); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; transition: color .2s var(--sl-ease), border-color .2s var(--sl-ease); }
ul.affwp-tab-nav li.active a, ul.affwp-tab-nav li a:hover { color: var(--sl-silver-hi); border-color: var(--sl-silver); }

.affwp-dashboard table, table.affwp-table, .affiliate-dashboard table {
  width: 100%; border: 1px solid var(--sl-line); border-radius: var(--sl-radius);
  border-collapse: separate; border-spacing: 0; overflow: hidden; background: var(--sl-bg-elev); margin: 0 0 24px;
}
.affwp-dashboard th, table.affwp-table th, .affiliate-dashboard th {
  background: transparent; color: var(--sl-text-mut); font-family: var(--sl-font-display);
  font-size: 11px; letter-spacing: .12em; text-transform: uppercase; padding: 14px; text-align: left; border-bottom: 1px solid var(--sl-line);
}
.affwp-dashboard td, table.affwp-table td, .affiliate-dashboard td { padding: 14px; border-top: 1px solid var(--sl-line); color: var(--sl-text-mut); }

/* referral URL generator + stat boxes */
.affwp-graph-controls, .affwp-referral-url-wrapper input { background: var(--sl-surface) !important; }
