/* ============================================================
   CREWTHAT — COMPONENT LIBRARY
   ------------------------------------------------------------
   Token-driven, framework-free components. Consumes design-tokens.css.
   Loaded on public + auth + styleguide surfaces (NOT the legacy app
   dashboards, which keep their own styles). Prefix: .c-*
   Components: button, field, card, badge, modal, toast, skeleton,
   empty-state, tabs, accordion, dropdown, spinner, countdown.
   ============================================================ */

/* ---------- button ---------- */
.c-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font: var(--weight-semi) var(--text-sm)/1 var(--font-ui); text-decoration: none; cursor: pointer;
  padding: 0 var(--space-4); height: 40px; border-radius: var(--radius-md);
  border: 1px solid transparent; transition: background var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
  white-space: nowrap; user-select: none;
}
.c-btn:active { transform: translateY(1px); }
.c-btn:focus-visible { outline: none; box-shadow: var(--ring); }
.c-btn[disabled], .c-btn.is-loading { opacity: .55; pointer-events: none; }
.c-btn--primary   { background: var(--color-primary); color: #fff; }
.c-btn--primary:hover { background: var(--color-primary-hi); }
.c-btn--secondary { background: var(--color-surface); color: var(--color-ink); border-color: var(--color-line-hi); }
.c-btn--secondary:hover { border-color: var(--color-accent); color: var(--color-accent); }
.c-btn--ghost     { background: transparent; color: var(--color-ink); border-color: var(--color-line-hi); }
.c-btn--ghost:hover { border-color: var(--color-accent); color: var(--color-accent); }
.c-btn--danger    { background: var(--color-danger); color: #fff; }
.c-btn--sm { height: 32px; font-size: var(--text-xs); padding: 0 var(--space-3); }
.c-btn--lg { height: 48px; font-size: var(--text-base); padding: 0 var(--space-6); }
.c-btn--block { width: 100%; }

/* ---------- field (input / select / textarea) ---------- */
.c-field { margin-bottom: var(--space-4); }
.c-field__label { display: block; font-size: var(--text-xs); font-weight: var(--weight-semi);
  color: var(--color-ink-dim); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-2); }
.c-input, .c-select, .c-textarea {
  width: 100%; background: var(--color-surface-2); color: var(--color-ink);
  border: 1px solid var(--color-line); border-radius: var(--radius-md);
  padding: 0 var(--space-3); height: 44px; font: var(--weight-normal) var(--text-base)/1.4 var(--font-ui); outline: none;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.c-textarea { height: auto; min-height: 96px; padding: var(--space-3); resize: vertical; }
.c-input:focus, .c-select:focus, .c-textarea:focus { border-color: var(--color-primary); box-shadow: var(--ring); }
.c-field--error .c-input, .c-field--error .c-textarea, .c-field--error .c-select { border-color: var(--color-danger); }
.c-field__hint { font-size: var(--text-xs); color: var(--color-ink-dim); margin-top: var(--space-2); }
.c-field__error { font-size: var(--text-xs); color: #ffbcbc; margin-top: var(--space-2); display: none; }
.c-field--error .c-field__error { display: block; }

/* ---------- card ---------- */
.c-card { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); }
.c-card--elevated { box-shadow: var(--shadow-lg); }
.c-card--accent { border-top: 3px solid var(--color-accent); }

/* ---------- badge ---------- */
.c-badge { display: inline-flex; align-items: center; gap: var(--space-1);
  font: var(--weight-bold) 10px/1 var(--font-mono); letter-spacing: var(--tracking-wide);
  padding: 5px 9px; border-radius: var(--radius-full); color: #0d0d0d; }
.c-badge--live { background: var(--color-success); }
.c-badge--soon { background: var(--color-accent); }
.c-badge--roadmap { background: var(--color-info); color: #fff; }
.c-badge--neutral { background: var(--color-line-hi); color: var(--color-ink); }
.c-badge--info { background: var(--color-info); color: #fff; }
.c-badge--warn { background: var(--color-warning); }
.c-badge--error { background: var(--color-danger); color: #fff; }

/* ---------- spinner ---------- */
.c-spinner { width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,.25); border-top-color: #fff; animation: c-spin .7s linear infinite; }
@keyframes c-spin { to { transform: rotate(360deg); } }

/* ---------- skeleton ---------- */
.c-skeleton { background: linear-gradient(90deg, var(--color-surface) 25%, var(--color-line) 37%, var(--color-surface) 63%);
  background-size: 400% 100%; animation: c-shimmer 1.4s ease infinite; border-radius: var(--radius-sm); height: 14px; }
@keyframes c-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* ---------- empty-state ---------- */
.c-empty { text-align: center; padding: var(--space-12) var(--space-6); color: var(--color-ink-dim); }
.c-empty__icon { font-size: var(--text-4xl); margin-bottom: var(--space-3); opacity: .8; }
.c-empty__title { font: var(--weight-bold) var(--text-lg) var(--font-ui); color: var(--color-ink); margin-bottom: var(--space-2); }
.c-empty__msg { font-size: var(--text-sm); max-width: 360px; margin: 0 auto var(--space-4); line-height: var(--leading-normal); }

/* ---------- modal ---------- */
.c-modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.65); z-index: var(--z-modal);
  display: flex; align-items: center; justify-content: center; padding: var(--space-5);
  opacity: 0; pointer-events: none; transition: opacity var(--dur-base); }
.c-modal-backdrop.is-open { opacity: 1; pointer-events: auto; }
.c-modal { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg);
  width: 100%; max-width: 480px; padding: var(--space-6); box-shadow: var(--shadow-xl);
  transform: translateY(8px) scale(.99); transition: transform var(--dur-base) var(--ease-out); }
.c-modal-backdrop.is-open .c-modal { transform: none; }
.c-modal__title { font: var(--weight-bold) var(--text-xl) var(--font-ui); color: var(--color-ink); margin-bottom: var(--space-2); }
.c-modal__close { position: absolute; top: var(--space-4); right: var(--space-4); background: none; border: none;
  color: var(--color-ink-dim); font-size: var(--text-xl); cursor: pointer; line-height: 1; }

/* ---------- toast ---------- */
.c-toasts { position: fixed; bottom: var(--space-5); left: 50%; transform: translateX(-50%);
  z-index: var(--z-toast); display: flex; flex-direction: column; gap: var(--space-2);
  align-items: center; width: calc(100% - 40px); max-width: 460px; }
.c-toast { width: 100%; background: #161616; border: 1px solid var(--color-success); color: var(--color-ink);
  padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-size: var(--text-sm);
  box-shadow: var(--shadow-lg); opacity: 0; transform: translateY(12px); transition: var(--dur-base); }
.c-toast.is-show { opacity: 1; transform: none; }
.c-toast--error { border-color: var(--color-danger); }
.c-toast--warn { border-color: var(--color-warning); }

/* ---------- tabs ---------- */
.c-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--color-line); }
.c-tab { padding: var(--space-3) var(--space-4); background: none; border: none;
  border-bottom: 2px solid transparent; color: var(--color-ink-dim); cursor: pointer;
  font: var(--weight-semi) var(--text-sm) var(--font-ui); }
.c-tab[aria-selected="true"] { color: var(--color-ink); border-bottom-color: var(--color-primary); }

/* ---------- accordion ---------- */
.c-accordion__item { border-bottom: 1px solid var(--color-line); }
.c-accordion__head { width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  padding: var(--space-4) 0; color: var(--color-ink); font: var(--weight-semi) var(--text-base) var(--font-ui);
  display: flex; justify-content: space-between; align-items: center; }
.c-accordion__head::after { content: '+'; color: var(--color-ink-dim); }
.c-accordion__item.is-open .c-accordion__head::after { content: '−'; }
.c-accordion__body { display: none; padding: 0 0 var(--space-4); color: var(--color-ink-dim); font-size: var(--text-sm); }
.c-accordion__item.is-open .c-accordion__body { display: block; }

/* ---------- dropdown ---------- */
.c-dropdown { position: relative; display: inline-block; }
.c-dropdown__menu { position: absolute; top: calc(100% + 6px); right: 0; min-width: 180px;
  background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg); padding: var(--space-2); z-index: var(--z-dropdown); display: none; }
.c-dropdown.is-open .c-dropdown__menu { display: block; }
.c-dropdown__item { display: block; width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); color: var(--color-ink);
  font: var(--weight-medium) var(--text-sm) var(--font-ui); text-decoration: none; }
.c-dropdown__item:hover { background: var(--color-surface-2); }
