/* ===========================================================================
   components.css — UI components. Depends on tokens.css + base.css.
   =========================================================================== */

/* ---- Buttons ---------------------------------------------------------- */
.btn {
  --btn-bg: transparent;
  --btn-fg: var(--color-ink);
  --btn-bd: var(--color-line-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.85rem 1.6rem;
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-bd);
  border-radius: var(--radius-pill);
  font-size: var(--fs-sm);
  font-weight: var(--weight-med);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease),
              border-color var(--dur) var(--ease), transform var(--dur-fast) var(--ease);
  white-space: nowrap;
}
.btn:hover { border-color: var(--color-ink); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn--accent { --btn-bg: var(--color-accent); --btn-fg: var(--color-accent-ink); --btn-bd: var(--color-accent); }
.btn--accent:hover { --btn-bg: var(--color-accent-soft); border-color: var(--color-accent-soft); }
.btn--solid  { --btn-bg: var(--color-ink); --btn-fg: var(--color-bg); --btn-bd: var(--color-ink); }
.btn--ghost  { --btn-bg: transparent; }
.btn--block  { width: 100%; }
.btn--sm     { padding: 0.55rem 1.05rem; font-size: var(--fs-2xs); }
.btn--lg     { padding: 1rem 2rem; }

.link-arrow {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: var(--fs-sm); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--color-ink); border-bottom: 1px solid var(--color-line-strong);
  padding-bottom: 2px; transition: gap var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.link-arrow:hover { gap: 0.7rem; border-color: var(--color-accent); }

/* ---- Header / nav ----------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: color-mix(in srgb, var(--color-bg) 82%, transparent);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: var(--border);
}
.site-header__inner {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  height: 68px;
}
.brand { display: inline-flex; align-items: center; margin-right: auto; }
.brand img { height: 26px; width: auto; }

.nav__list { display: flex; align-items: center; gap: clamp(1rem, 2.4vw, 2.2rem); }
.nav-link {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-muted);
  padding-block: 0.4rem;
  position: relative;
  transition: color var(--dur) var(--ease);
}
.nav-link::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px;
  background: var(--color-accent); transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur) var(--ease);
}
.nav-link:hover { color: var(--color-ink); }
.nav-link[aria-current='page'] { color: var(--color-ink); }
.nav-link[aria-current='page']::after,
.nav-link:hover::after { transform: scaleX(1); }

.cart-button {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--radius-pill);
  color: var(--color-ink); transition: background var(--dur) var(--ease);
}
.cart-button:hover { background: var(--color-surface-2); }
.cart-button__count {
  position: absolute; top: -2px; right: -2px;
  min-width: 18px; height: 18px; padding: 0 5px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-accent); color: var(--color-accent-ink);
  font-size: 10px; font-weight: var(--weight-bold); border-radius: var(--radius-pill);
  line-height: 1;
}

/* Hamburger */
.nav-toggle {
  display: none;
  width: 40px; height: 40px; border-radius: var(--radius);
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
  order: 3;
}
.nav-toggle__bar { width: 20px; height: 1.6px; background: var(--color-ink); transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.nav-toggle[aria-expanded='true'] .nav-toggle__bar:nth-child(1) { transform: translateY(6.6px) rotate(45deg); }
.nav-toggle[aria-expanded='true'] .nav-toggle__bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded='true'] .nav-toggle__bar:nth-child(3) { transform: translateY(-6.6px) rotate(-45deg); }

@media (max-width: 820px) {
  .nav-toggle { display: flex; }
  .cart-button { order: 2; }
  .nav {
    position: fixed; inset: 68px 0 0; z-index: var(--z-header);
    background: var(--color-bg);
    padding: var(--space-6) var(--gutter);
    transform: translateX(100%);
    transition: transform var(--dur) var(--ease);
    visibility: hidden;
  }
  .nav--open { transform: none; visibility: visible; }
  .nav__list { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
  .nav-link { font-size: var(--fs-lg); letter-spacing: 0.06em; padding-block: var(--space-3); }
}

/* ---- Footer ----------------------------------------------------------- */
.site-footer {
  border-top: var(--border);
  margin-top: var(--space-9);
  padding-block: var(--space-8) var(--space-5);
  background: linear-gradient(to bottom, transparent, rgba(46, 74, 138, 0.06));
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(3, 1fr) 1.8fr;
  gap: var(--space-6);
}
.footer__brand img { height: 24px; margin-bottom: var(--space-3); }
.footer__tagline { font-family: var(--font-script); font-size: 1.5rem; color: var(--color-accent); line-height: 1; }
.footer__est { color: var(--color-faint); font-size: var(--fs-xs); margin-top: var(--space-2); letter-spacing: 0.04em; }
.footer__col { display: flex; flex-direction: column; gap: var(--space-2); }
.footer__h {
  font-size: var(--fs-2xs); letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--color-faint); margin-bottom: var(--space-2); font-weight: var(--weight-med);
}
.footer__col a { color: var(--color-muted); font-size: var(--fs-sm); transition: color var(--dur) var(--ease); width: fit-content; }
.footer__col a:hover { color: var(--color-ink); }
.footer__news-copy { color: var(--color-muted); font-size: var(--fs-sm); margin-bottom: var(--space-3); }
.footer__base {
  display: flex; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap;
  margin-top: var(--space-7); padding-top: var(--space-4); border-top: var(--border);
  color: var(--color-faint); font-size: var(--fs-xs);
}
.footer__base-tag { letter-spacing: 0.08em; text-transform: uppercase; }

@media (max-width: 820px) {
  .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-6) var(--space-5); }
  .footer__brand, .footer__news { grid-column: 1 / -1; }
}

/* ---- Newsletter / form fields ---------------------------------------- */
.news-form__row { display: flex; gap: var(--space-2); }
.news-form__row input { flex: 1; min-width: 0; }

.field, .news-form input, .form input, .form textarea, .form select {
  width: 100%;
  background: var(--color-surface-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  color: var(--color-ink);
  padding: 0.8rem 0.95rem;
  font-size: var(--fs-base);
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.form textarea { min-height: 130px; resize: vertical; }
.field::placeholder, .form input::placeholder, .form textarea::placeholder { color: var(--color-faint); }
.field:focus, .form :is(input, textarea, select):focus {
  outline: none; border-color: var(--color-accent); background: var(--color-surface);
}
.form-label, .field-label {
  display: block; font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--color-muted); margin-bottom: var(--space-2);
}
.form { display: grid; gap: var(--space-4); }
.form__row { display: grid; gap: var(--space-4); grid-template-columns: 1fr 1fr; }
@media (max-width: 560px) { .form__row { grid-template-columns: 1fr; } }

.form-status { font-size: var(--fs-sm); min-height: 1.2em; margin-top: var(--space-1); }
.form-status[data-kind='ok']   { color: var(--color-success); }
.form-status[data-kind='err']  { color: var(--color-danger); }
.form-status[data-kind='warn'] { color: var(--color-accent); }

/* ---- Product card ----------------------------------------------------- */
.card { position: relative; display: flex; flex-direction: column; gap: var(--space-3); }
.card__media {
  position: relative;
  aspect-ratio: var(--ratio-product);
  background: var(--color-surface);
  border: var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.card__media img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease);
}
.card__media img.is-second { opacity: 0; }
.card:hover .card__media img.is-first  { opacity: 0; }
.card:hover .card__media img.is-second { opacity: 1; }
.card:hover .card__media img { transform: scale(1.03); }

.card__tags { position: absolute; top: var(--space-3); left: var(--space-3); display: flex; gap: 6px; flex-wrap: wrap; }
.badge {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: var(--weight-med);
  padding: 4px 9px; border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--color-bg) 60%, transparent);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  border: 1px solid var(--color-line-strong); color: var(--color-ink);
}
.badge--accent { background: var(--color-accent); color: var(--color-accent-ink); border-color: var(--color-accent); }
.badge--sold { background: color-mix(in srgb, var(--color-bg) 70%, transparent); color: var(--color-muted); }

.card__sold {
  position: absolute; inset: 0; display: grid; place-items: center;
  background: rgba(11, 11, 13, 0.5); color: var(--color-ink);
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase;
}
.card__info { display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-3); }
.card__name { font-size: var(--fs-sm); font-weight: var(--weight-med); color: var(--color-ink); }
.card__meta { font-size: var(--fs-xs); color: var(--color-faint); margin-top: 2px; }
.card__price { font-size: var(--fs-sm); color: var(--color-muted); white-space: nowrap; }
.card a.card__link::after { content: ''; position: absolute; inset: 0; } /* whole-card click target */

/* ---- Hero ------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: clamp(560px, 86vh, 880px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-bottom: var(--border);
}
.hero__media { position: absolute; inset: 0; z-index: -1; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11,11,13,0.95) 8%, rgba(11,11,13,0.35) 55%, rgba(11,11,13,0.55) 100%);
}
.hero__inner { padding-block: clamp(2.5rem, 7vw, 5.5rem); width: 100%; }
.hero__overline { margin-bottom: var(--space-4); }
.hero__title { font-size: var(--fs-3xl); font-weight: var(--weight-light); letter-spacing: var(--tracking-tight); line-height: 0.96; }
.hero__title .script { display: block; font-size: var(--fs-script); margin-top: -0.1em; }
.hero__copy { color: var(--color-muted); max-width: 46ch; margin-top: var(--space-4); font-size: var(--fs-md); }
.hero__actions { display: flex; gap: var(--space-3); margin-top: var(--space-6); flex-wrap: wrap; }

/* ---- Statement band --------------------------------------------------- */
.statement {
  text-align: center;
  padding-block: clamp(4rem, 12vw, 9rem);
  border-block: var(--border);
  background:
    radial-gradient(80% 120% at 50% 50%, var(--color-cosmic-glow), transparent 70%);
}
.statement__script { font-family: var(--font-script); font-size: var(--fs-3xl); color: var(--color-accent); line-height: 0.9; }
.statement__sub { color: var(--color-muted); letter-spacing: var(--tracking-wide); text-transform: uppercase; font-size: var(--fs-xs); margin-top: var(--space-4); }

/* ---- Chapter feature / lookbook -------------------------------------- */
.chapter-feature {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: center;
}
.chapter-feature--flip { grid-template-columns: 1fr 1.1fr; }
.chapter-feature--flip .chapter-feature__media { order: 2; }
.chapter-feature__media {
  aspect-ratio: 4 / 3; border-radius: var(--radius-lg); overflow: hidden;
  border: var(--border); background: var(--color-surface);
}
.chapter-feature__media img { width: 100%; height: 100%; object-fit: cover; }
.chapter-feature__label { font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--color-muted); }
.chapter-feature__title { font-size: var(--fs-2xl); font-weight: var(--weight-light); line-height: 1; margin-block: var(--space-2) var(--space-3); }
.chapter-feature__title .script { display: block; font-size: var(--fs-script); }
.chapter-feature__blurb { color: var(--color-muted); max-width: 48ch; margin-bottom: var(--space-5); }
.chapter-feature__badge {
  display: inline-block; font-size: var(--fs-2xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--color-accent); border: 1px solid var(--color-accent);
  border-radius: var(--radius-pill); padding: 4px 12px; margin-bottom: var(--space-4);
}
@media (max-width: 760px) {
  .chapter-feature, .chapter-feature--flip { grid-template-columns: 1fr; }
  .chapter-feature--flip .chapter-feature__media { order: 0; }
}

/* ---- Breadcrumb / page header ---------------------------------------- */
.page-head { padding-block: var(--space-7) var(--space-5); border-bottom: var(--border); }
.page-head h1 { font-size: var(--fs-2xl); font-weight: var(--weight-light); }
.breadcrumb { display: flex; gap: 0.5rem; font-size: var(--fs-xs); color: var(--color-faint); margin-bottom: var(--space-3); letter-spacing: 0.04em; }
.breadcrumb a:hover { color: var(--color-ink); }

/* ---- Shop toolbar / filters ------------------------------------------ */
.toolbar {
  display: flex; align-items: center; gap: var(--space-3) var(--space-4); flex-wrap: wrap;
  padding-block: var(--space-5); position: sticky; top: 68px; z-index: 50;
  background: color-mix(in srgb, var(--color-bg) 88%, transparent);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-bottom: var(--border);
}
.toolbar__group { display: flex; align-items: center; gap: var(--space-2); }
.toolbar__label { font-size: var(--fs-2xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-faint); }
.toolbar__count { margin-left: auto; font-size: var(--fs-xs); color: var(--color-faint); }
.select {
  background: var(--color-surface-2); border: 1px solid var(--color-line);
  border-radius: var(--radius-pill); color: var(--color-ink);
  padding: 0.5rem 2rem 0.5rem 0.9rem; font-size: var(--fs-sm);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23A2A29B' stroke-width='1.6'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.7rem center;
}
.chip {
  font-size: var(--fs-xs); letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.45rem 0.9rem; border-radius: var(--radius-pill);
  border: 1px solid var(--color-line-strong); color: var(--color-muted);
  background: transparent; transition: all var(--dur) var(--ease);
}
.chip:hover { color: var(--color-ink); border-color: var(--color-ink); }
.chip[aria-pressed='true'] { background: var(--color-accent); color: var(--color-accent-ink); border-color: var(--color-accent); }
.chip-row { display: flex; gap: var(--space-2); flex-wrap: wrap; }

.empty-state { text-align: center; padding-block: var(--space-9); color: var(--color-muted); }
.empty-state h2 { font-weight: var(--weight-light); margin-bottom: var(--space-3); }

@media (max-width: 640px) {
  .toolbar { top: 0; }
  .toolbar__count { width: 100%; order: 5; margin-left: 0; }
}

/* ---- Product page ----------------------------------------------------- */
.product { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(1.5rem, 5vw, 4rem); align-items: start; padding-block: var(--space-6); }
@media (max-width: 880px) { .product { grid-template-columns: 1fr; } }

.gallery { display: grid; grid-template-columns: 64px 1fr; gap: var(--space-3); position: sticky; top: 88px; }
.gallery__thumbs { display: flex; flex-direction: column; gap: var(--space-2); }
.gallery__thumb {
  aspect-ratio: var(--ratio-product); border: 1px solid var(--color-line); border-radius: var(--radius-sm);
  overflow: hidden; background: var(--color-surface); opacity: 0.6; transition: opacity var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumb[aria-current='true'] { opacity: 1; border-color: var(--color-accent); }
.gallery__main {
  aspect-ratio: var(--ratio-product); border: var(--border); border-radius: var(--radius);
  overflow: hidden; background: var(--color-surface);
}
.gallery__main img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 880px) {
  .gallery { position: static; grid-template-columns: 1fr; }
  .gallery__thumbs { flex-direction: row; order: 2; overflow-x: auto; }
  .gallery__thumb { flex: 0 0 60px; }
}

.pd__chapter { font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-accent); }
.pd__title { font-size: var(--fs-xl); font-weight: var(--weight-light); margin-block: var(--space-2) var(--space-3); }
.pd__price { font-size: var(--fs-lg); color: var(--color-ink); margin-bottom: var(--space-5); }
.pd__desc { color: var(--color-muted); margin-bottom: var(--space-5); max-width: 52ch; }
.pd__section { margin-block: var(--space-5); padding-top: var(--space-5); border-top: var(--border); }

.sizes { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-block: var(--space-3) var(--space-2); }
.size {
  min-width: 48px; padding: 0.6rem 0.5rem; text-align: center;
  border: 1px solid var(--color-line-strong); border-radius: var(--radius);
  font-size: var(--fs-sm); color: var(--color-ink); background: transparent;
  transition: all var(--dur) var(--ease);
}
.size:hover { border-color: var(--color-ink); }
.size[aria-pressed='true'] { background: var(--color-ink); color: var(--color-bg); border-color: var(--color-ink); }
.size:disabled { opacity: 0.3; cursor: not-allowed; text-decoration: line-through; }
.size-hint { font-size: var(--fs-xs); color: var(--color-danger); min-height: 1.1em; }

.pd__actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); flex-wrap: wrap; }
.pd__actions .btn { flex: 1; min-width: 180px; }

.details-list { display: grid; gap: var(--space-2); }
.details-list li { display: flex; gap: var(--space-3); color: var(--color-muted); font-size: var(--fs-sm); }
.details-list li::before { content: '—'; color: var(--color-accent); }

.external-buttons { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-3); }

/* ---- Cart drawer ------------------------------------------------------ */
.drawer-overlay {
  position: fixed; inset: 0; z-index: var(--z-overlay);
  background: rgba(5, 5, 7, 0.6); opacity: 0; transition: opacity var(--dur) var(--ease);
}
.drawer-overlay.is-open { opacity: 1; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: var(--z-drawer);
  width: min(420px, 100vw);
  background: var(--color-surface); border-left: var(--border);
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform var(--dur-slow) var(--ease);
  box-shadow: var(--shadow-lg);
}
.drawer.is-open { transform: none; }
.drawer__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-5); border-bottom: var(--border); }
.drawer__title { font-size: var(--fs-md); font-weight: var(--weight-med); letter-spacing: 0.02em; }
.drawer__close { font-size: 1.7rem; line-height: 1; color: var(--color-muted); width: 36px; height: 36px; border-radius: var(--radius); transition: color var(--dur) var(--ease); }
.drawer__close:hover { color: var(--color-ink); }
.drawer__body { flex: 1; overflow-y: auto; padding: var(--space-4) var(--space-5); display: flex; flex-direction: column; gap: var(--space-4); }
.drawer__empty { text-align: center; color: var(--color-muted); padding-block: var(--space-8); display: grid; gap: var(--space-4); place-items: center; }
.drawer__foot { padding: var(--space-5); border-top: var(--border); display: grid; gap: var(--space-3); }
.drawer__subtotal { display: flex; justify-content: space-between; font-size: var(--fs-md); }
.drawer__subtotal span:last-child { color: var(--color-accent); font-weight: var(--weight-med); }
.drawer__note { font-size: var(--fs-xs); color: var(--color-faint); }

.cart-line { display: grid; grid-template-columns: 64px 1fr auto; gap: var(--space-3); align-items: start; }
.cart-line__media { border-radius: var(--radius-sm); overflow: hidden; border: var(--border); background: var(--color-surface-2); }
.cart-line__media img { width: 64px; height: 80px; object-fit: cover; }
.cart-line__name { font-size: var(--fs-sm); font-weight: var(--weight-med); color: var(--color-ink); }
.cart-line__meta { font-size: var(--fs-xs); color: var(--color-faint); margin-block: 2px var(--space-2); }
.cart-line__end { text-align: right; display: flex; flex-direction: column; gap: var(--space-2); align-items: flex-end; }
.cart-line__total { font-size: var(--fs-sm); }
.cart-line__remove { font-size: var(--fs-xs); color: var(--color-faint); text-decoration: underline; text-underline-offset: 2px; transition: color var(--dur) var(--ease); }
.cart-line__remove:hover { color: var(--color-danger); }

.qty { display: inline-flex; align-items: center; border: 1px solid var(--color-line-strong); border-radius: var(--radius-pill); }
.qty__btn { width: 28px; height: 28px; display: grid; place-items: center; color: var(--color-muted); font-size: 1rem; transition: color var(--dur) var(--ease); }
.qty__btn:hover { color: var(--color-ink); }
.qty__val { min-width: 24px; text-align: center; font-size: var(--fs-sm); }

/* ---- Cart page -------------------------------------------------------- */
.cart-layout { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: start; padding-block: var(--space-6); }
@media (max-width: 880px) { .cart-layout { grid-template-columns: 1fr; } }
.cart-table { display: grid; gap: var(--space-2); }
.cart-row {
  display: grid; grid-template-columns: 88px 1fr auto auto; gap: var(--space-4); align-items: center;
  padding: var(--space-4) 0; border-bottom: var(--border);
}
.cart-row__media { aspect-ratio: var(--ratio-product); width: 88px; border-radius: var(--radius); overflow: hidden; border: var(--border); background: var(--color-surface); }
.cart-row__media img { width: 100%; height: 100%; object-fit: cover; }
.cart-row__name { font-weight: var(--weight-med); }
.cart-row__meta { font-size: var(--fs-xs); color: var(--color-faint); margin-top: 2px; }
.cart-row__price { white-space: nowrap; }
@media (max-width: 560px) {
  .cart-row { grid-template-columns: 64px 1fr auto; }
  .cart-row__media { width: 64px; }
  .cart-row .qty { grid-column: 2; }
}

.summary { position: sticky; top: 88px; background: var(--color-surface); border: var(--border); border-radius: var(--radius-lg); padding: var(--space-5); display: grid; gap: var(--space-3); }
.summary h2 { font-size: var(--fs-md); font-weight: var(--weight-med); }
.summary__row { display: flex; justify-content: space-between; color: var(--color-muted); font-size: var(--fs-sm); }
.summary__row--total { color: var(--color-ink); font-size: var(--fs-md); padding-top: var(--space-3); border-top: var(--border); }
.summary__row--total span:last-child { color: var(--color-accent); font-weight: var(--weight-med); }

/* ---- Checkout --------------------------------------------------------- */
.checkout { padding-block: var(--space-6); }
.checkout__steps { display: grid; gap: var(--space-5); }
.method-tabs { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-4); }
.confirm-box { background: var(--color-surface); border: var(--border); border-radius: var(--radius-lg); padding: var(--space-5); display: grid; gap: var(--space-3); }
.confirm-box code { background: var(--color-surface-2); padding: 2px 8px; border-radius: var(--radius-sm); color: var(--color-accent); font-size: var(--fs-sm); }
.bank-line { display: flex; justify-content: space-between; gap: var(--space-3); padding: var(--space-2) 0; border-bottom: var(--border); }
.notice { padding: var(--space-3) var(--space-4); border-radius: var(--radius); border: 1px solid var(--color-line-strong); background: var(--color-surface-2); font-size: var(--fs-sm); color: var(--color-muted); }
.notice--accent { border-color: color-mix(in srgb, var(--color-accent) 40%, transparent); }

/* ---- About / editorial ------------------------------------------------ */
.prose { max-width: 66ch; }
.prose p { color: var(--color-muted); margin-bottom: var(--space-4); }
.prose h2 { font-size: var(--fs-lg); font-weight: var(--weight-light); margin-block: var(--space-6) var(--space-3); color: var(--color-ink); }
.lead { font-size: var(--fs-md); color: var(--color-ink) !important; }
.pull-quote { font-family: var(--font-script); font-size: var(--fs-2xl); color: var(--color-accent); line-height: 0.95; text-align: center; padding-block: var(--space-6); }

.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-5); }
.info-card { border: var(--border); border-radius: var(--radius-lg); padding: var(--space-5); background: var(--color-surface); }
.info-card h3 { font-size: var(--fs-2xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-faint); margin-bottom: var(--space-2); }
.info-card a { color: var(--color-ink); }
.info-card a:hover { color: var(--color-accent); }

/* ---- Toast ------------------------------------------------------------ */
.toast {
  position: fixed; left: 50%; bottom: var(--space-6); transform: translate(-50%, 20px);
  z-index: var(--z-toast); background: var(--color-ink); color: var(--color-bg);
  padding: 0.75rem 1.3rem; border-radius: var(--radius-pill); font-size: var(--fs-sm); font-weight: var(--weight-med);
  box-shadow: var(--shadow-lg); opacity: 0; pointer-events: none;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.toast.is-visible { opacity: 1; transform: translate(-50%, 0); }

/* ---- Misc ------------------------------------------------------------- */
.tag-pill { display: inline-block; font-size: var(--fs-2xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-muted); border: var(--border); border-radius: var(--radius-pill); padding: 3px 10px; }
