/* Legacy storefront CSS (kept during migration).
   New tokens + base styles live in tokens.css/ui-base.css and are shipped via tailwind.css. */
:root{
  --accent: #ff7a18;           /* orange */
  --accent2: #ffb44a;          /* softer orange */
  --good: #22c55e;
  --warn: #f59e0b;
  --bad: #fb7185;

  /* defaults */
  --bg: #070707;
  --panel: #0f0f10;
  --panel2: #0b0b0c;
  --text: #f5f5f6;
  --muted: rgba(245,245,246,0.72);
  --border: rgba(245,245,246,0.14);
}

html[data-theme="dark"]{
  --bg: #070707;
  --panel: #0f0f10;
  --panel2: #0b0b0c;
  --text: #f5f5f6;
  --muted: rgba(245,245,246,0.72);
  --border: rgba(245,245,246,0.14);
}

html[data-theme="light"]{
  --bg: #fafafa;
  --panel: #f0f0f3;
  --panel2: #ffffff;
  --text: #141416;
  --muted: rgba(20,20,22,0.72);
  --border: rgba(20,20,22,0.16);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background:
              radial-gradient(1100px 520px at 20% -10%, rgba(255,122,24,0.10), transparent 60%),
              radial-gradient(900px 600px at 80% 0%, rgba(255,180,74,0.08), transparent 60%),
              var(--bg);
  color: var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  -webkit-font-smoothing: antialiased;
}
html[data-theme="light"] body {
  font-family: "Segoe UI", system-ui, -apple-system, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 450;
  letter-spacing: 0.01em;
}

a { color: var(--text); text-decoration: none; }
a:hover { color: var(--accent); }

.container { max-width: 1100px; margin: 0 auto; padding: 18px; }

.site-header {
  position: sticky;
  top: 0;
  backdrop-filter: blur(10px);
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  border-bottom: 1px solid var(--border);
  z-index: 10;
}

.header-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand { font-weight: 800; letter-spacing: 0.3px; }
.nav { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

.card {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 92%, transparent), color-mix(in srgb, var(--panel2) 78%, transparent));
}

.grid { display: grid; gap: 16px; }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 900px) { .grid-3 { grid-template-columns: 1fr; } .grid-2 { grid-template-columns: 1fr; } }

.btn {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 65%, transparent);
  color: var(--text);
  cursor: pointer;
}
.btn:hover { border-color: color-mix(in srgb, var(--accent) 30%, var(--border)); }
.btn-primary {
  border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--accent2) 18%, transparent));
}
html[data-theme="light"] .btn-primary {
  color: #1a0f08;
  font-weight: 600;
  border-color: color-mix(in srgb, var(--accent) 70%, #333);
  background: linear-gradient(180deg, #ffb44a, var(--accent));
  box-shadow: 0 1px 2px rgba(0,0,0,0.08);
}
html[data-theme="light"] .btn-primary:hover {
  filter: brightness(0.97);
}
html[data-theme="light"] .btn:not(.btn-primary) {
  background: var(--panel2);
  color: var(--text);
  border-color: var(--border);
  font-weight: 500;
}
html[data-theme="light"] .btn:not(.btn-primary):hover {
  background: var(--panel);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}

input, textarea, select {
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 70%, transparent);
  color: var(--text);
}
html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select {
  background: #ffffff;
  border-color: var(--border);
  color: var(--text);
  font-weight: 450;
}
html[data-theme="light"] input::placeholder,
html[data-theme="light"] textarea::placeholder {
  color: var(--muted);
  opacity: 1;
}
label { display: block; margin-bottom: 6px; color: var(--muted); font-size: 0.92rem; }
.form-row { display: grid; gap: 10px; }

.muted { color: var(--muted); }
.messages { display: grid; gap: 8px; margin: 14px 0; }
.message { padding: 10px 12px; border-radius: 12px; border: 1px solid var(--border); }
.message.success { border-color: rgba(52, 211, 153, 0.45); }
.message.error { border-color: rgba(251, 113, 133, 0.55); }
.message.warning { border-color: rgba(251, 191, 36, 0.55); }

.site-footer { border-top: 1px solid var(--border); margin-top: 36px; }

/* Light theme: invert some header icons, but never brand logos. */
html[data-theme="light"] .site-header img { filter: invert(1); opacity: 0.95; }
html[data-theme="light"] .site-header img.sm-logo { filter: none; opacity: 1; }

.pill { display: inline-flex; padding: 4px 10px; border-radius: 999px; border: 1px solid var(--border); color: var(--muted); font-size: 0.85rem; }
.pill.good { color: var(--good); border-color: rgba(52,211,153,0.35); }
.pill.warn { color: var(--warn); border-color: rgba(251,191,36,0.35); }
.pill.bad { color: var(--bad); border-color: rgba(251,113,133,0.35); }

.kanban { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; align-items: start; }
@media (max-width: 1100px) { .kanban { grid-template-columns: 1fr; } }
.col-title { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; }
.col-title h3 { margin: 0; font-size: 1rem; }
.card-mini { padding: 12px; border-radius: 14px; border: 1px solid var(--border); background: rgba(17, 26, 51, 0.6); display: grid; gap: 8px; }
.card-mini { background: color-mix(in srgb, var(--panel) 60%, transparent); }
.row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }

/* Theme toggle moved to ui-base.css (.sm-theme-toggle / .sm-theme-pill) */

/* Cup artwork: two-option segmented control (matches storefront cards) */
.cup-artwork-seg {
  display: flex;
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--border);
  overflow: hidden;
  background: color-mix(in srgb, var(--panel2) 50%, transparent);
}
.cup-artwork-seg .btn {
  flex: 1;
  min-width: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  padding: 12px 12px;
  font-size: 0.88rem;
  line-height: 1.3;
  text-align: center;
}
.cup-artwork-seg .btn + .btn {
  border-left: 1px solid var(--border);
}
.cup-artwork-seg .btn:not(.btn-primary) {
  background: transparent;
  color: var(--muted);
  font-weight: 500;
}
.cup-artwork-seg .btn:not(.btn-primary):hover {
  color: var(--text);
  background: color-mix(in srgb, var(--panel) 35%, transparent);
}
html[data-theme="light"] .cup-artwork-seg .btn:not(.btn-primary) {
  background: transparent;
  color: var(--muted);
}
html[data-theme="light"] .cup-artwork-seg .btn:not(.btn-primary):hover {
  background: color-mix(in srgb, var(--panel) 50%, transparent);
  color: var(--text);
}
.cup-artwork-seg .btn:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 65%, transparent);
  outline-offset: -2px;
  position: relative;
  z-index: 1;
}

/* Tracking page: outbound-style shipment timeline (public theme vars) */
.tracking-outbound-tl {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 10px;
}
.tracking-outbound-tl__row {
  display: grid;
  grid-template-columns: 14px minmax(0, 1fr);
  gap: 12px;
  padding-bottom: 14px;
}
.tracking-outbound-tl__row:last-child {
  padding-bottom: 0;
}
.tracking-outbound-tl__rail {
  position: relative;
  display: flex;
  justify-content: center;
  padding-top: 6px;
}
.tracking-outbound-tl__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent2), var(--accent));
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--panel2) 92%, transparent);
  flex-shrink: 0;
  z-index: 1;
}
.tracking-outbound-tl__rail::after {
  content: "";
  position: absolute;
  top: 14px;
  bottom: -14px;
  left: 50%;
  width: 2px;
  margin-left: -1px;
  background: var(--border);
  border-radius: 1px;
}
.tracking-outbound-tl__row:last-child .tracking-outbound-tl__rail::after {
  display: none;
}
.tracking-outbound-tl__body {
  min-width: 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--muted);
}
.tracking-outbound-tl__time {
  font-variant-numeric: tabular-nums;
  color: var(--text);
  font-weight: 600;
}
.tracking-outbound-tl__qty {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  background: color-mix(in srgb, var(--panel) 80%, transparent);
  border: 1px solid var(--border);
  color: var(--text);
}
.tracking-outbound-tl__note {
  display: block;
  margin-top: 4px;
  font-size: 0.75rem;
}
.tracking-outbound-tl__img {
  margin-top: 8px;
}
.tracking-outbound-tl__img a {
  display: inline-block;
  line-height: 0;
}
.tracking-outbound-tl__img img {
  height: 44px;
  width: 44px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid var(--border);
}

