/* ===== Shop ===== */
/* "Our Desserts" header — text left, photo bleeds in from the right and fades */
.shop-band { position: relative; overflow: hidden; color: var(--on-dark);
  background: linear-gradient(100deg, var(--espresso) 0%, var(--espresso-2) 52%, var(--cocoa) 100%); }
.shop-band::before { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(199,154,75,.5), transparent); z-index: 3; }
.shop-band-inner { position: relative; z-index: 2; padding: 54px 28px 50px; }
.shop-band-text { max-width: 560px; }
.shop-band .ark-crumbs { color: var(--on-dark-soft); margin-bottom: 14px; font-size: 12px; letter-spacing: .5px; }
.shop-band .ark-crumbs a:hover { color: var(--gold-soft); }
.shop-band .ark-crumbs .sep { margin: 0 8px; opacity: .6; }
.shop-band .ark-crumbs .cur { color: var(--gold-soft); }
.shop-band .ark-eyebrow { text-align: left; margin-bottom: 2px; }
.shop-band h1 { font-size: 44px; color: var(--on-dark); letter-spacing: .3px; }
.shop-band-sub { color: var(--on-dark-soft); font-size: 15px; line-height: 1.7; margin: 14px 0 0; max-width: 480px; }
.shop-band-art { position: absolute; top: 0; right: 0; bottom: 0; width: 50%; z-index: 1; pointer-events: none;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, rgba(0,0,0,.5) 30%, #000 66%);
  mask-image: linear-gradient(to right, transparent 0%, rgba(0,0,0,.5) 30%, #000 66%); }
.shop-band-art .ark-photo { height: 100% !important; width: 100% !important; border-radius: 0 !important; }
.shop-band-art .ark-photo span { display: none; }

.shop { padding: 48px 28px 40px; }
.shop-intro { text-align: center; max-width: 600px; margin: 0 auto 38px; }
.shop-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-bottom: 26px; }
.shop-tab { background: var(--card); border: 1px solid var(--card-line); border-radius: 999px;
  padding: 10px 20px; font-size: 12.5px; font-weight: 700; letter-spacing: .8px; color: var(--ink-soft);
  text-transform: uppercase; transition: .15s; }
.shop-tab:hover { border-color: var(--gold); color: var(--ink); }
.shop-tab.active { background: var(--maroon); color: #fbeede; border-color: var(--maroon); }
.shop-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 0 2px 22px; border-bottom: 1px solid var(--card-line); margin-bottom: 32px; }
.shop-count { font-size: 13.5px; color: var(--ink-soft); font-weight: 600; }
.shop-bar-right { display: flex; align-items: center; gap: 18px; }
.shop-sort { font-size: 12.5px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 8px; }
.shop-sort select { font-family: var(--sans); font-size: 13px; font-weight: 600; text-transform: none; letter-spacing: 0;
  border: 1px solid var(--card-line); background: var(--card); border-radius: 7px; padding: 8px 10px; color: var(--ink); }
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.shop-empty { text-align: center; padding: 60px 0; color: var(--ink-soft); }
.shop-empty p { font-size: 17px; margin-bottom: 18px; }

@media (max-width: 920px) { .shop-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px) {
  .shop-band h1 { font-size: 34px; }
  .shop-band-art { width: 100%; opacity: .16;
    -webkit-mask-image: linear-gradient(to bottom, #000, transparent 82%);
    mask-image: linear-gradient(to bottom, #000, transparent 82%); }
}
@media (max-width: 560px) {
  .shop-grid { grid-template-columns: 1fr; }
  .shop-bar { flex-direction: column; align-items: flex-start; gap: 12px; }
}
