:root{
  --paper:#faf3ee; --paper-2:#f0e5da; --paper-3:#e9dccd;
  --ink:#1a1318; --ink-soft:#5a4a52; --ink-muted:#8a7780;
  --rose:#b13e54; --rose-dark:#8b2d40; --rose-light:#e8a3b0;
  --rule:#e2cfbe; --rule-soft:#ede0d2;
  --shadow-sm:0 1px 2px rgba(26,19,24,.04);
  --shadow-md:0 12px 32px rgba(139,45,64,.10);
  --shadow-lg:0 30px 80px rgba(26,19,24,.14);
  --font-display:"Fraunces","Iowan Old Style","Palatino Linotype",Georgia,serif;
  --font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --max:74rem; --max-narrow:52rem;
  --radius:18px; --radius-lg:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-sans);
  color:var(--ink);background:var(--paper);
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:var(--rose-dark);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--rose)}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.wrap-narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 1.5rem}

/* === Header === */
header.site{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  background:color-mix(in oklab,var(--paper) 82%, transparent);
  border-bottom:1px solid color-mix(in oklab,var(--rule) 50%, transparent);
}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:1rem;padding-bottom:1rem}
.brand{
  font-family:var(--font-display);
  color:var(--ink);
  display:inline-flex;flex-direction:column;
  line-height:1;gap:.15rem;
}
.brand-name{
  font-weight:600;
  font-variation-settings:"opsz" 72,"SOFT" 80;
  font-size:1.95rem;letter-spacing:-.025em;line-height:.95;
  color:inherit;text-decoration:none;
  transition:color .2s ease;
}
.brand-name:hover{color:var(--rose-dark)}
.brand-name em{font-style:italic;color:var(--rose);font-weight:400}
.brand-attribution{
  display:inline-flex;flex-direction:column;
  gap:.05rem;margin-top:.15rem;
  text-decoration:none;color:inherit;
}
.brand-attribution .brand-by,
.brand-attribution .brand-artist{transition:color .2s ease}
.brand-attribution:hover .brand-by,
.brand-attribution:hover .brand-artist{color:var(--rose)}
.brand-by{
  font-style:italic;
  font-variation-settings:"opsz" 36,"SOFT" 100;
  font-weight:400;
  font-size:.86rem;color:var(--ink-soft);
  letter-spacing:.05em;
}
.brand-artist{
  font-family:var(--font-sans);
  font-size:.62rem;letter-spacing:.27em;
  text-transform:uppercase;color:var(--ink-muted);
  font-weight:600;
}
nav.primary{display:flex;align-items:center;gap:1.5rem}
nav.primary a{
  color:var(--ink-soft);text-decoration:none;
  font-size:.92rem;font-weight:500;transition:color .2s ease;
}
nav.primary a:hover,nav.primary a.is-current{color:var(--ink)}
nav.primary .btn-mini{
  background:var(--ink);color:var(--paper);
  padding:.55rem 1.1rem;border-radius:999px;
  font-weight:500;font-size:.88rem;
}
nav.primary .btn-mini:hover{background:var(--rose-dark);color:#fff}
@media (max-width:40rem){
  nav.primary{gap:.9rem}
  nav.primary a:not(.btn-mini):not(.priority):not(.is-current):not(.cart-link){display:none}
  nav.primary a.priority{font-weight:600;color:var(--ink)}
}

/* === Buttons === */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.95rem 1.5rem;border-radius:999px;
  font-family:var(--font-sans);font-weight:600;text-decoration:none;
  font-size:.95rem;cursor:pointer;border:1px solid transparent;
  transition:transform .15s ease,background .2s ease,color .2s ease,box-shadow .25s ease;
}
.btn-primary{background:var(--ink);color:var(--paper);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--rose-dark);color:#fff;box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* === Sections === */
section{padding:4rem 0;position:relative}
.eyebrow{
  font-family:var(--font-sans);font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--rose);
  display:inline-flex;align-items:center;gap:.6rem;margin:0 0 1.25rem;
}
.eyebrow::before{content:"";width:1.75rem;height:1px;background:currentColor;display:inline-block}
.h-display{
  font-family:var(--font-display);font-weight:400;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  letter-spacing:-.02em;line-height:1.02;color:var(--ink);margin:0;
}
h1.h-display{font-size:clamp(2.5rem,6vw,4.5rem)}
h2.h-display{font-size:clamp(1.8rem,4vw,2.75rem)}
.lede{
  font-family:var(--font-display);font-weight:350;
  font-variation-settings:"opsz" 36,"SOFT" 100;
  font-size:clamp(1.1rem,1.6vw,1.35rem);
  line-height:1.45;color:var(--ink-soft);max-width:38rem;
}

/* === Shop list === */
.shop-head{margin-bottom:3rem;text-align:center}
.shop-grid{
  display:grid;gap:1.5rem;
  grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));
}
.shop-card{
  background:var(--paper);border:1px solid var(--rule);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
  scroll-margin-top:6rem; /* clear the sticky header on anchor scroll */
}
.shop-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--rose-light);
}
.shop-card-area{
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;flex:1;
}
.shop-card .img{
  position:relative;
  aspect-ratio:4/5;background:var(--paper-3);overflow:hidden;
}

/* === Shop filters === */
.shop-filters{
  display:flex;justify-content:center;gap:.5rem;
  margin:0 0 2rem;flex-wrap:wrap;
}
.shop-filters a{
  padding:.5rem 1rem;border-radius:999px;
  font-size:.85rem;font-weight:500;text-decoration:none;
  color:var(--ink-soft);border:1px solid var(--rule);background:var(--paper);
  transition:all .15s ease;
}
.shop-filters a:hover{color:var(--ink);border-color:var(--ink)}
.shop-filters a.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* === Card badges (NEW / popularity flames) === */
.card-badges{
  position:absolute;top:.6rem;right:.6rem;
  z-index:2;display:flex;flex-direction:column;gap:.35rem;align-items:flex-end;
  pointer-events:none;
}
.card-badge{
  display:inline-flex;align-items:center;gap:.2rem;
  padding:.28rem .55rem;border-radius:999px;
  font-size:.65rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  backdrop-filter:saturate(160%) blur(6px);
  -webkit-backdrop-filter:saturate(160%) blur(6px);
}
.badge-new{
  background:var(--rose);color:#fff;
}
.badge-sold{
  background:var(--ink);color:var(--paper);
}
.shop-card.is-sold .img img{filter:grayscale(.45) brightness(.92)}
.shop-card.is-sold:hover .img img{filter:grayscale(.2) brightness(.96)}
.price-sold{color:var(--ink-muted) !important;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}
.badge-popular{
  background:rgba(255,255,255,.94);
  padding:.25rem .45rem;
  letter-spacing:0;
}
.badge-popular svg{display:block}
.badge-popular.tier-1{color:#c9a567}      /* gold */
.badge-popular.tier-2{color:#d97a3c}      /* orange */
.badge-popular.tier-3{color:var(--rose)}  /* rose */
.shop-card .img img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.shop-card:hover .img img{transform:scale(1.04)}
.shop-card .meta{padding:1rem 1.1rem 1.1rem}
.shop-card h3{
  font-family:var(--font-display);font-weight:500;
  font-variation-settings:"opsz" 36,"SOFT" 80;
  font-size:1.15rem;margin:0 0 .25rem;line-height:1.2;color:var(--ink);
}
.shop-card .price{color:var(--rose-dark);font-weight:600;font-size:.95rem}

/* Inline Add to cart on shop cards */
.shop-card:not(.is-sold) .shop-card-area .meta{padding-bottom:.6rem}
.shop-card-action{
  margin:0;padding:0 1.1rem 1.1rem;
}
.shop-card-action button,
.shop-card-action.shop-card-incart{
  display:inline-flex;align-items:center;justify-content:center;
  width:100%;padding:.55rem .75rem;
  border-radius:999px;border:1px solid var(--ink);
  background:transparent;color:var(--ink);
  font-family:var(--font-sans);font-weight:500;font-size:.82rem;
  text-decoration:none;cursor:pointer;
  transition:background .15s ease,color .15s ease;
}
.shop-card-action button:hover,
.shop-card-action.shop-card-incart:hover{
  background:var(--ink);color:var(--paper);
}
.shop-card-action button:disabled{opacity:.5;cursor:default}
.shop-card-action.shop-card-incart{
  border-color:var(--rose-dark);color:var(--rose-dark);
}
.shop-card-action.shop-card-incart:hover{
  background:var(--rose-dark);color:#fff;
}

.empty-shop{
  background:var(--paper-2);border:1px dashed var(--rule);
  border-radius:var(--radius);padding:4rem 2rem;text-align:center;
  color:var(--ink-soft);
}
.empty-shop h3{font-family:var(--font-display);font-size:1.5rem;margin:0 0 .5rem;color:var(--ink)}

/* === Product detail === */
.product{
  display:grid;gap:clamp(2rem,5vw,4rem);
  grid-template-columns:1.1fr 1fr;
  align-items:start;
}
@media (max-width:52rem){.product{grid-template-columns:1fr}}
.product-gallery{display:flex;flex-direction:column;gap:1rem}
.product-gallery .main-img{
  border-radius:var(--radius-lg);overflow:hidden;
  background:var(--paper-3);box-shadow:var(--shadow-lg);
  display:flex;justify-content:center;align-items:center;
}
.product-gallery .main-img img{
  /* Scale to the column width AND cap at 72vh so a small-laptop viewport
     never forces vertical scrolling. The image keeps its natural aspect
     ratio — no auto-cropping. */
  width:auto;max-width:100%;
  height:auto;max-height:72vh;
  object-fit:contain;
}
.product-gallery .thumbs{
  display:grid;gap:.5rem;
  /* Portrait thumbs match the source photo orientation so the whole
     doll fits; auto-fill keeps the row tidy at any width. */
  grid-template-columns:repeat(auto-fill,minmax(4.5rem,1fr));
}
.product-gallery .thumbs button{
  aspect-ratio:4/5;border-radius:8px;overflow:hidden;border:2px solid transparent;
  background:var(--paper-3);padding:0;cursor:pointer;
}
.product-gallery .thumbs button.active{border-color:var(--rose)}
.product-gallery .thumbs img{width:100%;height:100%;object-fit:cover;object-position:center top}

.product-info h1{margin:0 0 .5rem}
.product-info .price{
  font-family:var(--font-display);font-weight:500;
  font-size:2.25rem;color:var(--rose);margin:1rem 0 1.5rem;
}
.product-info .description{
  font-size:1rem;color:var(--ink-soft);line-height:1.7;
  white-space:pre-line;margin-bottom:1.75rem;
}
.product-info .sold-banner{
  background:var(--paper-3);border:1px solid var(--rule);
  border-radius:var(--radius);padding:1.25rem 1.4rem;color:var(--ink-soft);
  margin:1rem 0 1.5rem;
}
.product-info .sold-banner strong{color:var(--ink);display:block;font-family:var(--font-display);font-size:1.1rem;margin-bottom:.25rem}

/* AI photo disclaimer — small, readable, not loud */
.ai-disclaimer{
  font-size:.78rem;color:var(--ink-muted);font-style:italic;
  line-height:1.5;margin:1rem 0 .5rem;
}

/* Share row */
.share-row{
  display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;
  margin-top:1.75rem;padding-top:1.25rem;
  border-top:1px solid var(--rule);
}
.share-label{
  font-size:.75rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-muted);
  margin-right:.4rem;
}
.share-btn{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.45rem .7rem;border-radius:999px;
  border:1px solid var(--rule);background:var(--paper);
  color:var(--ink-soft);text-decoration:none;
  font-family:var(--font-sans);font-size:.78rem;font-weight:500;
  cursor:pointer;
  transition:color .15s ease,border-color .15s ease,background .15s ease;
}
.share-btn:hover{color:var(--ink);border-color:var(--ink);background:var(--paper-2)}
.share-btn svg{flex-shrink:0}
.share-btn.is-copied{background:var(--rose);color:#fff;border-color:var(--rose)}
.buy-card{
  background:var(--paper-2);border:1px solid var(--rule);
  border-radius:var(--radius);padding:1.5rem;
}
.buy-card .note{font-size:.85rem;color:var(--ink-muted);margin-top:1rem}

#paypal-button-container{min-height:44px}

/* === Footer === */
footer.site-foot{padding:3.5rem 0 2.5rem;background:var(--paper-2);color:var(--ink-soft);font-size:.9rem}
footer.site-foot .wrap{max-width:var(--max);text-align:center}
.sig{
  font-family:var(--font-display);font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  font-size:1.4rem;color:var(--ink);margin:0 0 .5rem;line-height:1;
}
.legal{font-size:.78rem;color:var(--ink-muted);margin-top:.75rem}

/* === Success page === */
.success-card{
  max-width:32rem;margin:5rem auto;text-align:center;
  background:var(--paper-2);border:1px solid var(--rule);
  border-radius:var(--radius-lg);padding:3rem 2rem;
}
.success-card h1{font-family:var(--font-display);font-weight:500;font-size:2rem;margin:0 0 1rem}
.success-card p{color:var(--ink-soft);margin-bottom:.5rem}

/* === Back link === */
.back-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.88rem;color:var(--ink-soft);
  text-decoration:none;margin-bottom:1.5rem;
}
.back-link:hover{color:var(--ink)}

/* === Cart link in header === */
.cart-link{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  color:var(--ink-soft);text-decoration:none;
  transition:color .2s ease, background .2s ease;
}
.cart-link:hover{color:var(--ink);background:color-mix(in oklab,var(--rule) 50%, transparent)}
.cart-link .cart-count{
  position:absolute;top:-2px;right:-4px;
  min-width:18px;height:18px;padding:0 5px;
  border-radius:9px;background:var(--rose);color:#fff;
  font-size:.7rem;font-weight:700;line-height:18px;text-align:center;
  display:none;
}
.cart-link.has-items{color:var(--rose-dark)}
.cart-link.has-items .cart-count{display:inline-block}

/* === Cart page === */
section.cart-section{padding:4rem 0 0} /* match shop top, no bottom */
/* But when the cart is empty, the empty-shop block is the only content
   in the section — add bottom padding back so it doesn't touch the
   footer. */
section.cart-section:has(.empty-shop){padding-bottom:4rem}
.cart-layout{
  display:grid;grid-template-columns:1fr;gap:2rem;
  margin:2rem 0;
}
/* Mobile (default): DOM order rules — items, summary, suggestions —
   so the summary + checkout button sit between the cart and the
   suggestion strip. The buyer's checkout flow stays uninterrupted. */
@media (min-width:880px){
  /* Desktop: 2-column grid. Cart items pin to the top of col 1; the
     suggestion strip pins to the BOTTOM of col 1 so its bottom edge
     aligns with the order summary's. Row 2 is 1fr — it expands to
     fill whatever space the summary creates. */
  .cart-layout{
    grid-template-columns:minmax(0, 1fr) 22rem;
    grid-template-rows:auto 1fr;
    grid-template-areas:
      "items summary"
      "suggestions summary";
    align-items:start;
  }
  .cart-items-col{grid-area:items}
  .cart-summary{grid-area:summary}
  .cart-suggestions{grid-area:suggestions; align-self:end; margin:0}
}
.cart-list{display:flex;flex-direction:column;gap:1rem}
.cart-row{
  display:grid;grid-template-columns:96px 1fr auto;gap:1rem;
  align-items:center;
  background:var(--paper-2);border:1px solid var(--rule);
  border-radius:var(--radius);padding:.85rem 1rem;
}
.cart-row-img{
  display:block;width:96px;height:96px;border-radius:12px;overflow:hidden;
  background:var(--paper-3);
}
.cart-row-img img{width:100%;height:100%;object-fit:cover}
.cart-row-meta{min-width:0}
.cart-row-title{
  display:block;font-family:var(--font-display);font-weight:500;
  font-size:1.1rem;color:var(--ink);text-decoration:none;line-height:1.2;
}
.cart-row-title:hover{color:var(--rose-dark)}
.cart-row-tag{font-size:.78rem;color:var(--ink-muted);margin:.3rem 0 0;text-transform:uppercase;letter-spacing:.06em}
.cart-row-side{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}
.cart-row-price{font-family:var(--font-display);font-weight:500;font-size:1.1rem}
.cart-row-remove{
  background:none;border:0;padding:0;cursor:pointer;
  color:var(--ink-muted);font-size:.78rem;text-decoration:underline;
}
.cart-row-remove:hover{color:var(--rose-dark)}
.cart-row-remove:disabled{opacity:.5;cursor:default}

.cart-list-actions{display:flex;justify-content:flex-end;margin-top:.85rem}
.cart-clear{
  background:none;border:0;padding:0;cursor:pointer;
  color:var(--ink-muted);font-size:.82rem;text-decoration:underline;
}
.cart-clear:hover{color:var(--rose-dark)}
.cart-clear:disabled{opacity:.5;cursor:default}

.cart-summary{
  background:var(--paper-2);border:1px solid var(--rule);
  border-radius:var(--radius);padding:1.5rem;
  align-self:start;
}
.cart-summary-title{
  font-family:var(--font-display);font-weight:500;font-size:1.25rem;
  margin:0 0 1rem;
}
.cart-summary-rows{margin:0 0 1.25rem;padding:0;display:flex;flex-direction:column;gap:.4rem}
.cart-summary-rows > div{
  display:flex;justify-content:space-between;align-items:baseline;
  border-bottom:1px dashed var(--rule-soft);padding-bottom:.4rem;
}
.cart-summary-rows dt,.cart-summary-rows dd{margin:0;color:var(--ink-soft);font-size:.92rem}
.cart-summary-rows dd{font-weight:500;color:var(--ink)}
.cart-summary-grand{padding-top:.4rem;border-bottom:0 !important}
.cart-summary-grand dt,.cart-summary-grand dd{
  font-family:var(--font-display);font-size:1.15rem;color:var(--ink);font-weight:500;
}
.cart-shipping-note{font-size:.82rem;color:var(--ink-soft);margin:.4rem 0 1rem;text-align:center;line-height:1.45}
.cart-shipping-note strong{color:var(--ink)}
.cart-shipping-rate{font-size:.74rem;color:var(--ink-muted)}
.cart-shipping-unlocked{
  background:color-mix(in oklab,var(--rose-light) 35%, transparent);
  border:1px solid var(--rose-light);
  border-radius:var(--radius);
  padding:.5rem .75rem;color:var(--rose-dark);
}
.cart-shipping-unlocked strong{color:var(--rose-dark)}

/* Coupon box in cart summary */
.cart-coupon{margin:.25rem 0 1rem}
.cart-coupon-label{display:block;font-size:.82rem;color:var(--ink-soft);margin-bottom:.4rem}
.cart-coupon-row{display:flex;gap:.5rem}
.cart-coupon-row input{
  flex:1;min-width:0;font:inherit;font-size:.9rem;
  padding:.5rem .7rem;border:1px solid var(--rule);border-radius:8px;
  background:#fff;color:var(--ink);text-transform:uppercase;
}
.cart-coupon-row input:focus{outline:none;border-color:var(--rose)}
.cart-coupon-row .btn{padding:.5rem .9rem;font-size:.85rem}
.cart-coupon-applied{
  font-size:.85rem;color:var(--ink-soft);margin:0;
  background:color-mix(in oklab,var(--rose-light) 35%, transparent);
  border:1px solid var(--rose-light);border-radius:var(--radius);
  padding:.5rem .75rem;
}
.cart-coupon-applied strong{color:var(--rose-dark)}
.cart-coupon-remove{
  background:none;border:0;padding:0;margin-left:.25rem;
  font:inherit;font-size:.8rem;color:var(--ink-muted);
  text-decoration:underline;cursor:pointer;
}
.cart-coupon-remove:hover{color:var(--rose-dark)}
.cart-coupon-error{font-size:.82rem;color:#7a1d2c;margin:.5rem 0 0}

/* Shop free-shipping banner */
.shop-banner{
  text-align:center;background:var(--ink);color:var(--paper);
  padding:.6rem 1rem;font-size:.88rem;letter-spacing:.02em;
}
.shop-banner strong{color:#fff}
.shop-banner-icon{color:var(--rose-light);margin-right:.4rem}
.cart-summary .note{font-size:.8rem;color:var(--ink-muted);margin-top:1rem}

/* === Cart suggestions === */
.cart-suggestions{text-align:center;padding:0}
.cart-suggestions-title{font-size:1.6rem;margin:0}
.cart-suggestion-grid{
  display:grid;gap:1.25rem;margin-top:1.5rem;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
}
.cart-suggestion{
  background:var(--paper-2);border:1px solid var(--rule);border-radius:var(--radius);
  padding:.75rem;display:flex;flex-direction:column;gap:.5rem;
  transition:opacity .35s ease, transform .35s ease;
}
.cart-suggestion.is-added{opacity:0;transform:scale(.94)}
.cart-suggestion-img{display:block;border-radius:12px;overflow:hidden;background:var(--paper-3);aspect-ratio:1/1}
.cart-suggestion-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.cart-suggestion-meta{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;text-align:left}
.cart-suggestion-title{
  font-family:var(--font-display);font-weight:500;color:var(--ink);
  text-decoration:none;font-size:.98rem;line-height:1.15;
}
.cart-suggestion-title:hover{color:var(--rose-dark)}
.cart-suggestion-price{font-family:var(--font-display);color:var(--ink-soft);font-size:.95rem;white-space:nowrap}

/* Add-to-cart "added" flash */
.cart-add-btn.is-added{background:var(--rose-dark)}

.cart-suggestions-actions{
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  margin-top:2rem;
}
.cart-suggestions-refresh{
  background:none;border:0;padding:.4rem .6rem;cursor:pointer;
  color:var(--ink-muted);font-size:.88rem;
  display:inline-flex;align-items:center;gap:.4rem;
  transition:color .2s ease;
}
.cart-suggestions-refresh:hover{color:var(--rose-dark)}
.cart-suggestions-refresh:disabled{opacity:.6;cursor:default}
.cart-suggestions-refresh .refresh-icon{
  display:inline-block;font-size:1rem;line-height:1;
  transition:transform .4s ease;
}
.cart-suggestions-refresh.is-spinning .refresh-icon{transform:rotate(360deg)}
.cart-suggestion-grid.is-fading{opacity:.35;transition:opacity .2s ease}
