/* ============================================================
   WAREWELL — CORE COMPONENTS (Program 0)
   Consumes warewell/tokens.css
   ============================================================ */

/* ---------- Base ---------- */
.ww {
  font-family: var(--ww-font-body);
  color: var(--ww-ink);
  background: var(--ww-bg);
  -webkit-font-smoothing: antialiased;
}

.ww-display { font-family: var(--ww-font-display); font-weight: 600; line-height: 1.05; letter-spacing: -0.01em; }
.ww-caps    { font-family: var(--ww-font-mono); font-size: var(--ww-text-caption); letter-spacing: var(--ww-track-caps); text-transform: uppercase; }
.ww-mono    { font-family: var(--ww-font-mono); }

/* ---------- Buttons ---------- */
.ww-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--ww-font-body); font-weight: 500; font-size: var(--ww-text-body);
  padding: 14px 26px; border-radius: calc(var(--ww-radius-button) * var(--ww-radius-scale));
  border: 1px solid transparent; cursor: pointer; text-decoration: none;
  min-height: 44px; white-space: nowrap;
  transition: transform var(--ww-dur-control) var(--ww-ease), background var(--ww-dur-control) var(--ww-ease), box-shadow var(--ww-dur-control) var(--ww-ease);
  user-select: none;
}
.ww-btn:active { transform: scale(0.98); }

.ww-btn--primary { background: var(--ww-brand); color: var(--ww-porcelain); }
.ww-btn--primary:hover { background: var(--ww-brand-deep); box-shadow: var(--ww-shadow-2); }

.ww-btn--cta { background: var(--ww-cta); color: #FFF6F0; }
.ww-btn--cta:hover { filter: brightness(0.94); box-shadow: var(--ww-shadow-2); }

.ww-btn--dark { background: var(--ww-carbon); color: var(--ww-porcelain); }
.ww-btn--dark:hover { background: var(--ww-graphite); }

.ww-btn--ghost { background: transparent; color: var(--ww-ink); border-color: var(--ww-ink); }
.ww-btn--ghost:hover { background: rgba(17,17,17,0.05); }

.ww-btn--quiet { background: var(--ww-surface); color: var(--ww-ink); border-color: var(--ww-border); }
.ww-btn--quiet:hover { border-color: var(--ww-taupe); }

.ww-btn--social { background: var(--ww-social); color: var(--ww-carbon); font-weight: 700; }
.ww-btn--social:hover { filter: brightness(0.96); }

.ww-btn--wide { width: 100%; }
.ww-btn--lg { padding: 18px 34px; font-size: 17px; }
.ww-btn--sm { padding: 9px 16px; font-size: var(--ww-text-sm); border-radius: calc(12px * var(--ww-radius-scale)); min-height: 40px; }
.ww-btn[disabled] { opacity: 0.45; pointer-events: none; }

/* ---------- Pills / chips (filters, status, segments ONLY) ---------- */
.ww-pill {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ww-font-body); font-size: var(--ww-text-sm); font-weight: 500;
  padding: 9px 16px; border-radius: var(--ww-radius-pill); min-height: 40px;
  background: var(--ww-surface); border: 1px solid var(--ww-border); color: var(--ww-ink-2);
  cursor: pointer; transition: all var(--ww-dur-control) var(--ww-ease);
  white-space: nowrap;
}
.ww-pill:hover { border-color: var(--ww-taupe); }
.ww-pill.is-selected { background: var(--ww-brand); border-color: var(--ww-brand); color: var(--ww-porcelain); }
.ww-pill--status { cursor: default; background: var(--ww-surface-soft); border-color: transparent; color: var(--ww-ink-3); font-size: var(--ww-text-caption); min-height: 0; }

/* Segmented control */
.ww-seg { display: inline-flex; background: var(--ww-surface-soft); border: 1px solid var(--ww-border); border-radius: var(--ww-radius-pill); padding: 3px; gap: 2px; }
.ww-seg button {
  font-family: var(--ww-font-body); font-size: var(--ww-text-sm); font-weight: 500;
  border: 0; background: transparent; color: var(--ww-ink-3); padding: 8px 18px;
  border-radius: var(--ww-radius-pill); cursor: pointer; transition: all var(--ww-dur-control) var(--ww-ease);
}
.ww-seg button.is-selected { background: var(--ww-surface); color: var(--ww-ink); box-shadow: var(--ww-shadow-1); }

/* ---------- Panels & cards (no nested cards) ---------- */
.ww-panel {
  background: var(--ww-surface); border: 1px solid var(--ww-border);
  border-radius: calc(var(--ww-radius-panel) * var(--ww-radius-scale));
  padding: var(--ww-s5);
}
.ww-panel--soft { background: var(--ww-surface-soft); border-color: transparent; }
.ww-panel--brand { background: var(--ww-brand); border-color: transparent; color: var(--ww-porcelain); }
.ww-panel--dark { background: var(--ww-carbon); border-color: transparent; color: var(--ww-porcelain); }

.ww-panel-label { font-family: var(--ww-font-mono); font-size: var(--ww-text-caption); letter-spacing: var(--ww-track-caps); text-transform: uppercase; color: var(--ww-ink-3); margin: 0 0 var(--ww-s3) 0; }
.ww-panel--brand .ww-panel-label, .ww-panel--dark .ww-panel-label { color: rgba(246,243,238,0.65); }

/* Item card (closet asset) */
.ww-item {
  background: var(--ww-surface); border: 1px solid var(--ww-border);
  border-radius: calc(var(--ww-radius-card) * var(--ww-radius-scale));
  overflow: hidden; transition: box-shadow var(--ww-dur-control) var(--ww-ease), transform var(--ww-dur-control) var(--ww-ease);
}
.ww-item:hover { box-shadow: var(--ww-shadow-2); transform: translateY(-2px); }
.ww-item-media { aspect-ratio: 4 / 5; background: var(--ww-surface-soft); display: grid; place-items: center; }
.ww-item-name { font-size: var(--ww-text-caption); font-weight: 500; color: var(--ww-ink-2); padding: 8px 10px; text-align: center; }

/* Imagery placeholder (subtle stripes + mono explainer) */
.ww-ph {
  width: 100%; height: 100%; display: grid; place-items: center;
  background: repeating-linear-gradient(-45deg, var(--ww-cream) 0 10px, #EFE6D4 10px 20px);
  color: var(--ww-ink-soft); font-family: var(--ww-font-mono); font-size: var(--ww-text-micro);
  letter-spacing: var(--ww-track-caps); text-transform: uppercase; text-align: center; padding: 8px;
}

/* ---------- Confidence score & meter ---------- */
.ww-score-num { font-family: var(--ww-font-display); font-weight: 600; font-size: 56px; line-height: 1; color: var(--ww-ink); }
.ww-meter { height: 6px; border-radius: 999px; background: var(--ww-champagne); overflow: hidden; }
.ww-meter > i { display: block; height: 100%; border-radius: 999px; background: var(--ww-brand); transition: width var(--ww-dur-transition) var(--ww-ease-out); }
.ww-meter--social > i { background: var(--ww-social); }

/* Scorecard row: label … value */
.ww-scorecard { display: grid; gap: 10px; }
.ww-scorecard-row { display: flex; align-items: baseline; gap: 10px; }
.ww-scorecard-row .k { font-family: var(--ww-font-mono); font-size: var(--ww-text-micro); letter-spacing: var(--ww-track-caps); text-transform: uppercase; color: var(--ww-ink-3); }
.ww-scorecard-row .dots { flex: 1; border-bottom: 1px dotted var(--ww-line); transform: translateY(-3px); }
.ww-scorecard-row .v { font-family: var(--ww-font-mono); font-size: var(--ww-text-sm); font-weight: 700; color: var(--ww-ink); }

/* ---------- Inputs ---------- */
.ww-field { display: grid; gap: 7px; }
.ww-field label { font-family: var(--ww-font-mono); font-size: var(--ww-text-micro); letter-spacing: var(--ww-track-caps); text-transform: uppercase; color: var(--ww-ink-3); }
.ww-input {
  font-family: var(--ww-font-body); font-size: var(--ww-text-body); color: var(--ww-ink);
  background: var(--ww-surface); border: 1px solid var(--ww-border);
  border-radius: calc(var(--ww-radius-card) * var(--ww-radius-scale));
  padding: 13px 16px; width: 100%; outline: none; box-sizing: border-box;
  transition: border-color var(--ww-dur-control) var(--ww-ease), box-shadow var(--ww-dur-control) var(--ww-ease);
}
.ww-input::placeholder { color: var(--ww-taupe); }
.ww-input:focus { border-color: var(--ww-brand); box-shadow: 0 0 0 3px rgba(63,74,47,0.14); }

/* Toggle */
.ww-toggle { position: relative; width: 46px; height: 28px; border-radius: 999px; background: var(--ww-line); border: 0; cursor: pointer; transition: background var(--ww-dur-control) var(--ww-ease); flex: none; }
.ww-toggle::after { content: ""; position: absolute; top: 3px; left: 3px; width: 22px; height: 22px; border-radius: 50%; background: #fff; box-shadow: var(--ww-shadow-1); transition: left var(--ww-dur-control) var(--ww-ease); }
.ww-toggle.is-on { background: var(--ww-brand); }
.ww-toggle.is-on::after { left: 21px; }

/* ---------- Banners / states ---------- */
.ww-banner {
  display: flex; align-items: center; gap: 12px;
  border-radius: calc(var(--ww-radius-card) * var(--ww-radius-scale));
  padding: 12px 16px; font-size: var(--ww-text-sm); font-weight: 500;
}
.ww-banner--success { background: rgba(47,107,60,0.10); color: var(--ww-success); }
.ww-banner--warning { background: rgba(184,121,22,0.10); color: var(--ww-warning); }
.ww-banner--danger  { background: rgba(163,58,43,0.10);  color: var(--ww-danger); }
.ww-banner--privacy { background: var(--ww-carbon); color: var(--ww-porcelain); }

/* ---------- Mobile tab bar ---------- */
.ww-tabbar {
  display: grid; grid-template-columns: repeat(5, 1fr); align-items: end;
  background: var(--ww-surface); border-top: 1px solid var(--ww-border);
  padding: 10px 8px calc(16px + env(safe-area-inset-bottom, 10px));
}
.ww-tab { display: grid; justify-items: center; gap: 5px; background: none; border: 0; cursor: pointer; color: var(--ww-ink-3); padding: 4px 0; min-height: 44px; }
.ww-tab svg { width: 22px; height: 22px; }
.ww-tab span { font-family: var(--ww-font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; }
.ww-tab.is-active { color: var(--ww-ink); }
.ww-tab--glint { transform: translateY(-14px); }
.ww-tab--glint .glint-disc {
  width: 54px; height: 54px; border-radius: 50%;
  background: var(--ww-brand); color: var(--ww-porcelain);
  display: grid; place-items: center; box-shadow: var(--ww-shadow-2);
}

/* ---------- Avatars ---------- */
.ww-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--ww-champagne); color: var(--ww-ink-2); display: inline-grid; place-items: center; font-family: var(--ww-font-mono); font-size: 10px; font-weight: 700; border: 2px solid var(--ww-surface); }
.ww-avatar-stack { display: inline-flex; }
.ww-avatar-stack .ww-avatar + .ww-avatar { margin-left: -10px; }

/* ============================================================
   0.2 EXTENSIONS — sheets, skeletons, progress, lists, auth
   ============================================================ */

/* Bottom sheet */
.ww-sheet-backdrop {
  position: absolute; inset: 0; z-index: 40;
  background: rgba(17,17,17,0.42);
  display: flex; align-items: flex-end;
  animation: wwFadeIn var(--ww-dur-control) var(--ww-ease) both;
}
.ww-sheet {
  width: 100%; max-height: 86%; overflow: auto;
  background: var(--ww-porcelain); border-radius: 20px 20px 0 0;
  padding: 10px 20px calc(20px + env(safe-area-inset-bottom, 12px));
  animation: wwSheetUp var(--ww-dur-transition) var(--ww-ease-out) both;
}
.ww-sheet-grab { width: 40px; height: 4px; border-radius: 999px; background: var(--ww-line); margin: 4px auto 16px; }
@keyframes wwFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes wwSheetUp { from { transform: translateY(40px); opacity: 0; } to { transform: none; opacity: 1; } }

/* Skeleton shimmer */
.ww-skeleton {
  position: relative; overflow: hidden; background: var(--ww-cream); border-radius: 10px;
}
.ww-skeleton::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(100deg, transparent 30%, rgba(255,255,255,0.65) 50%, transparent 70%);
  transform: translateX(-100%); animation: wwShimmer 1.4s infinite;
}
@keyframes wwShimmer { to { transform: translateX(100%); } }
@media (prefers-reduced-motion: reduce) { .ww-skeleton::after { animation: none; } }

/* Staged progress (upload / processing / try-on render) */
.ww-stages { display: grid; gap: 12px; }
.ww-stage { display: flex; align-items: center; gap: 12px; font-size: var(--ww-text-sm); color: var(--ww-ink-3); }
.ww-stage .dot { width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid var(--ww-line); display: grid; place-items: center; flex: none; color: transparent; transition: all var(--ww-dur-control) var(--ww-ease); }
.ww-stage.is-done { color: var(--ww-ink-2); }
.ww-stage.is-done .dot { background: var(--ww-success); border-color: var(--ww-success); color: #fff; }
.ww-stage.is-active { color: var(--ww-ink); font-weight: 500; }
.ww-stage.is-active .dot { border-color: var(--ww-brand); }
.ww-stage.is-active .dot::after { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--ww-brand); animation: wwPulse 1.1s infinite; }
@keyframes wwPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

/* List rows */
.ww-list { display: grid; }
.ww-list-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 2px; border-bottom: 1px solid var(--ww-surface-soft);
  background: none; border-left: 0; border-right: 0; border-top: 0;
  font-family: var(--ww-font-body); font-size: 15px; color: var(--ww-ink); text-align: left;
  width: 100%; cursor: pointer; min-height: 52px;
}
.ww-list-row:last-child { border-bottom: 0; }
.ww-list-row .ic { color: var(--ww-ink-3); display: grid; place-items: center; flex: none; }
.ww-list-row .grow { flex: 1; min-width: 0; }
.ww-list-row .sub { display: block; font-size: 12px; color: var(--ww-ink-3); margin-top: 2px; }
.ww-list-row .end { color: var(--ww-ink-soft); display: flex; align-items: center; gap: 6px; font-family: var(--ww-font-mono); font-size: 12px; }

/* Auth provider buttons */
.ww-provider {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  width: 100%; padding: 14px; border-radius: calc(var(--ww-radius-button) * var(--ww-radius-scale));
  background: var(--ww-surface); border: 1px solid var(--ww-border);
  font-family: var(--ww-font-body); font-size: 15px; font-weight: 500; color: var(--ww-ink);
  cursor: pointer; transition: border-color var(--ww-dur-control) var(--ww-ease);
}
.ww-provider:hover { border-color: var(--ww-taupe); }

.ww-link { background: none; border: 0; padding: 0; font-family: var(--ww-font-body); font-size: 14px; font-weight: 500; color: var(--ww-olive); cursor: pointer; text-decoration: underline; text-underline-offset: 3px; }

/* Selectable choice cards (onboarding, pickers) */
.ww-choice {
  display: flex; align-items: center; gap: 14px; width: 100%; text-align: left;
  background: var(--ww-surface); border: 1.5px solid var(--ww-border);
  border-radius: calc(var(--ww-radius-card) * var(--ww-radius-scale));
  padding: 16px; cursor: pointer; min-height: 56px;
  font-family: var(--ww-font-body); font-size: 15px; font-weight: 500; color: var(--ww-ink);
  transition: border-color var(--ww-dur-control) var(--ww-ease), background var(--ww-dur-control) var(--ww-ease);
}
.ww-choice .sub { display: block; font-size: 12.5px; font-weight: 400; color: var(--ww-ink-3); margin-top: 3px; }
.ww-choice .tick {
  margin-left: auto; width: 24px; height: 24px; border-radius: 50%; flex: none;
  border: 1.5px solid var(--ww-line); display: grid; place-items: center; color: transparent;
  transition: all var(--ww-dur-control) var(--ww-ease);
}
.ww-choice.is-selected { border-color: var(--ww-olive); background: rgba(63,74,47,0.06); }
.ww-choice.is-selected .tick { background: var(--ww-olive); border-color: var(--ww-olive); color: var(--ww-porcelain); }

/* Screen kicker row — mono context line above serif titles (prevents title/meta collisions) */
.ww-kicker { display: flex; align-items: center; justify-content: space-between; gap: 10px; font-family: var(--ww-font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ww-ink-3); }
.ww-kicker .hot { color: var(--ww-cta); }

/* Offline bar */
.ww-offline {
  display: flex; align-items: center; gap: 10px; justify-content: center;
  background: var(--ww-graphite); color: var(--ww-porcelain);
  font-family: var(--ww-font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 9px 16px;
}

/* Winner pulse — transform only, motion-gated */
@media (prefers-reduced-motion: no-preference) {
  .ww-winner-pulse { animation: wwWinnerPulse 2.4s var(--ww-ease) infinite; }
}
@keyframes wwWinnerPulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.015); } }

/* Accessibility: visible focus for keyboard users */
.ww button:focus-visible, .ww input:focus-visible, .ww [tabindex]:focus-visible {
  outline: 2px solid var(--ww-olive); outline-offset: 2px; border-radius: 6px;
}

/* ---------- P9: collage, reveal, toasts ---------- */
.ww-collage { position: relative; overflow: hidden; }
.ww-collage .piece {
  position: absolute; border-radius: 10px; overflow: hidden;
  box-shadow: 0 10px 24px -8px rgba(17,17,17,0.35);
  outline: 1px solid rgba(17,17,17,0.06);
}
@media (prefers-reduced-motion: no-preference) {
  .ww-collage.is-assembling .piece { animation: wwAssemble 560ms var(--ww-ease-out) both; }
}
@keyframes wwAssemble {
  from { transform: translateY(26px) rotate(0deg) scale(0.92); }
  to { transform: translateY(0) rotate(var(--rot, 0deg)) scale(1); }
}
.ww-collage .piece { transform: rotate(var(--rot, 0deg)); }

/* Toasts */
.ww-toast-host { position: absolute; left: 0; right: 0; bottom: 96px; z-index: 60; display: grid; justify-items: center; pointer-events: none; padding: 0 20px; }
.ww-toast {
  display: flex; align-items: center; gap: 12px; pointer-events: auto;
  background: var(--ww-carbon); color: var(--ww-porcelain);
  border-radius: 999px; padding: 11px 18px; box-shadow: var(--ww-shadow-3);
  font-size: 13.5px; font-weight: 500; max-width: 100%;
}
[data-ww-theme="dark"] .ww-toast { background: var(--ww-porcelain); color: var(--ww-carbon); }
.ww-toast button { background: none; border: 0; cursor: pointer; font-family: var(--ww-font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ww-social); padding: 2px 0 2px 4px; }
[data-ww-theme="dark"] .ww-toast button { color: var(--ww-olive); }
@media (prefers-reduced-motion: no-preference) {
  .ww-toast { animation: wwToastIn 240ms var(--ww-ease-out) both; }
}
@keyframes wwToastIn { from { transform: translateY(14px) scale(0.96); } to { transform: none; } }

/* Festival editorial skin */
.ww-festival { background: var(--ww-carbon) !important; color: var(--ww-porcelain) !important; }
.ww-festival .fest-title { font-family: var(--ww-font-body); font-weight: 900; text-transform: uppercase; letter-spacing: -0.02em; line-height: 0.92; }

/* Divider with word */
.ww-divider { display: flex; align-items: center; gap: 14px; color: var(--ww-taupe); font-family: var(--ww-font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; }
.ww-divider::before, .ww-divider::after { content: ""; flex: 1; border-top: 1px solid var(--ww-line); }
