﻿/* ============================================================
   LEEF â€” Shop (Ãndice tipogrÃ¡fico + Mural) CC
   ============================================================ */

.shop-page { min-height: 100vh; }

/* ---- Mast ---- */
.shop-mast {
  padding: 48px var(--px) 32px;
  border-bottom: var(--border);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
}
.shop-mast h1 { font-size: clamp(36px, 6vw, 72px); line-height: 1; }
.shop-meta {
  font-family: var(--mono-font);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  opacity: 0.5;
  text-align: right;
  flex-shrink: 0;
}

/* ---- Filter tabs ---- */
.shop-filters {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 var(--px);
  border-bottom: var(--border);
  overflow-x: auto;
}
.shop-filter-btn {
  font-family: var(--mono-font);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  padding: 14px 20px;
  border: none;
  border-right: var(--border-subtle);
  background: transparent;
  color: var(--ink);
  opacity: 0.55;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity var(--t-fast), background var(--t-fast), color var(--t-fast);
}
.shop-filter-btn:hover, .shop-filter-btn.on {
  opacity: 1;
  background: var(--ink);
  color: var(--paper);
}
.shop-filter-btn:first-child { border-left: var(--border-subtle); }

/* ---- Thumbnail (hidden desktop, visible mobile) ---- */
.sr-thumb {
  display: none;
}

/* ---- Index header (columns) ---- */
.shop-index-head {
  display: grid;
  grid-template-columns: 44px 1fr 140px 140px 80px 32px;
  gap: 12px;
  padding: 10px var(--px);
  border-bottom: var(--border);
}
.shop-index-head span {
  font-family: var(--mono-font);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  opacity: 0.45;
}

/* ---- Index rows ---- */
.shop-index { border-bottom: var(--border-subtle); }
.shop-row {
  display: grid;
  grid-template-columns: 44px 1fr 140px 140px 80px 32px;
  gap: 12px;
  align-items: center;
  padding: 20px var(--px);
  border-bottom: var(--border-subtle);
  cursor: pointer;
  transition: padding-left var(--t-mid), background var(--t-mid), color var(--t-mid);
  position: relative;
}
/* sr-thumb is invisible on desktop â€” only the grid columns above apply */
.shop-row:hover {
  padding-left: calc(var(--px) + 20px);
  background: var(--ink);
  color: var(--paper);
}
.shop-row:hover .price { color: var(--accent); }
.shop-row:hover .sr-tag, .shop-row:hover .sr-sizes { opacity: 0.65; }

.sr-n    { font-family: var(--mono-font); font-size: 10px; opacity: 0.5; text-align: center; }
.sr-name { font-family: var(--display-font); font-size: clamp(18px, 2.5vw, 26px); font-weight: 700; }
.sr-tag  { font-family: var(--mono-font); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.55; }
.sr-sizes { font-family: var(--mono-font); font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.55; }
.sr-arr  { font-family: var(--mono-font); font-size: 14px; opacity: 0.5; text-align: right; }

/* ---- Ghost image (follows cursor) ---- */
.ghost-img {
  position: fixed;
  width: 180px;
  height: 240px;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%) rotate(-3deg);
  display: none;
  border: var(--border);
  overflow: hidden;
  background: var(--paper-dark);
}
.ghost-img img { width: 100%; height: 100%; object-fit: cover; }
.ghost-img.visible { display: block; }

/* ---- Editorial block (substitui mural) ---- */
.shop-mural-wrap {
  border-top: var(--border);
  background: var(--ink);
  overflow: hidden;
}

.editorial-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 480px;
}

.editorial-cover {
  min-height: 480px;
  background: var(--paper-dark);
  border-right: 1px solid rgba(255,255,255,0.1);
}

.editorial-info {
  padding: 60px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 16px;
}

.editorial-kicker {
  font-family: var(--mono-font);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--accent);
}

.editorial-title {
  font-size: clamp(36px, 5vw, 72px);
  line-height: 0.95;
  font-weight: 700;
  color: var(--paper);
  font-family: var(--display-font);
}

.editorial-desc {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(243,239,230,0.6);
  max-width: 340px;
}

.editorial-cta {
  display: inline-block;
  margin-top: 8px;
  padding: 14px 28px;
  background: var(--accent);
  color: var(--ink);
  font-family: var(--mono-font);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: 700;
  text-decoration: none;
  align-self: flex-start;
  transition: background var(--t-fast), color var(--t-fast);
}
.editorial-cta:hover { background: var(--paper); color: var(--ink); }

.editorial-playlist { margin-top: 4px; }
.editorial-playlist-label {
  font-family: var(--mono-font);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(243,239,230,0.4);
  display: block;
  margin-bottom: 4px;
}
.editorial-playlist-link {
  font-family: var(--mono-font);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid rgba(254,194,0,0.3);
  padding-bottom: 2px;
  transition: border-color var(--t-fast);
}
.editorial-playlist-link:hover { border-color: var(--accent); }

/* ---- Runner ---- */
.shop-runner {
  border-top: var(--border);
  padding: 14px 0;
  overflow: hidden;
  white-space: nowrap;
  background: var(--ink);
}
.shop-runner span {
  display: inline-block;
  animation: marquee-slide 18s linear infinite;
  will-change: transform;
  backface-visibility: hidden;
  font-family: var(--mono-font);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--paper);
  opacity: 0.6;
}

/* ---- Empty state ---- */
.shop-empty { padding: 80px var(--px); text-align: center; }
.shop-empty p {
  font-family: var(--display-font);
  font-size: 24px;
  font-style: italic;
  opacity: 0.5;
  margin-bottom: 20px;
}

/* ---- Mural image placeholder ---- */
.mural-item .ph {
  display: block;
  width: 200px;
  aspect-ratio: 3/4;
  object-fit: cover;
  object-position: center center;
  border-bottom: var(--border);
  background: var(--paper-dark);
}

/* ===== MOBILE ===== */
@media (max-width: 960px) {
  .shop-mast { padding: 32px var(--px-mob) 24px; flex-direction: column; align-items: flex-start; }
  .shop-index-head { display: none; }

  /* Thumbnail visÃ­vel no mobile */
  .sr-thumb {
    display: block;
    width: 52px;
    aspect-ratio: 3/4;
    border: var(--border-subtle);
    flex-shrink: 0;
  }
  .sr-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
  }
  .shop-row {
    grid-template-columns: 32px 52px 1fr auto;
    gap: 10px;
    padding: 12px var(--px-mob);
    min-height: 72px;
  }
  .shop-row:hover { padding-left: calc(var(--px-mob) + 8px); }
  .sr-tag, .sr-sizes, .sr-arr { display: none; }
  .sr-name { font-size: clamp(15px, 4vw, 20px); }
  .ghost-img { display: none !important; }
  .shop-filters { padding: 0 var(--px-mob); }

  /* Editorial block: empilha em mobile */
  .editorial-block { grid-template-columns: 1fr; }
  .editorial-cover { min-height: 260px; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); }
  .editorial-info { padding: 36px var(--px-mob) 48px; }
  .editorial-cta { width: 100%; text-align: center; }
}

@media (max-width: 480px) {
  .shop-mast h1 { font-size: 32px; }
  .editorial-title { font-size: 40px; }
}





