/* 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-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;padding:.4rem 0 0}
.sh-filter{background:transparent;color:var(--muted);border:1px solid rgba(239,233,221,.18);
  border-radius:100px;padding:.5rem 1.1rem;cursor:pointer;font-family:var(--mono);
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;transition:color .2s,border-color .2s}
.sh-filter:hover{color:var(--text);border-color:rgba(239,233,221,.4)}
.sh-filter[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.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;color:var(--text);font-family:inherit;padding:0}
.sh-card:hover{border-color:rgba(182,9,18,.45);transform:translateY(-2px)}
.sh-card__media{position:relative;display:block}
.sh-card__img{width:100%;aspect-ratio:1;object-fit:contain;display:block;padding:7%;
  background:radial-gradient(58% 52% at 50% 44%,rgba(239,233,221,.07),transparent 72%);
  filter:drop-shadow(0 20px 28px rgba(0,0,0,.55));
  transition:opacity .3s ease}
.sh-card__img--back{position:absolute;inset:0;opacity:0}
.sh-card:hover .sh-card__img--back,.sh-card:focus-visible .sh-card__img--back{opacity:1}
.sh-card:hover .sh-card__media > .sh-card__img:first-child,
.sh-card:focus-visible .sh-card__media > .sh-card__img:first-child{opacity:0}
@media (prefers-reduced-motion:reduce){.sh-card__img{transition:none}}
.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:contain;padding:6%;
  background:radial-gradient(58% 52% at 50% 44%,rgba(239,233,221,.07),transparent 72%);
  filter:drop-shadow(0 18px 26px rgba(0,0,0,.5))}
.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:contain;background:rgba(239,233,221,.05)}
.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}

/* product info (Material, Pflege, Maße) */
.sh-info{margin-top:1.4rem;display:grid;gap:.5rem}
.sh-info__dl{display:grid;grid-template-columns:auto 1fr;gap:.35rem .9rem;margin:.2rem 0 .6rem}
.sh-info__dl dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding-top:.15rem;white-space:nowrap}
.sh-info__dl dd{font-size:13px;line-height:1.55;color:var(--text);opacity:.92}
.sh-info__scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.sh-sizetable{border-collapse:collapse;font-family:var(--mono);font-size:11.5px;margin:.3rem 0 .4rem;min-width:100%}
.sh-sizetable th,.sh-sizetable td{border:1px solid rgba(239,233,221,.12);padding:.4rem .55rem;text-align:center;color:var(--text);white-space:nowrap}
.sh-sizetable thead th{color:var(--muted);letter-spacing:.06em}
.sh-sizetable tbody th{text-align:left;color:var(--muted);font-weight:400}
.sh-info__prod{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
.sh-modal__hook{font-style:italic;color:var(--muted);font-size:14px;margin:.15rem 0 .2rem}

/* v8: Auto-Wechsel der Vorschau (Front/Back), Detail beide Motive */
.sh-card--swap .sh-card__img--back{animation:shB 20s cubic-bezier(.45,0,.55,1) infinite;animation-delay:var(--d,0s)}
.sh-card--swap .sh-card__media > .sh-card__img:first-child{animation:shF 20s cubic-bezier(.45,0,.55,1) infinite;animation-delay:var(--d,0s)}
@keyframes shB{0%,35%{opacity:0}50%,85%{opacity:1}100%{opacity:0}}
@keyframes shF{0%,35%{opacity:1}50%,85%{opacity:0}100%{opacity:1}}
@media(prefers-reduced-motion:reduce){.sh-card--swap .sh-card__img--back,.sh-card--swap .sh-card__media > .sh-card__img:first-child{animation:none}}
.sh-modal__media{display:flex;flex-direction:column;gap:.2rem;overflow-y:auto}
.sh-modal__img + .sh-modal__img{border-top:1px dashed rgba(239,233,221,.12)}
.sh-modal__imglabel{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:.2rem 1rem .6rem;text-align:center}

/* ── v6: Pride Drop Badge ── */
.sh-badge{position:absolute;top:10px;left:-6px;z-index:3;background:#FF2D1A;color:#EFE9DD;
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:.38rem .6rem;transform:rotate(-3deg);box-shadow:0 4px 10px rgba(0,0,0,.45)}
.sh-card__media{position:relative}
.sh-modal__badge{display:inline-block;background:#FF2D1A;color:#EFE9DD;font-family:var(--mono);
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:.32rem .55rem;transform:rotate(-2deg);margin:0 0 .5rem}

/* ── v10: individuelle Edding-Sublines auf Vorschau ── */
.sh-tag{position:absolute;left:10px;bottom:8px;z-index:3;font-size:clamp(15px,1.6vw,19px);
  line-height:1.1;transform:rotate(-2.2deg);pointer-events:none;
  text-shadow:0 1px 2px rgba(0,0,0,.8),0 2px 10px rgba(0,0,0,.6)}
.sh-tag--pm{font-family:'Permanent Marker',cursive}
.sh-tag--rs{font-family:'Rock Salt',cursive;font-size:clamp(12px,1.3vw,15px)}
.sh-tag--cv{font-family:'Caveat',cursive;font-weight:700;font-size:clamp(19px,2vw,24px)}


/* ── v11: Tagline nur noch im Modal, gross ── */
.sh-tag{display:none}
.sh-modal__tag{display:block;margin:.15rem 0 .45rem;transform:rotate(-1.6deg);width:fit-content;
  font-size:clamp(1.5rem,3.2vw,2rem);line-height:1.15}
.sh-modal__tag.sh-tag--rs{font-size:clamp(1.15rem,2.4vw,1.5rem)}
.sh-modal__tag.sh-tag--cv{font-size:clamp(1.9rem,4vw,2.5rem)}
