.shopCardHost{position:relative;z-index:0}.shopCardHost:hover{z-index:5}.shopCardImageWrap{position:relative;width:fit-content}.shopCardBuyBtn{position:absolute;bottom:0;top:auto;left:calc(100% - var(--spacing-2));z-index:4;white-space:nowrap;padding:var(--spacing-2) var(--spacing-4);background-color:var(--primary);color:var(--color-text-inverse);border:none;border-radius:var(--radius-pill);font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md,0 2px 8px rgba(0,0,0,.18));opacity:0;transform:translateX(calc(-1 * var(--spacing-1)));pointer-events:none;transition:opacity .18s ease .12s,transform .18s ease .12s,background-color .15s ease}.shopCardBuyBtn:before{content:"";position:absolute;top:calc(-1 * var(--spacing-2));bottom:calc(-1 * var(--spacing-2));left:calc(-1 * var(--spacing-5));width:var(--spacing-5)}.shopCardHost:hover .shopCardBuyBtn{opacity:1;transform:translateX(0);pointer-events:auto;transition-delay:0s}.shopCardBuyBtn:not(.shopCardBuyBtn--disabled):hover{opacity:.92}.shopCardBuyBtn--disabled{background-color:var(--color-gray-mid-2);cursor:not-allowed}@media (max-width:640px){.shopCardBuyBtn{left:auto;right:var(--spacing-2);top:auto;bottom:var(--spacing-2);opacity:.95;transform:none;pointer-events:auto}}.materialBuyBtn.shopBuyBtn--disabled{background-color:var(--color-gray-mid-2);cursor:not-allowed}.shopModalOverlay{position:fixed;inset:0;background-color:var(--color-overlay-dark);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);z-index:1000}.shopModal{background-color:var(--color-background-default);border-radius:var(--radius-modal);width:100%;max-width:720px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg,0 12px 40px rgba(0,0,0,.25))}.shopModalHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-4);padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--color-border-light)}.shopPreviewBadge{display:inline-block;padding:2px var(--spacing-2);background-color:var(--color-warning-light);color:var(--color-warning-text);border:1px solid var(--color-warning-border);border-radius:var(--radius-pill);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-bottom:var(--spacing-2)}.shopModalTitle{margin:0;font-size:22px;font-weight:700;color:var(--color-text-primary)}.shopModalClose{background:none;border:none;font-size:28px;line-height:1;color:var(--color-text-light);cursor:pointer;padding:0}.shopModalClose:hover{color:var(--color-text-primary)}.shopModalBody{padding:var(--spacing-5) var(--spacing-6);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-5)}.shopEmptyNote{margin:0;padding:var(--spacing-4);background-color:var(--color-background-darker);border-radius:var(--radius-card);color:var(--color-text-light);font-size:14px}.shopField{display:flex;flex-direction:column;gap:var(--spacing-3)}.shopField--inline{flex-direction:row;align-items:center;justify-content:space-between}.shopFieldLabel{font-size:13px;font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.03em}.shopChipRow{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.shopChip{padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-white);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-pill);font-size:14px;cursor:pointer;transition:border-color .15s ease,background-color .15s ease,color .15s ease}.shopChip--active,.shopChip:not(.shopChip--active):not(.shopChip--disabled):hover{border-color:var(--primary)}.shopChip--active{background-color:var(--primary);color:var(--color-text-inverse)}.shopChip--disabled{background-color:var(--color-gray-light-2);color:var(--color-text-secondary);border-color:var(--color-border-light);cursor:not-allowed}.shopChipEmpty{font-size:13px;color:var(--color-text-muted);font-style:italic}.shopNumberInput{width:120px;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-input);font-size:15px;color:var(--color-text-primary)}.shopNumberInput:focus{outline:none;border-color:var(--primary)}.shopQty{display:inline-flex;align-items:center;gap:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:var(--spacing-1) var(--spacing-2)}.shopQtyBtn{width:28px;height:28px;border:none;background-color:var(--color-background-darker);border-radius:var(--radius-full);font-size:18px;line-height:1;cursor:pointer;color:var(--color-text-primary)}.shopQtyBtn:hover{background-color:var(--color-gray-light)}.shopQtyValue{min-width:24px;text-align:center;font-size:15px;font-weight:600}.shopAvailability{font-size:13px}.shopInStock{color:var(--color-success-dark);font-weight:600}.shopOutStock{color:var(--color-error);font-weight:600}.shopStubNote{margin:0;font-size:12px;color:var(--color-text-muted);font-style:italic}.shopWarn{padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-error-light);color:var(--color-error-text);border:1px solid var(--color-error-border);border-radius:var(--radius-md);font-size:13px;font-weight:600}.shopFilterToggle{padding-top:8px;padding-bottom:8px;display:flex;align-items:center;gap:var(--spacing-3);cursor:pointer;font-size:14px;color:var(--color-text-primary)}.shopFilterToggle input{position:absolute;opacity:0;width:0;height:0}.shopFilterToggleTrack{position:relative;flex:0 0 auto;width:38px;height:22px;border-radius:var(--radius-pill);background-color:var(--color-gray-light);transition:background-color .18s ease}.shopFilterToggleTrack:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:var(--radius-full);background-color:var(--color-white);box-shadow:0 1px 2px rgba(0,0,0,.25);transition:transform .18s ease}.shopFilterToggle input:checked+.shopFilterToggleTrack{background-color:var(--primary)}.shopFilterToggle input:checked+.shopFilterToggleTrack:after{transform:translateX(16px)}.shopFilterToggleLabel{font-weight:600}.shopCsWrap{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) 0 var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.shopCsSvg{width:180px;height:180px;touch-action:none}.shopCsGuide{fill:var(--color-background-darker);stroke:var(--color-border-light);stroke-width:1}.shopCsRing{fill:none;stroke:var(--color-gray-mid-2);stroke-width:3;cursor:grab}.shopCsRing--active{stroke:var(--primary)}.shopCsRect{fill:var(--color-tint-7);fill-opacity:.5;stroke:var(--color-gray-mid-2);stroke-width:3;cursor:pointer}.shopCsRect.shopCsRing--active{stroke:var(--primary)}.shopCsMatch{font-size:12px;font-weight:700;color:var(--color-success-dark)}.shopCsHandle{fill:var(--primary);stroke:var(--color-white);stroke-width:2;cursor:grab}.shopCsLabel{fill:var(--color-text-light);font-size:12px;font-weight:600;pointer-events:none}.shopCsInfo{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap;justify-content:center}.shopCsInfoItem{font-size:12px;color:var(--color-text-light)}.shopCsReset{padding:var(--spacing-1) var(--spacing-4);border:1px solid var(--color-border);background-color:var(--color-white);border-radius:var(--radius-pill);font-size:12px;font-weight:600;color:var(--color-text-primary);cursor:pointer}.shopCsReset:not(:disabled):hover{border-color:var(--primary);color:var(--primary)}.shopCsReset:disabled{opacity:.5;cursor:default}.shopAutoH{height:auto;overflow:hidden;transition:height .3s ease}.shopCsCollapse{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}.shopCsCollapse--open{grid-template-rows:1fr}.shopCsCollapseInner{overflow:hidden;min-height:0}.shopAmount{display:inline-flex;align-items:center;gap:var(--spacing-1)}.shopAmountBtn{width:32px;height:32px;border:1px solid var(--color-border);background-color:var(--color-background-darker);border-radius:var(--radius-md);font-size:18px;line-height:1;cursor:pointer;color:var(--color-text-primary);transition:border-color .15s ease,background-color .15s ease}.shopAmountBtn:hover{border-color:var(--primary)}.shopAmountBtn--sm{width:26px;height:26px;font-size:13px;opacity:.85}.shopAmount .shopNumberInput{width:84px;text-align:center}.shopModalFooter{display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border-light);background-color:var(--color-background-light)}.shopModalFooterRow{gap:var(--spacing-4)}.shopAddedMsg,.shopModalFooterRow{display:flex;align-items:center;justify-content:space-between}.shopAddedMsg{gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-success-light);border:1px solid var(--color-success-border);border-radius:var(--radius-md);animation:shopFadeIn .2s ease}.shopAddedText{color:var(--color-success-text);font-weight:600;font-size:14px}.shopAddedCartBtn{color:var(--color-success-dark);font-weight:700;font-size:14px;text-decoration:none;white-space:nowrap}.shopAddedCartBtn:hover{text-decoration:underline}@keyframes shopFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.shopTotal{display:flex;flex-direction:column}.shopTotalLabel{font-size:12px;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.03em}.shopTotalValue{font-size:22px;font-weight:700;color:var(--color-text-primary)}.shopAddBtn{display:inline-block;width:fit-content;padding:var(--spacing-3) var(--spacing-5);border:none;border-radius:var(--radius-3xl);font-size:15px;font-weight:600;background-color:var(--primary);color:var(--color-text-inverse);cursor:pointer;transition:opacity .15s ease,background-color .15s ease}.shopAddBtn:hover:not(:disabled){opacity:.9}.shopAddBtn:disabled{background-color:var(--color-gray-mid-2);cursor:not-allowed}.shopAddBtn--done{background-color:var(--color-success)}.shopAddBtn--done:hover{opacity:.9}@media (max-width:560px){.shopModal{max-width:100%}.shopModalFooterRow{flex-direction:column;align-items:stretch}.shopModalFooter .shopAddBtn{width:100%;text-align:center}}