/* ——— SHARED LISTING (category) PAGE STYLES ——— */
.subnav {
  background: var(--paper);
  border-bottom: 1px solid var(--grey-line);
  position: sticky; top: 56px; z-index: 50;
  backdrop-filter: blur(10px);
}
.subnav__inner {
  display: flex; gap: 10px;
  overflow-x: auto;
  padding: 18px 0;
  scrollbar-width: none;
}
.subnav__inner::-webkit-scrollbar { display: none; }
.subpill {
  font-family: var(--sans);
  font-size: 11.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  white-space: nowrap;
  border: 1px solid var(--grey-line);
  padding: 10px 16px;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 200ms;
  background: transparent;
}
.subpill:hover { border-color: var(--ink); }
.subpill.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.subpill .num {
  font-family: var(--serif); font-style: italic; font-size: 13px; letter-spacing: 0;
  margin-left: 8px; color: var(--gold); text-transform: none;
}
.subpill.is-active .num { color: rgba(244,241,234,0.7); }

.controls {
  display: flex; justify-content: space-between; align-items: center;
  padding: 32px 0 24px;
  border-bottom: 1px solid var(--grey-line);
  margin-bottom: 40px;
  flex-wrap: wrap; gap: 16px;
}
.controls__count { font-family: var(--sans); font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--grey-warm); }
.controls__count strong { font-family: var(--serif); font-style: italic; font-weight: 400; color: var(--gold); font-size: 16px; letter-spacing: 0; }
.controls__right { display: flex; gap: 24px; align-items: center; }
.sort { font-family: var(--sans); font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--ink); border: 0; background: transparent; cursor: pointer; display: flex; align-items: center; gap: 8px; }
.sort .arrow::after { content: "↓"; font-size: 14px; }
.viewmode { display: flex; gap: 4px; }
.viewmode button { width: 32px; height: 32px; border: 1px solid var(--grey-line); background: transparent; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 150ms; }
.viewmode button.is-active { background: var(--ink); border-color: var(--ink); }
.viewmode button.is-active svg { stroke: var(--paper); }
.viewmode svg { width: 14px; height: 14px; stroke: var(--ink); stroke-width: 1.4; fill: none; }

.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(24px, 2.5vw, 40px) clamp(20px, 2vw, 28px);
  padding-bottom: 80px;
}
@media (max-width: 1180px) { .products { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px)  { .products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .products { grid-template-columns: 1fr; } }

.card { display: block; position: relative; cursor: pointer; }
.card__media { position: relative; aspect-ratio: 4/5; background: var(--paper-deep); overflow: hidden; margin-bottom: 18px; }
.card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1200ms var(--ease-out-expo); }
.card:hover .card__media img { transform: scale(1.05); }
.card__chip { position: absolute; top: 14px; left: 14px; font-family: var(--sans); font-size: 9.5px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--ink); background: var(--paper); padding: 5px 9px; border: 1px solid var(--ink); z-index: 2; }
.card__chip--gold { background: var(--gold); color: var(--paper); border-color: var(--gold); }
.card__chip--ink  { background: var(--ink);  color: var(--paper); border-color: var(--ink); }
.card__quick { position: absolute; left: 14px; right: 14px; bottom: 14px; z-index: 2; background: var(--ink); color: var(--paper); font-family: var(--sans); font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; padding: 12px; text-align: center; opacity: 0; transform: translateY(8px); transition: opacity 400ms, transform 400ms var(--ease-out-expo); }
.card:hover .card__quick { opacity: 1; transform: translateY(0); }
.card__brand { font-family: var(--sans); font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--grey-warm); margin-bottom: 6px; }
.card__name { font-family: var(--serif); font-weight: 400; font-size: clamp(20px, 1.4vw, 24px); line-height: 1.25; letter-spacing: -0.005em; margin-bottom: 6px; color: var(--ink); }
.card__name em { font-style: italic; }
.card__kr { font-family: var(--kr); font-size: 13px; color: var(--grey-warm); margin-bottom: 14px; font-weight: 300; }
.card__row { display: flex; justify-content: space-between; align-items: baseline; padding-top: 14px; border-top: 1px solid var(--grey-line); }
.card__price { font-family: var(--serif); font-weight: 400; font-size: 18px; letter-spacing: -0.01em; color: var(--ink); }
.card__price .strike { font-size: 13px; color: var(--grey-warm); text-decoration: line-through; margin-right: 10px; font-weight: 300; }
.card__swatches { display: flex; gap: 5px; }
.card__swatches span { width: 12px; height: 12px; border-radius: 50%; border: 1px solid var(--grey-line); display: inline-block; }

.editorial {
  grid-column: span 2;
  background: var(--ink); color: var(--paper);
  padding: clamp(28px, 2.5vw, 40px);
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden; aspect-ratio: 8/5; isolation: isolate;
}
.editorial__bg { position: absolute; inset: 0; z-index: -1; background: radial-gradient(ellipse at 70% 30%, rgba(184,153,104,0.18) 0%, transparent 60%), linear-gradient(135deg, #1a1612 0%, #0e0c0a 100%); }
.editorial__tag { font-family: var(--sans); font-size: 10.5px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--gold); }
.editorial__title { font-family: var(--serif); font-weight: 300; font-size: clamp(28px, 2.4vw, 40px); line-height: 1.15; letter-spacing: -0.01em; margin: 18px 0; max-width: 18ch; }
.editorial__title em { color: var(--gold); font-style: italic; }
.editorial__cta { display: inline-flex; align-items: center; gap: 14px; font-family: var(--sans); font-size: 11px; letter-spacing: 0.36em; text-transform: uppercase; color: var(--paper); border-bottom: 1px solid var(--gold); padding-bottom: 6px; align-self: flex-start; }
@media (max-width: 800px) { .editorial { grid-column: span 2; aspect-ratio: 5/3; } }
@media (max-width: 480px) { .editorial { grid-column: span 1; aspect-ratio: 4/3; } }

.pager { display: flex; justify-content: center; align-items: center; gap: 8px; padding: 40px 0 80px; border-top: 1px solid var(--grey-line); font-family: var(--sans); font-size: 12px; letter-spacing: 0.18em; }
.pager button { width: 40px; height: 40px; border: 1px solid transparent; background: transparent; cursor: pointer; color: var(--grey-warm); transition: all 150ms; }
.pager button:hover { color: var(--ink); border-color: var(--ink); }
.pager button.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.pager .nav-arrow { width: auto; padding: 0 16px; letter-spacing: 0.32em; text-transform: uppercase; font-size: 11px; }
