/* ============================================================
   FOLKDORE — Quiet redesign
   Three style variants (gallery / editorial / catalogue) as Tweaks
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;1,9..144,400;1,9..144,500&family=Inter:wght@400;500&family=JetBrains+Mono:wght@400&display=swap");

/* -------- Reset ------------------------------------------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; padding: 0; }
input, textarea, select { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, h5 { margin: 0; font-weight: 400; }
p { margin: 0; }

/* -------- Tokens: default + variants ---------------------- */
:root {
  --paper: #f6f4ef;
  --ink: #141210;
  --ink-soft: #55504a;
  --muted: #999088;
  --line: #e2ddd3;
  --line-soft: #edeadf;
  --accent: #6b4820;
  --serif: "Fraunces", Georgia, serif;
  --sans: "Inter", -apple-system, Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  --gutter: clamp(20px, 4vw, 72px);
  --ease: cubic-bezier(.22, .68, .3, 1);
}

/* Variant: Quiet Gallery (default) — near-white, minimal */
body.v-gallery {
  --paper: #fafaf7;
  --ink: #15130f;
  --ink-soft: #5c5750;
  --muted: #a8a19a;
  --line: #e6e3da;
  --accent: #2d1b10;
}

/* Variant: Editorial — cream paper, warmer, one accent */
body.v-editorial {
  --paper: #f1ece0;
  --ink: #1a1510;
  --ink-soft: #564a3c;
  --muted: #a09580;
  --line: #d8cfbb;
  --accent: #7a2e1f;
}

/* Variant: Utility Catalogue — library-ticket beige, monospace */
body.v-catalogue {
  --paper: #ebe7db;
  --ink: #161310;
  --ink-soft: #4a443b;
  --muted: #8c8476;
  --line: #c8c0ae;
  --accent: #14120e;
}

/* -------- Page shell -------------------------------------- */
.shell {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* -------- Nav -------------------------------------------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; width: 100%; z-index: 40;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
/* Push content below fixed nav on all non-landing routes */
body:not(.r-landing):not(.r-admin) { padding-top: 63px; }
@media (max-width: 480px) { body:not(.r-landing):not(.r-admin) { padding-top: 55px; } }
.nav-inner {
  max-width: 1320px; margin: 0 auto;
  padding: 18px var(--gutter);
  display: flex;
  align-items: baseline;
  gap: 32px;
}
.wm {
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -0.015em;
  font-weight: 500;
  font-style: italic;
  color: var(--ink);
}
.wm .sub {
  font-family: var(--mono);
  font-style: normal;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  margin-left: 10px;
  font-weight: 400;
}
.nav-spacer { flex: 1; }
.nav a.nav-link {
  font-family: var(--sans);
  font-size: 13.5px;
  color: var(--ink-soft);
  padding: 4px 0;
  border-bottom: 1px solid transparent;
  transition: color 120ms var(--ease), border-color 120ms var(--ease);
}
.nav a.nav-link:hover, .nav a.nav-link.active {
  color: var(--ink); border-bottom-color: var(--ink);
}
.cart-btn {
  font-family: var(--sans);
  font-size: 13.5px;
  padding: 7px 13px;
  border: 1px solid var(--ink);
  color: var(--ink);
  transition: background 120ms var(--ease), color 120ms var(--ease);
}
.cart-btn:hover { background: var(--ink); color: var(--paper); }
.cart-btn .count { font-family: var(--mono); font-size: 11px; margin-left: 8px; color: var(--muted); }
.cart-btn:hover .count { color: var(--paper); }

@media (max-width: 720px) {
  .nav-inner { flex-wrap: wrap; gap: 10px 14px; padding: 14px var(--gutter); }
  .nav-spacer { flex-basis: 100%; order: 5; display: none; }
}
@media (max-width: 480px) {
  .nav-inner { gap: 8px 10px; padding: 12px 16px; }
  .toolbar { top: 55px; padding: 10px 0; gap: 8px; }
  .toolbar .filter-row { width: 100%; margin-left: 0 !important; }
  .toolbar .filter-row input,
  .toolbar .filter-row select { width: 100%; min-width: 0 !important; box-sizing: border-box; }
  .shell { padding: 0 16px; }
  .section-head .meta { font-size: 10px; }
}

/* -------- Landing (simplified hero page) ---------------- */
.landing {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  background: #0b0a08;
}
.landing-stage {
  position: relative;
  min-height: 100vh;
  display: flex; align-items: flex-end;
}
.landing-slide {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1800ms ease;
  filter: saturate(0.9) contrast(1.02);
  transform: scale(1.04);
}
.landing-slide.on { opacity: 1; }
.landing-scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(to top, rgba(11,10,8,0.72) 0%, rgba(11,10,8,0.35) 40%, rgba(11,10,8,0.15) 65%, rgba(11,10,8,0.55) 100%),
    linear-gradient(to right, rgba(11,10,8,0.35), transparent 50%);
}
.landing-inner {
  position: relative;
  z-index: 2;
  max-width: 1320px; margin: 0 auto;
  padding: 0 var(--gutter) clamp(72px, 10vh, 140px);
  color: #f4f1ea;
  width: 100%;
}
.landing-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(244, 241, 234, 0.7);
  margin-bottom: 28px;
}
.landing-h1 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(50px, 9vw, 128px);
  line-height: 0.96;
  letter-spacing: -0.03em;
  max-width: 18ch;
  color: #f7f2e7;
  text-shadow: 0 2px 40px rgba(0, 0, 0, 0.25);
}
.landing-h1 em {
  font-style: italic;
  color: #e6c27a;
}
.landing-heading {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.3;
  color: #e6c27a;
  max-width: 52ch;
  margin-top: 24px;
  min-height: 1.3em;
  text-shadow: 0 1px 20px rgba(0, 0, 0, 0.4);
}
.landing-sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(16px, 1.6vw, 19px);
  line-height: 1.6;
  color: rgba(244, 241, 234, 0.78);
  max-width: 52ch;
  margin-top: 12px;
  min-height: 3.2em;
  text-shadow: 0 1px 20px rgba(0, 0, 0, 0.4);
}
.landing-ctas {
  display: flex;
  align-items: center;
  gap: 28px;
  margin-top: 44px;
  flex-wrap: wrap;
}
.btn.landing-primary {
  padding: 18px 28px;
  border: 1px solid #f4f1ea;
  color: #f4f1ea;
  background: transparent;
  font-family: var(--sans);
  font-size: 15px;
  letter-spacing: 0.02em;
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  min-width: 280px;
  transition: background 180ms var(--ease), color 180ms var(--ease);
}
.btn.landing-primary:hover {
  background: #f4f1ea; color: #141210;
}
.btn.landing-primary .arr {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  transition: transform 220ms var(--ease);
}
.btn.landing-primary:hover .arr { transform: translateX(6px); }
.landing-meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(244, 241, 234, 0.65);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.landing-dots {
  position: absolute;
  left: var(--gutter);
  top: 28px;
  z-index: 3;
  display: flex;
  gap: 6px;
}
.landing-dots button {
  width: 28px; height: 2px;
  background: rgba(244, 241, 234, 0.35);
  transition: background 200ms var(--ease);
}
.landing-dots button.on { background: #f4f1ea; }
.landing-caption {
  position: absolute;
  right: var(--gutter);
  top: 28px;
  z-index: 3;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(244, 241, 234, 0.75);
  display: flex;
  align-items: center;
  gap: 14px;
}
.landing-caption .src {
  color: rgba(244, 241, 234, 0.4);
  font-size: 9.5px;
  padding-left: 14px;
  border-left: 1px solid rgba(244, 241, 234, 0.25);
}

/* Darker nav over landing */
body.r-landing .nav {
  background: rgba(11, 10, 8, 0.75);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(244, 241, 234, 0.1);
  --ink: #f4f1ea;
  --ink-soft: rgba(244, 241, 234, 0.75);
  --muted: rgba(244, 241, 234, 0.5);
  --line: rgba(244, 241, 234, 0.15);
  color: #f4f1ea;
}
body.r-landing .nav .wm { color: #f4f1ea; }
body.r-landing .nav .wm .sub { color: rgba(244, 241, 234, 0.55); }
body.r-landing .nav .nav-link { color: rgba(244, 241, 234, 0.75); }
body.r-landing .nav .nav-link:hover,
body.r-landing .nav .nav-link.active { color: #f4f1ea; border-bottom-color: #f4f1ea; }

body.r-landing .nav .cart-btn { border-color: #f4f1ea; color: #f4f1ea; }
body.r-landing .nav .cart-btn:hover { background: #f4f1ea; color: #141210; }
body.r-landing .nav .cart-btn .count { color: rgba(244, 241, 234, 0.5); }

/* Hide footer on landing page; it's for deeper pages */
body.r-landing .foot { display: none; }

@media (max-width: 720px) {
  .landing-caption { display: none; }
  .landing-dots { top: 18px; }
  .landing-inner { padding-bottom: 60px; }
  .btn.landing-primary { min-width: 0; width: 100%; }
}

/* -------- Hero ------------------------------------------- */
.hero {
  padding: clamp(80px, 12vw, 180px) 0 clamp(60px, 10vw, 140px);
}
.hero .label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 40px;
}
.hero h1 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(44px, 7vw, 104px);
  line-height: 0.98;
  letter-spacing: -0.025em;
  max-width: 14ch;
}
.hero h1 em {
  font-style: italic;
  color: var(--accent);
}
.hero .sub {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(17px, 1.6vw, 21px);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 44ch;
  margin-top: 32px;
}

/* Editorial: two-column hero */
body.v-editorial .hero .hero-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(32px, 5vw, 96px);
  align-items: end;
}
body.v-editorial .hero .hero-right {
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-soft);
  padding-bottom: 14px;
  border-top: 1px solid var(--line);
  padding-top: 20px;
  max-width: 42ch;
}
body.v-editorial .hero .hero-right em { color: var(--accent); font-style: italic; }
@media (max-width: 900px) {
  body.v-editorial .hero .hero-inner { grid-template-columns: 1fr; }
}

/* Catalogue: compressed hero, table of contents feel */
body.v-catalogue .hero {
  padding: 48px 0 32px;
  border-bottom: 1px solid var(--ink);
}
body.v-catalogue .hero h1 {
  font-size: clamp(32px, 4.5vw, 56px);
  font-family: var(--serif);
}
body.v-catalogue .hero .sub {
  font-family: var(--mono);
  font-style: normal;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 18px;
}

/* -------- Section head ------------------------------------ */
.section { padding: clamp(40px, 6vw, 80px) 0; }
.section-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px 24px;
  padding-bottom: 22px;
  margin-bottom: 36px;
  border-bottom: 1px solid var(--line);
}
.section-head h2 {
  font-family: var(--serif);
  font-size: clamp(28px, 3.6vw, 48px);
  letter-spacing: -0.02em;
  line-height: 1;
}
.section-head h2 em { font-style: italic; color: var(--accent); }
.section-head .meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: right;
}

body.v-catalogue .section { padding: 32px 0; }
body.v-catalogue .section-head { border-bottom: 1px solid var(--ink); }
body.v-catalogue .section-head h2 {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
body.v-catalogue .section-head h2 em { font-style: normal; color: var(--ink); }

/* -------- Toolbar ----------------------------------------- */
.toolbar {
  display: flex;
  gap: 12px 18px;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
  margin-bottom: 28px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 63px;
  z-index: 20;
  background: var(--paper);
}
.filter-row { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.filter-row > span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  margin-right: 4px;
}
.chip {
  font-family: var(--sans);
  font-size: 13px;
  padding: 6px 12px;
  border: 0;
  color: var(--ink-soft);
  background: transparent;
  transition: color 100ms var(--ease), background 100ms var(--ease);
  border-radius: 0;
}
.chip:hover { color: var(--ink); }
.chip.active {
  color: var(--ink);
  background: var(--paper);
  position: relative;
}
.chip.active::after {
  content: "";
  position: absolute;
  left: 12px; right: 12px; bottom: 2px;
  height: 1px;
  background: var(--ink);
}
.chip .cnt { color: var(--muted); font-family: var(--mono); font-size: 10px; margin-left: 4px; }

body.v-catalogue .chip {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid var(--line);
  padding: 6px 10px;
}
body.v-catalogue .chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
body.v-catalogue .chip.active::after { display: none; }

/* -------- Catalogue grid --------------------------------- */
.catalog {
  display: grid;
  grid-template-columns: repeat(var(--cols, 4), 1fr);
  gap: var(--row-gap, 52px) var(--col-gap, 28px);
}
body.v-gallery .catalog { --cols: 4; --row-gap: 56px; --col-gap: 24px; }
body.v-editorial .catalog { --cols: 3; --row-gap: 60px; --col-gap: 40px; }
body.v-catalogue .catalog { --cols: 1; --row-gap: 0; --col-gap: 0; }

@media (max-width: 1100px) {
  body.v-gallery .catalog { --cols: 3; }
  body.v-editorial .catalog { --cols: 2; }
}
@media (max-width: 720px) {
  body.v-gallery .catalog, body.v-editorial .catalog { --cols: 2; --row-gap: 36px; --col-gap: 16px; }
}
@media (max-width: 480px) {
  body.v-gallery .catalog, body.v-editorial .catalog { --cols: 1; }
}

/* -------- Product card (Gallery + Editorial) -------------- */
.pcard {
  cursor: pointer;
  position: relative;
}
.pcard .swatch {
  aspect-ratio: 4/5;
  background: var(--sw-bg, #d5cdbe);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px;
  position: relative;
  overflow: hidden;
  transition: transform 400ms var(--ease);
}
.pcard:hover .swatch { transform: translateY(-3px); }
.pcard .swatch .mark {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sw-ink, #fff);
  opacity: 0.75;
  position: absolute;
  top: 18px;
  left: 18px;
}
.pcard .swatch .dest {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(22px, 2.2vw, 30px);
  letter-spacing: -0.02em;
  line-height: 0.95;
  color: var(--sw-ink, #fff);
}
.pcard .swatch .prod-type {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sw-ink, #fff);
  opacity: 0.6;
  margin-top: 10px;
}

.pcard .meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-top: 14px;
  font-size: 14px;
}
.pcard .meta .lhs { color: var(--ink); }
.pcard .meta .lhs .title { font-family: var(--serif); font-size: 17px; letter-spacing: -0.01em; line-height: 1.25; }
.pcard .meta .lhs .title em { font-style: italic; font-weight: 500; color: var(--ink-soft); }
.pcard .meta .lhs .code { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
.pcard .meta .rhs { text-align: right; font-family: var(--serif); font-size: 17px; letter-spacing: -0.01em; }
.pcard .meta .rhs .unit { font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); display: block; margin-top: 2px; }

/* Sold out mark — only visible when stock control is on */
body.v-stock .pcard.sold .swatch::after {
  content: "Out of stock";
  position: absolute;
  top: 18px; right: 18px;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: var(--paper);
  color: var(--ink);
}

/* -------- Catalogue variant: tabular row ----------------- */
body.v-catalogue .pcard {
  display: grid;
  grid-template-columns: 60px 90px 1fr 120px 90px 110px;
  gap: 24px;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
}
body.v-catalogue .pcard:hover { background: rgba(0,0,0,0.02); }
body.v-catalogue .pcard .swatch {
  aspect-ratio: 1/1;
  width: 60px;
  padding: 0;
  background: var(--sw-bg);
}
body.v-catalogue .pcard .swatch .mark,
body.v-catalogue .pcard .swatch .dest,
body.v-catalogue .pcard .swatch .prod-type { display: none; }
body.v-catalogue .pcard .code-col {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--ink-soft);
}
body.v-catalogue .pcard .name-col {
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: -0.01em;
  line-height: 1.2;
}
body.v-catalogue .pcard .name-col em { font-style: italic; color: var(--accent); }
body.v-catalogue .pcard .name-col .dest { color: var(--ink); display: block; font-size: 14px; font-family: var(--sans); font-style: normal; color: var(--muted); margin-top: 2px; letter-spacing: 0; }
body.v-catalogue .pcard .cat-col {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-soft);
}
body.v-catalogue .pcard .moq-col,
body.v-catalogue .pcard .price-col {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  color: var(--ink-soft);
  text-align: right;
}
body.v-catalogue .pcard .price-col { color: var(--ink); font-size: 14px; }
body.v-catalogue .pcard .meta { display: contents; }

body.v-catalogue.v-stock .pcard { grid-template-columns: 60px 90px 1fr 120px 90px 90px 110px; }

body.v-catalogue .catalogue-header {
  display: grid;
  grid-template-columns: 60px 90px 1fr 120px 90px 110px;
  gap: 24px;
  padding: 10px 0;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
}
body.v-catalogue .catalogue-header span:nth-child(n+4) { text-align: right; }
body.v-catalogue.v-stock .catalogue-header { grid-template-columns: 60px 90px 1fr 120px 90px 90px 110px; }

@media (max-width: 900px) {
  body.v-catalogue .pcard,
  body.v-catalogue .catalogue-header {
    grid-template-columns: 50px 1fr 80px;
    gap: 14px;
  }
  body.v-catalogue .pcard .code-col,
  body.v-catalogue .pcard .cat-col,
  body.v-catalogue .pcard .moq-col,
  body.v-catalogue .pcard .stock-col,
  body.v-catalogue .catalogue-header span:nth-child(2),
  body.v-catalogue .catalogue-header span:nth-child(4),
  body.v-catalogue .catalogue-header span:nth-child(5),
  body.v-catalogue.v-stock .catalogue-header span:nth-child(6) { display: none; }
}

/* -------- Sheets (product detail, cart, checkout) -------- */
.sheet-back {
  position: fixed; inset: 0;
  background: rgba(20, 18, 16, 0.38);
  z-index: 80;
  display: flex; justify-content: flex-end;
  animation: fadein 160ms ease;
}
@keyframes fadein { from { opacity: 0; } }
.sheet {
  width: min(560px, 100%);
  background: var(--paper);
  display: flex; flex-direction: column;
  animation: slidein 240ms var(--ease);
  border-left: 1px solid var(--line);
}
@keyframes slidein { from { transform: translateX(24px); opacity: 0; } }

.sheet > header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 28px;
  border-bottom: 1px solid var(--line);
}
.sheet > header .ht {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
}
.sheet > header .ht b { color: var(--ink); font-weight: 500; }
.icon-btn {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 22px;
  color: var(--ink-soft);
  transition: color 120ms var(--ease);
}
.icon-btn:hover { color: var(--ink); }

.sheet-body { flex: 1; overflow-y: auto; }
.sheet-foot {
  padding: 18px 28px 24px;
  border-top: 1px solid var(--line);
  display: grid; gap: 10px;
}

/* product sheet */
.ps-swatch {
  aspect-ratio: 1/1;
  background: var(--sw-bg);
  border-bottom: 1px solid var(--line);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 36px;
  position: relative;
}
.ps-swatch .mark {
  position: absolute; top: 20px; left: 20px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--sw-ink); opacity: 0.75;
}
.ps-swatch .dest {
  font-family: var(--serif); font-style: italic; font-weight: 500;
  font-size: clamp(40px, 6vw, 72px); line-height: 0.95; letter-spacing: -0.025em;
  color: var(--sw-ink);
}

.ps-info { padding: 28px 28px 0; }
.ps-info .cat { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.ps-info h2 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(28px, 3.6vw, 42px);
  line-height: 1; letter-spacing: -0.02em;
  margin-top: 10px;
}
.ps-info h2 em { font-style: italic; color: var(--accent); }
.ps-info .note {
  font-family: var(--serif); font-style: italic; font-size: 17px;
  color: var(--ink-soft); margin-top: 14px; max-width: 50ch; line-height: 1.5;
}
.ps-info .desc { font-size: 14px; color: var(--ink-soft); margin-top: 10px; max-width: 50ch; line-height: 1.55; }

.ps-specs {
  display: grid; grid-template-columns: 1fr 1fr;
  margin: 28px 28px 0;
  border-top: 1px solid var(--line);
}
.ps-specs > div { padding: 12px 0; border-bottom: 1px solid var(--line); }
.ps-specs > div:nth-child(odd) { border-right: 1px solid var(--line); padding-right: 14px; }
.ps-specs > div:nth-child(even) { padding-left: 14px; }
.ps-specs dt { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.ps-specs dd { margin: 4px 0 0; font-family: var(--serif); font-size: 16px; letter-spacing: -0.01em; }

.size-group { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 8px; }
.size-chip {
  padding: 7px 12px; border: 1px solid var(--line); background: transparent;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft);
}
.size-chip:hover { border-color: var(--ink); color: var(--ink); }
.size-chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.qty-row { display: flex; justify-content: space-between; align-items: flex-end; gap: 14px; margin-top: 8px; }
.qty-step { display: inline-flex; align-items: stretch; border: 1px solid var(--line); }
.qty-step button { width: 38px; height: 40px; font-size: 16px; color: var(--ink-soft); }
.qty-step button:hover { background: var(--ink); color: var(--paper); }
.qty-step input {
  width: 64px; text-align: center; border: 0; background: transparent;
  border-left: 1px solid var(--line); border-right: 1px solid var(--line);
  font-family: var(--mono); font-size: 13px;
}
.qty-sub { text-align: right; }
.qty-sub .val { font-family: var(--serif); font-size: 24px; letter-spacing: -0.01em; }
.qty-sub .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-top: 2px; }

.mini-note { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); display: flex; justify-content: space-between; }
.mini-note.warn { color: var(--accent); }

.ps-section { padding: 22px 28px; border-top: 1px solid var(--line); }
.ps-section .label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }

/* cart */
.cart-item {
  display: grid; grid-template-columns: 64px 1fr auto; gap: 16px;
  padding: 16px 28px; border-bottom: 1px solid var(--line);
  align-items: center;
}
.cart-item .ci-sw { width: 64px; aspect-ratio: 1/1; background: var(--sw-bg); }
.cart-item .ci-name { font-family: var(--serif); font-size: 17px; letter-spacing: -0.01em; line-height: 1.2; }
.cart-item .ci-name em { font-style: italic; color: var(--accent); }
.cart-item .ci-meta { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin-top: 3px; }
.cart-item .ci-right { text-align: right; display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.cart-item .ci-price { font-family: var(--serif); font-size: 18px; letter-spacing: -0.01em; }
.cart-item .ci-rm { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.cart-item .ci-rm:hover { color: var(--ink); }

.totals { padding: 20px 28px; border-top: 1px solid var(--ink); }
.tot-row { display: flex; justify-content: space-between; padding: 4px 0; font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); }
.tot-row.big {
  font-family: var(--serif); font-size: 26px; letter-spacing: -0.015em;
  text-transform: none; color: var(--ink); padding-top: 12px; margin-top: 8px;
  border-top: 1px solid var(--line);
}

.empty {
  padding: 100px 28px; text-align: center;
}
.empty h3 { font-family: var(--serif); font-size: 32px; letter-spacing: -0.02em; margin-bottom: 8px; }
.empty h3 em { font-style: italic; color: var(--accent); }
.empty p { font-family: var(--serif); font-style: italic; color: var(--ink-soft); font-size: 16px; max-width: 30ch; margin: 0 auto; }

/* -------- Buttons + inputs ------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 18px;
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  border: 1px solid var(--ink); background: transparent; color: var(--ink);
  transition: background 120ms var(--ease), color 120ms var(--ease);
}
.btn:hover { background: var(--ink); color: var(--paper); }
.btn.primary { background: var(--ink); color: var(--paper); }
.btn.primary:hover { background: var(--accent); border-color: var(--accent); }
.btn.text { border: 0; padding: 6px 0; font-size: 13px; color: var(--ink-soft); }
.btn.text:hover { background: transparent; color: var(--ink); text-decoration: underline; text-underline-offset: 4px; }
.btn.small { padding: 8px 12px; font-size: 13px; }
.btn:disabled { opacity: 0.35; cursor: not-allowed; }
.btn.primary:disabled { background: var(--muted); border-color: var(--muted); color: var(--paper); }

.input, .select, .textarea {
  width: 100%;
  padding: 11px 12px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--ink);
  font-family: var(--sans); font-size: 14px;
  border-radius: 0;
}
.input:focus, .select:focus, .textarea:focus {
  outline: none; border-color: var(--ink);
}
.textarea { min-height: 64px; resize: vertical; }
.field label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--muted);
  display: block; margin-bottom: 6px;
}
.field .req { color: var(--accent); }

.fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; padding: 20px 28px; }
.fields .full { grid-column: 1 / -1; }

/* -------- Checkout / confirmation ----------------------- */
.form-hd { padding: 26px 28px 8px; }
.form-hd .label { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.form-hd h2 { font-family: var(--serif); font-size: clamp(28px, 3.5vw, 40px); letter-spacing: -0.02em; line-height: 1; }
.form-hd h2 em { font-style: italic; color: var(--accent); }
.form-hd .sub { font-family: var(--serif); font-style: italic; font-size: 15px; color: var(--ink-soft); margin-top: 10px; max-width: 44ch; }

.summary { margin: 0 28px; padding: 16px 18px; border: 1px solid var(--line); background: transparent; }
.summary h5 { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.summary .line { display: flex; justify-content: space-between; padding: 3px 0; font-size: 13px; color: var(--ink-soft); }
.summary .line.total { border-top: 1px solid var(--line); margin-top: 8px; padding-top: 8px; font-family: var(--serif); font-size: 18px; color: var(--ink); }

.confirm {
  padding: 70px 32px 40px; text-align: center;
}
.confirm .stamp {
  display: inline-block;
  padding: 9px 22px;
  border: 1px solid var(--accent);
  color: var(--accent);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  margin-bottom: 36px;
}
.confirm h2 { font-family: var(--serif); font-size: clamp(36px, 5vw, 56px); letter-spacing: -0.025em; line-height: 0.98; }
.confirm h2 em { font-style: italic; color: var(--accent); }
.confirm p { font-family: var(--serif); font-style: italic; font-size: 17px; color: var(--ink-soft); margin: 18px auto 24px; max-width: 42ch; }
.confirm .oid { font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; color: var(--muted); padding-bottom: 18px; border-bottom: 1px solid var(--line); display: inline-block; min-width: 260px; margin-bottom: 32px; }
.confirm .acts { display: flex; gap: 10px; justify-content: center; }

/* -------- Footer ---------------------------------------- */
.foot {
  border-top: 1px solid var(--line);
  padding: 48px var(--gutter) 32px;
  margin-top: 80px;
}
.foot-inner { max-width: 1320px; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 24px; }
.foot-left .wm { font-size: 22px; }
.foot-left p {
  font-family: var(--serif); font-style: italic;
  font-size: 15px; color: var(--ink-soft);
  margin-top: 8px; max-width: 34ch;
}
.foot-right {
  font-family: var(--mono);
  font-size: 10.5px; letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  display: grid; gap: 4px; text-align: right;
}
.foot-bottom {
  margin-top: 32px; padding-top: 18px;
  border-top: 1px solid var(--line);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px;
}
.foot-legal {
  color: var(--muted); text-decoration: none;
  transition: color 120ms var(--ease);
}
.foot-legal:hover { color: var(--ink); }

/* -------- Privacy page ------------------------------------- */
.privacy-page { max-width: 760px; margin: 0 auto; padding: 60px var(--gutter) 80px; }
.privacy-inner h1 { font-family: var(--serif); font-size: clamp(36px,5vw,60px); letter-spacing: -0.025em; line-height: 0.95; margin-bottom: 40px; }
.privacy-inner h1 em { font-style: italic; color: var(--accent); }
.privacy-inner section { margin-bottom: 36px; }
.privacy-inner h2 { font-family: var(--serif); font-size: 22px; letter-spacing: -0.01em; margin-bottom: 10px; }
.privacy-inner p, .privacy-inner li { font-size: 15px; line-height: 1.7; color: var(--ink-soft); margin-bottom: 10px; }
.privacy-inner ul { padding-left: 1.4em; }
.privacy-inner li { margin-bottom: 6px; }
.privacy-inner a { color: var(--ink); }
.privacy-inner a:hover { color: var(--accent); }

/* -------- Admin ----------------------------------------- */
.admin-wrap { max-width: 1440px; margin: 0 auto; padding: 28px var(--gutter) 80px; }
.admin-head {
  display: flex; justify-content: space-between; align-items: baseline; gap: 20px;
  padding-bottom: 18px; border-bottom: 1px solid var(--ink); margin-bottom: 28px;
  flex-wrap: wrap;
}
.admin-head .label { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.admin-head h1 { font-family: var(--serif); font-size: clamp(40px, 5vw, 64px); letter-spacing: -0.025em; line-height: 0.95; }
.admin-head h1 em { font-style: italic; color: var(--accent); }
.admin-head .rhs { display: flex; gap: 8px; align-items: center; }

.admin-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--line); margin-bottom: 24px; }
.admin-tabs button {
  padding: 12px 20px 14px;
  font-size: 14px; color: var(--muted);
  border-bottom: 1px solid transparent; margin-bottom: -1px;
}
.admin-tabs button.active { color: var(--ink); border-bottom-color: var(--ink); }
.admin-tabs .cnt { font-family: var(--mono); font-size: 11px; margin-left: 6px; color: var(--muted); }

.stock-stats { display: grid; grid-template-columns: repeat(5, 1fr); border: 1px solid var(--line); margin-bottom: 24px; }
.stock-stats > div { padding: 16px 20px; border-right: 1px solid var(--line); font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }
.stock-stats > div:last-child { border-right: 0; }
.stock-stats > div b { display: block; font-family: var(--serif); font-size: 30px; letter-spacing: -0.02em; color: var(--ink); font-weight: 400; margin-bottom: 4px; }
@media (max-width: 900px) { .stock-stats { grid-template-columns: 1fr 1fr; } .stock-stats > div { border-bottom: 1px solid var(--line); } }

.search { padding: 8px 12px; border: 1px solid var(--line); background: transparent; min-width: 260px; font-size: 13px; }
.search:focus { outline: none; border-color: var(--ink); }

.stock-toolbar { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; align-items: center; }

.stock-table { width: 100%; border-collapse: collapse; }
.stock-table th, .stock-table td {
  padding: 10px 12px; text-align: left; vertical-align: middle;
  border-bottom: 1px solid var(--line); font-size: 14px;
}
.stock-table th { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); font-weight: 400; background: transparent; }
.stock-table tr.hidden-row { opacity: 0.45; }
.stock-table tr.low td { background: rgba(122, 46, 31, 0.05); }
.mini-sw { width: 40px; height: 40px; background: var(--sw-bg); }
.stock-input { width: 70px; padding: 6px 8px; border: 1px solid var(--line); font-family: var(--mono); font-size: 12px; text-align: center; }
.toggle { position: relative; display: inline-block; width: 38px; height: 20px; background: var(--line); cursor: pointer; border-radius: 999px; transition: background 120ms var(--ease); }
.toggle::after { content: ""; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px; background: var(--paper); border-radius: 50%; transition: transform 120ms var(--ease); }
.toggle.on { background: var(--ink); }
.toggle.on::after { transform: translateX(18px); }
.badge { padding: 2px 7px; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.15em; text-transform: uppercase; border: 1px solid currentColor; display: inline-block; }
.badge.live { color: var(--ink-soft); }
.badge.hidden { color: var(--muted); }
.badge.oos { color: var(--accent); }
.badge.low { color: var(--accent); }

.order-card { border: 1px solid var(--line); padding: 20px 22px; margin-bottom: 14px; display: grid; grid-template-columns: 1fr auto; gap: 6px 14px; }
.order-card h3 { font-family: var(--serif); font-size: 22px; letter-spacing: -0.015em; }
.order-card .om { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }
.order-card .ot { font-family: var(--serif); font-size: 26px; letter-spacing: -0.02em; text-align: right; }
.order-card .li { grid-column: 1 / -1; margin-top: 10px; display: grid; gap: 4px; font-size: 13px; color: var(--ink-soft); }
.order-card .li > div { display: flex; justify-content: space-between; padding: 3px 0; border-top: 1px solid var(--line); }
.order-card .li > div:first-child { border-top: 0; }
.order-card .sr { grid-column: 1 / -1; display: flex; gap: 8px; align-items: center; padding-top: 12px; margin-top: 12px; border-top: 1px solid var(--line); flex-wrap: wrap; }
.order-card .sr .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }

/* Gate */
.gate { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.gate-card { width: min(420px, 100%); border: 1px solid var(--ink); padding: 36px 32px; background: var(--paper); }
.gate-card .label { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
.gate-card h1 { font-family: var(--serif); font-size: 48px; letter-spacing: -0.025em; line-height: 0.95; margin-bottom: 4px; }
.gate-card h1 em { font-style: italic; color: var(--accent); }
.gate-card .note { font-family: var(--serif); font-style: italic; color: var(--ink-soft); font-size: 15px; margin: 8px 0 24px; }
.gate-card input { margin-bottom: 12px; }
.gate-card .err { color: var(--accent); font-size: 12px; margin-bottom: 8px; }
.gate-hint { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-top: 14px; }

/* Tweaks panel */
.tweaks {
  position: fixed; right: 20px; bottom: 20px;
  width: 260px;
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: 16px 18px;
  z-index: 60;
  box-shadow: 0 14px 34px rgba(20, 18, 16, 0.15);
  display: none;
}
.tweaks.open { display: block; }
.tweaks h4 {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  display: flex; justify-content: space-between;
  font-weight: 400;
  margin-bottom: 12px;
}
.tweaks h4 .serif { font-family: var(--serif); font-style: italic; text-transform: none; letter-spacing: 0; font-size: 14px; color: var(--accent); }
.tweak-row { margin-bottom: 10px; }
.tweak-row > label { display: block; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.tweak-row .opts { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 4px; }
.tweak-row .opts button {
  padding: 6px 4px;
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.1em;
  text-transform: uppercase;
  border: 1px solid var(--line);
  color: var(--ink-soft);
}
.tweak-row .opts button.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--paper); }
::-webkit-scrollbar-thumb { background: var(--line); border: 2px solid var(--paper); }
::-webkit-scrollbar-thumb:hover { background: var(--muted); }

/* -------- Admin: stats, filters, panels ---------------- */
.filters {
  display: flex; gap: 12px; flex-wrap: wrap;
  padding: 14px 16px; margin-bottom: 24px;
  border: 1px solid var(--line); background: transparent;
  align-items: flex-end;
}
.filter-grp { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 150px; }
.filter-grp label { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.select-sm {
  padding: 7px 8px; border: 1px solid var(--line); background: transparent;
  font-family: var(--sans); font-size: 13px; color: var(--ink);
  border-radius: 0;
}
.select-sm:focus { outline: none; border-color: var(--ink); }

.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); margin-bottom: 24px; }
.kpi { padding: 20px 22px; border-right: 1px solid var(--line); }
.kpi:last-child { border-right: 0; }
.kpi-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.kpi-value { font-family: var(--serif); font-size: 38px; letter-spacing: -0.02em; line-height: 1; }
.kpi-sub { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; color: var(--muted); margin-top: 8px; text-transform: uppercase; }
@media (max-width: 900px) { .kpi-grid { grid-template-columns: 1fr 1fr; } .kpi { border-bottom: 1px solid var(--line); } }

.panel { border: 1px solid var(--line); margin-bottom: 24px; }
.panel-head { display: flex; justify-content: space-between; align-items: baseline; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.panel-head h3 { font-family: var(--serif); font-size: 20px; letter-spacing: -0.015em; }
.panel-meta { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.chart-wrap { padding: 18px; }

.top-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 16px; }
@media (max-width: 1100px) { .top-grid { grid-template-columns: 1fr; } }

.mini-table { width: 100%; border-collapse: collapse; }
.mini-table td { padding: 10px 14px; border-top: 1px solid var(--line); font-size: 13px; }
.mini-table tr:first-child td { border-top: 0; }
.mini-table .mt-name { font-family: var(--serif); font-size: 15px; letter-spacing: -0.01em; }
.mini-table .mt-name em { font-style: italic; color: var(--accent); }
.mini-table .mt-sub { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; color: var(--muted); text-transform: uppercase; margin-top: 2px; }
.mini-table .num { text-align: right; font-family: var(--mono); font-size: 12px; white-space: nowrap; }
.mini-table .strong { color: var(--ink); font-size: 13px; }
.mini-table .empty-row { text-align: center; color: var(--muted); padding: 28px; font-style: italic; font-family: var(--serif); }

.stats-table th.sortable { cursor: pointer; user-select: none; }
.stats-table th.sortable:hover { color: var(--ink); }
.stats-table th.sortable.active { color: var(--ink); }
.stats-table th.sortable.active::after { content: " ↓"; font-family: var(--mono); }
.stats-table th.sortable.active.asc::after { content: " ↑"; }
.stats-table .num { text-align: right; font-family: var(--mono); font-size: 12px; }
.stats-table .td-mono { font-family: var(--mono); font-size: 11px; letter-spacing: 0.05em; color: var(--ink-soft); }
.stats-table .strong { font-family: var(--serif); font-size: 14px; color: var(--ink); letter-spacing: -0.005em; }
.stats-table .empty-row { text-align: center; padding: 40px; color: var(--muted); font-style: italic; font-family: var(--serif); }

.pill { display: inline-block; padding: 1px 6px; margin-left: 8px; font-family: var(--mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; border: 1px solid currentColor; }
.pill.oos { color: var(--accent); }
.pill.low { color: var(--accent); opacity: 0.7; }
.pill.custom { color: var(--ink-soft); }

.share-bar { height: 6px; background: var(--line); }
.share-bar > div { height: 100%; background: var(--ink); }

/* -------- Admin: add product ---------------------------- */
.mode-tabs { display: flex; gap: 0; margin-bottom: 24px; border-bottom: 1px solid var(--line); }
.mode-tabs button { padding: 10px 20px; font-size: 14px; color: var(--muted); border-bottom: 2px solid transparent; margin-bottom: -1px; }
.mode-tabs button.active { color: var(--ink); border-bottom-color: var(--ink); }

.add-grid { display: grid; grid-template-columns: 1fr 340px; gap: 32px; align-items: flex-start; }
@media (max-width: 900px) { .add-grid { grid-template-columns: 1fr; } }

.form-section { border: 1px solid var(--line); padding: 18px 20px 22px; margin-bottom: 20px; }
.form-section h3 { font-family: var(--serif); font-size: 20px; letter-spacing: -0.015em; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.form-section .fg { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-section .fg .full { grid-column: 1 / -1; }
.form-section .hint { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em; color: var(--muted); line-height: 1.6; }
.form-section code { font-family: var(--mono); font-size: 10.5px; color: var(--ink-soft); background: rgba(0,0,0,0.04); padding: 1px 5px; }

.preview-col { position: sticky; top: 88px; }
.preview-col .label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.preview-card { border: 1px solid var(--line); padding: 12px; }
.preview-card .swatch { aspect-ratio: 4/5; padding: 16px; display: flex; flex-direction: column; justify-content: flex-end; position: relative; background: var(--sw-bg); }
.preview-card .swatch .mark { position: absolute; top: 14px; left: 14px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--sw-ink); opacity: 0.7; }
.preview-card .swatch .dest { font-family: var(--serif); font-style: italic; font-size: 28px; letter-spacing: -0.02em; line-height: 0.95; color: var(--sw-ink); }
.preview-card .swatch .prod-type { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--sw-ink); opacity: 0.55; margin-top: 8px; }
.preview-card .meta { display: flex; justify-content: space-between; padding: 12px 4px 4px; gap: 10px; }
.preview-card .meta .title { font-family: var(--serif); font-size: 15px; letter-spacing: -0.01em; }
.preview-card .meta .title em { font-style: italic; color: var(--ink-soft); }
.preview-card .meta .code { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; color: var(--muted); text-transform: uppercase; margin-top: 4px; }
.preview-card .meta .rhs { text-align: right; font-family: var(--serif); font-size: 15px; }
.preview-card .meta .unit { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.14em; color: var(--muted); text-transform: uppercase; display: block; margin-top: 2px; }

.shade-grid { display: grid; grid-template-columns: repeat(8, 1fr); gap: 4px; }
.shade { aspect-ratio: 1/1; border: 2px solid transparent; position: relative; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.shade.active { border-color: var(--ink); }
.shade > span { font-family: var(--mono); font-size: 8.5px; letter-spacing: 0.08em; color: #fff; text-transform: uppercase; mix-blend-mode: difference; }

.csv-drop { padding: 18px; border: 1px dashed var(--line); background: rgba(0,0,0,0.015); }
.csv-drop input[type=file] { font-family: var(--mono); font-size: 12px; }
.csv-preview { font-size: 11px; }
.csv-preview th { font-size: 9.5px; }

.icon-del { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; font-size: 18px; color: var(--muted); border: 1px solid transparent; transition: all 120ms var(--ease); }
.icon-del:hover { color: var(--accent); border-color: var(--accent); }

/* -------- Curated Lists ------------------------------------ */
.list-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; margin-top: 8px; }
.list-card { border: 1px solid var(--line); padding: 20px 22px; display: flex; flex-direction: column; gap: 10px; }
.list-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.list-card-name { font-family: var(--serif); font-size: 19px; letter-spacing: -0.015em; line-height: 1.2; }
.list-card-customer { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
.list-card-meta { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); display: flex; gap: 14px; }
.list-card-note { font-family: var(--serif); font-style: italic; font-size: 13.5px; color: var(--ink-soft); line-height: 1.5; border-left: 2px solid var(--line); padding-left: 12px; }
.list-card-url { font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; color: var(--muted); background: var(--line); padding: 6px 9px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.list-card-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.list-product-rows { display: flex; flex-direction: column; gap: 2px; }
.lp-row { display: flex; align-items: center; gap: 12px; padding: 9px 10px; border: 1px solid var(--line); background: var(--paper); }
.lp-row:hover { background: var(--line); }
.lp-info { flex: 1; min-width: 0; }
.lp-name { font-family: var(--serif); font-size: 14px; letter-spacing: -0.01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lp-name em { font-style: italic; color: var(--ink-soft); }
.lp-meta { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-top: 2px; }

.link-box { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 12px 14px; border: 1px solid var(--line); background: var(--line); margin-top: 12px; }
.link-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); white-space: nowrap; }
.link-url { font-family: var(--mono); font-size: 11.5px; color: var(--ink); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; background: none; }

/* -------- Product detail: profit strip & upload ------------ */
.profit-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 16px; }
@media (max-width: 900px) { .profit-strip { grid-template-columns: 1fr 1fr; } }
.ps-item { background: var(--paper); padding: 12px 14px; }
.ps-item span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 4px; }
.ps-item strong { font-family: var(--serif); font-size: 18px; letter-spacing: -0.015em; }

.upload-zone { cursor: pointer; }
.upload-zone:hover .swatch { opacity: 0.82; }

.ps-img-nav { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); display: flex; align-items: center; gap: 10px; background: rgba(0,0,0,0.45); color: #fff; padding: 4px 10px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; }
.ps-img-nav button { font-size: 18px; line-height: 1; color: #fff; padding: 0 2px; }
.ps-img-nav button:hover { opacity: 0.7; }

.extra-images-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-top: 10px; }
.extra-img-item { position: relative; aspect-ratio: 4/5; }
.extra-img-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.extra-img-item button { position: absolute; top: 4px; right: 4px; background: var(--paper); border: 1px solid var(--line); padding: 1px 5px; font-size: 11px; }

/* -------- Auto-visuals ------------------------------------- */
.visuals-banner { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 300; background: var(--ink); color: var(--paper); padding: 14px 18px 14px 20px; display: flex; align-items: center; gap: 16px; max-width: 500px; width: calc(100% - 40px); box-shadow: 0 4px 40px rgba(0,0,0,0.22); }
.visuals-banner p { font-size: 13.5px; flex: 1; line-height: 1.5; }
.visuals-banner p em { font-style: italic; opacity: 0.72; }
.visuals-banner-btns { display: flex; gap: 8px; flex-shrink: 0; }
.visuals-banner-btns button { padding: 7px 14px; font-size: 12px; border: 1px solid rgba(255,255,255,0.3); color: var(--paper); font-family: var(--mono); letter-spacing: 0.1em; text-transform: uppercase; transition: background 120ms; }
.visuals-banner-btns button.primary { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.visuals-banner-btns button.primary:hover { background: var(--line); }
.visuals-banner-btns button:not(.primary):hover { background: rgba(255,255,255,0.1); }

.pcard { position: relative; }
.pcard-video-wrap { position: absolute; top: 0; left: 0; right: 0; bottom: 48px; z-index: 4; overflow: hidden; }
.pcard-video-wrap video { width: 100%; height: 100%; object-fit: cover; display: block; }

body.visuals-active .catalog .pcard:not(.pcard-hovered) { opacity: 0.38; transition: opacity 220ms var(--ease); }
body.visuals-active .catalog .pcard.pcard-hovered { transition: opacity 220ms var(--ease); }
body.visuals-active { background: var(--paper); }

/* -------- Customer / Product detail panel overlay ---------- */
.detail-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.45); z-index: 500; display: flex; align-items: flex-start; justify-content: flex-end; padding: 20px; overflow-y: auto; }
.detail-panel { background: var(--paper); width: 600px; max-width: 100%; min-height: 100%; padding: 0; display: flex; flex-direction: column; box-shadow: -4px 0 40px rgba(0,0,0,0.12); }
.dp-head { display: flex; justify-content: space-between; align-items: flex-start; padding: 28px 28px 20px; border-bottom: 1px solid var(--line); gap: 16px; }
.dp-body { flex: 1; overflow-y: auto; padding: 0 28px 40px; }
.dp-section { padding: 24px 0; border-bottom: 1px solid var(--line); }
.dp-section:last-child { border-bottom: none; }
.dp-section h4 { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin: 0 0 14px; font-weight: 400; }
.dp-grid { display: grid; grid-template-columns: 130px 1fr; gap: 8px 16px; font-size: 13.5px; }
.dp-grid span:nth-child(odd) { color: var(--muted); font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; padding-top: 2px; }
.dp-order { margin-bottom: 14px; padding: 12px; background: var(--field, #f9f9f7); border: 1px solid var(--line); }
.dp-order-head { display: flex; gap: 10px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.dp-order .badge { padding: 2px 7px; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; border-radius: 0; }
.badge.complete { background: var(--lichen, #5b7560); color: #fff; }
.badge.shipped  { background: var(--ink); color: var(--paper); }
.badge.picking  { background: var(--amber, #c8932a); color: #fff; }
.badge.new      { background: var(--accent); color: #fff; }

/* -------- AI Tab: Bill & Gill ----------------------------- */
.ai-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: flex-start; }
@media (max-width: 1000px) { .ai-wrap { grid-template-columns: 1fr; } }

.ai-section { border: 1px solid var(--line); display: flex; flex-direction: column; min-height: 520px; }

.ai-agent-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 22px; border-bottom: 1px solid var(--line);
}
.ai-agent-head .label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.ai-name { font-family: var(--serif); font-size: 28px; letter-spacing: -0.02em; font-weight: 400; }
.ai-status-dot { width: 8px; height: 8px; border-radius: 50%; background: #4caf50; flex-shrink: 0; }

/* Chat */
.ai-chat { flex: 1; overflow-y: auto; padding: 16px 20px; display: flex; flex-direction: column; gap: 12px; min-height: 300px; }
.ai-empty { color: var(--ink-soft); }
.ai-empty p { font-family: var(--serif); font-style: italic; font-size: 15px; margin-bottom: 14px; }
.ai-suggestions { display: flex; flex-direction: column; gap: 6px; }
.ai-suggest {
  text-align: left; padding: 8px 12px;
  border: 1px solid var(--line); background: transparent;
  font-size: 13px; color: var(--ink-soft);
  transition: all 100ms var(--ease);
}
.ai-suggest:hover { border-color: var(--ink); color: var(--ink); background: var(--line); }

.ai-msg { display: flex; }
.ai-msg.user { justify-content: flex-end; }
.ai-msg.assistant { justify-content: flex-start; }
.ai-bubble {
  max-width: 85%; padding: 10px 14px;
  font-size: 14px; line-height: 1.6; white-space: pre-wrap;
}
.ai-msg.user .ai-bubble { background: var(--ink); color: var(--paper); }
.ai-msg.assistant .ai-bubble { background: var(--line); color: var(--ink); }

.ai-thinking { display: flex; gap: 5px; align-items: center; min-height: 20px; }
.ai-thinking span {
  width: 6px; height: 6px; border-radius: 50%; background: var(--muted);
  animation: ai-bounce 1.2s infinite ease-in-out;
}
.ai-thinking span:nth-child(2) { animation-delay: 0.2s; }
.ai-thinking span:nth-child(3) { animation-delay: 0.4s; }
@keyframes ai-bounce { 0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; } 40% { transform: scale(1); opacity: 1; } }

.ai-input-row {
  display: flex; gap: 8px; padding: 12px 16px;
  border-top: 1px solid var(--line);
}
.ai-input {
  flex: 1; padding: 9px 12px; border: 1px solid var(--line);
  background: transparent; font-size: 14px;
}
.ai-input:focus { outline: none; border-color: var(--ink); }

/* Outreach */
.ai-outreach-cards { flex: 1; display: flex; flex-direction: column; gap: 1px; background: var(--line); }
.ai-outreach-card {
  background: var(--paper); padding: 18px 22px;
  display: flex; justify-content: space-between; align-items: flex-end; gap: 16px;
}
.aoc-title { font-family: var(--serif); font-size: 17px; letter-spacing: -0.01em; margin-bottom: 4px; }
.aoc-desc { font-size: 13px; color: var(--ink-soft); line-height: 1.5; margin-bottom: 6px; max-width: 36ch; }
.aoc-count { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }
.aoc-result { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; margin-top: 6px; }
.aoc-result.ok { color: #4caf50; }
.aoc-result.err { color: var(--accent); }

/* Confirm dialog */
.ai-confirm {
  background: var(--paper); border: 1px solid var(--ink);
  padding: 32px; width: min(480px, 90vw); margin: auto;
  align-self: center;
}
.ai-confirm h3 { font-family: var(--serif); font-size: 22px; letter-spacing: -0.015em; margin-bottom: 12px; }
.ai-confirm p { font-size: 14px; line-height: 1.6; color: var(--ink-soft); margin-bottom: 24px; }
.ai-confirm-actions { display: flex; gap: 10px; }

/* -------- Settings panel ---------------------------------- */
.settings-wrap { max-width: 680px; display: flex; flex-direction: column; gap: 0; }
.settings-alert { background: #fff3cd; border: 1px solid #f0c36d; padding: 14px 20px; margin-bottom: 24px; font-size: 14px; color: #7a5c00; border-radius: 3px; }
.settings-sec { border-top: 1px solid var(--line); padding: 32px 0; }
.settings-sec:first-of-type { border-top: none; padding-top: 0; }
.settings-sec-head { margin-bottom: 24px; }
.settings-sec-title { font-family: var(--serif); font-size: 20px; letter-spacing: -0.01em; color: var(--ink); }
.settings-sec-sub { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
.settings-sec-body { display: flex; flex-direction: column; gap: 16px; }
.settings-field { display: flex; flex-direction: column; gap: 6px; }
.settings-label { font-family: var(--sans); font-size: 13px; font-weight: 500; color: var(--ink); }
.settings-hint { font-size: 12px; color: var(--muted); line-height: 1.4; }
.settings-note { font-size: 12px; color: var(--muted); line-height: 1.5; padding: 10px 14px; background: var(--line); border-radius: 3px; }
.settings-info-box { background: var(--card-bg, #faf7f1); border: 1px solid var(--line); padding: 18px 20px; border-radius: 3px; }
.settings-toggle-row { display: flex; align-items: center; gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--line); cursor: pointer; user-select: none; }
.settings-toggle-row:last-child { border-bottom: none; }
.settings-toggle { width: 40px; height: 22px; border-radius: 11px; background: var(--line); position: relative; flex-shrink: 0; transition: background 200ms; }
.settings-toggle.on { background: #2d7d2d; }
.settings-toggle-knob { position: absolute; top: 3px; left: 3px; width: 16px; height: 16px; border-radius: 50%; background: #fff; transition: left 200ms; box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
.settings-toggle.on .settings-toggle-knob { left: 21px; }

/* ============================================================
   Setup guide — Bill & Gill onboarding
   ============================================================ */
.setup-wrap { max-width: 760px; }

.setup-hero {
  padding: 32px 0 40px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 0;
}
.setup-hero-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 20px;
}
.setup-hero-agents {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 28px;
}
.setup-agent {
  padding: 22px 24px;
  border-top: 3px solid var(--line);
}
.setup-agent-bill { border-top-color: #4a6fa5; }
.setup-agent-gill { border-top-color: #5b7560; }
.setup-agent-name {
  font-family: var(--serif);
  font-size: 28px;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 4px;
}
.setup-agent-bill .setup-agent-name { color: #4a6fa5; }
.setup-agent-gill .setup-agent-name { color: #5b7560; }
.setup-agent-role {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
}
.setup-agent-desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.65;
  margin: 0 0 16px;
}
.setup-agent-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.setup-agent-tags span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: var(--line);
  color: var(--muted);
  border-radius: 2px;
}
.setup-progress-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
}
.setup-progress-bar-track {
  flex: 1;
  height: 3px;
  background: var(--line);
  border-radius: 2px;
  overflow: hidden;
}
.setup-progress-bar-fill {
  height: 100%;
  background: #2d7d2d;
  border-radius: 2px;
  transition: width 500ms ease;
}
.setup-progress-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--muted);
  white-space: nowrap;
}

/* Steps */
.setup-step {
  display: flex;
  gap: 0;
  padding: 36px 0;
  border-bottom: 1px solid var(--line);
}
.setup-step-marker {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 52px;
  flex-shrink: 0;
  padding-top: 2px;
}
.setup-step-n {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  background: var(--paper);
  flex-shrink: 0;
  transition: all 200ms;
}
.setup-step-done .setup-step-n {
  border-color: #2d7d2d;
  background: #2d7d2d;
  color: #fff;
}
.setup-step-line {
  flex: 1;
  width: 2px;
  background: var(--line);
  margin-top: 8px;
  min-height: 24px;
}
.setup-step-done .setup-step-line { background: #2d7d2d; }
.setup-step-content { flex: 1; padding-top: 2px; }
.setup-step-head { margin-bottom: 22px; }
.setup-step-title {
  font-family: var(--serif);
  font-size: 22px;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 6px;
}
.setup-step-done .setup-step-title { color: var(--ink-soft); }
.setup-step-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.55;
  max-width: 60ch;
}
.setup-step-body { display: flex; flex-direction: column; gap: 0; }
.setup-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.setup-field:last-child { margin-bottom: 0; }
.setup-label { font-size: 13px; font-weight: 500; color: var(--ink); }
.setup-hint { font-size: 12px; color: var(--muted); line-height: 1.4; }
.setup-note {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  padding: 10px 14px;
  background: var(--line);
  border-radius: 3px;
  margin-top: 18px;
}

/* First conversations */
.setup-first-conv {
  padding: 36px 0;
}

@media (max-width: 700px) {
  .setup-hero-agents { grid-template-columns: 1fr; }
  .setup-first-conv > div[style*="grid"] { grid-template-columns: 1fr !important; }
}
