/*
Theme Name: AscendBioLabs
Theme URI: https://ascendbiolabs.local
Description: Pixel-coded research-peptides storefront. Standalone WordPress theme with WooCommerce (via hooks) and a full Customizer color system — recolor the entire site live from Appearance ▸ Customize ▸ AscendBioLabs Colors.
Author: Codewyse
Author URI: https://codewyse.io
Version: 2.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: ascendbiolabs
Tags: woocommerce, ecommerce, custom-colors, full-width-template
*/

/* =========================================================================
   DESIGN TOKENS — overridden live by the Customizer (inc/customizer.php)
   ========================================================================= */
:root {
  --abl-primary:        #202c44;
  --abl-primary-hover:  #161e2e;
  --abl-accent:         #6366F1;
  --abl-secondary:      #1E1B4B;
  --abl-text:           #0F172A;
  --abl-text-muted:     #6B7280;
  --abl-bg:             #FFFFFF;
  --abl-bg-soft:        #F8F9FC;
  --abl-bg-alt:         #F1F0FB;
  --abl-dark:           #0B0F1A;
  --abl-border:         #E7E8EE;
  --abl-success:        #16A34A;

  --abl-font:        "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --abl-font-serif:  "Fraunces", "Playfair Display", Georgia, serif;

  --abl-radius:      14px;
  --abl-radius-sm:   10px;
  --abl-radius-pill: 999px;
  --abl-shadow-sm:   0 1px 2px rgba(16,24,40,.05);
  --abl-shadow:      0 4px 20px rgba(16,24,40,.08);
  --abl-shadow-lg:   0 24px 60px rgba(16,24,40,.18);

  --abl-container:   1200px;
  --abl-topbar-h:    38px;
  --abl-header-h:    72px;
}

/* =========================================================================
   RESET / BASE
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: var(--abl-font); color: var(--abl-text);
  background: var(--abl-bg); line-height: 1.6; -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--abl-primary); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--abl-primary-hover); }
h1,h2,h3,h4,h5,h6 { margin: 0; font-weight: 700; letter-spacing: -.02em; color: var(--abl-text); }
p { margin: 0 0 1em; }
ul { margin: 0; padding: 0; }
button { font-family: inherit; }

.abl-container { max-width: var(--abl-container); margin-inline: auto; padding-inline: 24px; }
.abl-narrow { max-width: 820px; margin-inline: auto; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.abl-center { text-align: center; }

/* =========================================================================
   BUTTONS
   ========================================================================= */
.abl-btn,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce a.button.alt, .woocommerce button.button.alt {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--abl-primary); color: #fff !important;
  font-weight: 600; font-size: 15px; line-height: 1;
  padding: 14px 24px; border: 0; border-radius: var(--abl-radius-pill);
  cursor: pointer; transition: background .18s ease, transform .18s ease, box-shadow .18s ease;
  text-decoration: none;
}
.abl-btn:hover,
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce a.button.alt:hover {
  background: var(--abl-primary-hover); color: #fff !important; transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(32,44,68,.25);
}
.abl-btn--ghost { background: transparent; color: var(--abl-primary) !important; border: 1.5px solid var(--abl-border); }
.abl-btn--ghost:hover { background: var(--abl-bg-soft); color: var(--abl-primary) !important; box-shadow: none; transform: none; }
.abl-btn--light { background: #fff; color: var(--abl-primary) !important; }
.abl-btn--block { width: 100%; }
.abl-btn--lg { padding: 16px 30px; font-size: 16px; }
.abl-btn--sm { padding: 9px 18px; font-size: 14px; }

/* =========================================================================
   SECTION HELPERS
   ========================================================================= */
.abl-section { padding: 84px 0; }
.abl-section--alt  { background: var(--abl-bg-alt); }
.abl-section--soft { background: var(--abl-bg-soft); }
.abl-section--dark { background: var(--abl-dark); color: #fff; }
.abl-eyebrow { font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--abl-primary); display: inline-flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.abl-eyebrow::before { content: ""; width: 24px; height: 1px; background: currentColor; opacity: .55; }
.abl-sec-head .abl-eyebrow, .abl-center .abl-eyebrow { justify-content: center; }
.abl-sec-head .abl-eyebrow::before { display: none; }
.abl-h1 { font-size: clamp(40px, 6vw, 62px); line-height: 1.03; }
.abl-h2 { font-size: clamp(28px, 4vw, 40px); line-height: 1.1; }
.abl-lead { font-size: 18px; color: var(--abl-text-muted); }
.abl-sec-head { max-width: 640px; margin: 0 auto 48px; text-align: center; }
.abl-prodhead { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; flex-wrap: wrap; margin-bottom: 40px; }
.abl-prodhead h2 { margin-top: 10px; }
.abl-sec-head p { color: var(--abl-text-muted); font-size: 17px; margin: 12px 0 0; }
.abl-accent-text { color: var(--abl-primary); }

.abl-badge { display:inline-flex; align-items:center; gap:6px; font-size: 11px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; padding: 5px 11px; border-radius: 999px; background: rgba(32,44,68,.08); color: var(--abl-primary); }
.abl-badge--green { background: rgba(22,163,74,.1); color: var(--abl-success); }

/* =========================================================================
   TOP ANNOUNCEMENT BAR + TRUST BAR
   ========================================================================= */
.abl-topbar {
  background: var(--abl-primary); color: #fff; font-size: 12px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase; text-align: center;
  padding: 0 16px; min-height: var(--abl-topbar-h); display: flex; align-items: center; justify-content: center;
}
.abl-topbar .abl-code { background: rgba(255,255,255,.2); padding: 2px 8px; border-radius: 6px; margin: 0 6px; }
.abl-trustbar { background: var(--abl-primary-hover); overflow: hidden; border-top: 1px solid rgba(255,255,255,.12); }
.abl-trustbar__track { display: flex; gap: 42px; white-space: nowrap; padding: 11px 0; width: max-content; animation: abl-marquee 40s linear infinite; }
.abl-trustbar__item { font-size: 12px; font-weight: 600; letter-spacing: .01em; color: rgba(255,255,255,.92); display:inline-flex; align-items:center; gap:9px; }
.abl-trustbar__item svg { color: var(--abl-accent); flex:0 0 auto; }
@keyframes abl-marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* =========================================================================
   HEADER
   ========================================================================= */
.abl-header { background: var(--abl-bg); border-bottom: 1px solid var(--abl-border); position: sticky; top: 0; z-index: 60; }
.abl-header__inner { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px; height: var(--abl-header-h); }
.abl-header__brand { justify-self: start; }
.abl-logo { font-family: var(--abl-font-serif); font-size: 27px; font-weight: 600; color: var(--abl-secondary) !important; display:inline-flex; align-items:center; gap:4px; letter-spacing:-.01em; }
.abl-logo img { height: 34px; width:auto; }
.abl-logo__mark { flex:0 0 auto; margin-top:-8px; }
.abl-logo__text { line-height: 1; }
.abl-footer__brand .abl-logo, .abl-account__aside .abl-logo, .abl-authheader .abl-logo { color:#fff !important; }
.abl-nav { display: flex; gap: 30px; list-style: none; margin: 0; padding: 0; justify-content: center; }
.abl-nav a { color: var(--abl-text); font-size: 15px; font-weight: 500; }
.abl-nav a:hover, .abl-nav .current-menu-item > a { color: var(--abl-primary); }
.abl-header__actions { justify-self: end; display: flex; align-items: center; gap: 20px; }
.abl-account-link { color: var(--abl-text); font-size: 15px; font-weight: 500; display: inline-flex; align-items: center; gap: 7px; }
.abl-account-link:hover { color: var(--abl-primary); }
.abl-iconbtn { position: relative; background: none; border: 0; cursor: pointer; color: var(--abl-text); display:inline-flex; padding:6px; }
.abl-iconbtn:hover { color: var(--abl-primary); }
.abl-cart-count { position: absolute; top: -3px; right: -5px; background: var(--abl-primary); color:#fff; font-size: 10px; font-weight: 700; min-width: 17px; height:17px; border-radius: 999px; display: flex; align-items:center; justify-content:center; padding: 0 4px; }
.abl-burger { display:none; background:none; border:0; cursor:pointer; color:var(--abl-text); padding:6px; }

/* =========================================================================
   HERO
   ========================================================================= */
.abl-hero { background: #fff; padding: 72px 0 0; overflow: hidden; }
.abl-hero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px; align-items: center; }
.abl-hero__eyebrow { display:inline-flex; align-items:center; gap:9px; font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--abl-text); background: #fff; border: 1px solid var(--abl-border); border-radius: 999px; padding: 8px 16px; margin-bottom: 24px; box-shadow: var(--abl-shadow-sm); }
.abl-hero__eyebrow::before { content:""; width:7px; height:7px; border-radius:50%; background: var(--abl-primary); }
.abl-hero h1 { margin: 0; font-size: clamp(42px, 5.2vw, 74px); line-height: 1.04; letter-spacing: -.03em; }
.abl-hero h1 .l2 { color: var(--abl-primary); display: block; }
.abl-hero p.abl-lead { margin: 26px 0 32px; max-width: 460px; }
.abl-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.abl-hero__note { margin-top: 22px; font-size: 13px; color: var(--abl-text-muted); display:flex; align-items:center; gap:7px; }
.abl-hero__media { position: relative; }
.abl-herocard { background: #0b0f1a center/cover no-repeat; border-radius: 22px; box-shadow: var(--abl-shadow-lg); aspect-ratio: 5/5.6; max-width: 560px; margin-left:auto; position:relative; overflow:hidden; }
.abl-herocard__cap { position:absolute; bottom:0; left:0; right:0; padding: 60px 22px 22px; text-align:center; color:rgba(255,255,255,.8); font-size: 11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; background: linear-gradient(to top, rgba(5,8,15,.85), transparent); }
/* Browse-by-category pill bar (between hero and restocked strip) */
.abl-browsebar-sec { background: var(--abl-bg-soft); border-top: 1px solid var(--abl-border); border-bottom: 1px solid var(--abl-border); padding: 26px 0; margin-top: 64px; }
.abl-browsebar { display: flex; align-items: center; gap: 20px; }
.abl-browsebar__label { flex: 0 0 auto; font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--abl-text-muted); }
.abl-browsebar__pills { display: flex; gap: 12px; overflow-x: auto; scrollbar-width: none; }
.abl-browsebar__pills::-webkit-scrollbar { display: none; }
.abl-browse-pill { flex: 0 0 auto; font-size: 13px; font-weight: 600; color: var(--abl-text); background: #fff; border: 1px solid var(--abl-border); border-radius: 999px; padding: 9px 17px; white-space: nowrap; transition: border-color .15s ease, color .15s ease; }
.abl-browse-pill:hover { border-color: var(--abl-primary); color: var(--abl-primary); }

/* Recently-restocked strip section */
.abl-restock { padding: 48px 0 72px; }
.abl-restock .abl-stripcap { margin-top: 28px; }

/* product thumbnail strip under hero */
.abl-hero__strip { margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--abl-border); }
.abl-striphead { display:flex; justify-content:space-between; align-items:center; margin-bottom: 18px; }
.abl-striphead span { font-size: 11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color: var(--abl-text-muted); }
.abl-striphead a { font-size: 11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color: var(--abl-primary); }
/* Auto-scrolling marquee. Symmetric vertical padding leaves room for the pop
   (auto-centred + hover) so it isn't clipped; the mask only fades the edges. */
.abl-strip { overflow: hidden; padding: 52px 0; -webkit-mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent); }
.abl-strip__track { display: flex; gap: 16px; width: max-content; animation: abl-marquee 36s linear infinite; }
.abl-strip:hover .abl-strip__track { animation-play-state: paused; }
@media (prefers-reduced-motion: reduce) { .abl-strip__track { animation: none; } .abl-strip { overflow-x: auto; } }
.abl-strip__item { flex: 0 0 auto; width: 96px; transition: transform .4s ease, box-shadow .4s ease; transform-origin: center; will-change: transform; }
.abl-strip__item img { width: 96px; height: 120px; object-fit: contain; background: var(--abl-bg-soft); border: 1px solid var(--abl-border); border-radius: 12px; padding: 8px; transition: border-color .4s ease, box-shadow .4s ease, background .4s ease; }
/* The vial pops bigger as it passes the centre (auto) and on hover. */
.abl-strip__item.is-center,
.abl-strip__item:hover { transform: scale(1.5); position: relative; z-index: 5; }
.abl-strip__item.is-center img,
.abl-strip__item:hover img { border-color: var(--abl-primary); box-shadow: var(--abl-shadow-lg); background: #fff; }
.abl-stripcap { text-align:center; margin-top: 22px; font-size: 11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color: var(--abl-text-muted); }

/* STATS — featured big number + 3 mini stats with full-height dividers */
.abl-statsband { padding: 76px 0; border-top: 1px solid var(--abl-border); border-bottom: 1px solid var(--abl-border); }
.abl-statsrow { display:grid; grid-template-columns: 1fr 1.3fr; gap: 60px; align-items: stretch; }
.abl-stats-feature { display:flex; flex-direction:column; justify-content:center; gap: 20px; }
.abl-stat__num--xl { font-size: clamp(64px, 8vw, 104px); font-weight:700; letter-spacing:-.04em; line-height:.88; }
.abl-stat__num--xl .abl-dot { color: var(--abl-primary); }
.abl-stats-feature p { font-size: 15px; line-height:1.6; color: var(--abl-text-muted); margin:0; max-width:330px; }
.abl-stats-mini { display:grid; grid-template-columns: repeat(3,1fr); border-left: 1px solid var(--abl-border); }
.abl-statm { padding: 8px 30px; display:flex; flex-direction:column; justify-content:center; }
.abl-statm:not(:last-child) { border-right: 1px solid var(--abl-border); }
.abl-statm__n { font-size: clamp(34px, 4vw, 46px); font-weight:700; letter-spacing:-.02em; line-height:1; }
.abl-statm__l { font-size: 11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color: var(--abl-text-muted); margin-top:12px; line-height:1.4; }
@media (max-width: 860px) {
  .abl-statsrow { grid-template-columns: 1fr; gap: 36px; }
  .abl-stats-mini { border-left: 0; }
  .abl-statm { padding: 0 16px; }
}

/* =========================================================================
   STATS
   ========================================================================= */
.abl-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.abl-stat__num { font-size: 48px; font-weight: 700; letter-spacing: -.03em; line-height: 1; }
.abl-stat__label { color: var(--abl-text-muted); font-size: 14px; margin-top: 8px; }

/* =========================================================================
   PRODUCT GRID (cards — used by home + woocommerce)
   ========================================================================= */
.abl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.abl-card {
  background:#fff; border: 1px solid var(--abl-border); border-radius: var(--abl-radius);
  padding: 14px; display:flex; flex-direction:column; transition: box-shadow .2s ease, transform .2s ease;
}
.abl-card:hover { box-shadow: var(--abl-shadow); transform: translateY(-3px); }
.abl-card__media { background: var(--abl-bg-soft); border-radius: var(--abl-radius-sm); aspect-ratio: 1; display:flex; align-items:center; justify-content:center; overflow:hidden; margin-bottom: 14px; }
.abl-card__media img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; }
.abl-card__badge { align-self:flex-start; margin-bottom: 10px; }
.abl-card__title { font-size: 15px; font-weight: 600; margin: 0 0 12px; }
.abl-card__title a { color: var(--abl-text); }
.abl-card__meta { font-size: 13px; color: var(--abl-text-muted); margin-bottom: 12px; }
.abl-card__foot { margin-top: auto; display:flex; flex-direction:column; align-items:flex-start; gap: 6px; }
.abl-card__price { font-weight: 600; font-size: 14px; color: var(--abl-text); }
.abl-card__price del { color: var(--abl-text-muted); font-weight: 400; margin-right: 6px; }
.abl-card__details { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--abl-text-muted); }
.abl-card__details:hover { color: var(--abl-primary); }
.abl-signin-price { font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--abl-text); }
.abl-signin-price:hover { color: var(--abl-primary); }
.abl-card__add { font-size: 13px; font-weight: 600; color: var(--abl-primary); }

/* =========================================================================
   PROBLEM / COMPARISON
   ========================================================================= */
.abl-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; max-width: 940px; margin: 0 auto; align-items: stretch; }
.abl-compare__col { background:#fff; border:1px solid var(--abl-border); border-radius: 16px; padding: 34px; }
.abl-compare__col--us { position: relative; border:1.5px solid var(--abl-primary); box-shadow: 0 18px 55px rgba(32,44,68,.16); }
.abl-compare__label { display:block; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--abl-text-muted); margin-bottom: 16px; }
.abl-compare__label--accent { color: var(--abl-primary); }
.abl-compare__claim { color: #DC2626; text-decoration: line-through; font-weight: 600; font-size: 18px; margin: 0 0 24px; }
.abl-badge--solid { background: var(--abl-primary); color: #fff; }
.abl-compare__col--us .abl-badge--solid { position: absolute; top: -13px; left: 30px; margin: 0; padding: 6px 14px; font-size: 11px; }
.abl-compare__h { font-size: 22px; font-weight: 700; letter-spacing: -.01em; text-transform: none; color: var(--abl-text); margin: 0 0 24px; }
.abl-list { list-style:none; display:flex; flex-direction:column; gap:16px; }
.abl-list li { display:flex; gap:13px; align-items:center; font-size: 15px; }
.abl-listicon { width: 24px; height: 24px; border-radius: 50%; display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.abl-listicon--bad { background: rgba(220,38,38,.1); color: #DC2626; }
.abl-listicon--good { background: rgba(32,44,68,.1); color: var(--abl-primary); }

/* =========================================================================
   BUILT FOR THE LAB
   ========================================================================= */
.abl-split { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: start; }
.abl-featurecard { border: 1px solid var(--abl-border); border-radius: var(--abl-radius); background:#fff; padding: 0 28px; box-shadow: var(--abl-shadow-sm); }
.abl-feature { display:flex; gap:16px; padding: 24px 0; border-bottom: 1px solid var(--abl-border); }
.abl-feature:last-child { border-bottom: 0; }
.abl-feature__ico { flex:0 0 auto; width: 40px; height: 40px; border-radius: 10px; background: rgba(32,44,68,.08); color: var(--abl-primary); display:flex; align-items:center; justify-content:center; }
.abl-feature__body { flex: 1; }
.abl-feature__head { display:flex; justify-content:space-between; align-items:baseline; gap:12px; }
.abl-feature__head h4 { font-size: 16px; }
.abl-feature__n { font-size: 11px; font-weight: 700; letter-spacing: .1em; color: var(--abl-text-muted); }
.abl-feature h4 { font-size: 16px; margin-bottom: 4px; }
.abl-feature p { font-size: 14px; color: var(--abl-text-muted); margin: 6px 0 0; }

/* =========================================================================
   STEPS
   ========================================================================= */
.abl-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.abl-step { background:#fff; border:1px solid var(--abl-border); border-radius: var(--abl-radius); padding: 28px; }
.abl-step__n { font-size: 30px; font-weight: 700; color: var(--abl-primary); margin-bottom: 12px; }
.abl-step h4 { font-size: 18px; margin-bottom: 8px; }
.abl-step p { font-size: 14px; color: var(--abl-text-muted); margin: 0; }

/* Connected-line steps (home) */
.abl-steps2 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; position: relative; }
.abl-steps2::before { content: ""; position: absolute; top: 26px; left: 16.6%; right: 16.6%; height: 1px; background: var(--abl-border); z-index: 0; }
.abl-step2 { text-align: center; position: relative; z-index: 1; }
.abl-step2__circle { width: 52px; height: 52px; margin: 0 auto 18px; border-radius: 50%; background: #fff; border: 1px solid var(--abl-border); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; color: var(--abl-primary); box-shadow: var(--abl-shadow-sm); }
.abl-step2 h4 { font-size: 19px; margin-bottom: 8px; }
.abl-step2 p { font-size: 14px; color: var(--abl-text-muted); margin: 0 auto; max-width: 280px; }

/* Home curated-bundles 2x2 cards */
.abl-bundlegrid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.abl-bundlecard { background:#fff; border:1px solid var(--abl-border); border-radius: var(--abl-radius); padding: 22px; transition: box-shadow .2s ease, transform .2s ease; }
.abl-bundlecard:hover { box-shadow: var(--abl-shadow); transform: translateY(-3px); }
.abl-bundlecard__tags { display:flex; gap:8px; flex-wrap:wrap; margin-bottom: 14px; }
.abl-bundlecard h3 { font-size: 21px; margin-bottom: 18px; }
.abl-bundlecard__vials { display:grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 18px; }
.abl-bvial { text-align:center; border:1px solid var(--abl-border); border-radius: 10px; padding: 10px; }
.abl-bvial img { width:100%; aspect-ratio:4/5; object-fit:contain; background: var(--abl-bg-soft); border-radius: 6px; margin-bottom: 8px; }
.abl-bvial span { font-size: 10px; font-weight: 700; letter-spacing:.04em; text-transform: uppercase; color: var(--abl-text-muted); }
.abl-bundlecard__foot { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--abl-border); padding-top: 16px; }

/* Mobile: bundles become a horizontal swipe carousel — one bundle per view. */
@media (max-width: 600px) {
	.abl-bundlegrid {
		display: flex; grid-template-columns: none; gap: 16px;
		overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
		margin-inline: -24px; padding: 4px 24px 14px; scrollbar-width: none;
	}
	.abl-bundlegrid::-webkit-scrollbar { display: none; }
	.abl-bundlecard { flex: 0 0 86%; scroll-snap-align: center; }
}

/* 2-column FAQ */
.abl-faq2 { display:grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items:start; }
.abl-faq2__right { background:#fff; border:1px solid var(--abl-border); border-radius: var(--abl-radius); padding: 6px 24px; box-shadow: var(--abl-shadow-sm); }
@media (max-width: 768px) {
  .abl-faq2 { grid-template-columns: 1fr; gap: 28px; }
}

/* =========================================================================
   BUNDLES
   ========================================================================= */
.abl-bundles { display:flex; flex-direction:column; gap: 26px; }
.abl-bundle { display: grid; grid-template-columns: 1.7fr 1fr; gap: 24px; background:#fff; border:1px solid var(--abl-border); border-radius: 20px; padding: 28px; box-shadow: var(--abl-shadow-sm); }
.abl-bundle__main { display:flex; flex-direction:column; }
.abl-bundle__featured { align-self:flex-start; display:inline-flex; align-items:center; gap:7px; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--abl-primary); background:rgba(32,44,68,.08); padding:7px 14px; border-radius:var(--abl-radius-pill); margin-bottom:16px; }
.abl-bundle__featured svg { color:var(--abl-primary); }
.abl-bundle__tags { display:flex; gap:8px; flex-wrap:wrap; margin-bottom: 18px; }
.abl-bundle__tag { font-size:11px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--abl-text-muted); border:1px solid var(--abl-border); border-radius:var(--abl-radius-pill); padding:5px 12px; }
.abl-bundle__title { font-size: clamp(32px,3.6vw,48px); line-height:1; font-weight:800; color:var(--abl-primary); margin-bottom: 12px; text-transform: uppercase; letter-spacing:-.01em; }
.abl-bundle__desc { font-size: 16px; color: var(--abl-text-muted); margin-bottom: 22px; }
.abl-bundle__vials { display:grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top:auto; }
.abl-vial { border:1px solid var(--abl-border); border-radius: 14px; overflow:hidden; background:#fff; }
.abl-vial__img { background: #F4F5FA; border-bottom:1px solid var(--abl-border); padding: 16px; }
.abl-vial__img img { width:100%; aspect-ratio:4/5; object-fit:contain; display:block; }
.abl-vial__dose { display:block; padding:12px 14px 0; font-size: 11px; font-weight: 700; letter-spacing:.06em; text-transform: uppercase; color: var(--abl-primary); }
.abl-vial__name { display:block; padding:2px 14px 14px; font-size: 16px; font-weight:700; color:var(--abl-text); }
.abl-bundle__side { background: #F4F4FB; border:1px solid var(--abl-border); border-radius: 16px; padding: 26px; display:flex; flex-direction:column; }
.abl-bundle__pill { align-self:flex-start; display:inline-flex; align-items:center; gap:7px; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#fff; background:var(--abl-primary); padding:8px 15px; border-radius:var(--abl-radius-pill); margin-bottom:22px; }
.abl-bundle__pricelabel { font-size: 11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color: var(--abl-text-muted); }
.abl-bundle__price { font-size: 56px; font-weight: 800; line-height:1; color: var(--abl-primary); margin: 8px 0 16px; }
.abl-bundle__side p { font-size: 14px; color: var(--abl-text-muted); margin-bottom: 20px; line-height:1.6; }
.abl-bundle__cta { margin-top: auto; justify-content:space-between; text-transform:uppercase; letter-spacing:.08em; font-size:13px; background:#fff; padding:16px 22px; }
.abl-bundle__cta:hover { background:#fff; box-shadow: var(--abl-shadow-sm); }

/* =========================================================================
   FAQ ACCORDION
   ========================================================================= */
.abl-faq { max-width: 820px; margin: 0 auto; }
.abl-faq__item { border-bottom: 1px solid var(--abl-border); }
.abl-faq__q { width:100%; background:none; border:0; cursor:pointer; text-align:left; padding: 20px 0; font-size: 15px; font-weight: 600; color: var(--abl-text); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.abl-faq__q::after { content:""; flex:0 0 auto; width:9px; height:9px; border-right:2px solid var(--abl-text-muted); border-bottom:2px solid var(--abl-text-muted); transform: rotate(45deg); transition: transform .2s ease; margin-top:-4px; }
.abl-faq__item.is-open .abl-faq__q::after { transform: rotate(-135deg); margin-top:2px; }
.abl-faq__a { max-height: 0; overflow: hidden; transition: max-height .28s ease; }
.abl-faq__a p { padding: 0 0 22px; color: var(--abl-text-muted); margin: 0; font-size: 15px; }

/* =========================================================================
   CTA
   ========================================================================= */
.abl-cta { text-align:center; }
.abl-cta h2 { color: var(--abl-text); font-size: clamp(30px,4vw,44px); max-width: 720px; margin: 0 auto 20px; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.abl-footer { background: var(--abl-dark); color: rgba(255,255,255,.7); padding: 64px 0 28px; }
.abl-footer a { color: rgba(255,255,255,.7); }
.abl-footer a:hover { color: #fff; }
.abl-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 40px; }
.abl-footer__brand .abl-logo { color:#fff !important; margin-bottom: 14px; }
.abl-footer__brand p { font-size: 14px; max-width: 280px; color: rgba(255,255,255,.6); }
.abl-footer h4 { color: #fff; font-size: 12px; letter-spacing:.1em; text-transform:uppercase; margin: 0 0 16px; }
.abl-footer ul { list-style:none; display:flex; flex-direction:column; gap:10px; font-size: 14px; }
.abl-footer ul.abl-footer__legallinks { font-size: 13px; flex-direction: row; flex-wrap: wrap; column-gap: 22px; row-gap: 10px; max-width: 520px; }
.abl-footer__legal { font-size: 11px; color: rgba(255,255,255,.45); border:1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 16px; margin: 40px 0 24px; line-height:1.6; }
.abl-footer__copy { display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size: 12px; color: rgba(255,255,255,.45); border-top: 1px solid rgba(255,255,255,.1); padding-top: 22px; }

/* =========================================================================
   CART DRAWER + POPUPS
   ========================================================================= */
.abl-drawer-overlay { position: fixed; inset: 0; background: rgba(11,15,26,.45); opacity: 0; visibility: hidden; transition: opacity .25s ease; z-index: 100; }
.abl-drawer-overlay.is-open { opacity: 1; visibility: visible; }
.abl-drawer { position: fixed; top: 0; right: 0; height: 100%; width: 420px; max-width: 92vw; background: #fff; box-shadow: var(--abl-shadow-lg); transform: translateX(100%); transition: transform .3s cubic-bezier(.4,0,.2,1); z-index: 101; display:flex; flex-direction: column; }
.abl-drawer.is-open { transform: translateX(0); }
.abl-drawer__head { display:flex; align-items:center; justify-content:space-between; padding: 20px 24px; border-bottom: 1px solid var(--abl-border); }
.abl-drawer__head h3 { font-size: 16px; }
.abl-drawer__close { background:none; border:0; cursor:pointer; color: var(--abl-text-muted); display:inline-flex; }
.abl-drawer__body { flex: 1; overflow-y: auto; padding: 16px 24px; }
.abl-drawer__empty { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; gap:14px; color: var(--abl-text-muted); text-align:center; }
.abl-drawer__empty svg { color: var(--abl-border); }

/* =========================================================================
 * CART DRAWER (custom)
 * ========================================================================= */
.abl-drawer--cart { width: 440px; }
.abl-drawer__title { display:flex; align-items:center; gap:10px; font-size:18px; font-weight:700; }
.abl-drawer__title svg { color: var(--abl-text); }
.abl-cart-num { display:inline-flex; align-items:center; justify-content:center; min-width:24px; height:24px; padding:0 7px; border-radius:999px; background:var(--abl-bg-alt); color:var(--abl-primary); font-size:13px; font-weight:700; }

.abl-cart { flex:1; display:flex; flex-direction:column; min-height:0; }
.abl-cart__scroll { flex:1; overflow-y:auto; padding:20px 22px; display:flex; flex-direction:column; gap:16px; }
.abl-cart__empty { display:flex; flex-direction:column; align-items:center; justify-content:center; flex:1; gap:14px; color:var(--abl-text-muted); text-align:center; padding:24px; }
.abl-cart__empty svg { color:var(--abl-border); }

/* free shipping bar */
.abl-cart__ship { background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:12px 14px; }
.abl-cart__shiprow { display:flex; align-items:center; gap:9px; font-size:13px; color:var(--abl-text); margin-bottom:10px; }
.abl-cart__shiprow svg { color:var(--abl-primary); flex:none; }
.abl-cart__shiprow strong { font-weight:700; }
.abl-cart__shipbar { height:6px; border-radius:999px; background:var(--abl-border); overflow:hidden; }
.abl-cart__shipbar span { display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,var(--abl-accent),var(--abl-primary)); transition:width .4s ease; }
.abl-cart__ship.is-unlocked .abl-cart__shipbar span { background:var(--abl-success); }

/* line items */
.abl-cart__items { display:flex; flex-direction:column; }
.abl-cart__item { display:grid; grid-template-columns:56px 1fr auto; gap:14px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--abl-border); }
.abl-cart__item:first-child { padding-top:0; }
.abl-cart__thumb { width:56px; height:56px; border-radius:10px; border:1px solid var(--abl-border); background:var(--abl-bg-soft); overflow:hidden; }
.abl-cart__thumb img { width:100%; height:100%; object-fit:contain; }
.abl-cart__name { font-size:15px; font-weight:700; color:var(--abl-text); line-height:1.2; }
.abl-cart__variant { font-size:12px; color:var(--abl-text-muted); margin-top:3px; }
.abl-cart__qty { display:flex; align-items:center; gap:0; margin-top:10px; }
.abl-cart__step { width:28px; height:28px; border:1px solid var(--abl-border); background:#fff; cursor:pointer; font-size:16px; line-height:1; color:var(--abl-text); display:inline-flex; align-items:center; justify-content:center; }
.abl-cart__step:first-of-type { border-radius:8px 0 0 8px; }
.abl-cart__step:hover { background:var(--abl-bg-soft); }
.abl-cart__qtynum { min-width:36px; height:28px; border-top:1px solid var(--abl-border); border-bottom:1px solid var(--abl-border); display:inline-flex; align-items:center; justify-content:center; font-size:14px; font-weight:600; }
.abl-cart__qty .abl-cart__step + .abl-cart__qtynum { border-left:0; }
.abl-cart__qtynum + .abl-cart__step { border-radius:0 8px 8px 0; border-left:0; }
.abl-cart__rm { margin-left:12px; border:0; background:none; cursor:pointer; color:var(--abl-text-muted); display:inline-flex; padding:4px; }
.abl-cart__rm:hover { color:#dc2626; }
.abl-cart__price { font-size:15px; font-weight:700; color:var(--abl-text); white-space:nowrap; }
.abl-cart__free { color:var(--abl-success); font-weight:700; }

/* free BAC water upsell */
.abl-cart__unlock { display:flex; align-items:center; gap:10px; width:100%; text-align:left; border:1px solid rgba(99,102,241,.3); background:linear-gradient(100deg,rgba(99,102,241,.08),rgba(32,44,68,.06)); color:var(--abl-text); border-radius:var(--abl-radius-sm); padding:13px 15px; font-size:13px; cursor:pointer; transition:border-color .15s, box-shadow .15s; }
.abl-cart__unlock:hover { border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.08); }
.abl-cart__unlock svg { color:var(--abl-primary); flex:none; }
.abl-cart__unlock strong { color:var(--abl-primary); font-weight:700; }

/* required BAC water add-on */
.abl-cart__addon { border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:14px; }
.abl-cart__addonhead { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.abl-cart__addontitle { font-size:12px; font-weight:700; letter-spacing:.1em; color:var(--abl-text); }
.abl-cart__req { font-size:11px; font-weight:700; color:#dc2626; background:rgba(220,38,38,.08); padding:3px 9px; border-radius:999px; }
.abl-cart__addonrow { display:grid; grid-template-columns:44px 1fr auto auto; gap:12px; align-items:center; }
.abl-cart__addonimg { width:44px; height:44px; border-radius:8px; border:1px solid var(--abl-border); background:var(--abl-bg-soft); overflow:hidden; }
.abl-cart__addonimg img { width:100%; height:100%; object-fit:contain; }
.abl-cart__addoninfo strong { display:block; font-size:14px; font-weight:700; }
.abl-cart__addoninfo span { display:block; font-size:12px; color:var(--abl-text-muted); }
.abl-cart__addonprice { font-size:14px; font-weight:700; color:var(--abl-text); }
.abl-cart__addbtn { background:var(--abl-primary); color:#fff; border:0; border-radius:8px; padding:8px 16px; font-size:13px; font-weight:600; cursor:pointer; }
.abl-cart__addbtn:hover { background:var(--abl-primary-hover); }

/* pinned footer */
.abl-cart__foot { flex:none; border-top:1px solid var(--abl-border); padding:18px 22px 22px; background:#fff; }
.abl-cart__discount { margin-bottom:16px; }
.abl-cart__discountlabel { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--abl-text); margin-bottom:10px; }
.abl-cart__discountlabel svg { color:var(--abl-text-muted); }
.abl-cart__coupon { display:flex; gap:8px; }
.abl-cart__couponinput { flex:1; height:44px; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:0 14px; font-size:13px; letter-spacing:.04em; text-transform:uppercase; font-family:inherit; }
.abl-cart__couponinput:focus { outline:none; border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.1); }
.abl-cart__couponbtn { background:var(--abl-bg-alt); color:var(--abl-primary); border:0; border-radius:var(--abl-radius-sm); padding:0 20px; font-size:14px; font-weight:600; cursor:pointer; }
.abl-cart__couponbtn:hover { background:#e6e5fb; }
.abl-cart__appliedcoupon { display:inline-flex; align-items:center; gap:8px; margin-top:10px; font-size:12px; font-weight:600; color:var(--abl-success); background:rgba(22,163,74,.08); padding:5px 10px; border-radius:999px; }
.abl-cart__appliedcoupon button { border:0; background:none; cursor:pointer; color:inherit; font-size:15px; line-height:1; }
.abl-cart__subtotal { display:flex; align-items:center; justify-content:space-between; margin-bottom:4px; }
.abl-cart__subtotal span { font-size:18px; font-weight:700; color:var(--abl-text); }
.abl-cart__subtotal strong { font-size:22px; font-weight:800; color:var(--abl-text); }
.abl-cart__taxnote { font-size:13px; color:var(--abl-text-muted); margin:0 0 16px; }
.abl-cart__checkout { display:flex; align-items:center; justify-content:center; width:100%; height:54px; background:var(--abl-secondary); color:#fff !important; border-radius:var(--abl-radius-sm); font-size:16px; font-weight:700; transition:background .15s; }
.abl-cart__checkout:hover { background:var(--abl-dark); }
.abl-drawer.is-loading .abl-cart__scroll { opacity:.55; pointer-events:none; transition:opacity .15s; }

.abl-modal-overlay { position: fixed; inset: 0; background: rgba(11,15,26,.55); backdrop-filter: blur(2px); display:none; align-items:center; justify-content:center; z-index: 120; padding: 20px; }
.abl-modal-overlay.is-open { display:flex; }
.abl-modal { background:#fff; border-radius: 18px; box-shadow: var(--abl-shadow-lg); width: 440px; max-width: 100%; padding: 28px; animation: abl-pop .25s ease; }
@keyframes abl-pop { from{opacity:0; transform: translateY(8px) scale(.98)} to{opacity:1; transform:none} }
.abl-modal__dots { display:flex; gap:6px; justify-content:center; margin-bottom: 18px; }
.abl-modal__dots span { width:7px; height:7px; border-radius:50%; background: var(--abl-border); transition: all .2s ease; }
.abl-modal__dots span.is-active { background: var(--abl-primary); width: 22px; border-radius: 999px; }
.abl-modal h2 { font-size: 22px; margin-bottom: 8px; }
.abl-modal p { color: var(--abl-text-muted); font-size: 14px; margin: 0 0 18px; }
.abl-modal__check { display:flex; gap:10px; align-items:flex-start; background: var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius: 12px; padding: 14px; font-size: 13px; color: var(--abl-text); margin-bottom: 18px; }
.abl-modal__check input { margin-top: 2px; }
.abl-modal__actions { display:flex; gap: 12px; }
.abl-modal__actions .abl-btn { flex:1; }
.abl-modal .abl-btn[disabled] { opacity: .45; cursor: not-allowed; transform:none; box-shadow:none; }
.abl-modal__foot { text-align:center; margin-top: 14px; font-size: 12px; color: var(--abl-text-muted); }

/* =========================================================================
   WOOCOMMERCE (hook-driven layout + skin)
   ========================================================================= */
/* Catalog hero band */
.abl-shop-hero { background: var(--abl-bg-alt); padding: 64px 0 72px; }
.abl-shop-hero__title { margin: 6px 0 14px; }
.abl-shop-hero__sub { max-width: 560px; }
.abl-shop-wrap { padding: 44px 24px 90px; }

/* Shop grid (sidebar + products) */
.woocommerce-page .abl-shop { display: grid; grid-template-columns: 248px 1fr; gap: 44px; align-items: start; }
.abl-shop__sidebar { position: sticky; top: 96px; }

/* Filters */
.abl-filters__h { font-size: 12px; letter-spacing:.12em; text-transform:uppercase; color: var(--abl-text-muted); margin: 0 0 20px; }
.abl-filter { padding: 0 0 22px; margin-bottom: 22px; border-bottom: 1px solid var(--abl-border); }
.abl-filter:last-child { border-bottom: 0; }
.abl-filter h4 { font-size: 12px; letter-spacing:.1em; text-transform:uppercase; color: var(--abl-text); margin: 0 0 14px; }
.abl-filter .woocommerce-product-search { position: relative; display:flex; }
.abl-filter .woocommerce-product-search input[type="search"] { width: 100%; font-family: var(--abl-font); font-size: 14px; padding: 11px 13px; border: 1px solid var(--abl-border); border-radius: 10px; }
.abl-filter .woocommerce-product-search button { position:absolute; right:6px; top:50%; transform:translateY(-50%); background:none; border:0; color:var(--abl-text-muted); font-size:0; padding:8px; cursor:pointer; }
.abl-filter .woocommerce-product-search button::before { content:"⌕"; font-size:18px; }
.abl-filter__list { list-style:none; display:flex; flex-direction:column; gap:13px; margin:0; }
.abl-check { display:flex; align-items:center; gap:10px; font-size:14px; color: var(--abl-text); cursor:pointer; }
.abl-check__box { width:18px; height:18px; border:1.5px solid var(--abl-border); border-radius:5px; flex:0 0 auto; position:relative; transition: all .15s ease; }
.abl-check.is-checked .abl-check__box { background: var(--abl-primary); border-color: var(--abl-primary); }
.abl-check.is-checked .abl-check__box::after { content:""; position:absolute; left:5px; top:1px; width:5px; height:10px; border:solid #fff; border-width:0 2px 2px 0; transform:rotate(45deg); }
.abl-check:hover { color: var(--abl-primary); }
.abl-check input { display:none; }
.abl-check label.abl-check input[disabled] ~ * { opacity:.85; }
/* price slider */
.abl-price__range { width:100%; accent-color: var(--abl-primary); margin: 4px 0 12px; }
.abl-price__vals { display:flex; justify-content:space-between; font-size:13px; font-weight:600; color: var(--abl-text); }
.abl-price__cur { color: var(--abl-primary); }

/* Toolbar */
.abl-shop__toolbar { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom: 24px; }
.abl-shop__count { color: var(--abl-text-muted); font-size: 14px; margin:0; }
.abl-shop__count strong { color: var(--abl-text); }
.woocommerce .woocommerce-ordering { margin:0 !important; }
.woocommerce .woocommerce-ordering select { border: 1px solid var(--abl-border); border-radius: 10px; padding: 10px 14px; font-family: var(--abl-font); font-size:14px; background:#fff; }

/* Product grid + cards */
.woocommerce ul.products { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: 0 !important; padding:0; list-style:none; }
.woocommerce ul.products::before, .woocommerce ul.products::after { display:none; }
.woocommerce ul.products li.product.abl-pcard { width: auto !important; margin: 0 !important; float: none !important; background:#fff; border: 1px solid var(--abl-border); border-radius: var(--abl-radius); overflow:hidden; display:flex; flex-direction:column; text-align:left; transition: box-shadow .2s ease, transform .2s ease; }
.abl-pcard:hover { box-shadow: var(--abl-shadow); transform: translateY(-3px); }
.abl-pcard__media { position:relative; display:block; background: var(--abl-bg-soft); aspect-ratio: 1; overflow:hidden; }
.abl-pcard__media img { width:100%; height:100%; object-fit:contain; margin:0 !important; mix-blend-mode:multiply; }
.abl-pcard__sale { position:absolute; top:14px; left:14px; background: var(--abl-primary); color:#fff; font-size:11px; font-weight:800; letter-spacing:.05em; padding:6px 12px; border-radius:8px; }
.abl-pcard__dose { position:absolute; top:16px; right:16px; color: var(--abl-text-muted); font-size:11px; font-weight:700; letter-spacing:.06em; }
.abl-pcard__body { padding: 18px; display:flex; flex-direction:column; gap:11px; flex:1; }
.abl-pcard__title { font-size:20px; font-weight:700; margin:0; }
.abl-pcard__title a { color: var(--abl-primary); }
.abl-pcard__title a:hover { color: var(--abl-primary-hover); }
.abl-pcard__coa { display:flex; align-items:center; gap:7px; font-size:13px; color: var(--abl-text-muted); }
.abl-pcard__coa svg { color: var(--abl-text-muted); flex:0 0 auto; }
.abl-pcard__rating { display:flex; align-items:center; gap:7px; font-size:13px; color: var(--abl-text-muted); }
.abl-pcard__rating .abl-stars { color:#F59E0B; letter-spacing:1px; }
.abl-pcard__rating .abl-stars .off { color: var(--abl-border); }
.abl-pcard__rating strong { color: var(--abl-text); }
.abl-pcard__reviews { color: var(--abl-text-muted); }
.woocommerce ul.products li.product.abl-pcard .button { margin-top: 6px; width:100%; background:#fff; color: var(--abl-primary) !important; border: 1.5px solid var(--abl-border); text-transform:uppercase; letter-spacing:.05em; font-size:13px; padding:13px 16px; border-radius: var(--abl-radius-pill); }
.woocommerce ul.products li.product.abl-pcard .button:hover { background: var(--abl-primary); color:#fff !important; border-color: var(--abl-primary); box-shadow:none; }
.woocommerce-breadcrumb { color: var(--abl-text-muted); font-size: 13px; margin-bottom: 14px; }

/* single product */
.woocommerce div.product div.images img { border-radius: var(--abl-radius); background: var(--abl-bg-soft); }
.woocommerce div.product .product_title { font-size: 34px; margin-bottom: 10px; }
.woocommerce div.product p.price, .woocommerce div.product span.price { color: var(--abl-text); font-size: 26px; font-weight: 700; }
.woocommerce div.product form.cart .button { padding: 15px 28px; }
.woocommerce .quantity .qty { border: 1px solid var(--abl-border); border-radius: 10px; padding: 12px; }
.woocommerce-tabs ul.tabs li { border-radius: 8px 8px 0 0; }

/* Minimal auth chrome (header/footer) */
.abl-authheader { background:#fff; border-bottom:1px solid var(--abl-border); }
.abl-authheader .abl-container { display:flex; justify-content:center; padding-block:20px; }
.abl-main--auth { background:#fff; }
.abl-authwrap { max-width:1200px; margin-inline:auto; padding:56px 24px 72px; }
.abl-authfooter { background:#fff; border-top:1px solid var(--abl-border); padding:26px 0; }
.abl-authfooter .abl-container { text-align:center; }
.abl-authfooter__note { font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--abl-text-muted); margin:0 0 14px; }
.abl-authfooter__links { list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:20px; }
.abl-authfooter__links a { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--abl-text-muted); }
.abl-authfooter__links a:hover { color:var(--abl-primary); }

/* account / login split */
.abl-account { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: stretch; }
.abl-account__aside { background: linear-gradient(150deg,#171a2e 0%,#0b0f1a 52%,#161b3c 100%); border-radius: 6px; padding: 48px 44px; color:#fff; display:flex; flex-direction:column; min-height: 720px; position:relative; overflow:hidden; }
.abl-account__aside .abl-logo { color:#fff !important; }
.abl-account__brand { margin-bottom: auto; }
.abl-account__asidebody { margin-top: auto; }
.abl-account__eyebrow { color:#8b8df0 !important; margin-bottom:18px; }
.abl-account__eyebrow::before { background:#8b8df0; }
.abl-account__title { color:#fff; font-size: clamp(30px,3.1vw,42px); line-height:1.05; margin: 0 0 18px; }
.abl-account__lead { color: rgba(255,255,255,.62); font-size: 16px; max-width: 420px; margin: 0 0 28px; }
.abl-account__checks { list-style:none; display:flex; flex-direction:column; gap:16px; font-size: 14px; color: rgba(255,255,255,.82); }
.abl-account__checks li { display:flex; gap:12px; align-items:center; }
.abl-account__check { flex:none; width:22px; height:22px; border-radius:50%; border:1.5px solid rgba(139,141,240,.5); color:#8b8df0; display:inline-flex; align-items:center; justify-content:center; }
.abl-account__note { margin-top: 44px; display:flex; align-items:center; gap:10px; font-size:12px; color: rgba(255,255,255,.4); }
.abl-account__note .abl-account__check { width:18px; height:18px; border-color:rgba(255,255,255,.18); color:rgba(255,255,255,.45); }
.abl-account__form { padding: 40px 0; display:flex; align-items:flex-start; }

/* auth form (create account / sign in) */
.abl-auth { width:100%; max-width: 440px; }
.abl-auth__title { font-size: 30px; margin-bottom: 8px; }
.abl-auth__sub { color: var(--abl-text-muted); font-size: 14px; margin-bottom: 28px; }
.abl-auth__form { display:flex; flex-direction:column; gap:18px; }
.abl-field { display:flex; flex-direction:column; gap:7px; margin:0; }
.abl-field label { font-size:14px; font-weight:600; color:var(--abl-text); }
.abl-field input { height:48px; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:0 14px; font-size:15px; font-family:inherit; color:var(--abl-text); transition:border-color .15s, box-shadow .15s; }
.abl-field input:focus { outline:none; border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12); }
.abl-field__hint { font-size:12px; color:var(--abl-text-muted); }
.abl-auth__agree { display:flex; gap:12px; align-items:flex-start; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:14px; font-size:13px; color:var(--abl-text-muted); line-height:1.5; cursor:pointer; }
.abl-auth__agree input { margin-top:2px; width:16px; height:16px; flex:none; accent-color:var(--abl-primary); }
.abl-auth__agree a { text-decoration:underline; color:var(--abl-primary); }
.abl-auth__agree em { display:block; font-style:normal; opacity:.8; margin-top:3px; }
.abl-auth__submit { margin-top:4px; height:52px; border-radius:var(--abl-radius-sm) !important; background:#8b8de8 !important; }
.abl-auth__submit:hover { background:#7376e0 !important; }
.abl-auth__switch { text-align:center; font-size:14px; color:var(--abl-text-muted); margin-top:22px; }
.abl-auth__switch a { font-weight:600; }
.abl-auth__row { display:flex; justify-content:space-between; align-items:center; }
.abl-auth__remember { display:inline-flex; gap:8px; align-items:center; font-size:13px; color:var(--abl-text-muted); cursor:pointer; }
.abl-auth__remember input { accent-color:var(--abl-primary); }
.abl-auth__lost { font-size:13px; }
.abl-auth .woocommerce-form-row, .abl-auth .woocommerce-privacy-policy-text { margin:0; }
/* strip WooCommerce's default bordered box around the login/register forms */
.abl-auth form.register, .abl-auth form.login { border:0 !important; padding:0 !important; margin:0 !important; background:none !important; }
@media (max-width:860px) {
  .abl-account { grid-template-columns:1fr; gap:0; }
  .abl-account__aside { min-height:0; border-radius:0; padding:40px 28px; }
  .abl-account__brand { margin-bottom:32px; }
  .abl-account__form { padding:28px 0 0; }
  .abl-auth { max-width:none; }
}
.abl-gate { max-width: 520px; margin: 80px auto; text-align:center; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1024px) {
  .abl-footer__grid { grid-template-columns: 1fr 1fr 1fr; }
  .abl-bundle { grid-template-columns: 1fr; }
}
@media (max-width: 880px) {
  .abl-nav, .abl-account-link span { display:none; }
  .abl-burger { display:inline-flex; }
  .abl-hero__grid, .abl-split, .abl-account { grid-template-columns: 1fr; }
  .abl-stats { grid-template-columns: 1fr 1fr; gap: 32px; }
  .abl-grid, .abl-steps, .woocommerce ul.products { grid-template-columns: 1fr 1fr; }
  .abl-compare { grid-template-columns: 1fr; }
  .woocommerce-page .abl-shop { grid-template-columns: 1fr; }
  .abl-account__aside { border-radius: 0; }
}
@media (max-width: 560px) {
  .abl-section { padding: 56px 0; }
  .abl-grid, .abl-steps, .abl-stats, .woocommerce ul.products, .abl-footer__grid { grid-template-columns: 1fr; }
  .abl-drawer { width: 100%; }
  .abl-bundle__vials { grid-template-columns: repeat(3,1fr); }
}

/* =========================================================================
   FORMS (affiliate, WooCommerce inputs)
   ========================================================================= */
.abl-form { display:flex; flex-direction:column; gap:16px; }
.abl-form__row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.abl-form label { display:flex; flex-direction:column; gap:7px; font-size:13px; font-weight:600; color:var(--abl-text); }
.abl-form input, .abl-form textarea,
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea,
.woocommerce-account input[type="text"], .woocommerce-account input[type="email"],
.woocommerce-account input[type="password"], .woocommerce .input-text {
  font-family: var(--abl-font); font-size:15px; color:var(--abl-text);
  padding:13px 14px; border:1px solid var(--abl-border); border-radius:10px;
  background:#fff; width:100%; transition:border-color .15s ease, box-shadow .15s ease;
}
.abl-form input:focus, .abl-form textarea:focus, .woocommerce .input-text:focus {
  outline:0; border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12);
}
.abl-form textarea { resize:vertical; }

/* =========================================================================
   ENTRY CONTENT (pages / posts)
   ========================================================================= */
.abl-entry { font-size:17px; color:var(--abl-text); }
.abl-entry h2 { font-size:28px; margin:1.6em 0 .5em; }
.abl-entry h3 { font-size:22px; margin:1.4em 0 .5em; }
.abl-entry p { margin:0 0 1.1em; line-height:1.7; }
.abl-entry a { text-decoration:underline; }
.abl-entry img { border-radius:var(--abl-radius); margin:1.2em 0; }
.abl-entry ul, .abl-entry ol { padding-left:1.3em; margin:0 0 1.1em; }
.abl-entry blockquote { border-left:3px solid var(--abl-primary); padding-left:18px; color:var(--abl-text-muted); margin:1.2em 0; }

/* Pagination */
.pagination, .woocommerce-pagination { display:flex; }
.pagination .nav-links, .woocommerce nav.woocommerce-pagination ul { display:flex; gap:8px; list-style:none; }
.pagination a, .pagination span, .woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  display:inline-flex; align-items:center; justify-content:center; min-width:40px; height:40px; padding:0 12px;
  border:1px solid var(--abl-border); border-radius:10px; color:var(--abl-text); font-weight:600;
}
.pagination .current, .woocommerce nav.woocommerce-pagination ul li span.current { background:var(--abl-primary); color:#fff; border-color:var(--abl-primary); }

/* WooCommerce notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error { border-top-color:var(--abl-primary) !important; border-radius:10px; }
.woocommerce-message::before, .woocommerce-info::before { color:var(--abl-primary) !important; }

/* Mobile nav drawer */
.abl-mobilenav { position: fixed; inset: 0 0 0 auto; width: 280px; max-width: 84vw; background:#fff; box-shadow: var(--abl-shadow-lg); transform: translateX(100%); transition: transform .3s ease; z-index: 101; padding: 80px 24px 24px; }
.abl-mobilenav.is-open { transform: translateX(0); }
.abl-mobilenav ul { list-style:none; display:flex; flex-direction:column; gap:4px; }
.abl-mobilenav a { display:block; padding: 12px 0; font-size: 16px; font-weight: 500; color: var(--abl-text); border-bottom: 1px solid var(--abl-border); }

/* =========================================================================
 * Single product (PDP) — product & bundle detail views
 * ========================================================================= */
.abl-pdp { padding-top: 32px; }
.abl-pdp__crumbs { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--abl-text-muted); margin-bottom:22px; }
.abl-pdp__crumbs a { color:var(--abl-text-muted); }
.abl-pdp__crumbs a:hover { color:var(--abl-primary); }
.abl-pdp__crumbs span[aria-current] { color:var(--abl-text); font-weight:600; }

.abl-pdp__head { margin-bottom:22px; }
.abl-pdp__title { font-size:clamp(32px,4.4vw,46px); line-height:1.05; margin:0 0 12px; }

.abl-pdp__grid { display:grid; grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); gap:48px; align-items:start; }

/* Gallery */
.abl-pdp__gallery { position:sticky; top:96px; }
.abl-pdp__stage { position:relative; background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius:var(--abl-radius); aspect-ratio: 1 / 1.04; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.abl-pdp__mainimg { width:100%; height:100%; object-fit:contain; padding:34px; }
.abl-pdp__badge { position:absolute; top:16px; left:16px; }
.abl-pdp__badge--left { left:16px; right:auto; }
.abl-pdp__badge--right { left:auto; right:16px; background:none; padding:0; font-size:13px; font-weight:700; color:var(--abl-text); }
.abl-pdp__thumbs { display:flex; gap:12px; margin-top:14px; }
.abl-pdp__thumb { width:84px; height:84px; border:1.5px solid var(--abl-border); border-radius:var(--abl-radius-sm); background:var(--abl-bg-soft); padding:6px; cursor:pointer; overflow:hidden; transition:border-color .15s, box-shadow .15s; }
.abl-pdp__thumb img { width:100%; height:100%; object-fit:contain; }
.abl-pdp__thumb.is-active { border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12); }

/* Info column */
.abl-pdp__info > .abl-eyebrow { margin-bottom:10px; }
.abl-pdp__rating { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.abl-stars { color:#F5A524; letter-spacing:2px; font-size:16px; }
.abl-pdp__reviews { font-size:13px; color:var(--abl-text-muted); }

.abl-pdp__dosages, .abl-pdp__purchase { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:18px; }
.abl-pill { padding:9px 18px; border:1.5px solid var(--abl-border); border-radius:var(--abl-radius-pill); background:#fff; font-size:13px; font-weight:600; color:var(--abl-text); cursor:pointer; transition:all .15s; }
.abl-pill:hover { border-color:var(--abl-primary); }
.abl-pill.is-active { background:var(--abl-primary); border-color:var(--abl-primary); color:#fff; }

.abl-pdp__purchase { gap:0; border:1.5px solid var(--abl-border); border-radius:var(--abl-radius-pill); padding:4px; width:max-content; max-width:100%; }
.abl-toggle { display:inline-flex; align-items:center; gap:8px; padding:9px 20px; border:none; border-radius:var(--abl-radius-pill); background:transparent; font-size:14px; font-weight:600; color:var(--abl-text-muted); cursor:pointer; transition:all .15s; }
.abl-toggle.is-active { background:var(--abl-primary); color:#fff; }

.abl-pdp__desc { color:var(--abl-text-muted); line-height:1.7; font-size:15px; margin-bottom:18px; }
.abl-pdp__desc p { margin:0 0 10px; }
.abl-pdp__price { font-family:var(--abl-font-serif); font-size:40px; font-weight:600; color:var(--abl-primary); margin-bottom:20px; }
.abl-pdp__price .abl-signin-price { font-family:var(--abl-font); font-size:16px; }

/* Volume tier cards */
.abl-pdp__tiers { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:18px; }
.abl-pdp__tier { border:1.5px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:12px 10px; text-align:center; cursor:pointer; transition:border-color .15s; }
.abl-pdp__tier:hover { border-color:var(--abl-primary); }
.abl-pdp__tierqty { display:block; font-size:11px; font-weight:700; letter-spacing:.06em; color:var(--abl-text-muted); }
.abl-pdp__tierprice { display:block; font-size:18px; font-weight:700; color:var(--abl-text); margin:4px 0 2px; }
.abl-pdp__tiernote { display:block; font-size:11px; color:var(--abl-text-muted); }

/* Bulk discount grid */
.abl-pdp__bulk { background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:16px; margin-bottom:20px; }
.abl-pdp__bulklabel { display:block; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--abl-text-muted); margin-bottom:12px; }
.abl-pdp__bulkgrid { display:grid; grid-template-columns:repeat(8,1fr); gap:8px; }
.abl-pdp__bulkcell { text-align:center; }
.abl-pdp__bulkcell span { display:block; font-size:13px; font-weight:700; color:var(--abl-text); }
.abl-pdp__bulkcell em { display:block; font-size:12px; font-style:normal; color:var(--abl-text-muted); }

/* Title tag pills */
.abl-pdp__tags { display:flex; gap:8px; flex-wrap:wrap; margin-top:4px; }
.abl-pdp--bundle .abl-pdp__tags { margin-bottom:20px; }
.abl-pdp__tag { font-size:11px; font-weight:600; letter-spacing:.04em; color:var(--abl-text-muted); border:1px solid var(--abl-border); border-radius:999px; padding:5px 12px; white-space:nowrap; }

/* Field labels + dosage pill row */
.abl-pdp__fieldlabel { display:block; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--abl-text-muted); margin-bottom:10px; }
.abl-pdp__pillrow { display:flex; flex-wrap:wrap; gap:10px; }
.abl-pdp__pricerow { margin:4px 0 18px; }

/* Bundle & save deal cards */
.abl-pdp__deals { margin-bottom:20px; }
.abl-pdp__dealgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:10px; }
.abl-pdp__deal { position:relative; display:flex; flex-direction:column; align-items:center; width:100%; border:1.5px solid var(--abl-border); border-radius:var(--abl-radius); padding:24px 12px 16px; text-align:center; background:#fff; cursor:pointer; font:inherit; transition:border-color .15s, box-shadow .15s; }
.abl-pdp__deal:hover { border-color:var(--abl-primary); }
.abl-pdp__deal.is-active { border:2px solid var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12); }
.abl-pdp__deal strong { display:block; font-size:15px; }
.abl-pdp__dealprice { display:block; font-size:14px; color:var(--abl-text-muted); margin-top:4px; }
.abl-pdp__dealprice em { font-style:normal; }
.abl-pdp__dealnote { display:block; font-size:11px; color:var(--abl-primary); font-weight:600; margin-top:4px; }
.abl-pdp__dealtag { position:absolute; top:-9px; left:50%; transform:translateX(-50%); background:var(--abl-secondary); color:#fff; font-size:10px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; padding:3px 11px; border-radius:999px; white-space:nowrap; }
.abl-pdp__dealtag--accent { background:var(--abl-primary); }
/* vial thumbnails inside the deal cards */
.abl-pdp__dealvials { display:flex; flex-wrap:wrap; gap:3px; justify-content:center; margin:6px 0 10px; }
.abl-pdp__dealvials img { width:26px; height:34px; object-fit:contain; background:var(--abl-bg-soft); border-radius:4px; }
.abl-pdp__dealvials--row { gap:2px; }
.abl-pdp__dealvials--row img { width:22px; height:30px; }
.abl-pdp__dealfree { display:block; width:100%; border-top:1px dashed var(--abl-border); margin-top:10px; padding-top:10px; }
.abl-pdp__dealfreehdr { display:block; color:var(--abl-success); font-size:11px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.abl-pdp__dealvials--free { margin:8px 0 4px; }
.abl-pdp__dealfreelbl { display:block; font-size:10px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--abl-text-muted); }
/* wide 10-bottle card: centred stack */
.abl-pdp__deal--wide { padding:24px 18px 18px; }
.abl-pdp__deal--wide .abl-pdp__dealprice { font-size:18px; font-weight:700; color:var(--abl-text); margin-top:6px; }

/* COA Set (bundle) — grid of per-vial certificates inside the media stage */
.abl-pdp__stage--coaset { align-items:stretch; justify-content:stretch; padding:22px; }
.abl-pdp__coaset { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; width:100%; align-content:center; }
.abl-pdp__coacard { background:#fff; border:1px solid var(--abl-border); border-radius:10px; padding:10px; display:flex; flex-direction:column; gap:8px; }
.abl-pdp__coacard img { width:100%; aspect-ratio:3/4; object-fit:contain; background:var(--abl-bg-soft); border-radius:6px; }
.abl-pdp__coacard span { text-align:center; font-size:12px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--abl-text-muted); }
@media (max-width:560px) { .abl-pdp__coaset { grid-template-columns:1fr 1fr; } }

/* Test Results (COA) panel */
.abl-pdp__coastats { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:20px; margin-bottom:16px; }
.abl-pdp__coastat span { display:block; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--abl-text-muted); margin-bottom:6px; }
.abl-pdp__coastat strong { font-size:18px; color:var(--abl-text); }
@media (max-width:560px) { .abl-pdp__coastats { grid-template-columns:1fr; } }

/* Disclaimer */
.abl-pdp__disclaimer { margin-top:16px; font-size:12px; color:var(--abl-text-muted); background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:12px 14px; line-height:1.6; }

/* Buy box (wraps WooCommerce add-to-cart) */
.abl-pdp__buy { margin-bottom:20px; }
.abl-pdp__buy form.cart { display:flex; gap:12px; align-items:stretch; flex-wrap:wrap; }
.abl-pdp__buy .quantity { display:inline-flex; align-items:center; border:1.5px solid var(--abl-border); border-radius:var(--abl-radius-sm); overflow:hidden; }
.abl-pdp__buy .quantity input.qty { width:64px; height:54px; border:none; text-align:center; font-size:16px; font-weight:600; background:#fff; -moz-appearance:textfield; }
.abl-pdp__buy .quantity input.qty::-webkit-outer-spin-button,
.abl-pdp__buy .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.abl-pdp__buy .quantity .abl-qtybtn { width:46px; height:54px; border:0; background:#fff; color:var(--abl-text); font-size:22px; font-weight:400; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .15s, color .15s; }
.abl-pdp__buy .quantity .abl-qtybtn:first-child { border-right:1px solid var(--abl-border); }
.abl-pdp__buy .quantity .abl-qtybtn:last-child { border-left:1px solid var(--abl-border); }
.abl-pdp__buy .quantity .abl-qtybtn:hover { background:var(--abl-bg-soft); color:var(--abl-primary); }
.abl-pdp__buy button.single_add_to_cart_button {
  flex:1 1 auto; min-width:200px; display:inline-flex; align-items:center; justify-content:center; gap:10px;
  background:var(--abl-primary); color:#fff; border:none; border-radius:var(--abl-radius-sm); padding:16px 30px;
  font-size:16px; font-weight:700; cursor:pointer; transition:background .15s, transform .15s;
}
.abl-pdp__buy button.single_add_to_cart_button:hover { background:var(--abl-primary-hover); transform:translateY(-1px); }
.abl-pdp__buy .variations { width:100%; margin-bottom:8px; }
.abl-pdp__buy .variations td, .abl-pdp__buy .variations th { padding:6px 0; }

/* Variable product: dosage is chosen via our pills, so hide the native
   dropdown, the in-form variation price and clear-link; keep qty + button. */
.abl-pdp__buy form.variations_form { display:block; }
.abl-pdp__buy form.variations_form .variations,
.abl-pdp__buy form.variations_form .reset_variations,
.abl-pdp__buy form.variations_form .woocommerce-variation-price,
.abl-pdp__buy form.variations_form .woocommerce-variation-availability { display:none !important; }
.abl-pdp__buy .single_variation_wrap { display:block; }
.abl-pdp__buy .woocommerce-variation-add-to-cart { display:flex; gap:12px; align-items:stretch; flex-wrap:wrap; }
/* Keep the add-to-cart button solid indigo at all times (no washed-out disabled look). */
.abl-pdp__buy button.single_add_to_cart_button,
.abl-pdp__buy button.single_add_to_cart_button:disabled,
.abl-pdp__buy .woocommerce-variation-add-to-cart-disabled button.single_add_to_cart_button {
	opacity:1 !important; background:var(--abl-primary) !important; color:#fff !important; cursor:pointer;
}

/* Trust badges */
.abl-pdp__trust { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:16px; }
.abl-pdp__trustitem { display:flex; align-items:center; gap:10px; }
.abl-pdp__trusticon { display:inline-flex; width:38px; height:38px; align-items:center; justify-content:center; border-radius:50%; background:#fff; border:1px solid var(--abl-border); color:var(--abl-primary); flex:none; }
.abl-pdp__trustitem strong { display:block; font-size:13px; }
.abl-pdp__trustitem em { display:block; font-size:12px; font-style:normal; color:var(--abl-text-muted); }

/* "Inside the bundle" */
.abl-pdp__inside { margin-bottom:20px; }
.abl-pdp__insidelabel { display:block; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--abl-text-muted); margin-bottom:12px; }
.abl-pdp__insidegrid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.abl-pdp__insideitem { border:1.5px solid var(--abl-border); border-radius:var(--abl-radius); padding:12px; text-align:center; transition:border-color .15s, box-shadow .15s; color:var(--abl-text); }
.abl-pdp__insideitem:hover { border-color:var(--abl-primary); box-shadow:var(--abl-shadow-sm); }
.abl-pdp__insideimg { display:block; background:var(--abl-bg-soft); border-radius:var(--abl-radius-sm); padding:8px; margin-bottom:8px; }
.abl-pdp__insideimg img { width:100%; height:96px; object-fit:contain; }
.abl-pdp__insidedose { display:block; font-size:11px; font-weight:700; color:var(--abl-primary); }
.abl-pdp__insideitem strong { display:block; font-size:14px; }

/* Spec sheet + FAQ split sections */
.abl-pdp__split { display:grid; grid-template-columns: minmax(0,.9fr) minmax(0,1.1fr); gap:56px; align-items:start; }
.abl-pdp__splitintro .abl-h2 { margin-bottom:14px; }
.abl-pdp__spectable { border:1px solid var(--abl-border); border-radius:var(--abl-radius); overflow:hidden; background:#fff; }
.abl-pdp__specrow { display:flex; justify-content:space-between; gap:16px; padding:16px 20px; border-bottom:1px solid var(--abl-border); font-size:14px; }
.abl-pdp__specrow:last-child { border-bottom:none; }
.abl-pdp__specrow span { color:var(--abl-text-muted); }
.abl-pdp__specrow strong { color:var(--abl-text); text-align:right; }

.abl-pdp__faq { display:flex; flex-direction:column; gap:0; border-top:1px solid var(--abl-border); }
.abl-pdp__faqitem { border-bottom:1px solid var(--abl-border); }
.abl-pdp__faqitem summary { display:flex; justify-content:space-between; align-items:center; gap:16px; padding:18px 4px; font-size:16px; font-weight:600; cursor:pointer; list-style:none; }
.abl-pdp__faqitem summary::-webkit-details-marker { display:none; }
.abl-pdp__faqicon { font-size:22px; font-weight:400; color:var(--abl-primary); transition:transform .2s; flex:none; }
.abl-pdp__faqitem[open] .abl-pdp__faqicon { transform:rotate(45deg); }
.abl-pdp__faqitem p { padding:0 4px 18px; margin:0; color:var(--abl-text-muted); line-height:1.7; }

/* Related row */
.abl-pdp__related-head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:24px; gap:16px; }
.abl-pdp__viewall { font-weight:600; color:var(--abl-primary); white-space:nowrap; }
.abl-pdp__rail { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }

@media (max-width:1024px) {
  .abl-pdp__grid { grid-template-columns:1fr; gap:32px; }
  .abl-pdp__gallery { position:static; }
  .abl-pdp__split { grid-template-columns:1fr; gap:28px; }
  .abl-pdp__rail { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:768px) {
  .abl-pdp__tiers { grid-template-columns:repeat(2,1fr); }
  .abl-pdp__bulkgrid { grid-template-columns:repeat(4,1fr); }
  .abl-pdp__trust { grid-template-columns:1fr; }
  .abl-pdp__rail { grid-template-columns:repeat(2,1fr); }
  .abl-pdp__buy button.single_add_to_cart_button { min-width:0; }
}

/* =========================================================================
 * Affiliate page — hero image, earnings section
 * ========================================================================= */
.abl-aff-hero { position:relative; background:var(--abl-bg-alt); border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:28px; aspect-ratio:5/4; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.abl-aff-hero img { width:100%; height:100%; object-fit:contain; }
.abl-aff-hero__badge { position:absolute; right:18px; bottom:18px; background:#fff; box-shadow:var(--abl-shadow); border-radius:var(--abl-radius-sm); padding:10px 16px; font-size:22px; font-weight:800; color:var(--abl-primary); }
.abl-aff-hero__badge em { font-size:13px; font-weight:600; font-style:normal; color:var(--abl-text-muted); }

.abl-aff-earn { display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr); gap:48px; align-items:center; }
.abl-aff-card { background:#fff; border:1px solid var(--abl-border); border-radius:var(--abl-radius); box-shadow:var(--abl-shadow); padding:28px 26px; }
.abl-aff-card__label { font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--abl-text-muted); }
.abl-aff-card__num { font-family:var(--abl-font-serif); font-size:52px; font-weight:700; color:var(--abl-primary); line-height:1.05; margin:6px 0 18px; }
.abl-aff-card__num em { font-family:var(--abl-font); font-size:16px; font-weight:600; font-style:normal; color:var(--abl-text-muted); }
.abl-aff-card__row { display:flex; justify-content:space-between; align-items:center; padding:13px 0; border-top:1px solid var(--abl-border); font-size:14px; }
.abl-aff-card__row span { color:var(--abl-text-muted); }
.abl-aff-card__row strong { color:var(--abl-text); }

@media (max-width:900px) {
  .abl-aff-earn { grid-template-columns:1fr; gap:28px; }
}

/* =========================================================================
 * CHECKOUT (two-column, two-step)
 * ========================================================================= */
.abl-checkout-page .abl-shop__single { max-width:none; width:100%; }
.abl-checkout__grid { display:grid; grid-template-columns:minmax(0,1.55fr) minmax(0,1fr); gap:56px; align-items:start; }
.abl-checkout__title { font-size:clamp(26px,3vw,34px); margin-bottom:6px; }
.abl-checkout__sub { color:var(--abl-text-muted); font-size:15px; margin-bottom:28px; }
.abl-checkout__sectiontitle { font-size:18px; margin:0 0 14px; }

/* fields */
.abl-checkout__fields { display:flex; flex-wrap:wrap; gap:18px 16px; margin-bottom:8px; }
.abl-checkout__fields .form-row { flex:0 0 100%; margin:0; padding:0; display:flex; flex-direction:column; }
.abl-checkout__fields .form-row.abl-col { flex:1 1 0; min-width:0; }
.abl-checkout__fields .abl-hiddenfield { display:none !important; }
.abl-checkout__fields label { font-size:14px; font-weight:600; color:var(--abl-text); margin-bottom:7px; }
.abl-checkout__fields label .required { color:#dc2626; border:0; text-decoration:none; }
.abl-checkout__fields label .optional { color:var(--abl-text-muted); font-weight:400; }
.abl-checkout__fields .woocommerce-input-wrapper { display:block; width:100%; }
.abl-checkout__fields input.input-text,
.abl-checkout__fields select { width:100%; height:52px; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:0 15px; font-size:15px; font-family:inherit; color:var(--abl-text); background:#fff; transition:border-color .15s, box-shadow .15s; }
.abl-checkout__fields input.input-text:focus,
.abl-checkout__fields select:focus { outline:none; border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12); }
.abl-checkout__fields select { -webkit-appearance:none; -moz-appearance:none; appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }
.abl-checkout__fields .description { font-size:13px; color:var(--abl-text-muted); margin:7px 0 0; }
.abl-checkout__fields .form-row.woocommerce-invalid input.input-text,
.abl-checkout__fields .form-row.woocommerce-invalid select { border-color:#dc2626; box-shadow:0 0 0 3px rgba(220,38,38,.1); }
/* Neutralise WooCommerce's green "validated" border so pre-filled fields (State) match the rest. */
.abl-checkout__fields .form-row.woocommerce-validated input.input-text,
.abl-checkout__fields .form-row.woocommerce-validated select { border-color:var(--abl-border); box-shadow:none; }
.abl-checkout__fields .form-row.woocommerce-validated input.input-text:focus,
.abl-checkout__fields .form-row.woocommerce-validated select:focus { border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12); }

/* opt-in boxes */
.abl-checkout__optbox { display:flex; gap:12px; align-items:flex-start; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:16px; margin-top:16px; cursor:pointer; font-size:14px; color:var(--abl-text); }
.abl-checkout__optbox input { margin-top:1px; width:18px; height:18px; flex:none; accent-color:var(--abl-primary); }
.abl-checkout__optsplit { display:flex; justify-content:space-between; gap:16px; flex:1; color:var(--abl-text-muted); line-height:1.5; }
.abl-checkout__optsplit strong { color:var(--abl-text); font-weight:600; }
.abl-checkout__optlinks { white-space:nowrap; }
.abl-checkout__optlinks a { color:var(--abl-primary); text-decoration:underline; }

/* continue / back / payment */
.abl-checkout__continue { width:100%; height:56px; margin-top:26px; background:var(--abl-secondary); color:#fff; border:0; border-radius:var(--abl-radius-sm); font-size:16px; font-weight:700; cursor:pointer; transition:background .15s; }
.abl-checkout__continue:hover { background:var(--abl-dark); }
.abl-checkout__back { background:none; border:0; color:var(--abl-text-muted); font-size:14px; font-weight:600; cursor:pointer; padding:0; margin-bottom:18px; }
.abl-checkout__back:hover { color:var(--abl-primary); }
.abl-checkout__delivery { margin-bottom:28px; }
.abl-checkout__nodelivery { font-size:14px; color:var(--abl-text-muted); border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:14px; }
.abl-checkout__payment #payment { background:transparent; border-radius:0; }
.abl-checkout__payment .wc_payment_methods { list-style:none; margin:0 0 18px; padding:0; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); overflow:hidden; }
/* Each method = one row: [radio] [label] with the info box wrapping full-width below.
   (WooCommerce renders the radio as a sibling BEFORE the label, not inside it.) */
.abl-checkout__payment .wc_payment_method { display:flex; flex-wrap:wrap; align-items:center; gap:10px; padding:16px; border-bottom:1px solid var(--abl-border); }
.abl-checkout__payment .wc_payment_method:last-child { border-bottom:0; }
.abl-checkout__payment .wc_payment_method > input[type="radio"] { flex:none; width:18px; height:18px; margin:0; accent-color:var(--abl-primary); cursor:pointer; }
.abl-checkout__payment .wc_payment_method > label { flex:1 1 auto; display:flex; align-items:center; gap:8px; margin:0; font-weight:600; cursor:pointer; }
.abl-checkout__payment .wc_payment_method > label img { max-height:24px; width:auto; }
.abl-checkout__payment .payment_box { flex-basis:100%; background:var(--abl-bg-soft); padding:14px 16px; font-size:13px; color:var(--abl-text-muted); margin:14px -16px -16px; border-top:1px solid var(--abl-border); }
.abl-checkout__payment .payment_box p { margin:0; }
.abl-checkout__payment .payment_box::before { display:none !important; }
.abl-checkout__payment #place_order { width:100%; height:56px; background:var(--abl-secondary); color:#fff !important; border:0; border-radius:var(--abl-radius-sm); font-size:16px; font-weight:700; cursor:pointer; }
.abl-checkout__payment #place_order:hover { background:var(--abl-dark); }
.abl-checkout__payment .woocommerce-terms-and-conditions-wrapper { margin-bottom:16px; font-size:13px; }

/* order summary card */
.abl-checkout__summary { position:sticky; top:96px; }
.abl-checkout__summarycard { border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:24px; box-shadow:var(--abl-shadow-sm); background:#fff; }
.abl-checkout__summarytitle { font-size:18px; margin-bottom:20px; }
.abl-summary__items { display:flex; flex-direction:column; gap:18px; margin-bottom:22px; }
.abl-summary__item { display:grid; grid-template-columns:48px 1fr auto; gap:14px; align-items:start; }
.abl-summary__thumb { width:48px; height:48px; border:1px solid var(--abl-border); border-radius:8px; background:var(--abl-bg-soft); overflow:hidden; }
.abl-summary__thumb img { width:100%; height:100%; object-fit:contain; }
.abl-summary__name { font-size:14px; font-weight:700; color:var(--abl-text); line-height:1.25; }
.abl-summary__variant { font-size:12px; color:var(--abl-text-muted); margin-top:2px; }
.abl-summary__qty { font-size:12px; color:var(--abl-text-muted); margin-top:2px; }
.abl-summary__price { font-size:14px; font-weight:700; color:var(--abl-text); white-space:nowrap; }
.abl-summary__discount { border-top:1px solid var(--abl-border); padding-top:18px; margin-bottom:6px; }
.abl-summary__discountlabel { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:600; margin-bottom:10px; }
.abl-summary__discountlabel svg { color:var(--abl-text-muted); }
.abl-summary__totals { border-top:1px solid var(--abl-border); padding-top:18px; }
.abl-summary__row { display:flex; align-items:center; justify-content:space-between; font-size:14px; color:var(--abl-text); margin-bottom:12px; }
.abl-summary__row span:first-child { color:var(--abl-text-muted); }
.abl-summary__row--discount span:last-child { color:var(--abl-success); }
.abl-summary__muted { color:var(--abl-text-muted); }
.abl-summary__row--total { border-top:1px solid var(--abl-border); padding-top:16px; margin-top:4px; margin-bottom:0; }
.abl-summary__row--total span { font-size:18px; font-weight:800; color:var(--abl-text); }
.abl-summary__row--total span:first-child { color:var(--abl-text); }

@media (max-width:1024px) {
  .abl-checkout__grid { grid-template-columns:1fr; gap:36px; }
  .abl-checkout__summary { position:static; order:-1; }
}
@media (max-width:560px) {
  .abl-checkout__fields .form-row.abl-col { flex:0 0 100%; }
  .abl-checkout__optsplit { flex-direction:column; gap:8px; }
}

/* =========================================================================
 * CHECKOUT — progress steps bar + delivery/payment steps
 * ========================================================================= */
.abl-steps { display:flex; align-items:center; max-width:760px; margin:0 auto 48px; }
.abl-steps__node { display:flex; flex-direction:column; align-items:center; gap:8px; background:none; border:0; cursor:default; padding:0; flex:none; }
.abl-steps__node[data-step-node] { cursor:pointer; }
.abl-steps__circle { position:relative; width:34px; height:34px; border-radius:50%; border:2px solid var(--abl-border); background:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; color:var(--abl-text-muted); transition:all .2s; }
.abl-steps__num { display:inline; }
.abl-steps__check { display:none; color:#fff; }
.abl-steps__label { font-size:13px; font-weight:600; color:var(--abl-text-muted); }
.abl-steps__line { flex:1; height:2px; background:var(--abl-border); margin:0 6px; margin-bottom:24px; transition:background .2s; }
.abl-steps__node.is-active .abl-steps__circle { background:var(--abl-primary); border-color:var(--abl-primary); color:#fff; }
.abl-steps__node.is-active .abl-steps__label { color:var(--abl-text); }
.abl-steps__node.is-done .abl-steps__circle { background:var(--abl-bg-alt); border-color:var(--abl-primary); }
.abl-steps__node.is-done .abl-steps__num { display:none; }
.abl-steps__node.is-done .abl-steps__check { display:inline-flex; color:var(--abl-primary); }
.abl-steps__node.is-done .abl-steps__label { color:var(--abl-text); }

/* step nav buttons (Back / Continue) */
.abl-checkout__nav { display:flex; gap:16px; margin-top:28px; }
.abl-checkout__navback { flex:none; min-width:120px; height:56px; padding:0 26px; background:#fff; color:var(--abl-text); border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); font-size:16px; font-weight:600; cursor:pointer; }
.abl-checkout__navback:hover { background:var(--abl-bg-soft); }
.abl-checkout__nav .abl-checkout__continue { flex:1; margin-top:0; }
.abl-checkout__navback--solo { width:100%; margin-top:18px; }

/* "Researchers also bought" upsell */
.abl-checkout__upsell { border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:18px; margin-bottom:18px; }
.abl-checkout__upselltitle { display:block; font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--abl-text-muted); margin-bottom:14px; }
.abl-checkout__upsellrow { display:grid; grid-template-columns:48px 1fr auto; gap:14px; align-items:center; padding:12px; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); margin-bottom:10px; }
.abl-checkout__upsellrow:last-child { margin-bottom:0; }
.abl-checkout__upsellimg { width:48px; height:48px; border:1px solid var(--abl-border); border-radius:8px; background:var(--abl-bg-soft); overflow:hidden; }
.abl-checkout__upsellimg img { width:100%; height:100%; object-fit:contain; }
.abl-checkout__upsellinfo strong { display:block; font-size:14px; font-weight:700; }
.abl-checkout__upsellinfo > span { display:block; font-size:13px; color:var(--abl-text-muted); }
.abl-checkout__upsellinfo .woocommerce-Price-amount { white-space:nowrap; }
.abl-checkout__upsellinfo .woocommerce-Price-currencySymbol { display:inline; }
.abl-checkout__upselladd { background:#fff; color:var(--abl-primary); border:1.5px solid var(--abl-border); border-radius:8px; padding:8px 22px; font-size:14px; font-weight:600; cursor:pointer; }
.abl-checkout__upselladd:hover { border-color:var(--abl-primary); background:var(--abl-bg-soft); }

/* Shipping protection */
.abl-checkout__protection { border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:18px; margin-bottom:14px; transition:border-color .15s, background .15s; }
.abl-checkout__protection.is-on { border-color:var(--abl-primary); background:rgba(32,44,68,.03); }
.abl-checkout__protectionhead { display:grid; grid-template-columns:auto 1fr auto; gap:14px; align-items:start; }
.abl-checkout__protectionicon { color:var(--abl-primary); display:inline-flex; }
.abl-checkout__protectioncopy strong { display:block; font-size:16px; }
.abl-checkout__protectioncopy p { font-size:13px; color:var(--abl-text-muted); margin:4px 0 0; line-height:1.5; }
.abl-checkout__protectioncopy b { color:var(--abl-text); }
.abl-checkout__protectionprice { font-size:16px; font-weight:700; }
.abl-checkout__toggle { display:flex; align-items:center; gap:12px; margin-top:14px; cursor:pointer; }
.abl-checkout__toggle input { position:absolute; opacity:0; width:0; height:0; }
.abl-checkout__toggleswitch { position:relative; width:44px; height:26px; border-radius:999px; background:var(--abl-border); transition:background .2s; flex:none; }
.abl-checkout__toggleswitch::after { content:""; position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; box-shadow:0 1px 3px rgba(0,0,0,.25); transition:transform .2s; }
.abl-checkout__toggle input:checked + .abl-checkout__toggleswitch { background:var(--abl-primary); }
.abl-checkout__toggle input:checked + .abl-checkout__toggleswitch::after { transform:translateX(18px); }
.abl-checkout__togglelabel { font-size:14px; font-weight:600; }

/* delivery / shipping options (native Woo shipping list, restyled) */
.abl-checkout__delivery #shipping_method, .abl-checkout__delivery ul { list-style:none; margin:0; padding:0; }
.abl-checkout__delivery li, .abl-checkout__shipoption { display:flex; align-items:center; gap:12px; border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:18px; margin:0 0 12px; font-size:15px; font-weight:600; cursor:pointer; }
.abl-checkout__delivery li:has(input:checked) { border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.08); }
.abl-checkout__delivery li input[type="radio"] { accent-color:var(--abl-primary); width:18px; height:18px; }
.abl-checkout__delivery li label { display:flex; justify-content:space-between; align-items:center; width:100%; margin:0; font-weight:600; cursor:pointer; }
.abl-checkout__delivery .woocommerce-Price-amount { font-weight:700; }
.abl-checkout__shipoption { justify-content:space-between; }
.abl-checkout__shipoption.is-active { border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.08); }
.abl-checkout__radio { width:18px; height:18px; border-radius:50%; border:5px solid var(--abl-primary); flex:none; }
.abl-checkout__shipname { flex:1; margin-left:0; }

/* step 3 — ship-to / delivery review cards */
.abl-checkout__review { display:flex; flex-direction:column; gap:14px; margin-bottom:26px; }
.abl-checkout__reviewcard { border:1px solid var(--abl-border); border-radius:var(--abl-radius); padding:18px; }
.abl-checkout__reviewhead { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.abl-checkout__reviewhead > span { display:inline-flex; align-items:center; gap:9px; font-size:15px; font-weight:700; }
.abl-checkout__reviewhead svg { color:var(--abl-primary); }
.abl-checkout__edit { display:inline-flex; align-items:center; gap:6px; background:none; border:0; color:var(--abl-primary); font-size:14px; font-weight:600; cursor:pointer; }
.abl-checkout__reviewbody { font-size:14px; color:var(--abl-text-muted); line-height:1.7; }
.abl-checkout__reviewbody strong { color:var(--abl-text); font-weight:600; display:block; }

/* =========================================================================
 * AFFILIATE DASHBOARD
 * ========================================================================= */
.abl-affdash__copyrow { display:flex; gap:10px; }
.abl-affdash__url { flex:1; height:48px; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm); padding:0 14px; font-size:14px; font-family:inherit; color:var(--abl-text); background:var(--abl-bg-soft); }
.abl-affdash__copyrow .abl-btn { flex:none; }
.abl-affdash__stats { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.abl-affdash__statlabel { display:block; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--abl-text-muted); margin-bottom:8px; }
.abl-affdash__statnum { font-size:28px; font-weight:800; color:var(--abl-text); }
.abl-affdash__statnum .woocommerce-Price-amount { font-weight:800; }

/* sidebar layout */
.abl-affdash__layout { display:grid; grid-template-columns:230px minmax(0,1fr); gap:32px; align-items:start; }
.abl-affdash__nav { display:flex; flex-direction:column; gap:4px; position:sticky; top:96px; }
.abl-affdash__navlink { display:flex; align-items:center; gap:10px; padding:11px 14px; border-radius:var(--abl-radius-sm); font-size:14px; font-weight:600; color:var(--abl-text-muted); transition:background .15s, color .15s; }
.abl-affdash__navlink:hover { background:var(--abl-bg-soft); color:var(--abl-text); }
.abl-affdash__navlink.is-active { background:var(--abl-secondary); color:#fff; }
.abl-affdash__navlink svg { flex:none; }
.abl-affdash__navbadge { margin-left:auto; min-width:22px; height:22px; padding:0 6px; border-radius:999px; background:var(--abl-bg-alt); color:var(--abl-primary); font-size:12px; font-weight:700; display:inline-flex; align-items:center; justify-content:center; }
.abl-affdash__navlink.is-active .abl-affdash__navbadge { background:rgba(255,255,255,.2); color:#fff; }
.abl-affdash__navfoot { margin-top:14px; padding-top:10px; border-top:1px solid var(--abl-border); display:flex; flex-direction:column; gap:4px; }
.abl-affdash__navfoot .abl-affdash__navlink { font-weight:500; font-size:13px; }
.abl-affdash__main { min-width:0; }
.abl-affdash__head { margin-bottom:4px; }

/* recruited-affiliates table */
.abl-afftable { width:100%; border-collapse:collapse; font-size:14px; }
.abl-afftable thead th { text-align:left; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--abl-text-muted); padding:14px 16px; border-bottom:1px solid var(--abl-border); background:var(--abl-bg-soft); }
.abl-afftable tbody td { padding:14px 16px; border-bottom:1px solid var(--abl-border); vertical-align:middle; }
.abl-afftable tbody tr:last-child td { border-bottom:0; }
.abl-afftable__sub { font-size:12px; color:var(--abl-text-muted); }
.abl-affbadge { display:inline-block; font-size:11px; font-weight:700; padding:3px 9px; border-radius:999px; text-transform:capitalize; }
.abl-affbadge--approved { background:rgba(22,163,74,.1); color:var(--abl-success); }
.abl-affbadge--pending { background:rgba(178,106,0,.12); color:#b26a00; }
.abl-affbadge--rejected { background:rgba(220,38,38,.1); color:#dc2626; }

@media (max-width:880px) {
  .abl-affdash__layout { grid-template-columns:1fr; gap:20px; }
  .abl-affdash__nav { position:static; flex-direction:row; flex-wrap:wrap; }
  .abl-affdash__navfoot { width:100%; flex-direction:row; border-top:0; padding-top:0; margin-top:0; }
}
@media (max-width:680px) {
  .abl-affdash__stats { grid-template-columns:1fr; }
  .abl-afftable thead { display:none; }
  .abl-afftable, .abl-afftable tbody, .abl-afftable tr, .abl-afftable td { display:block; width:100%; }
  .abl-afftable tr { padding:12px 16px; border-bottom:1px solid var(--abl-border); }
  .abl-afftable td { border:0; padding:3px 0; }
}

/* ============================================================ MY ACCOUNT */
.abl-acctpage { width:100%; }

/* Dashboard hero */
.abl-acct-hero { padding-block:64px 56px; }
.abl-acct-hero__title { font-size:clamp(40px,5.4vw,64px); line-height:1.05; letter-spacing:-.02em; font-weight:800; color:var(--abl-text); margin:10px 0 0; }
.abl-acct-hero__sub { font-size:18px; color:var(--abl-text-muted); margin:16px 0 0; max-width:560px; }

/* Dashboard card grid */
.abl-acct-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.abl-acct-card {
	display:block; padding:28px; background:var(--abl-bg); border:1px solid var(--abl-border);
	border-radius:18px; color:inherit; transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.abl-acct-card:hover { transform:translateY(-3px); border-color:var(--abl-primary); box-shadow:0 16px 40px -22px rgba(32,44,68,.45); color:inherit; }
.abl-acct-card__ico {
	display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px;
	border-radius:13px; background:var(--abl-bg-alt); color:var(--abl-primary); margin-bottom:18px;
}
.abl-acct-card__title { font-size:22px; font-weight:700; letter-spacing:-.01em; color:var(--abl-text); margin:0 0 6px; }
.abl-acct-card__desc { font-size:14px; color:var(--abl-text-muted); margin:0; line-height:1.55; }

/* Endpoint views: sidebar nav + content */
.abl-acct { display:grid; grid-template-columns:248px 1fr; gap:40px; align-items:start; }
.abl-acct__nav { display:flex; flex-direction:column; gap:4px; position:sticky; top:96px; }
.abl-acct__link {
	display:flex; align-items:center; gap:11px; padding:11px 14px; border-radius:11px;
	font-size:15px; font-weight:600; color:var(--abl-text-muted); transition:background .15s ease, color .15s ease;
}
.abl-acct__link svg { flex:none; opacity:.85; }
.abl-acct__link:hover { background:var(--abl-bg-soft); color:var(--abl-text); }
.abl-acct__link.is-active { background:var(--abl-primary); color:#fff; }
.abl-acct__link.is-active svg { opacity:1; }
.abl-acct__content { min-width:0; }

@media (max-width:880px) {
	.abl-acct { grid-template-columns:1fr; gap:24px; }
	.abl-acct__nav { position:static; flex-flow:row wrap; }
	.abl-acct-cards { grid-template-columns:1fr; }
}

/* --- Account content panels (WooCommerce endpoints: addresses, forms, tables) --- */
.abl-acct__content { font-size:15px; color:var(--abl-text); }
.abl-acct__content > p { color:var(--abl-text-muted); margin:0 0 24px; }
.abl-acct__content h2,
.abl-acct__content h3 { color:var(--abl-text); letter-spacing:-.01em; }

/* Addresses: two cards (override WooCommerce's default floats/column widths) */
.abl-acct__content .woocommerce-Addresses,
.abl-acct__content .u-columns.col2-set,
.abl-acct__content .addresses {
	display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin:0;
}
.abl-acct__content .woocommerce-Addresses::before,
.abl-acct__content .woocommerce-Addresses::after,
.abl-acct__content .u-columns::before,
.abl-acct__content .u-columns::after { content:none; display:none; }
.abl-acct__content .woocommerce-Address,
.abl-acct__content .col2-set .col-1,
.abl-acct__content .col2-set .col-2 { float:none !important; width:auto !important; margin:0 !important; }
.abl-acct__content .woocommerce-Address {
	background:var(--abl-bg); border:1px solid var(--abl-border); border-radius:16px; padding:26px 28px;
}
.abl-acct__content .woocommerce-Address-title h2,
.abl-acct__content .woocommerce-Address-title h3 { flex:1 1 auto; min-width:0; }
.abl-acct__content .woocommerce-Address-title .edit { flex:none; }
.abl-acct__content .woocommerce-Address-title {
	display:flex; align-items:center; justify-content:space-between; gap:14px; margin:0 0 16px;
}
.abl-acct__content .woocommerce-Address-title h2,
.abl-acct__content .woocommerce-Address-title h3 { font-size:19px; font-weight:700; margin:0; }
.abl-acct__content .woocommerce-Address-title .edit {
	font-size:13px; font-weight:600; padding:7px 15px; border:1.5px solid var(--abl-border);
	border-radius:var(--abl-radius-pill); color:var(--abl-primary); white-space:nowrap; transition:background .15s ease, border-color .15s ease;
}
.abl-acct__content .woocommerce-Address-title .edit:hover { background:var(--abl-bg-soft); border-color:var(--abl-primary); }
.abl-acct__content address { font-style:normal; font-size:14px; line-height:1.75; color:var(--abl-text-muted); margin:0; }

/* Buttons inside content → brand pill */
.abl-acct__content .button,
.abl-acct__content .woocommerce-Button,
.abl-acct__content button[type="submit"] {
	display:inline-block; background:var(--abl-primary); color:#fff !important; border:0;
	border-radius:var(--abl-radius-pill); padding:12px 24px; font-weight:600; font-size:14px;
	line-height:1.2; cursor:pointer; transition:background .15s ease, transform .15s ease;
}
.abl-acct__content .button:hover,
.abl-acct__content .woocommerce-Button:hover,
.abl-acct__content button[type="submit"]:hover { background:var(--abl-primary-hover); color:#fff !important; transform:translateY(-1px); }

/* Orders / downloads tables */
.abl-acct__content table.woocommerce-orders-table,
.abl-acct__content table.woocommerce-table,
.abl-acct__content table.shop_table {
	width:100%; border-collapse:collapse; border:1px solid var(--abl-border); border-radius:14px; overflow:hidden;
}
.abl-acct__content table.woocommerce-orders-table th,
.abl-acct__content table.woocommerce-table th,
.abl-acct__content table.shop_table th {
	text-align:left; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
	color:var(--abl-text-muted); padding:14px 16px; background:var(--abl-bg-soft); border-bottom:1px solid var(--abl-border);
}
.abl-acct__content table.woocommerce-orders-table td,
.abl-acct__content table.woocommerce-table td,
.abl-acct__content table.shop_table td { padding:16px; border-bottom:1px solid var(--abl-border); font-size:14px; }
.abl-acct__content table tr:last-child td { border-bottom:0; }

/* Forms (account details, add address) */
.abl-acct__content form .form-row { margin:0 0 18px; }
.abl-acct__content form label { display:block; font-weight:600; font-size:14px; margin-bottom:7px; color:var(--abl-text); }
.abl-acct__content form input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.abl-acct__content form textarea,
.abl-acct__content form select {
	width:100%; padding:12px 14px; border:1px solid var(--abl-border); border-radius:var(--abl-radius-sm);
	font-size:14px; background:#fff; color:var(--abl-text); transition:border-color .15s ease, box-shadow .15s ease;
}
.abl-acct__content form input:focus,
.abl-acct__content form textarea:focus,
.abl-acct__content form select:focus { outline:none; border-color:var(--abl-primary); box-shadow:0 0 0 3px rgba(32,44,68,.12); }
.abl-acct__content fieldset { border:1px solid var(--abl-border); border-radius:14px; padding:22px 24px; margin:28px 0 0; }
.abl-acct__content fieldset legend { font-weight:700; font-size:16px; padding:0 8px; }

/* Notices inside content */
.abl-acct__content .woocommerce-message,
.abl-acct__content .woocommerce-info,
.abl-acct__content .woocommerce-error {
	display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
	background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-left:3px solid var(--abl-primary);
	border-radius:var(--abl-radius-sm); padding:14px 18px; font-size:14px; margin:0 0 22px; list-style:none;
}
.abl-acct__content .woocommerce-error { border-left-color:#c0392b; }

@media (max-width:680px) {
	.abl-acct__content .woocommerce-Addresses { grid-template-columns:1fr; }
}

/* ===================================================== ORDER RECEIVED / THANK YOU */
.woocommerce-order { font-size:15px; }
.woocommerce-order .woocommerce-thankyou-order-received { font-size:16px; color:var(--abl-text-muted); margin:0 0 26px; }
.woocommerce-order > p { color:var(--abl-text-muted); margin:0 0 26px; }

/* Order overview → stat card */
.woocommerce-order .woocommerce-order-overview {
	list-style:none; margin:0 0 44px; padding:24px 30px; display:flex; flex-wrap:wrap; gap:22px 48px;
	background:var(--abl-bg-soft); border:1px solid var(--abl-border); border-radius:16px;
}
.woocommerce-order .woocommerce-order-overview li {
	flex:0 1 auto; min-width:120px; max-width:100%; float:none !important; width:auto !important;
	border:0 !important; padding:0 !important; margin:0; list-style:none; word-break:break-word;
	font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--abl-text-muted);
}
.woocommerce-order .woocommerce-order-overview li strong {
	display:block; margin-top:7px; font-size:16px; font-weight:700; letter-spacing:0; text-transform:none; color:var(--abl-text);
}

/* Section titles */
.woocommerce-order .woocommerce-order-details__title,
.woocommerce-order .woocommerce-column__title { font-size:22px; font-weight:700; letter-spacing:-.01em; margin:0 0 18px; }
.woocommerce-order .woocommerce-customer-details > h2 { font-size:22px; font-weight:700; letter-spacing:-.01em; margin:36px 0 18px; }

/* Order details table */
.woocommerce-order table.shop_table {
	width:100%; border-collapse:collapse; border:1px solid var(--abl-border);
	border-radius:14px; overflow:hidden; margin:0 0 12px;
}
.woocommerce-order table.shop_table thead th {
	text-align:left; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
	color:var(--abl-text-muted); background:var(--abl-bg-soft); padding:14px 16px; border-bottom:1px solid var(--abl-border);
}
.woocommerce-order table.shop_table td,
.woocommerce-order table.shop_table tfoot th {
	padding:15px 16px; border-bottom:1px solid var(--abl-border); font-size:14px; text-align:left; vertical-align:top;
}
.woocommerce-order table.shop_table tfoot th { font-weight:600; color:var(--abl-text-muted); width:55%; }
.woocommerce-order table.shop_table tfoot tr:last-child th,
.woocommerce-order table.shop_table tfoot tr:last-child td { border-bottom:0; }
.woocommerce-order table.shop_table tfoot tr:last-child th { color:var(--abl-text); font-weight:700; }
.woocommerce-order table.shop_table a { color:var(--abl-primary); font-weight:600; }
.woocommerce-order table.shop_table .woocommerce-Price-amount { font-weight:700; white-space:nowrap; }

/* Customer / addresses */
.woocommerce-order .woocommerce-customer-details .woocommerce-columns--addresses { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin:0; }
.woocommerce-order .woocommerce-customer-details address {
	font-style:normal; font-size:14px; line-height:1.8; color:var(--abl-text-muted);
	background:var(--abl-bg); border:1px solid var(--abl-border); border-radius:16px; padding:24px 26px; margin:0;
}
.woocommerce-order .woocommerce-customer-details address a { color:var(--abl-text-muted); }

@media (max-width:680px) {
	.woocommerce-order .woocommerce-customer-details .woocommerce-columns--addresses { grid-template-columns:1fr; }
}
