/* ASSC Shop — THE KEY storefront on the ASSC design system (inherits /styles.css). */

.sh-top{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:1rem;
  padding:.85rem clamp(1rem,4vw,2.4rem);background:rgba(4,3,5,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(239,233,221,.08)}
.sh-top__brand{display:flex;align-items:center;gap:.55rem}
.sh-top__key{height:24px;width:auto}
.sh-top__word{font-family:var(--mono);font-weight:700;letter-spacing:.18em;font-size:12.5px;text-transform:uppercase;color:var(--text)}
.sh-top__cart{margin-left:auto;background:none;border:1px solid rgba(239,233,221,.2);border-radius:100px;
  color:var(--text);font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:.5rem .9rem;cursor:pointer}
.sh-top__cart:hover{border-color:var(--accent)}

.sh-wrap{max-width:1100px;margin:0 auto;padding:0 clamp(1rem,4vw,2.4rem) 4rem}
.sh-head{text-align:center;padding:clamp(2rem,6vw,3.6rem) 0 1.4rem}
.sh-head__key{height:60px;margin:0 auto 1rem;filter:drop-shadow(0 0 26px rgba(255,255,255,.06))}
.sh-head h1{font-size:clamp(1.9rem,6vw,3rem);letter-spacing:-.02em;text-transform:uppercase}
.sh-head p{color:var(--muted);margin-top:.7rem;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}

.sh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.1rem;padding:1.4rem 0}
.sh-card{background:var(--panel);border:1px solid rgba(239,233,221,.07);border-radius:14px;overflow:hidden;
  cursor:pointer;transition:border-color .2s,transform .2s;text-align:left}
.sh-card:hover{border-color:rgba(182,9,18,.45);transform:translateY(-2px)}
.sh-card__img{width:100%;aspect-ratio:1;object-fit:cover;background:#ece9e2;display:block}
.sh-card__b{padding:.9rem 1rem 1.1rem}
.sh-card__name{font-weight:700;font-size:14.5px;line-height:1.25}
.sh-card__price{color:var(--muted);font-family:var(--mono);font-size:13px;margin-top:.35rem}

/* modal */
.sh-modal{position:fixed;inset:0;z-index:50;background:rgba(4,3,5,.9);display:none;align-items:center;justify-content:center;padding:1.2rem}
.sh-modal.is-open{display:flex}
.sh-modal__box{background:var(--panel);border:1px solid rgba(239,233,221,.1);border-radius:18px;
  max-width:780px;width:100%;max-height:90vh;overflow:auto;display:grid;grid-template-columns:1fr 1fr}
@media(max-width:640px){.sh-modal__box{grid-template-columns:1fr}}
.sh-modal__img{width:100%;aspect-ratio:1;object-fit:cover;background:#ece9e2}
.sh-modal__b{padding:1.6rem 1.6rem 1.8rem}
.sh-modal__name{font-size:1.4rem;line-height:1.15;letter-spacing:-.01em}
.sh-modal__price{font-family:var(--mono);font-size:1.05rem;color:var(--text);margin:.5rem 0 1.1rem}
.sh-modal__close{position:absolute;top:1rem;right:1.1rem;background:none;border:none;color:var(--text);font-size:1.6rem;cursor:pointer;z-index:2}
.sh-sizes{display:flex;flex-wrap:wrap;gap:.45rem;margin:.3rem 0 1.2rem}
.sh-size{min-width:46px;background:transparent;color:var(--text);border:1px solid rgba(239,233,221,.2);
  border-radius:10px;padding:.55rem .7rem;cursor:pointer;font-family:var(--mono);font-size:13px}
.sh-size[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.sh-size[disabled]{opacity:.3;cursor:not-allowed;text-decoration:line-through}
.sh-label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}

/* cart drawer */
.sh-drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,92vw);background:var(--panel);z-index:60;
  border-left:1px solid rgba(239,233,221,.1);transform:translateX(100%);transition:transform .25s ease;
  display:flex;flex-direction:column}
.sh-drawer.is-open{transform:none}
.sh-drawer__h{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.3rem;border-bottom:1px solid rgba(239,233,221,.08)}
.sh-drawer__h h2{font-size:1.1rem}
.sh-drawer__close{background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}
.sh-items{flex:1;overflow:auto;padding:1rem 1.3rem}
.sh-item{display:flex;gap:.85rem;padding:.8rem 0;border-bottom:1px solid rgba(239,233,221,.06)}
.sh-item img{width:54px;height:54px;border-radius:8px;object-fit:cover;background:#ece9e2}
.sh-item__n{font-size:13.5px;font-weight:700;line-height:1.2}
.sh-item__m{font-family:var(--mono);font-size:11.5px;color:var(--muted);margin-top:.2rem}
.sh-item__rm{background:none;border:none;color:var(--muted);font-family:var(--mono);font-size:11px;cursor:pointer;margin-top:.3rem}
.sh-item__rm:hover{color:var(--accent)}
.sh-empty{color:var(--muted);text-align:center;padding:2.5rem 1rem;font-size:14px}
.sh-drawer__f{padding:1.2rem 1.3rem;border-top:1px solid rgba(239,233,221,.08)}
.sh-total{display:flex;justify-content:space-between;font-family:var(--mono);margin-bottom:1rem}
.sh-total strong{font-size:1.1rem}
.sh-note{font-size:12px;color:var(--muted);line-height:1.5;margin-top:.8rem;text-align:center}

.sh-foot{border-top:1px solid rgba(239,233,221,.08);margin-top:2.5rem;padding:1.8rem clamp(1rem,4vw,2.4rem);
  font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--muted);text-align:center;line-height:1.7}
.sh-foot a{color:var(--muted);text-decoration:underline;text-decoration-color:rgba(239,233,221,.2)}
.sh-scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55;display:none}
.sh-scrim.is-open{display:block}
