/** Shopify CDN: Minification failed

Line 1903:17 Expected identifier but found whitespace
Line 1903:18 Unexpected "12px"

**/
    /* ═══════════════════════════════════════════════════════════════
       AGPB — FULL STYLES v3
       No hydration — no hide/show wrappers needed
       ═══════════════════════════════════════════════════════════════ */

    .agpb, .agpb * { box-sizing: border-box; }
    .is-hidden { display: none !important; }

    .agpb {
      padding: var(--agpb-section-pt, 10px) 0 10px;
      max-width: 100vw;
      overflow: visible;
      --agpb-base-img-h: 90px;
    }
    @media (max-width: 989px) {
      .agpb { padding-top: var(--agpb-section-pt-m, 4px); }
    }
    .agpb__wrap {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    /* ── Layout ─────────────────────────────────────────────── */
    .agpb__layout {
      display: grid;
      grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
      gap: 8px;
      align-items: start;
      min-width: 0;
    }
    .agpb__media,
    .agpb__builder,
    .agpb__blk { min-width: 0; }
    .agpb__blk { margin: 1px 0; }

    .agpb__mobileTop  { display: none; }
    .agpb__hideMobile { display: block; }

    @media (max-width: 989px) {
      .agpb__layout          { grid-template-columns: 1fr; }
      .agpb__mobileTop       { display: block; margin-bottom: 1px; }
      .agpb__hideMobile      { display: none !important; }
    }
    @media (max-width: 768px) {
      .agpb__blk             { margin: 0; }
      .agpb__layout          { gap: 2px; }
      .agpb__blk--heading    { margin-bottom: 1px; }
      .agpb__blk--subheading { margin-top: 0; margin-bottom: 2px; }
      .agpb__media           { margin-top: 0; }
    }

    /* ── Typography ─────────────────────────────────────────── */
    .agpb__heading {
      margin: 0 0 2px;
      font-weight: 800;
      letter-spacing: -.02em;
      font-size: var(--agpb-heading-d, 32px);
    }
    @media (max-width: 749px) {
      .agpb__heading { font-size: var(--agpb-heading-m, 24px); }
    }
    .agpb__subheading { margin: 0; opacity: .85; }

    /* ── Quiz CTA ── */
    .agpb__blk--quizCta { margin-top: 4px; margin-bottom: 2px; }
    .agpb__quizCta {
      display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 8px;
      background: #0c0c0c;
      border: 1px solid rgba(255,255,255,.1);
      border-left: 3px solid #d42b2b;
      border-radius: 6px;
      padding: 8px 10px;
      text-decoration: none;
      transition: border-color .2s, background .2s;
    }
    a.agpb__quizCta:hover { background: #141414; border-left-color: #ff3535; }
    .agpb__quizCtaText {
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 12px; font-weight: 700;
      letter-spacing: .04em; text-transform: uppercase;
      color: rgba(255,255,255,.75); line-height: 1.3;
    }
    .agpb__quizCtaBtn {
      flex-shrink: 0;
      display: inline-flex; align-items: center; gap: 5px;
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 11px; font-weight: 700;
      letter-spacing: .1em; text-transform: uppercase;
      color: #fff; background: #d42b2b;
      border-radius: 4px; padding: 5px 10px;
      white-space: nowrap; transition: background .18s;
    }
    a.agpb__quizCta:hover .agpb__quizCtaBtn { background: #ff3535; }
    .agpb__quizCtaBtn svg { flex-shrink: 0; }

    /* ── Compare link — matches comparison page design ── */
    .agpb__compareLink { margin-top: 10px; display: flex; justify-content: center; }
    .agpb__compareLinkAnchor {
      display: inline-flex; align-items: center; gap: 12px;
      flex-wrap: wrap; justify-content: center;
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 13px; font-weight: 700;
      letter-spacing: .22em; text-transform: uppercase;
      color: rgba(255,255,255,.55);
      background: #0c0c0c;
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 6px; padding: 7px 14px;
      text-decoration: none;
      transition: color .2s, border-color .2s;
    }
    .agpb__compareLinkAnchor:hover { color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.22); }
    .agpb__compareLinkDeco { display: flex; align-items: center; gap: 5px; color: #d42b2b; opacity: .7; flex-shrink: 0; }
    .agpb__compareLinkDeco span { display: block; width: 20px; height: 1px; background: currentColor; }
    .agpb__compareLinkDeco svg { width: 10px; height: 10px; flex-shrink: 0; }
    @media (max-width: 480px) {
      .agpb__compareLinkAnchor { font-size: 12px; padding: 7px 12px; }
      .agpb__compareLinkDeco { display: none; }
    }

    .agpb__head,
    .agpb__groupHead {
      display: flex;
      justify-content: space-between;
      gap: 10px;
      align-items: flex-end;
      margin: 0 0 2px;
      min-width: 0;
      flex-wrap: wrap;
    }
    .agpb__title { font-weight: 800; line-height: 1.2; flex: 1 1 auto; min-width: 0; }
    .agpb__hint  { opacity: .75;     line-height: 1.1; text-align: right; flex: 0 0 auto; }
    .agpb__hintInline { font-weight: 400; opacity: .65; white-space: nowrap; }
    @media (max-width: 480px) {
      .agpb__hint { text-align: left; width: 100%; }
    }

    /* ── Gallery ────────────────────────────────────────────── */
    @media (min-width: 990px) {
      .agpb__media {
        position: sticky;
        top: 16px;
        align-self: start;
        max-height: calc(100vh - 32px);
      }
    }
    .agpb__mediaMain {
      width: 100%;
      min-width: 0;
      position: relative;
      border-radius: 18px;
      overflow: hidden;
      background: #f6f6f6;
      aspect-ratio: 1 / 1;
    }
    .agpb__viewBundle {
      position: absolute;
      bottom: 10px; right: 10px;
      z-index: 5;
      display: flex;
      align-items: center;
      gap: 5px;
      background: #111;
      color: #fff;
      border: none;
      border-radius: 999px;
      padding: 6px 12px 6px 9px;
      font-size: 12px;
      font-weight: 700;
      cursor: pointer;
      opacity: 0;
      transition: opacity .2s ease;
      white-space: nowrap;
    }
    .agpb__viewBundle.is-ready { opacity: .9; }
    .agpb__viewBundle.is-ready:hover { opacity: 1; }

    .agpb__compositeCanvas {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      border-radius: 18px;
      opacity: 0;
      transition: opacity .3s ease;
      cursor: zoom-in;
    }
    .agpb__compositeCanvas.is-visible { opacity: 1; }

    .agpb__mediaStage { width: 100%; height: 100%; display: block; position: relative; }
    .agpb__mediaMain--empty {
      padding: 24px;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .agpb__mainImg {
      width: 100%;
      height: 100%;
      display: block;
      max-width: 100%;
      object-fit: contain;
      transition: opacity .2s ease, transform .25s ease;
    }
    .agpb__mainImg--entering { opacity: 0; position: absolute; inset: 0; }
    .agpb__mainImg--leaving  { opacity: 0; }
    @media (hover: hover) {
      .agpb__mediaMain:hover .agpb__mainImg { transform: scale(1.05); }
    }

    .agpb__nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 38px; height: 38px;
      border-radius: 50%;
      background: rgba(255,255,255,.9);
      border: 1px solid #ddd;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 18px;
      cursor: pointer;
      z-index: 5;
      user-select: none;
    }
    .agpb__nav--prev { left: 10px; }
    .agpb__nav--next { right: 10px; }

    .agpb__mediaCount {
      position: absolute;
      top: 10px; right: 10px;
      z-index: 5;
      user-select: none;
      background: rgba(0,0,0,.6);
      color: #fff;
      padding: 4px 8px;
      border-radius: 999px;
      font-size: 12px;
    }

    .agpb__zoomBtn {
      position: absolute;
      bottom: 10px; left: 10px;
      width: 32px; height: 32px;
      background: rgba(255,255,255,.9);
      border: 1px solid rgba(0,0,0,.08);
      border-radius: 8px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #555;
      cursor: pointer;
      opacity: 0;
      transition: opacity .2s ease, background .15s ease;
      z-index: 4;
    }
    .agpb__mediaMain:hover .agpb__zoomBtn { opacity: 1; }
    .agpb__zoomBtn:hover { background: #fff; color: #111; }
    @media (max-width: 989px) {
      .agpb__zoomBtn { opacity: 1; }
    }

    /* ── Lightbox ───────────────────────────────────────────── */
    .agpb__lightbox {
      position: fixed;
      inset: 0;
      z-index: 9010;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .agpb__lightbox.is-hidden { display: none !important; }
    .agpb__lightboxBackdrop {
      position: absolute;
      inset: 0;
      background: rgba(0,0,0,.92);
      cursor: zoom-out;
    }
    .agpb__lightboxStage {
      position: relative;
      z-index: 1;
      max-width: calc(100vw - 120px);
      max-height: calc(100vh - 80px);
      display: flex;
      align-items: center;
      justify-content: center;
    }
    @media (max-width: 749px) {
      .agpb__lightboxStage {
        max-width: 92vw;
        max-height: calc(100vh - 80px);
      }
    }
    .agpb__lightboxImg {
      max-width: 100%;
      max-height: calc(100vh - 80px);
      object-fit: contain;
      border-radius: 4px;
      display: block;
      user-select: none;
      cursor: zoom-out;
    }
    .agpb__lightboxClose {
      position: absolute;
      top: -14px; right: -14px;
      z-index: 3;
      width: 34px; height: 34px;
      border-radius: 50%;
      background: rgba(0,0,0,.75);
      border: 2px solid rgba(255,255,255,.7);
      color: #fff;
      font-size: 18px;
      line-height: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: background .15s;
    }
    .agpb__lightboxClose:hover { background: #000; }
    .agpb__lightboxNav {
      position: fixed;
      top: 50%; transform: translateY(-50%);
      z-index: 2;
      width: 44px; height: 44px;
      border-radius: 50%;
      background: rgba(255,255,255,.15);
      border: 1px solid rgba(255,255,255,.2);
      color: #fff;
      font-size: 24px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: background .15s;
    }
    .agpb__lightboxNav:hover { background: rgba(255,255,255,.25); }
    .agpb__lightboxNav--prev { left: 12px; }
    .agpb__lightboxNav--next { right: 12px; }
    .agpb__lightboxNav.is-hidden { display: none !important; }
    .agpb__lightboxCount {
      position: fixed;
      bottom: 16px; left: 50%;
      transform: translateX(-50%);
      z-index: 2;
      color: rgba(255,255,255,.7);
      font-size: 13px;
      font-weight: 600;
      pointer-events: none;
    }

    .agpb__thumbRow {
      margin-top: 10px;
      display: grid;
      grid-auto-flow: column;
      grid-auto-columns: 88px;
      gap: 10px;
      overflow-x: auto;
      padding-bottom: 6px;
      max-width: 100%;
      -webkit-overflow-scrolling: touch;
      scroll-snap-type: x mandatory;
    }
    .agpb__thumb {
      border: 1px solid #e6e6e6;
      background: #fff;
      border-radius: 14px;
      padding: 6px;
      cursor: pointer;
      min-width: 0;
      scroll-snap-align: start;
    }
    .agpb__thumb.is-active {
      border-color: #111;
      box-shadow: 0 0 0 2px #111 inset, 0 4px 12px rgba(0,0,0,.08);
    }
    .agpb__thumbInner {
      height: 64px;
      border-radius: 10px;
      overflow: hidden;
      background: #f6f6f6;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .agpb__thumbInner img { width: 100%; height: 100%; object-fit: contain; display: block; }

    /* ── Base status bar ────────────────────────────────────── */
    .agpb__baseStatus {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 8px;
      flex-wrap: wrap;
      margin: 0 0 6px;
      min-height: 30px;
    }
    .agpb__baseStatus .agpb__sysPill {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 8px 14px;
      border-radius: 999px;
      font-weight: 900;
      font-size: 12px;
      line-height: 1;
      letter-spacing: 0;
      text-transform: none;
      color: #fff;
      box-shadow: 0 4px 12px rgba(0,0,0,.12);
      white-space: nowrap;
    }
    .agpb__baseStatus .agpb__sysPill.is-preorder { background: #b10f0f; }
    .agpb__baseStatus .agpb__sysPill.is-oos       { background: #999;   }
    .agpb__baseStatus .agpb__sysPill--date {
      background: #333;
      color: #fff;
      font-weight: 700;
      font-size: 12px;
    }

    .agpb__notifyTrigger {
      border: 1px solid #111;
      background: #fff;
      border-radius: 999px;
      padding: 7px 14px;
      font-size: 12px;
      font-weight: 800;
      cursor: pointer;
      white-space: nowrap;
      line-height: 1;
      text-decoration: none;
      color: inherit;
      display: inline-flex;
      align-items: center;
    }
    .agpb__notifyTrigger:hover { background: #111; color: #fff; }
    .agpb__sysPill--link {
      text-decoration: none;
      cursor: pointer;
      transition: opacity .15s ease;
    }
    .agpb__sysPill--link:hover { opacity: .8; }

    /* ── Tiles ──────────────────────────────────────────────── */
    .agpb__tile {
      width: 100%; min-width: 0; max-width: 100%;
      border-style: solid;
      border-width: var(--agpb-tile-bw-idle, 1px);
      border-color: var(--agpb-tile-bc-idle, #e6e6e6);
      background: #fff;
      padding: var(--agpb-tile-pad, 10px);
      border-radius: var(--agpb-radius, 14px);
      cursor: pointer;
      text-align: left;
      position: relative;
      transition: border-color .15s ease, border-width .15s ease, transform .05s ease;
      overflow: hidden;
    }
    .agpb__tile:hover {
      border-color: var(--agpb-tile-bc-active, #111);
      transform: translateY(-1px);
    }
    .agpb__tile.is-active {
      /* Keep the border at the IDLE width so the inner content area
         doesn't shift when the tile is selected. The visual "selected"
         outline is added via an outer box-shadow which follows the
         tile's border-radius and doesn't push the ribbon inward.
         No inset shadow — it'd read as a second inner line next to
         the active border colour, which looks messy. */
      border-width: var(--agpb-tile-bw-idle, 1px);
      border-color: var(--agpb-tile-bc-active, #111);
      box-shadow: 0 0 0 2px var(--agpb-tile-bc-active, #111);
    }
    .agpb__tile.is-disabled,
    .agpb__tile:disabled {
      opacity: .45;
      cursor: not-allowed;
    }
    .agpb__tile--base.is-disabled,
    .agpb__tile--base:disabled {
      opacity: .45;
      background: #fafafa;
      border-color: #ccc !important;
      pointer-events: none;
    }
    .agpb__tile--base.is-disabled .agpb__tileTitle--base {
      text-decoration: line-through;
      opacity: .7;
    }
    [data-agpb-base-item][data-available="false"] { cursor: pointer; }

    .agpb__tile--addon.is-disabled,
    .agpb__tile--addon:disabled {
      pointer-events: none;
      border-color: #ccc !important;
    }
    [data-agpb-addon-item][data-available="false"] { cursor: pointer; }

    .agpb__tileInner { position: relative; min-width: 0; }

    .agpb__tile--base,
    .agpb__tile--base .agpb__tileInner { text-align: center; }

    .agpb__tile--base.no-img .agpb__tileInner {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 4px 0;
      gap: 2px;
    }
    .agpb__tile--base.has-img .agpb__tileInner {
      min-height: var(--agpb-base-tile-minh-img, 140px);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 8px;
    }
    .agpb__tile--base.is-active {
      background: #f5f5f5;
    }

    /* ── Status banner — full-width top bar on any tile ─────── */
    .agpb__ribbon {
      position: absolute;
      top: 0; left: 0; right: 0;
      padding: 4px 6px;
      font-size: 8px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .08em;
      line-height: 1;
      text-align: center;
      color: #fff;
      white-space: nowrap;
      pointer-events: none;
      z-index: 5;
      /* Follow the tile's top corners, square off the bottom */
      border-radius: var(--agpb-radius, 14px) var(--agpb-radius, 14px) 0 0;
    }
    .agpb__ribbon.is-preorder { background: #b10f0f; }
    .agpb__ribbon.is-oos      { background: #999; }
    .has-ribbon-tiles .agpb__tile { padding-top: 0; }
    .has-ribbon-tiles .agpb__tileInner { padding-top: 18px; }

    /* ── Images ──────────────────────────────────────────────── */
    .agpb__img {
      width: 100%; min-width: 0;
      border-radius: calc(var(--agpb-radius, 14px) - 4px);
      overflow: hidden;
      background: #f6f6f6;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 8px;
      position: relative;
    }
    .agpb__img--base img.agpb__tileImg { height: var(--agpb-base-img-h, 90px); }

    /* ── Horizontal addon tile layout ───────────────────────────── */
    .agpb__tileInner--addonH {
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: 10px;
      text-align: left;
    }
    .agpb__img--addonH {
      flex: 0 0 62px;
      width: 62px;
      height: 62px;
      margin: 0;
      border-radius: calc(var(--agpb-radius, 14px) - 6px);
      overflow: hidden;
      background: #f6f6f6;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .agpb__img--addonH img.agpb__tileImg {
      width: 62px;
      height: 62px;
      object-fit: contain;
    }
    .agpb__tileText {
      flex: 1;
      min-width: 0;
    }
    .agpb__tileTitle--addonH {
      margin: 0 0 2px;
      word-break: break-word;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      overflow: hidden;
      line-height: 1.2;
      font-size: .9em;
    }
    .agpb__tilePrice--addonH {
      display: flex;
      flex-direction: column;
      gap: 1px;
      line-height: 1.25;
    }
    .agpb__tilePrice--addonH .agpb__priceMain {
      display: flex;
      align-items: baseline;
      gap: 3px;
      white-space: nowrap;
    }
    .agpb__tilePrice--addonH .agpb__priceWas {
      display: flex;
      align-items: baseline;
      gap: 3px;
      white-space: nowrap;
      opacity: .55;
      font-size: .85em;
    }
    .agpb__tilePrice--addonH .agpb__money--compare {
      text-decoration: line-through;
      white-space: nowrap;
    }

    /* ── "Added" badge — shown when addon tile is selected ───────── */
    .agpb__addedBadge {
      display: none;
      align-items: center;
      gap: 4px;
      font-size: .75em;
      font-weight: 700;
      color: #1c6b22;
      white-space: nowrap;
    }
    /* When tile is active: show badge alongside price, tint tile */
    .agpb__tile--addon.is-active {
      background: #f0f7f0;
      border-color: #1c6b22;
    }
    .agpb__tile--addon.is-active .agpb__addedBadge { display: flex; }

    img.agpb__tileImg {
      width: 100%; height: 100%;
      object-fit: contain;
      display: block;
      max-width: 100%;
    }

    /* ── Tile titles ─────────────────────────────────────────── */
    .agpb__tileTitle { font-weight: 750; line-height: 1.15; min-width: 0; }
    .agpb__tileTitle--base {
      margin-top: 2px;
      text-align: center;
      word-break: break-word;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      overflow: hidden;
    }
    .agpb__variantTitle {
      margin-top: 6px;
      font-size: 12px;
      opacity: .75;
      line-height: 1.15;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .agpb__variantTitle--center { margin: 0 0 8px; text-align: center; }

    /* ── Price rows ──────────────────────────────────────────── */
    /* ── Base tile integrated price ─────────────────────────── */
    .agpb__basePrice {
      display: flex;
      align-items: baseline;
      justify-content: center;
      gap: 5px;
      flex-wrap: wrap;
      min-width: 0; max-width: 100%;
      overflow: hidden;
      line-height: 1.15;
      margin-top: 2px;
      opacity: .85;
    }
    .agpb__basePrice .agpb__money--compare {
      text-decoration: line-through;
      opacity: .55;
      font-size: .9em;
      white-space: nowrap;
    }
    .agpb__basePrice .agpb__money:not(.agpb__money--compare) {
      font-weight: 800;
    }
    .agpb__rrpWrap {
      display: inline-flex;
      align-items: baseline;
      gap: 3px;
      white-space: nowrap;
    }
    .agpb__rrpLabel {
      font-size: .8em;
      opacity: .55;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: .03em;
    }
    .agpb__saveBadge {
      font-size: .75em;
      font-weight: 700;
      color: #c0392b;
      white-space: nowrap;
    }
    .agpb__comparePrefix { opacity: .75; font-weight: 700; white-space: nowrap; }
    .agpb__small         { opacity: .8; }

    /* ── Grid layouts ────────────────────────────────────────── */
    .agpb__baseTiles,
    .agpb__tiles--grid {
      display: grid;
      gap: var(--agpb-gap, 10px);
      min-width: 0; max-width: 100%;
      padding-top: 2px;
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    [data-agpb-base-tiles].agpb__grid-fixed {
      grid-template-columns: repeat(var(--agpb-base-cols-d, 3), minmax(0, 1fr));
    }
    @media (max-width: 749px) {
      [data-agpb-base-tiles].agpb__grid-fixed {
        grid-template-columns: repeat(var(--agpb-base-cols-m, 2), minmax(0, 1fr));
      }
    }
    [data-agpb-base-tiles].agpb__grid-minw {
      grid-template-columns: repeat(auto-fit, minmax(var(--agpb-base-minw-d, 160px), 1fr));
    }
    @media (max-width: 749px) {
      [data-agpb-base-tiles].agpb__grid-minw {
        grid-template-columns: repeat(auto-fit, minmax(var(--agpb-base-minw-m, 120px), 1fr));
      }
    }

    [data-agpb-tiles].agpb__grid-fixed {
      grid-template-columns: repeat(var(--agpb-cols-d, 2), minmax(0, 1fr));
    }
    [data-agpb-tiles].agpb__grid-minw {
      grid-template-columns: repeat(auto-fit, minmax(var(--agpb-minw-d, 160px), 1fr));
    }
    @media (max-width: 749px) {
      [data-agpb-tiles].agpb__grid-fixed {
        grid-template-columns: repeat(var(--agpb-cols-m, 2), minmax(0, 1fr));
      }
      [data-agpb-tiles].agpb__grid-minw {
        grid-template-columns: repeat(auto-fit, minmax(var(--agpb-minw-m, 120px), 1fr));
      }
    }

    .agpb__tiles--swipe {
      display: grid;
      grid-auto-flow: column;
      grid-auto-columns: minmax(var(--agpb-cardw, 220px), 1fr);
      gap: var(--agpb-gap, 10px);
      overflow-x: auto;
      padding-top: 2px;
      padding-bottom: 6px;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      min-width: 0; max-width: 100%;
      scrollbar-width: none;
    }
    .agpb__tiles--swipe::-webkit-scrollbar { display: none; }
    .agpb__tiles--swipe > * { scroll-snap-align: start; min-width: 0; }
    @media (max-width: 749px) {
      .agpb__tiles--swipe {
        grid-auto-columns: minmax(var(--agpb-cardw-m, 180px), 1fr);
      }
    }

    /* ── Accordion ───────────────────────────────────────────── */
    .agpb__groupBody {
      overflow: hidden;
      transition: max-height .3s ease;
    }
    .agpb__accBtn {
      border: 1px solid #e6e6e6;
      background: #fff;
      border-radius: 50%;
      width: 32px; height: 32px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      flex: 0 0 auto;
      transition: background .15s, border-color .15s;
    }
    .agpb__accBtn:hover { background: #f5f5f5; border-color: #ccc; }
    .agpb__accIcon {
      width: 8px; height: 8px;
      border-right: 2px solid #555;
      border-bottom: 2px solid #555;
      transform: rotate(45deg) translate(-1px, -1px);
      transition: transform .2s ease;
    }
    [data-agpb-group].is-open .agpb__accIcon { transform: rotate(-135deg) translate(-1px, -1px); }

    /* ── Selection chips ─────────────────────────────────────── */
    .agpb__chips {
      display: flex;
      flex-wrap: wrap;
      gap: var(--agpb-chip-gap, 6px);
      margin-top: 2px;
      min-width: 0;
    }
    .agpb__chipOut {
      position: relative;
      border: 1px solid #e6e6e6;
      border-radius: 10px;
      background: #fff;
      padding: 4px 8px 4px 4px;
      font-size: var(--agpb-chip-font, 12px);
      line-height: 1.2;
      min-width: 0;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    /* Pre-order treatment — red border + small pill ribbon over the
       top-left of the chip so customers see at a glance which selected
       items are pre-order. */
    .agpb__chipOut--preorder {
      border-color: #b10f0f;
      box-shadow: 0 0 0 1px #b10f0f;
    }
    .agpb__chipRibbon {
      position: absolute;
      top: -7px; left: 8px;
      background: #b10f0f; color: #fff;
      font-size: 8px; font-weight: 900;
      letter-spacing: .08em; text-transform: uppercase;
      padding: 2px 6px; border-radius: 999px;
      pointer-events: none;
      line-height: 1;
    }
    .agpb__chipThumb {
      width: 28px; height: 28px;
      border-radius: 6px;
      object-fit: contain;
      background: #f6f6f6;
      display: block;
      flex-shrink: 0;
    }
    .agpb__chipText {
      display: flex;
      flex-direction: column;
      gap: 1px;
      min-width: 0;
    }
    .agpb__chipGroup {
      opacity: .5;
      font-weight: 500;
      font-size: .85em;
      white-space: nowrap;
    }
    .agpb__chipItem {
      font-weight: 700;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      max-width: 140px;
    }

    /* ── Selection summary ───────────────────────────────────── */
    .agpb__selHeader {
      display: flex;
      align-items: center;
      gap: 7px;
      margin-bottom: 3px;
      padding-bottom: 3px;
    }
    .agpb__selIcon {
      width: 22px; height: 22px;
      background: #111;
      color: #fff;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .agpb__selTitle {
      font-weight: 800;
      letter-spacing: -.01em;
    }

    /* ── Price summary ───────────────────────────────────────── */
    .agpb__priceRow {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      gap: 6px;
      margin: 0;
    }
    .agpb__priceLabel  { font-weight: 800; font-size: var(--agpb-price-label-size, 14px); color: var(--agpb-price-label-color, inherit); }
    .agpb__priceVal    { font-size: var(--agpb-price-value-size, 26px); color: var(--agpb-price-value-color, inherit); }
    .agpb__money--total { font-weight: 900; letter-spacing: -.02em; }
    .agpb__savingsRow {
      text-align: right;
      margin-top: 2px;
    }
    .agpb__savingsText {
      font-size: .8em;
      font-weight: 700;
      color: #1c6b22;
    }
    .agpb__money--total[data-agpb-loading],
    .agpb__priceMain .agpb__money[data-agpb-loading],
    [data-agpb-base-item] .agpb__basePrice .agpb__money[data-agpb-loading] {
      display: inline-block;
      min-width: 60px;
      background: linear-gradient(90deg, #e8e8e8 25%, #f5f5f5 50%, #e8e8e8 75%);
      background-size: 200% 100%;
      animation: agpb-shimmer 1.2s infinite;
      border-radius: 4px;
      color: transparent;
    }
    @keyframes agpb-shimmer {
      0%   { background-position: 200% 0; }
      100% { background-position: -200% 0; }
    }
    .agpb__priceNote   { font-size: var(--agpb-price-note-size, 12px); color: var(--agpb-price-note-color, inherit); opacity: 1; }

    /* ── ATC row ─────────────────────────────────────────────── */
    .agpb__blk--atc .agpb__atcRow {
      width: 100% !important; max-width: 100% !important; min-width: 0 !important;
      display: grid !important;
      grid-template-columns: 1fr !important;
      gap: 4px !important;
      align-items: stretch !important;
    }
    .agpb__atcLeft {
      border: 1px solid rgba(0,0,0,.08);
      background: #fff;
      border-radius: 14px;
      padding: 10px 12px;
      min-width: 0; overflow: hidden;
    }
    .agpb__atcLeftLabel  { font-weight: 800; opacity: .9; margin-bottom: 4px; }
    .agpb__atcSelections { opacity: .85; line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

    @media (min-width: 750px) {
      .agpb__blk--atc .agpb__atcRow.has-left.is-inline-d {
        grid-template-columns: 1.2fr minmax(150px, .7fr) 1fr !important;
        align-items: center !important;
      }
      .agpb__blk--atc .agpb__atcRow.has-left:not(.has-qty).is-inline-d {
        grid-template-columns: 1.2fr 1fr !important;
      }
    }
    .agpb__blk--atc .agpb__atcRow.has-left.is-inline-m       { grid-template-columns: 1.2fr 1fr !important; }
    .agpb__blk--atc .agpb__atcRow.has-left.has-qty.is-inline-m { grid-template-columns: 1.2fr minmax(150px,.7fr) 1fr !important; }
    .agpb__blk--atc .agpb__atcRow.has-qty.is-inline-m:not(.has-left) { grid-template-columns: minmax(150px,1fr) 2fr !important; }
    @media (min-width: 750px) {
      .agpb__blk--atc .agpb__atcRow.has-qty.is-inline-d:not(.has-left) { grid-template-columns: minmax(150px,1fr) 2fr !important; }
    }

    .agpb__blk--atc .agpb__qty {
      width: 100% !important;
      display: grid !important;
      grid-template-columns: 42px 1fr 42px !important;
      border: 1px solid var(--agpb-atc-br, #111) !important;
      border-radius: 14px !important;
      overflow: hidden !important;
      height: 50px !important;
    }
    .agpb__blk--atc .agpb__qtyBtn   { border: 0 !important; background: #fff !important; cursor: pointer !important; font-size: 18px !important; font-weight: 800 !important; }
    .agpb__blk--atc .agpb__qtyInput { border: 0 !important; text-align: center !important; font-size: 16px !important; font-weight: 700 !important; width: 100% !important; }

    .agpb__blk--atc .agpb__atcBtn {
      width: 100% !important;
      height: 50px !important;
      border: 1px solid var(--agpb-atc-br, #111) !important;
      border-radius: 14px !important;
      font-weight: 900 !important;
      cursor: pointer !important;
      display: flex;
      align-items: center;
      justify-content: center;
      min-width: 0;
    }
    .agpb__atcBtn.is-loading { opacity: .75; cursor: progress; }
    .agpb__atcBtn.is-success  { background: #1a6e1a !important; border-color: #1a6e1a !important; cursor: default; }

    .agpb__error {
      margin-top: 6px;
      background: #fff2f2;
      border: 1px solid #ffd1d1;
      color: #8a1f1f;
      padding: 8px 12px;
      border-radius: 14px;
    }

    /* ── Shake / required highlight ─────────────────────────────── */
    @keyframes agpb-shake {
      0%, 100% { transform: translateX(0); }
      15%       { transform: translateX(-6px); }
      30%       { transform: translateX(6px); }
      45%       { transform: translateX(-4px); }
      60%       { transform: translateX(4px); }
      75%       { transform: translateX(-2px); }
      90%       { transform: translateX(2px); }
    }
    .agpb__tiles.is-required-err,
    .agpb__baseTiles.is-required-err {
      animation: agpb-shake .45s ease;
      border-radius: var(--agpb-radius, 14px);
      outline: 2px solid #b10f0f;
      outline-offset: 3px;
    }

    /* ── Buy it now ──────────────────────────────────────────── */
    .agpb__trustStrip {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      flex-wrap: wrap;
      margin-top: 8px;
      font-size: 11px;
      font-weight: 700;
      color: #1c6b22;
      line-height: 1;
    }
    .agpb__trustItem {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      white-space: nowrap;
    }
    .agpb__trustItem svg { flex-shrink: 0; }
    .agpb__trustLink {
      color: inherit;
      text-decoration: underline;
      text-decoration-color: rgba(28,107,34,.3);
      text-underline-offset: 2px;
    }
    .agpb__trustLink:hover {
      text-decoration-color: currentColor;
    }
    .agpb__buyNowWrap { margin-top: 4px; }

    .agpb__buyNowBtn {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      padding: 11px 16px;
      border: 1.5px solid #e6e6e6;
      background: #fff;
      border-radius: 14px;
      font-weight: 700;
      font-size: 14px;
      cursor: pointer;
      color: #333;
      transition: border-color .15s ease, color .15s ease, background .15s ease;
      letter-spacing: -.01em;
      white-space: nowrap;
      overflow: hidden;
    }
    .agpb__buyNowBtn:hover { border-color: #111; color: #111; background: #fafafa; }
    .agpb__buyNowBtn.is-loading { opacity: .75; cursor: progress; }

    .agpb__buyNowBtnArrow {
      font-size: 15px;
      flex-shrink: 0;
      transition: transform .15s ease;
    }
    .agpb__buyNowBtn:hover .agpb__buyNowBtnArrow { transform: translateX(3px); }

    /* Thin vertical rule separating label from timer */
    .agpb__buyNowDivider {
      flex-shrink: 0;
      width: 1px;
      height: 16px;
      background: currentColor;
      opacity: .18;
      border-radius: 1px;
    }

    /* Inline timer — clock icon + ticking text, right of the divider */
    .agpb__buyNowTimerInline {
      display: flex;
      align-items: center;
      gap: 4px;
      font-size: 11.5px;
      font-weight: 600;
      opacity: .6;
      flex: 0 1 auto;
      min-width: 0;
      max-width: 100%;
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis;
      font-variant-numeric: tabular-nums;
    }
    .agpb__buyNowTimerInline strong { font-weight: 800; opacity: 1; }
    .agpb__buyNowTimerIcon { flex-shrink: 0; opacity: .75; }


    .agpb__buyNowNote    { margin-top: 5px; font-size: 11px; opacity: .6; text-align: center; }
    .agpb__buyNowPay     { margin-top: 8px; }
    .agpb__buyNowPayLabel { font-size: 11px; opacity: .7; margin-bottom: 6px; }
    .agpb__buyNowLogos   { display: flex; flex-wrap: wrap; gap: 6px; }
    .agpb__payPill       { display: flex; align-items: center; border: 1px solid #e6e6e6; border-radius: 6px; padding: 4px 8px; }
    .agpb__payPill img   { height: 18px; width: auto; display: block; }

    /* ── Finance ──────────────────────────────────────────────── */
    .agpb__blk--fin {
      padding-top: 4px;
    }
    .agpb__finHeader {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 3px;
      gap: 6px;
    }
    .agpb__finTitle {
      font-weight: 700;
      opacity: .75;
    }
    .agpb__finLearnMore {
      font-size: 11px;
      font-weight: 600;
      opacity: .6;
      text-decoration: underline;
      text-underline-offset: 2px;
      color: inherit;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .agpb__finLearnMore:hover { opacity: 1; }

    /* Representative example & credit statement — info icon tooltips */
    .agpb__finFromLabelRow {
      display: flex;
      align-items: center;
      gap: 4px;
    }
    .agpb__finProvidersRow {
      display: flex;
      align-items: center;
      gap: 4px;
      justify-content: flex-end;
    }
    [data-agpb-fin-rep-ex-icon-slot],
    [data-agpb-fin-credit-icon-slot] {
      position: relative;
      display: inline-flex;
    }
    .agpb__finInfoBtn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: none;
      border: none;
      padding: 0;
      cursor: pointer;
      color: #999;
      flex-shrink: 0;
      transition: color .15s;
      position: relative;
    }
    .agpb__finInfoBtn:hover { color: #333; }
    .agpb__finTooltip {
      position: absolute;
      z-index: 50;
      bottom: calc(100% + 6px);
      left: 50%;
      transform: translateX(-50%);
      width: 240px;
      background: #1a1a1a;
      color: #fff;
      font-size: 11px;
      line-height: 1.5;
      font-weight: 400;
      padding: 8px 10px;
      border-radius: 8px;
      box-shadow: 0 4px 16px rgba(0,0,0,.2);
      pointer-events: none;
    }
    .agpb__finTooltip::after {
      content: '';
      position: absolute;
      top: 100%;
      left: 50%;
      transform: translateX(-50%);
      border: 5px solid transparent;
      border-top-color: #1a1a1a;
    }
    .agpb__finTooltipLabel {
      display: block;
      font-weight: 700;
      margin-bottom: 3px;
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: .04em;
      opacity: .7;
    }

    /* Chip grid */
    .agpb__finChips {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 5px;
      margin-bottom: 3px;
    }
    .agpb__chip {
      border: 1.5px solid #e6e6e6;
      background: #fafafa;
      border-radius: 10px;
      padding: 4px 4px 3px;
      font-weight: 800;
      cursor: pointer;
      font-size: var(--agpb-fin-chip, 12px);
      text-align: center;
      white-space: nowrap;
      width: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 1px;
      transition: border-color .15s, background .15s, box-shadow .15s;
      line-height: 1.1;
    }
    .agpb__chipLabel { font-weight: 900; font-size: 1em; }
    .agpb__chipSub   { font-size: .72em; font-weight: 600; opacity: .55; }
    .agpb__chip:hover { border-color: #bbb; background: #fff; }
    .agpb__chip.is-active {
      border-color: #111;
      background: #111;
      color: #fff;
      box-shadow: 0 2px 8px rgba(0,0,0,.15);
    }
    .agpb__chip.is-active .agpb__chipSub { opacity: .7; }

    /* Pay in 30 — distinct BNPL chip */
    .agpb__chip--bnpl {
      border-color: #d4af37;
      background: #fffdf0;
      color: #7a6000;
    }
    .agpb__chip--bnpl:hover { border-color: #b8960c; background: #fffbe0; }
    .agpb__chip--bnpl.is-active {
      border-color: #b8960c;
      background: #d4af37;
      color: #fff;
      box-shadow: 0 2px 8px rgba(180,140,0,.25);
    }

    /* Description */
    .agpb__finDesc {
      font-size: 12px;
      opacity: .65;
      margin: 0 0 3px;
      line-height: 1.4;
      padding: 6px 10px;
      background: #f7f7f7;
      border-radius: 8px;
    }

    /* From price box */
    .agpb__finFromBox {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      background: #f7f7f7;
      border-radius: 10px;
      padding: 5px 8px;
    }
    .agpb__finFromLeft  { display: flex; flex-direction: column; gap: 0; }
    .agpb__finFromLabel { font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; opacity: .55; }
    .agpb__finFromRow   { display: flex; align-items: baseline; gap: 3px; }
    .agpb__finFromValue { font-weight: 900; letter-spacing: -.02em; }
    .agpb__finFromSuffix { font-weight: 600; opacity: .6; }
    .agpb__finRight {
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      gap: 5px;
    }
    .agpb__finProviders { display: flex; flex-wrap: wrap; gap: 5px; align-items: center; justify-content: flex-end; }
    .agpb__finProv      { display: inline-flex; align-items: center; gap: 5px; padding: 4px 8px; border-radius: 7px; border: 1px solid #e6e6e6; background: #fff; font-weight: 800; font-size: 11px; line-height: 1; white-space: nowrap; }
    .agpb__finProv--btn {
      cursor: pointer;
      transition: border-color .15s, box-shadow .15s;
    }
    .agpb__finProv--btn:hover {
      border-color: #111;
      box-shadow: 0 0 0 1px #111;
    }
    .agpb__finProvArrow { opacity: .4; flex-shrink: 0; }
    .agpb__finApplyBtn {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      padding: 5px 10px;
      border-radius: 7px;
      border: 1.5px solid #111;
      background: #fff;
      color: #111;
      font-size: 11px;
      font-weight: 700;
      cursor: pointer;
      white-space: nowrap;
      transition: background .15s, color .15s;
      letter-spacing: -.01em;
    }
    .agpb__finApplyBtn:hover { background: #111; color: #fff; }
    .agpb__finApplyBtn:hover svg path { stroke: #fff; }
    .agpb__finLogo      { height: 13px; width: auto; display: block; }
    .agpb__finProvText  { opacity: .85; }

    /* Finance checkout button */
    /* ── Finance modal ───────────────────────────────────────── */
    .agpb__modalBox--finance {
      max-width: 400px;
      width: 100%;
      padding: 20px;
    }
    .agpb__finModalHeader {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 14px;
    }
    .agpb__finModalBadge {
      font-size: 10px;
      font-weight: 800;
      letter-spacing: .08em;
      text-transform: uppercase;
      background: #111;
      color: #fff;
      padding: 3px 8px;
      border-radius: 99px;
    }
    .agpb__finModalBack {
      font-size: 12px;
      font-weight: 700;
      color: #555;
      background: none;
      border: none;
      cursor: pointer;
      padding: 0;
    }
    .agpb__finModalBack:hover { color: #111; }
    .agpb__modalClose {
      background: none;
      border: none;
      font-size: 18px;
      cursor: pointer;
      color: #aaa;
      padding: 0 2px;
      line-height: 1;
    }
    .agpb__modalClose:hover { color: #111; }
    .agpb__finModalTitle {
      font-size: 17px;
      font-weight: 800;
      margin: 0 0 3px;
      letter-spacing: -.02em;
    }
    .agpb__finModalSub {
      font-size: 12px;
      color: #888;
      margin: 0 0 14px;
    }
    .agpb__finModalChips {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      margin-bottom: 10px;
    }
    .agpb__finModalChip {
      flex: 1 1 auto;
      min-width: 50px;
    }
    .agpb__finModalFromBox {
      display: flex;
      align-items: center;
      gap: 6px;
      margin-bottom: 14px;
      padding: 8px 10px;
      background: #f5f5f5;
      border-radius: 8px;
    }
    .agpb__finModalBnplMsg {
      display: flex;
      flex-direction: column;
      gap: 2px;
      margin-bottom: 14px;
      padding: 10px 12px;
      background: #fffdf0;
      border: 1px solid #e8d87a;
      border-radius: 8px;
      font-size: 13px;
      line-height: 1.4;
    }
    .agpb__finModalBnplMsg strong { font-weight: 800; }
    .agpb__finModalBnplMsg span   { opacity: .65; font-size: 12px; }
    .agpb__finModalFromLabel {
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: #999;
      white-space: nowrap;
    }
    .agpb__finModalFromValue {
      font-size: 22px;
      font-weight: 900;
      letter-spacing: -.03em;
      line-height: 1;
    }
    .agpb__finModalFromSuffix {
      font-size: 12px;
      font-weight: 600;
      color: #888;
      align-self: flex-end;
      padding-bottom: 2px;
    }
    .agpb__finModalProvLabel {
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: #999;
      margin: 0 0 6px;
    }
    .agpb__finModalProvError {
      font-size: 12px;
      color: #c0392b;
      font-weight: 600;
      margin: 6px 0 0;
    }
    .agpb__finModalProviders--shake { animation: agpb-shake 0.4s ease; }
    .agpb__finModalProviders {
      display: flex;
      flex-wrap: wrap;
      gap: 7px;
      margin-bottom: 4px;
    }
    .agpb__finModalProv {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      padding: 7px 11px;
      border-radius: 8px;
      border: 2px solid #e6e6e6;
      background: #fff;
      font-weight: 700;
      font-size: 12px;
      cursor: pointer;
      transition: border-color .15s, box-shadow .15s;
    }
    .agpb__finModalProv:hover { border-color: #bbb; }
    .agpb__finModalProv.is-active {
      border-color: #111;
      box-shadow: 0 0 0 2px rgba(17,17,17,.08);
      background: #fafafa;
    }

    /* Cart choice — step 2 */
    .agpb__finCartOptions {
      display: flex;
      flex-direction: column;
      gap: 6px;
      margin: 14px 0 10px;
    }
    .agpb__finCartOption {
      display: flex;
      align-items: flex-start;
      gap: 9px;
      padding: 10px 12px;
      border: 2px solid #e8e8e8;
      border-radius: 10px;
      cursor: pointer;
      transition: border-color .15s;
      background: #fff;
    }
    .agpb__finCartOption:has(input:checked) {
      border-color: #111;
      background: #fafafa;
    }
    .agpb__finCartOption input {
      margin-top: 2px;
      flex-shrink: 0;
      accent-color: #111;
      width: 15px;
      height: 15px;
    }
    .agpb__finCartOptionInner { flex: 1; min-width: 0; }
    .agpb__finCartOptionHead {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 8px;
      margin-bottom: 8px;
    }
    .agpb__finCartOptionTitle {
      font-weight: 800;
      font-size: 13px;
      letter-spacing: -.01em;
    }
    .agpb__finCartOptionTotal {
      font-weight: 800;
      font-size: 14px;
      letter-spacing: -.02em;
      white-space: nowrap;
    }

    /* Thumbnail item cards */
    .agpb__finItems {
      display: flex;
      flex-direction: column;
      gap: 4px;
      max-height: 160px;
      overflow-y: auto;
    }
    .agpb__finItem {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 3px 0;
      border-bottom: 1px solid #f2f2f2;
    }
    .agpb__finItem:last-child { border-bottom: none; }
    .agpb__finItemThumb {
      width: 32px;
      height: 32px;
      border-radius: 6px;
      border: 1px solid #e8e8e8;
      background: #f6f6f6;
      object-fit: contain;
      display: block;
      padding: 2px;
      flex-shrink: 0;
    }
    .agpb__finItemThumb--placeholder {
      background: #efefef;
    }
    .agpb__finItemTitle {
      flex: 1;
      font-size: 12px;
      font-weight: 600;
      color: #333;
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .agpb__finItemQty   { font-size: 11px; font-weight: 500; color: #aaa; margin-left: 3px; }
    .agpb__finItemPrice { font-size: 12px; font-weight: 700; white-space: nowrap; flex-shrink: 0; color: #333; }
    .agpb__finCartLoading { font-size: 12px; color: #aaa; padding: 4px 0; }
    .agpb__finModalDisclaimer {
      font-size: 11px;
      color: #bbb;
      text-align: center;
      margin: 8px 0 0;
    }
    .agpb__finCheckoutNote {
      display: flex;
      align-items: flex-start;
      gap: 8px;
      margin-top: 10px;
      padding: 10px 12px;
      background: #f0f6ff;
      border: 1px solid #c5daf7;
      border-radius: 8px;
      font-size: 12px;
      line-height: 1.45;
      color: #1a4a8a;
    }
    .agpb__finCheckoutNote strong { font-weight: 800; }

    /* ── Learn more link ─────────────────────────────────────── */
    .agpb__learnMore {
      display: block;
      font-size: 11px;
      font-weight: 600;
      color: #666;
      text-align: center;
      text-decoration: underline;
      text-underline-offset: 2px;
      padding-top: 4px;
      position: relative;
      z-index: 1;
      pointer-events: all;
    }
    .agpb__learnMore:hover { color: #111; }

    /* ── Sticky ATC bar ──────────────────────────────────────── */
    .agpb__stickyAtc {
      position: fixed;
      left: 0; right: 0; bottom: var(--agpb-sticky-bottom, 0px);
      z-index: 30;
      background: rgba(255,255,255,.96);
      border-top: 1px solid rgba(0,0,0,.08);
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      padding: 8px calc(10px + var(--agpb-sticky-pr, 0px)) calc(8px + env(safe-area-inset-bottom)) calc(10px + var(--agpb-sticky-pl, 0px));
      pointer-events: none;
    }
    .agpb__stickyAtc:not(.is-hidden) { pointer-events: auto; }
    .agpb__stickyAtc.has-preview-bar {
      bottom: calc(var(--agpb-sticky-bottom, 0px) + var(--agpb-preview-bar, 56px));
    }
    .agpb__stickyInner {
      max-width: 1200px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: auto 1fr auto;
      gap: 8px;
      align-items: center;
    }
    .agpb__stickyThumbStrip {
      display: flex;
      gap: 2px;
      align-items: center;
      justify-content: flex-start;
      flex-wrap: nowrap;
      overflow-x: auto;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
      min-width: 0;
      padding: 2px 2px;
    }
    .agpb__stickyThumbStrip::-webkit-scrollbar { display: none; }
    .agpb__stickyThumbItem {
      position: relative;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 2px;
      flex-shrink: 0;
    }
    /* Pre-order treatment in the sticky thumb strip — red thumb border
       only, no ribbon (the strip is too cramped vertically and the
       border alone is a clear enough signal here). */
    .agpb__stickyThumbItem--preorder .agpb__stickyThumb {
      border-color: #b10f0f;
      box-shadow: 0 0 0 1px #b10f0f;
    }
    @media (min-width: 750px) {
      .agpb__stickyThumbItem--preorder {
        border-color: #b10f0f !important;
        box-shadow: 0 0 0 1px #b10f0f;
      }
    }
    @media (min-width: 750px) {
      .agpb__stickyThumbItem {
        flex-direction: row;
        align-items: center;
        gap: 6px;
        background: #fff;
        border: 1px solid #e6e6e6;
        border-radius: 10px;
        padding: 4px 8px 4px 4px;
      }
    }
    .agpb__stickyThumb {
      width: 36px; height: 36px;
      border-radius: 7px;
      border: 2px solid #111;
      background: #f6f6f6;
      object-fit: contain;
      display: block;
      padding: 2px;
      flex-shrink: 0;
    }
    @media (min-width: 750px) {
      .agpb__stickyThumb { width: 40px; height: 40px; }
    }
    .agpb__stickyThumbName {
      font-size: 8px;
      font-weight: 700;
      text-align: center;
      max-width: 40px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      opacity: .6;
    }
    @media (min-width: 750px) {
      .agpb__stickyThumbName {
        font-size: 12px;
        max-width: 120px;
        text-align: left;
        opacity: 1;
      }
    }
    .agpb__stickyThumbText  { display: none; flex-direction: column; gap: 1px; min-width: 0; }
    .agpb__stickyThumbGroup { font-size: 10px; font-weight: 500; opacity: .5; white-space: nowrap; }
    @media (min-width: 750px) {
      .agpb__stickyThumbText { display: flex; }
    }
    .agpb__stickyTotalLabel { font-size: 9px; font-weight: 700; letter-spacing: .02em; text-transform: uppercase; opacity: .5; white-space: nowrap; line-height: 1; }
    .agpb__stickyMiddle     { min-width: 0; display: flex; flex-direction: column; align-items: center; gap: 3px; }
    .agpb__stickyThumbWrap  { display: flex; align-items: center; gap: 4px; min-width: 0; width: 100%; }
    .agpb__stickyThumbArrow {
      flex-shrink: 0;
      width: 20px; height: 20px;
      border-radius: 50%;
      border: 1px solid #ddd;
      background: #fff;
      display: flex; align-items: center; justify-content: center;
      font-size: 14px;
      cursor: pointer;
      color: #333;
      line-height: 1;
      padding: 0;
    }
    .agpb__stickyThumbArrow:hover { border-color: #111; color: #111; }
    .agpb__stickySelLabel   { font-size: 9px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; opacity: .45; white-space: nowrap; }
    .agpb__stickyPrice      { font-weight: 900; white-space: nowrap; font-size: 16px; line-height: 1.1; }
    .agpb__stickySavings    { font-size: 10px; font-weight: 700; color: #1c6b22; white-space: nowrap; line-height: 1; }
    .agpb__stickyBtn        { flex-shrink: 0; height: 40px; border-radius: 12px; border: 1px solid #111; background: #111; color: #fff; padding: 0 12px; font-weight: 900; cursor: pointer; white-space: nowrap; font-size: 13px; }

    /* ── Modals (shared base) ────────────────────────────────── */
    .agpb__modal {
      position: fixed;
      inset: 0;
      z-index: 9020;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 16px;
      overflow-y: auto;
      pointer-events: none;
    }
    .agpb__modal:not(.is-hidden) { pointer-events: auto; }
    .agpb__modalBackdrop {
      position: absolute;
      inset: 0;
      background: rgba(0,0,0,.5);
      backdrop-filter: blur(4px);
      -webkit-backdrop-filter: blur(4px);
    }
    .agpb__modalBox {
      position: relative;
      background: #fff;
      border-radius: 20px;
      padding: 28px 24px 24px;
      max-width: 420px;
      width: 100%;
      box-shadow: 0 24px 60px rgba(0,0,0,.18);
      z-index: 1;
      text-align: center;
    }
    .agpb__modalIcon {
      font-size: 32px;
      margin-bottom: 12px;
      display: block;
    }
    .agpb__modalTitle {
      margin: 0 0 10px;
      font-size: 20px;
      font-weight: 900;
      letter-spacing: -.02em;
    }
    .agpb__modalBody {
      margin: 0 0 20px;
      font-size: 14px;
      opacity: .8;
      line-height: 1.5;
    }
    .agpb__modalActions {
      display: flex;
      gap: 10px;
      justify-content: center;
      flex-wrap: wrap;
    }
    .agpb__modalBtn {
      border-radius: 12px;
      padding: 11px 20px;
      font-size: 14px;
      font-weight: 800;
      cursor: pointer;
      border: 1px solid transparent;
      line-height: 1;
    }
    .agpb__modalBtn--primary   { background: #111; color: #fff; border-color: #111; }
    .agpb__modalBtn--secondary { background: #fff; color: #111; border-color: #e6e6e6; }
    .agpb__modalBtn--primary:hover   { background: #333; border-color: #333; }
    .agpb__modalBtn--secondary:hover { border-color: #111; }

    /* ── Pre-order modal specific ────────────────────────────── */
    .agpb__modalBox--preorder { padding: 32px 28px 28px; }
    .agpb__poBadge {
      display: block;
      background: #b10f0f;
      color: #fff;
      font-size: 13px;
      font-weight: 900;
      letter-spacing: .14em;
      text-transform: uppercase;
      padding: 14px 24px;
      border-radius: 12px 12px 0 0;
      margin: -32px -28px 24px;
    }
    .agpb__poProductName {
      margin: 0 0 8px;
      font-size: 22px;
      font-weight: 900;
      letter-spacing: -.02em;
      line-height: 1.15;
    }
    .agpb__poStockNote {
      margin: 0 0 16px;
      font-size: 14px;
      color: #555;
      line-height: 1.5;
    }
    .agpb__poDateBox {
      background: #f7f7f7;
      border-radius: 12px;
      padding: 12px 16px;
      margin: 0 0 16px;
      display: flex;
      flex-direction: column;
      gap: 2px;
    }
    .agpb__poDateLabel {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: #999;
    }
    .agpb__poDateValue {
      font-size: 18px;
      font-weight: 900;
      color: #111;
    }
    .agpb__poTerms {
      font-size: 12px;
      color: #888;
      margin: 0 0 20px;
      line-height: 1.5;
    }
    .agpb__poTerms a {
      color: #111;
      font-weight: 600;
    }

    /* ── Notify modal specific ───────────────────────────────── */
    .agpb__modalBox--notify { padding: 32px 28px 48px; }
    .agpb__nmBadge {
      display: block;
      background: #333;
      color: #fff;
      font-size: 13px;
      font-weight: 900;
      letter-spacing: .14em;
      text-transform: uppercase;
      padding: 14px 24px;
      border-radius: 12px 12px 0 0;
      margin: -32px -28px 24px;
    }

    /* Addon group status bar — same pill/button styles as base,
       just tighter top margin since it lives inside the group body */
    .agpb__addonStatus {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 8px;
      flex-wrap: wrap;
      margin: 0 0 10px;
    }
    .agpb__notifyInput  {
      width: 100%;
      border: 1px solid #e6e6e6;
      border-radius: 12px;
      padding: 11px 14px;
      font-size: 14px;
      margin-bottom: 20px;
      outline: none;
    }
    .agpb__notifyInput:focus { border-color: #111; box-shadow: 0 0 0 2px rgba(17,17,17,.1); }
      margin-top: 12px;
      font-size: 13px;
      color: #1a6e1a;
      font-weight: 700;
      text-align: center;
    }
    .agpb__notifyFeedback.is-error { color: #8a1f1f; }

    /* ── Finance cards block (BNPL + Payl8r) ─────────────────────── */
    .agpb__fc {
      --fc-red: #c8102e;
      --fc-ink: #111;
      --fc-line: #e6e6e6;
      --fc-muted: #6b6b6b;
      display: flex;
      flex-direction: column;
      gap: 5px;
      margin-top: 8px;
    }
    .agpb__fcCard {
      position: relative;
      border: 1px solid var(--fc-line);
      border-radius: 8px;
      padding: 7px 11px 7px 13px;
      background: #fff;
      overflow: hidden;
    }
    .agpb__fcCard::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      bottom: 0;
      width: 3px;
      background: var(--fc-ink);
    }
    .agpb__fcCard--bnpl {
      background: linear-gradient(180deg, #fafafa 0%, #f4f4f4 100%);
    }
    .agpb__fcCard--bnpl::before { background: var(--fc-ink); }
    .agpb__fcCard--payl8r::before { background: var(--fc-red); }

    /* BNPL card — title + logos on one row, copy below */
    .agpb__fcBnplHead {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
    }
    .agpb__fcTitle {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: .06em;
      margin: 0;
      color: var(--fc-ink);
    }
    .agpb__fcCopy {
      margin: 3px 0 0;
      font-size: 11px;
      color: var(--fc-muted);
      line-height: 1.4;
    }
    .agpb__fcLogos {
      display: flex;
      flex-wrap: wrap;
      gap: 6px 10px;
      align-items: center;
    }
    .agpb__fcLogoWrap {
      display: inline-flex;
      align-items: center;
      height: 22px;
    }
    .agpb__fcLogo {
      max-height: 22px;
      width: auto;
      display: block;
      border-radius: 3px;
    }
    .agpb__fcLogo--payl8r { max-height: 24px; }
    .agpb__fcLogo--text {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 14px;
      letter-spacing: .04em;
      color: #111;
    }
    .agpb__fcLink {
      font-size: 11px;
      color: #111;
      text-decoration: underline;
      white-space: nowrap;
    }
    .agpb__fcLink:hover { color: var(--fc-red); }

    /* Payl8r card — chips up top serve as the price, meta row below */
    .agpb__fcPayl8rBody.is-hidden { display: none; }

    /* Term chips — always-visible, clickable. Active chip = current price. */
    /* Horizontal scroll fallback on narrow widths so chips never squash. */
    .agpb__fcChips {
      display: flex;
      gap: 4px;
      margin-bottom: 5px;
      flex-wrap: nowrap;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      scroll-snap-type: x proximity;
      scrollbar-width: none;
      -ms-overflow-style: none;
      /* Prevent vertical scrollbar from rounding artifacts */
      padding-bottom: 1px;
    }
    .agpb__fcChips::-webkit-scrollbar { display: none; }
    .agpb__fcChip {
      flex: 1 1 60px;
      min-width: 60px;
      scroll-snap-align: start;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 1px;
      padding: 5px 4px;
      background: #fff;
      border: 1px solid var(--fc-line);
      border-radius: 6px;
      cursor: pointer;
      transition: background .12s, border-color .12s, color .12s, transform .08s;
      font-family: inherit;
      color: var(--fc-ink);
    }
    .agpb__fcChip:hover {
      border-color: var(--fc-ink);
    }
    .agpb__fcChip.is-active {
      background: var(--fc-ink);
      border-color: var(--fc-ink);
      color: #fff;
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
    }
    .agpb__fcChipTerm {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .08em;
      color: inherit;
      opacity: .7;
    }
    .agpb__fcChip.is-active .agpb__fcChipTerm { opacity: .85; }
    .agpb__fcChipPermo {
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 14px;
      font-weight: 700;
      color: inherit;
      line-height: 1;
      white-space: nowrap;
    }
    .agpb__fcChip.is-active .agpb__fcChipPermo { font-size: 17px; }
    .agpb__fcChipMo {
      font-size: .65em;
      font-weight: 600;
      opacity: .8;
      margin-left: 1px;
    }
    .agpb__fcPayl8rLogo {
      display: inline-flex;
      align-items: center;
    }
    .agpb__fcPayl8rLogo .agpb__fcLogo--payl8r { max-height: 18px; }

    /* Meta row — rep APR + ⓘ + disclaimer + apply, all on one line */
    .agpb__fcMeta {
      display: flex;
      align-items: center;
      gap: 6px;
      flex-wrap: wrap;
      font-size: 10.5px;
      color: var(--fc-muted);
    }
    .agpb__fcMetaSpacer { display: none; } /* legacy — kept for any older rendered DOM */
    .agpb__fcRep {
      font-weight: 700;
      color: var(--fc-ink);
      white-space: nowrap;
      letter-spacing: .02em;
    }
    .agpb__fcDisclaimer { color: #8a8a8a; }
    .agpb__fcDisclaimer--bnpl {
      display: block;
      margin: 5px 0 0;
      font-size: 10px;
      line-height: 1.45;
      letter-spacing: .01em;
    }
    .agpb__fcInfoBtn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: none;
      border: none;
      padding: 0;
      cursor: pointer;
      color: #aaa;
      transition: color .15s;
    }
    .agpb__fcInfoBtn:hover { color: var(--fc-red); }
    .agpb__fcApply {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 4px;
      padding: 5px 12px;
      margin-left: auto;
      background: var(--fc-red);
      color: #fff;
      border-radius: 999px;
      font-size: 10.5px;
      font-weight: 700;
      text-decoration: none;
      letter-spacing: .06em;
      text-transform: uppercase;
      transition: background .15s ease, transform .08s ease;
    }
    .agpb__fcApply:hover {
      background: #a30d24;
      color: #fff;
      transform: translateY(-1px);
    }

    /* Mobile-specific tweaks ─────────────────────────────────────── */
    @media (max-width: 480px) {
      .agpb__fcCard {
        padding: 8px 11px 8px 13px;
      }
      .agpb__fcChip {
        padding: 6px 5px;
        min-width: 62px;
      }
      .agpb__fcChipPermo { font-size: 13px; }
      .agpb__fcChip.is-active .agpb__fcChipPermo { font-size: 16px; }
      /* Apply button gets full width + bigger tap target on its own line */
      .agpb__fcApply {
        width: 100%;
        margin-left: 0;
        margin-top: 4px;
        padding: 9px 14px;
        font-size: 11px;
      }
      /* BNPL head: title + logos can wrap; logos go below title cleanly */
      .agpb__fcBnplHead { gap: 6px; }
    }

    .agpb__fcTooltip {
      background: #1a1a1a;
      color: #fff;
      border-radius: 8px;
      padding: 9px 11px;
      margin-top: 6px;
      font-size: 11px;
      line-height: 1.5;
      display: flex;
      flex-direction: column;
      gap: 5px;
    }
    .agpb__fcTooltip.is-hidden { display: none; }
    .agpb__fcTooltipLabel {
      font-weight: 700;
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: .05em;
      opacity: .7;
    }
    .agpb__fcTooltipBody { color: #f6f6f6; }
    .agpb__fcTooltipFooter {
      font-size: 10px;
      color: #bbb;
      border-top: 1px solid #333;
      padding-top: 5px;
    }

    .agpb__fcPayl8rMsg.is-hidden { display: none; }
    .agpb__fcOutMsg {
      font-size: 12px;
      color: #777;
      margin: 0;
    }
