/* ============================================================================
   emboros 스토어프론트 컴포넌트 CSS — 디자인 토큰(tokens-base/moods) 위에서만 동작.
   매직 넘버 없음(모든 값은 토큰 인용). 모션은 transform/opacity, focus-visible 링, 44px 타겟.
   ============================================================================ */

*, *::before, *::after { box-sizing: border-box; }
[x-cloak] { display: none !important; }

body {
  margin: 0;
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-ink);
  line-height: var(--lh-body);
  font-size: var(--fs-base);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }

:where(a, button, input, textarea, select, [tabindex]):focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--gutter); }
.muted { color: var(--color-ink-muted); }
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
/* skip-navigation — 키보드 첫 Tab에 나타나 본문(#content)으로 점프(WCAG 2.4.1) */
.skip-link {
  position: fixed; inset-block-start: var(--space-3); inset-inline-start: var(--space-3); z-index: var(--z-toast);
  padding: var(--space-2) var(--space-4); font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  color: var(--color-on-primary); background: var(--color-primary-strong); border-radius: var(--radius-md);
  transform: translateY(calc(-100% - var(--space-4))); transition: transform var(--dur-fast) var(--ease-out);
}
.skip-link:focus { transform: translateY(0); }
#content:focus { outline: none; }  /* 프로그램적 포커스 대상(마우스 아웃라인 억제, 키보드는 skip-link 경유) */

/* ── Buttons ── */
.btn {
  --_bg: var(--color-surface-2);
  --_fg: var(--color-ink);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  min-height: var(--tap-min); padding: 0 var(--space-5);
  font: inherit; font-weight: var(--fw-semibold); font-size: var(--fs-sm);
  color: var(--_fg); background: var(--_bg);
  border: 1px solid transparent; border-radius: var(--radius-md); cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-out), filter var(--dur-fast) var(--ease-standard);
}
.btn:hover { filter: brightness(0.97); }
.btn:active { transform: translateY(1px); }
.btn--primary { --_bg: var(--color-primary-strong); --_fg: var(--color-on-primary); }
.btn--accent { --_bg: var(--color-accent); --_fg: var(--color-on-accent); }
.btn--ghost { --_bg: transparent; --_fg: var(--color-ink); border-color: var(--color-border); }
.btn--lg { min-height: calc(var(--tap-min) + var(--space-2)); padding-inline: var(--space-6); font-size: var(--fs-base); }
.btn--block { width: 100%; }

.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: var(--tap-min); min-height: var(--tap-min);
  color: var(--color-ink-muted); background: transparent; border: 0; border-radius: var(--radius-md);
  cursor: pointer; transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.icon-btn:hover { color: var(--color-ink); background: var(--color-surface-2); }

/* ── Header ── */
.site-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  background: color-mix(in oklch, var(--color-bg) 85%, transparent);
  backdrop-filter: blur(10px) saturate(1.4);
  border-bottom: 1px solid var(--color-border);
}
.site-header__inner { display: flex; align-items: center; gap: var(--space-5); min-height: 4rem; }
.brand {
  font-family: var(--font-display); font-weight: var(--fw-bold);
  font-size: var(--fs-lg); letter-spacing: var(--tracking-tight); color: var(--color-ink);
}
.nav { display: none; gap: var(--space-5); flex: 1; }
.nav__link {
  font-size: var(--fs-sm); color: var(--color-ink-muted);
  padding-block: var(--space-2); border-bottom: 2px solid transparent;
  transition: color var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard);
}
.nav__link:hover, .nav__link[aria-current="page"] { color: var(--color-ink); border-color: var(--color-primary); }
.header-actions { display: flex; align-items: center; gap: var(--space-1); margin-inline-start: auto; }
.header-search { position: relative; display: none; align-items: center; }
.header-search__icon { position: absolute; inset-inline-start: var(--space-3); color: var(--color-ink-subtle); pointer-events: none; }
.header-search__input {
  font: inherit; font-size: var(--fs-sm); color: var(--color-ink);
  background: var(--color-surface-2); border: 1px solid transparent; border-radius: var(--radius-full);
  padding-block: var(--space-2); padding-inline: calc(var(--space-6) + var(--space-1)) var(--space-4);
  min-height: var(--tap-min); width: 11rem;
  transition: border-color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard), width var(--dur-fast) var(--ease-standard);
}
.header-search__input:focus { border-color: var(--color-primary); background: var(--color-surface); width: 13rem; }
@media (min-width: 40rem) { .header-search { display: inline-flex; } }
.cart-btn { position: relative; }
.cart-count {
  position: absolute; top: 2px; inset-inline-end: 2px; min-width: 1.1rem; height: 1.1rem;
  display: grid; place-items: center; padding-inline: 4px;
  font-size: 0.625rem; font-weight: var(--fw-bold);
  color: var(--color-on-accent); background: var(--color-accent); border-radius: var(--radius-full);
}
@media (min-width: 48rem) { .nav { display: flex; } }

/* ── Hero (home) ── */
.hero { padding-block: var(--space-8) var(--space-7); border-bottom: 1px solid var(--color-border); }
.hero__eyebrow { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-primary); letter-spacing: var(--tracking-wide); }
.hero__title {
  font-family: var(--font-display); font-weight: var(--fw-bold);
  font-size: var(--fs-4xl); line-height: var(--lh-tight); letter-spacing: var(--tracking-tight);
  margin: var(--space-3) 0 0; max-width: 18ch;
}
.hero__sub { margin: var(--space-4) 0 var(--space-6); font-size: var(--fs-lg); color: var(--color-ink-muted); max-width: 46ch; }

/* ── Section heading ── */
.section { padding-block: var(--space-7); }
.section__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-5); }
.section__title { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); margin: 0; }
.section__link { font-size: var(--fs-sm); color: var(--color-primary); font-weight: var(--fw-medium); }

/* ── Category chips ── */
.chips { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); }
.chip {
  padding: var(--space-2) var(--space-4); font-size: var(--fs-sm); font-weight: var(--fw-medium);
  color: var(--color-ink-muted); background: var(--color-surface-2);
  border: 1px solid transparent; border-radius: var(--radius-full);
  transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.chip:hover { color: var(--color-ink); }
.chip[aria-current="true"] { color: var(--color-on-primary); background: var(--color-primary-strong); }

/* ── Product grid + card ── */
.product-grid {
  display: grid; gap: var(--space-5) var(--space-4);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
}
.card { display: flex; flex-direction: column; }
.card__media {
  position: relative; aspect-ratio: 4 / 5; overflow: hidden;
  background: var(--color-surface-2); border-radius: var(--radius-md);
}
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-enter) var(--ease-out); }
.card:hover .card__media img { transform: scale(1.04); }
.card__media--empty { display: grid; place-items: center; color: var(--color-ink-subtle); font-size: var(--fs-sm); }
.card__badge {
  position: absolute; top: var(--space-2); inset-inline-start: var(--space-2);
  padding: 2px var(--space-2); font-size: var(--fs-xs); font-weight: var(--fw-bold);
  color: var(--color-on-accent); background: var(--color-accent); border-radius: var(--radius-sm);
}
.card__body { padding-top: var(--space-3); }
.card__name {
  font-size: var(--fs-base); font-weight: var(--fw-medium); line-height: var(--lh-snug);
  color: var(--color-ink); margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.card:hover .card__name { color: var(--color-primary); }
.price { display: flex; align-items: baseline; gap: var(--space-2); margin-top: var(--space-2); }
.price__now { font-size: var(--fs-base); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.price__was { font-size: var(--fs-sm); color: var(--color-ink-subtle); text-decoration: line-through; }
.price__off { font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--color-primary); }

/* ── Empty state ── */
.empty { padding: var(--space-8) var(--space-4); text-align: center; border: 1px dashed var(--color-border); border-radius: var(--radius-lg); }
.empty__title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); margin: 0 0 var(--space-2); }
.empty__sub { color: var(--color-ink-muted); margin: 0 0 var(--space-5); }

/* ── PDP ── */
.pdp { display: grid; gap: var(--space-6); padding-block: var(--space-6) var(--space-8); }
.pdp__media { aspect-ratio: 4 / 5; overflow: hidden; background: var(--color-surface-2); border-radius: var(--radius-lg); }
.pdp__media img { width: 100%; height: 100%; object-fit: cover; }
.pdp__media--empty { display: grid; place-items: center; color: var(--color-ink-subtle); }
.pdp__gallery { display: flex; flex-direction: column; gap: var(--space-3); min-width: 0; }
.pdp__thumbs { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.pdp__thumb {
  width: 4rem; height: 4rem; padding: 0; overflow: hidden; cursor: pointer;
  border: 2px solid var(--color-border); border-radius: var(--radius-sm); background: var(--color-surface-2);
  transition: border-color var(--dur-fast) var(--ease-standard);
}
.pdp__thumb--on { border-color: var(--color-primary); }
.pdp__thumb img { width: 100%; height: 100%; object-fit: cover; }
.pdp__opts { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-5); }
.pdp__cat { font-size: var(--fs-sm); color: var(--color-primary); font-weight: var(--fw-medium); }
.pdp__title { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); line-height: var(--lh-tight); margin: var(--space-2) 0 var(--space-4); }
.pdp__price { display: flex; align-items: baseline; gap: var(--space-3); margin-bottom: var(--space-5); }
.pdp__price .price__now { font-size: var(--fs-2xl); }
.pdp__price .price__was { font-size: var(--fs-lg); }
.pdp__desc { color: var(--color-ink-muted); line-height: var(--lh-body); margin-bottom: var(--space-6); white-space: pre-line; }
.pdp__meta { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-5); background: var(--color-surface-2); border-radius: var(--radius-md); margin-bottom: var(--space-6); }
.pdp__meta-row { display: flex; justify-content: space-between; gap: var(--space-4); font-size: var(--fs-sm); }
.pdp__meta-row dt { color: var(--color-ink-muted); }
.pdp__meta-row dd { margin: 0; font-weight: var(--fw-medium); }
.pdp__actions { display: flex; gap: var(--space-3); align-items: stretch; }
.pdp__actions > .btn { flex: 1 1 auto; width: auto; }
.qty { display: inline-flex; align-items: center; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; }
.qty__btn {
  min-width: var(--tap-min); min-height: var(--tap-min); display: grid; place-items: center;
  font-size: var(--fs-lg); color: var(--color-ink); background: var(--color-surface); border: 0; cursor: pointer;
  transition: background var(--dur-fast) var(--ease-standard);
}
.qty__btn:hover { background: var(--color-surface-2); }
.qty__val { min-width: 2.75rem; text-align: center; font-weight: var(--fw-semibold); font-variant-numeric: tabular-nums; }
@media (min-width: 48rem) {
  .pdp { grid-template-columns: 1.1fr 1fr; gap: var(--space-7); align-items: start; }
  .pdp__info { position: sticky; top: 5rem; }
}

/* ── Cart ── */
.cart-list { display: flex; flex-direction: column; gap: var(--space-4); }
.cart-line {
  display: grid; grid-template-columns: 4.5rem 1fr auto;
  grid-template-areas: "media info total" "media qty remove";
  align-items: center; column-gap: var(--space-4); row-gap: var(--space-2);
  padding-bottom: var(--space-4); border-bottom: 1px solid var(--color-border);
}
.cart-line__media { grid-area: media; align-self: start; aspect-ratio: 1; width: 4.5rem; overflow: hidden; border-radius: var(--radius-sm); background: var(--color-surface-2); }
.cart-line__media img { width: 100%; height: 100%; object-fit: cover; }
.cart-line__info { grid-area: info; display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; }
.cart-line__name { font-weight: var(--fw-medium); color: var(--color-ink); }
.cart-line__opts { display: block; font-size: var(--fs-xs); margin-top: 2px; }
.cart-line__name:hover { color: var(--color-primary); }
.cart-line__qty { grid-area: qty; justify-self: start; display: inline-flex; align-items: center; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; }
.cart-line__total { grid-area: total; justify-self: end; font-weight: var(--fw-bold); font-variant-numeric: tabular-nums; }
.cart-line__remove-form { grid-area: remove; justify-self: end; align-self: end; }
.cart-summary { margin-top: var(--space-6); margin-inline-start: auto; max-width: 24rem; }
.cart-summary__row { display: flex; justify-content: space-between; align-items: baseline; padding-block: var(--space-3); font-size: var(--fs-lg); border-top: 1px solid var(--color-border); }
.cart-summary__row strong { font-size: var(--fs-xl); letter-spacing: var(--tracking-tight); }
.cart-summary__note { font-size: var(--fs-sm); color: var(--color-ink-muted); margin: var(--space-1) 0 var(--space-4); }

/* ── Forms / Checkout ── */
.section--narrow { max-width: 40rem; margin-inline: auto; }
.checkout { display: grid; gap: var(--space-6); }
.form-card { border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); margin: 0 0 var(--space-4); }
.form-card__title { font-size: var(--fs-base); font-weight: var(--fw-semibold); padding: 0; margin-bottom: var(--space-4); }
.field { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
.field:last-child { margin-bottom: 0; }
.field__label { font-size: var(--fs-sm); color: var(--color-ink-muted); }
.field__input {
  font: inherit; font-size: var(--fs-base); color: var(--color-ink);
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4); min-height: var(--tap-min); width: 100%;
  transition: border-color var(--dur-fast) var(--ease-standard);
}
.field__input:focus { border-color: var(--color-primary); }
textarea.field__input { resize: vertical; min-height: 4rem; }
.summary-card { border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); background: var(--color-surface); }
.summary-card__title { font-size: var(--fs-lg); font-weight: var(--fw-bold); margin: 0 0 var(--space-4); }
.summary-list { display: flex; flex-direction: column; gap: var(--space-2); padding-bottom: var(--space-4); margin: 0 0 var(--space-2); border-bottom: 1px solid var(--color-border); font-size: var(--fs-sm); }
.summary-list li { display: flex; justify-content: space-between; gap: var(--space-3); }
.summary-row { display: flex; justify-content: space-between; align-items: baseline; padding-block: var(--space-2); font-size: var(--fs-sm); color: var(--color-ink-muted); }
.summary-row--total { padding-top: var(--space-3); margin-top: var(--space-1); border-top: 1px solid var(--color-border); font-size: var(--fs-base); color: var(--color-ink); }
.summary-row--total strong { font-size: var(--fs-xl); letter-spacing: var(--tracking-tight); }
@media (min-width: 56rem) {
  .checkout { grid-template-columns: 1.4fr 1fr; align-items: start; }
  .checkout__summary { position: sticky; top: 5rem; }
}
.order-done { text-align: center; padding-block: var(--space-6); }
.order-done__check { width: 3.5rem; height: 3.5rem; margin: 0 auto var(--space-4); display: grid; place-items: center; color: var(--color-on-primary); background: var(--color-primary-strong); border-radius: var(--radius-full); }
.order-done__title { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-bold); margin: 0 0 var(--space-2); }

/* ── Footer ── */
.site-footer { margin-top: var(--space-9); padding-block: var(--space-7); border-top: 1px solid var(--color-border); color: var(--color-ink-muted); font-size: var(--fs-sm); }
.site-footer__inner { display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: space-between; }
.store-legal { padding-top: var(--space-4); margin-top: var(--space-4); border-top: 1px solid var(--color-border); font-size: var(--fs-xs); color: var(--color-ink-subtle); line-height: var(--lh-body); }
.store-legal p { margin: 0 0 var(--space-1); }
.store-legal strong { color: var(--color-ink-muted); font-weight: var(--fw-semibold); margin-inline-end: var(--space-1); }
.store-legal__biz { white-space: normal; }

/* ── breadcrumb ── */
.crumbs { display: flex; gap: var(--space-2); font-size: var(--fs-sm); color: var(--color-ink-muted); padding-block: var(--space-5) 0; }
.crumbs a:hover { color: var(--color-ink); }
.crumbs span[aria-current] { color: var(--color-ink); }

/* ── Header account links ── */
.header-link {
  font: inherit; font-size: var(--fs-sm); font-weight: var(--fw-medium);
  color: var(--color-ink-muted); background: transparent; border: 0; cursor: pointer;
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-md);
  min-height: var(--tap-min); display: inline-flex; align-items: center;
  transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.header-link:hover { color: var(--color-ink); background: var(--color-surface-2); }
.inline-form { display: inline-flex; margin: 0; }

/* ── Auth (login / register) ── */
.auth { max-width: 26rem; margin-inline: auto; padding-block: var(--space-8) var(--space-9); }
.auth__title { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); margin: 0 0 var(--space-2); }
.auth__sub { margin: 0 0 var(--space-6); }
.auth__form { margin-bottom: var(--space-5); }
.auth__form .btn { margin-top: var(--space-2); }
.auth__alt { text-align: center; font-size: var(--fs-sm); color: var(--color-ink-muted); }
.auth__alt a { color: var(--color-primary); font-weight: var(--fw-medium); }
.form-error {
  padding: var(--space-3) var(--space-4); margin: 0 0 var(--space-5);
  font-size: var(--fs-sm); color: var(--color-danger);
  background: color-mix(in oklch, var(--color-danger) 10%, var(--color-surface));
  border: 1px solid color-mix(in oklch, var(--color-danger) 35%, transparent);
  border-radius: var(--radius-md);
}

/* ── Account (my page + order history) ── */
.account-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-6); }
.account-subtitle { font-size: var(--fs-lg); font-weight: var(--fw-semibold); margin: 0 0 var(--space-4); }
.order-list { display: flex; flex-direction: column; gap: var(--space-3); }
.order-card { padding: var(--space-4) var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-md); transition: border-color var(--dur-fast) var(--ease-standard); }
.order-card:hover { border-color: var(--color-ink-subtle); }
.order-card__head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-2); }
.order-card__no { font-weight: var(--fw-semibold); font-variant-numeric: tabular-nums; letter-spacing: var(--tracking-tight); }
.order-card__no:hover { color: var(--color-primary); }
.order-card__meta { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3); font-size: var(--fs-sm); }
.order-card__total { font-size: var(--fs-base); font-variant-numeric: tabular-nums; }
.order-card__items { display: flex; flex-direction: column; gap: var(--space-1); margin-top: var(--space-3); padding-top: var(--space-3); border-top: 1px solid var(--color-border); font-size: var(--fs-sm); }
.order-card__items li { display: flex; gap: var(--space-2); align-items: baseline; flex-wrap: wrap; }
.status-badge {
  padding: 2px var(--space-2); font-size: var(--fs-xs); font-weight: var(--fw-bold);
  color: var(--color-on-semantic); border-radius: var(--radius-sm); white-space: nowrap;
  background: var(--color-ink-subtle);
}
.status-badge--paid, .status-badge--preparing, .status-badge--shipping { background: var(--color-info); }
.status-badge--delivered { background: var(--color-success); }
.status-badge--pending { background: var(--color-warning); color: var(--color-on-warning); }
.status-badge--cancelled, .status-badge--refunded { background: var(--color-danger); }

/* ── Seller console ── */
.seller-tag {
  font-family: var(--font-sans); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  color: var(--color-ink-muted); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); padding: 1px var(--space-2); margin-inline-start: var(--space-1);
  vertical-align: middle; letter-spacing: var(--tracking-normal);
}
.seller-intro { max-width: 52ch; margin-bottom: var(--space-5); line-height: var(--lh-body); }
.btn--sm { min-height: calc(var(--tap-min) - var(--space-2)); padding-inline: var(--space-4); font-size: var(--fs-sm); margin-top: var(--space-3); }
.form-success {
  padding: var(--space-3) var(--space-4); margin: 0 0 var(--space-5);
  font-size: var(--fs-sm); color: var(--color-success);
  background: color-mix(in oklch, var(--color-success) 10%, var(--color-surface));
  border: 1px solid color-mix(in oklch, var(--color-success) 35%, transparent);
  border-radius: var(--radius-md);
}
.form-notice {
  padding: var(--space-3) var(--space-4); margin: 0 0 var(--space-5);
  font-size: var(--fs-sm); color: var(--color-ink);
  background: color-mix(in oklch, var(--color-info) 10%, var(--color-surface));
  border: 1px solid color-mix(in oklch, var(--color-info) 35%, transparent);
  border-radius: var(--radius-md);
}
.form-notice p { margin: 0 0 var(--space-1); }
.form-notice p:last-child { margin-bottom: 0; }
.form-notice a { color: var(--color-primary); font-weight: var(--fw-medium); }
.field__hint { display: block; font-size: var(--fs-xs); margin-top: var(--space-1); }
.check { display: flex; align-items: flex-start; gap: var(--space-3); margin-block: var(--space-4); font-size: var(--fs-sm); cursor: pointer; }
.check input { width: 1.1rem; height: 1.1rem; margin-top: 2px; accent-color: var(--color-primary-strong); flex: none; }

/* stat cards */
.stat-grid { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr)); margin-bottom: var(--space-7); }
.stat-card { padding: var(--space-4) var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-lg); display: flex; flex-direction: column; gap: var(--space-2); }
.stat-card__label { font-size: var(--fs-sm); color: var(--color-ink-muted); }
.stat-card__value { font-size: var(--fs-xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }

/* 셀러 대시보드: 내 스토어 주소 카드 */
.store-url-card {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap;
  padding: var(--space-4) var(--space-5); margin-bottom: var(--space-6); border-radius: var(--radius-lg);
  background: color-mix(in oklch, var(--color-primary) 8%, var(--color-surface));
  border: 1px solid color-mix(in oklch, var(--color-primary) 22%, transparent);
}
.store-url-card__label { font-size: var(--fs-sm); color: var(--color-ink-muted); margin: 0 0 var(--space-1); }
.store-url-card__link { font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--color-primary-strong); font-variant-numeric: tabular-nums; word-break: break-all; }
.store-url-card__link:hover { text-decoration: underline; }

/* 통계 — 상태 분포 막대 */
.stat-bars { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-7); }
.stat-bar { display: grid; grid-template-columns: 5rem 1fr 3.5rem; align-items: center; gap: var(--space-3); }
.stat-bar__label { font-size: var(--fs-sm); color: var(--color-ink-muted); }
.stat-bar__track { height: 0.75rem; background: var(--color-surface-2); border-radius: var(--radius-full); overflow: hidden; }
.stat-bar__fill { height: 100%; border-radius: var(--radius-full); min-width: 3px; }
.stat-bar__val { font-size: var(--fs-sm); text-align: end; font-variant-numeric: tabular-nums; }

/* onboarding checklist */
.onboard { display: flex; flex-direction: column; gap: var(--space-3); counter-reset: step; }
.onboard__step { display: flex; gap: var(--space-4); padding: var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.onboard__step--done { border-color: color-mix(in oklch, var(--color-success) 40%, var(--color-border)); background: color-mix(in oklch, var(--color-success) 5%, transparent); }
.step-check {
  flex: none; width: 1.75rem; height: 1.75rem; display: grid; place-items: center;
  font-size: var(--fs-sm); font-weight: var(--fw-bold); border-radius: var(--radius-full);
  color: var(--color-ink-muted); background: var(--color-surface-2);
}
.onboard__step--done .step-check { color: var(--color-on-semantic); background: var(--color-success); }
.onboard__title { font-weight: var(--fw-semibold); margin: 0 0 var(--space-1); }
.onboard__desc { margin: 0 0 var(--space-2); font-size: var(--fs-sm); }
.onboard__body { min-width: 0; }

/* admin table (셀러 상품 목록) */
.header-link--danger { color: var(--color-danger); }
.header-link--danger:hover { color: var(--color-danger); background: color-mix(in oklch, var(--color-danger) 12%, transparent); }
.table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.admin-table th, .admin-table td { padding: var(--space-3) var(--space-3); text-align: start; border-bottom: 1px solid var(--color-border); vertical-align: middle; }
.admin-table th { font-weight: var(--fw-semibold); color: var(--color-ink-muted); font-size: var(--fs-xs); }
.admin-table .num { text-align: end; font-variant-numeric: tabular-nums; }
.admin-table__name { font-weight: var(--fw-medium); color: var(--color-ink); }
.admin-table__name:hover { color: var(--color-primary); }
.admin-table__sub { display: block; font-size: var(--fs-xs); }
.admin-table__actions { display: flex; gap: var(--space-1); justify-content: flex-end; align-items: center; }

/* 반복 입력 행(상품 이미지·옵션 에디터) */
.repeat-row { display: flex; gap: var(--space-2); margin-bottom: var(--space-2); align-items: center; }
.repeat-row .field__input { flex: 1; }
.repeat-row .btn { flex: none; }

/* 2열 폼 행 */
.field-row { display: grid; gap: var(--space-4); }
@media (min-width: 34rem) { .field-row { grid-template-columns: 1fr 1fr; } }
.field-row .field { margin-bottom: var(--space-4); }

/* 구독 플랜 */
.current-plan__head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4); }
.current-plan__name { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: var(--fw-bold); margin: var(--space-1) 0 0; }
.plan-grid { display: grid; gap: var(--space-4); grid-template-columns: repeat(auto-fit, minmax(min(100%, 15rem), 1fr)); }
.plan-card { display: flex; flex-direction: column; padding: var(--space-6) var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.plan-card--featured { border-color: var(--color-primary); box-shadow: 0 0 0 1px var(--color-primary); }
.plan-card__name { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-bold); margin: 0 0 var(--space-2); }
.plan-card__price { margin: 0 0 var(--space-3); }
.plan-card__price strong { font-size: var(--fs-2xl); letter-spacing: var(--tracking-tight); }
.plan-card__desc { margin: 0 0 var(--space-4); font-size: var(--fs-sm); }
.plan-card__features { display: flex; flex-direction: column; gap: var(--space-2); margin: 0 0 var(--space-6); font-size: var(--fs-sm); color: var(--color-ink-muted); flex: 1; }
.plan-card__features li { padding-inline-start: var(--space-5); position: relative; }
.plan-card__features li::before { content: "✓"; position: absolute; inset-inline-start: 0; color: var(--color-success); font-weight: var(--fw-bold); }

/* 리뷰 */
.reviews { margin-top: var(--space-8); padding-top: var(--space-6); border-top: 1px solid var(--color-border); }
.review-list { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-5); }
.review-item { padding-bottom: var(--space-4); border-bottom: 1px solid var(--color-border); }
.review-item__head { display: flex; gap: var(--space-3); align-items: baseline; margin-bottom: var(--space-2); }
.review-item__stars { color: var(--color-accent); letter-spacing: 0.08em; }
.review-item__body { margin: 0; color: var(--color-ink-muted); line-height: var(--lh-body); white-space: pre-line; }
.review-reply { margin-top: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--color-surface-2); border-radius: var(--radius-md); }
.review-reply__label { display: block; font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--color-primary); margin-bottom: var(--space-1); }
.review-reply p { margin: 0; color: var(--color-ink-muted); line-height: var(--lh-body); white-space: pre-line; }
.review-reply-edit { margin-top: var(--space-2); }
.review-reply-edit summary { font-size: var(--fs-sm); color: var(--color-primary); cursor: pointer; }
.review-reply-edit form { margin-top: var(--space-2); display: flex; flex-direction: column; gap: var(--space-2); align-items: flex-start; }
.review-votes { margin-top: var(--space-3); }
.review-votes form { display: flex; gap: var(--space-2); }
.vote-btn {
  display: inline-flex; align-items: center; gap: var(--space-2); min-height: 2rem;
  padding: var(--space-1) var(--space-4); font: inherit; font-size: var(--fs-sm);
  color: var(--color-ink-muted); background: var(--color-surface-2);
  border: 1px solid var(--color-border); border-radius: var(--radius-full); cursor: pointer;
  transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.vote-btn:hover { color: var(--color-ink); }
.vote-btn--on { color: var(--color-on-primary); background: var(--color-primary-strong); border-color: transparent; }
.vote-btn__n { font-variant-numeric: tabular-nums; font-weight: var(--fw-semibold); }
.star-input { display: flex; gap: var(--space-1); }
.star { cursor: pointer; font-size: var(--fs-2xl); color: var(--color-border); line-height: 1; transition: color var(--dur-fast) var(--ease-standard); }
.star--on { color: var(--color-accent); }
.star:has(input:focus-visible) { outline: 2px solid var(--color-focus); outline-offset: 2px; border-radius: var(--radius-sm); }

/* ── 취소·환불 요청(구매자 주문 상세 + 셀러 콘솔) ── */
.refund-box {
  padding: var(--space-4) var(--space-5); border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}
.refund-box--pending {
  border-color: color-mix(in oklch, var(--color-warning) 40%, transparent);
  background: color-mix(in oklch, var(--color-warning) 8%, var(--color-surface));
}
.refund-box--rejected {
  border-color: color-mix(in oklch, var(--color-danger) 35%, transparent);
  background: color-mix(in oklch, var(--color-danger) 6%, var(--color-surface));
}
.refund-box__title { font-weight: var(--fw-semibold); margin: 0 0 var(--space-1); }
.refund-box__reason { font-size: var(--fs-sm); margin: var(--space-2) 0 0; }
/* 구매자용 접기 요청 폼 */
.refund-request > summary {
  cursor: pointer; font-size: var(--fs-sm); color: var(--color-ink-muted);
  padding: var(--space-2) 0; list-style-position: inside;
}
.refund-request > summary:hover { color: var(--color-ink); }
.refund-request > summary:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 2px; border-radius: var(--radius-sm); }
.refund-request__note { font-size: var(--fs-xs); margin: var(--space-3) 0; }
/* 셀러 콘솔: 요청 강조 박스 + 목록 배지 */
.refund-req-box {
  border-color: color-mix(in oklch, var(--color-warning) 40%, transparent);
  background: color-mix(in oklch, var(--color-warning) 8%, var(--color-surface));
}
.refund-req-box__reason { font-size: var(--fs-sm); font-style: italic; margin: var(--space-2) 0; color: var(--color-ink); }
.req-badge {
  display: inline-block; padding: 1px var(--space-2); font-size: var(--fs-xs); font-weight: var(--fw-bold);
  color: var(--color-on-warning); background: var(--color-warning);
  border-radius: var(--radius-sm); margin-inline-start: var(--space-1); vertical-align: middle;
}

/* 오류 페이지(독립형) */
.error-page { min-height: 70vh; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-4); text-align: center; padding: var(--space-8) var(--gutter); }
.error-page__code { font-family: var(--font-display); font-size: var(--fs-4xl); font-weight: var(--fw-bold); color: var(--color-ink-subtle); margin: 0; letter-spacing: var(--tracking-tight); }
.error-page__msg { font-size: var(--fs-lg); color: var(--color-ink-muted); margin: 0 0 var(--space-2); max-width: 32ch; }
