/* Shop page — inherits tokens from styles.css */

html:has(.shop-body), .shop-body { overflow: auto; height: auto; }
.shop-body {
  display: block;
  min-height: 100svh;
  padding-bottom: 6rem;
}
.shop-body #wave { opacity: 0.32; }
.shop-body .vignette { z-index: 1; }

.shop-head {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.4rem clamp(1rem, 4vw, 3rem);
  backdrop-filter: blur(6px);
  background: linear-gradient(180deg, rgba(3,16,13,0.85), rgba(3,16,13,0));
}

.back { text-decoration: none; display: flex; gap: 0.4rem; align-items: baseline; }
.back .mark {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 300;
  font-size: 0.92rem;
  letter-spacing: 0.34em;
  color: var(--ink);
}
.back .mark.b { font-weight: 500; color: var(--teal); }
.back:hover .mark.b { text-shadow: 0 0 14px rgba(31,240,200,0.7); }

.cart-btn {
  background: transparent;
  border: 1px solid rgba(215,255,244,0.22);
  color: var(--ink);
  font-family: "Space Mono", monospace;
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  padding: 0.6rem 1rem;
  cursor: pointer;
  transition: all 0.35s var(--ease);
}
.cart-btn:hover { border-color: var(--teal); color: var(--teal); box-shadow: 0 0 16px rgba(31,240,200,0.25); }
#cart-count {
  color: var(--teal);
  margin-left: 0.3rem;
}

.shop-main {
  position: relative;
  z-index: 3;
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(2rem, 6vw, 4rem) clamp(1rem, 4vw, 3rem) 0;
}

.shop-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 300;
  font-size: clamp(2rem, 6vw, 3.6rem);
  letter-spacing: 0.36em;
  text-indent: 0.36em;
  color: var(--ink);
  text-shadow: 0 0 22px rgba(31,240,200,0.3);
}
.shop-sub {
  margin-top: 0.9rem;
  font-family: "Space Mono", monospace;
  font-size: 0.8rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(215,255,244,0.45);
}

.grid {
  margin-top: clamp(2rem, 5vw, 3.4rem);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: clamp(1rem, 2.5vw, 2rem);
}
.empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 5rem 1rem;
  font-family: "Space Mono", monospace;
  font-size: 0.85rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgba(215,255,244,0.4);
}

.card {
  position: relative;
  cursor: pointer;
  border: 1px solid rgba(215,255,244,0.1);
  background: rgba(8,22,18,0.4);
  transition: border-color 0.4s var(--ease), transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
  overflow: hidden;
}
.card:hover {
  border-color: rgba(31,240,200,0.55);
  transform: translateY(-4px);
  box-shadow: 0 14px 40px rgba(0,0,0,0.5), 0 0 24px rgba(31,240,200,0.15);
}
.card-img {
  aspect-ratio: 1;
  width: 100%;
  object-fit: cover;
  background: #061712;
  display: block;
  filter: saturate(1.05);
}
.card-body { padding: 1rem 1.1rem 1.3rem; }
.card-title {
  font-family: "Space Grotesk", sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  color: var(--ink);
}
.card-price {
  margin-top: 0.4rem;
  font-family: "Space Mono", monospace;
  font-size: 0.82rem;
  color: var(--teal);
  letter-spacing: 0.06em;
}
.sold-out {
  position: absolute; top: 0.8rem; left: 0.8rem;
  font-family: "Space Mono", monospace;
  font-size: 0.62rem; letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(215,255,244,0.6);
  border: 1px solid rgba(215,255,244,0.25);
  padding: 0.25rem 0.5rem;
  background: rgba(0,0,0,0.5);
}

/* Product detail + cart shared overlay */
.pdp, .cart { position: fixed; inset: 0; z-index: 50; }
.pdp[hidden], .cart[hidden] { display: none; }
.pdp-backdrop, .cart-backdrop {
  position: absolute; inset: 0;
  background: rgba(1,7,5,0.78);
  backdrop-filter: blur(4px);
}

.pdp-card {
  position: relative;
  z-index: 1;
  max-width: 880px;
  margin: 5vh auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: #051310;
  border: 1px solid rgba(31,240,200,0.22);
  box-shadow: 0 0 60px rgba(0,0,0,0.7);
  max-height: 90vh;
  overflow: auto;
}
@media (max-width: 720px) { .pdp-card { grid-template-columns: 1fr; margin: 0; max-height: 100vh; height: 100%; } }
.pdp-media { background: #061712; }
.pdp-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp-info { padding: clamp(1.4rem, 4vw, 2.6rem); display: flex; flex-direction: column; gap: 1rem; }
.pdp-info h2 { font-family: "Space Grotesk", sans-serif; font-weight: 400; font-size: 1.6rem; letter-spacing: 0.05em; }
.pdp-price { font-family: "Space Mono", monospace; color: var(--teal); font-size: 1.05rem; }
.pdp-desc { font-size: 0.9rem; line-height: 1.7; color: rgba(215,255,244,0.6); white-space: pre-line; }
.pdp-x, .cart-x {
  position: absolute; top: 0.6rem; right: 0.9rem;
  background: none; border: none; color: var(--ink);
  font-size: 1.8rem; cursor: pointer; line-height: 1; z-index: 2;
}
.pdp-x:hover, .cart-x:hover { color: var(--teal); }

.opt { margin-bottom: 0.8rem; }
.opt-name {
  font-family: "Space Mono", monospace;
  font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(215,255,244,0.45); display: block; margin-bottom: 0.5rem;
}
.opt-vals { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.opt-val {
  background: transparent;
  border: 1px solid rgba(215,255,244,0.2);
  color: var(--ink);
  font-family: "Space Mono", monospace;
  font-size: 0.78rem;
  padding: 0.5rem 0.85rem;
  cursor: pointer;
  transition: all 0.3s var(--ease);
}
.opt-val:hover { border-color: rgba(31,240,200,0.6); }
.opt-val[aria-pressed="true"] { border-color: var(--teal); color: var(--teal); box-shadow: inset 0 0 0 1px var(--teal); }
.opt-val:disabled { opacity: 0.3; cursor: not-allowed; text-decoration: line-through; }

.add-btn, .checkout-btn {
  margin-top: 0.6rem;
  background: transparent;
  border: 1px solid var(--teal);
  color: var(--teal);
  font-family: "Space Mono", monospace;
  font-size: 0.82rem;
  letter-spacing: 0.22em;
  padding: 0.95rem 1rem;
  cursor: pointer;
  transition: all 0.35s var(--ease);
}
.add-btn:hover, .checkout-btn:hover:not(:disabled) {
  background: var(--teal);
  color: #03110d;
  box-shadow: 0 0 26px rgba(31,240,200,0.5);
}
.add-btn:disabled, .checkout-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.pdp-msg { font-family: "Space Mono", monospace; font-size: 0.76rem; letter-spacing: 0.16em; color: var(--teal); min-height: 1em; }

/* Cart drawer */
.cart-panel {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(420px, 100vw);
  background: #051310;
  border-left: 1px solid rgba(31,240,200,0.2);
  display: flex; flex-direction: column;
  animation: slide 0.4s var(--ease);
}
@keyframes slide { from { transform: translateX(100%); } to { transform: translateX(0); } }
.cart-top {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.4rem 1.6rem;
  font-family: "Space Mono", monospace;
  letter-spacing: 0.22em; font-size: 0.82rem;
  border-bottom: 1px solid rgba(215,255,244,0.1);
}
.cart-x { position: static; font-size: 1.6rem; }
.cart-lines { flex: 1; overflow: auto; padding: 1rem 1.6rem; display: flex; flex-direction: column; gap: 1.1rem; }
.cart-empty { color: rgba(215,255,244,0.4); font-family: "Space Mono", monospace; font-size: 0.8rem; letter-spacing: 0.18em; text-align: center; padding: 3rem 0; }
.line { display: grid; grid-template-columns: 56px 1fr auto; gap: 0.9rem; align-items: center; }
.line img { width: 56px; height: 56px; object-fit: cover; background: #061712; }
.line-t { font-size: 0.85rem; }
.line-v { font-family: "Space Mono", monospace; font-size: 0.7rem; color: rgba(215,255,244,0.45); margin-top: 0.2rem; }
.qty { display: flex; align-items: center; gap: 0.5rem; margin-top: 0.4rem; }
.qty button { background: none; border: 1px solid rgba(215,255,244,0.2); color: var(--ink); width: 22px; height: 22px; cursor: pointer; }
.qty button:hover { border-color: var(--teal); color: var(--teal); }
.line-price { font-family: "Space Mono", monospace; font-size: 0.8rem; color: var(--teal); }
.cart-foot { padding: 1.4rem 1.6rem; border-top: 1px solid rgba(215,255,244,0.1); }
.cart-sub { display: flex; justify-content: space-between; font-family: "Space Mono", monospace; font-size: 0.85rem; letter-spacing: 0.16em; margin-bottom: 1rem; }
#cart-subtotal { color: var(--teal); }
.checkout-btn { width: 100%; }
.cart-note { margin-top: 0.8rem; text-align: center; font-family: "Space Mono", monospace; font-size: 0.62rem; letter-spacing: 0.14em; color: rgba(215,255,244,0.35); }

@media (prefers-reduced-motion: reduce) { .cart-panel { animation: none; } }
