/* training-community.css — Community authorship surfaces (Tier 12) */

/* ── Screen shell ─────────────────────────────────────────────────────────── */

.tcauth-screen {
  padding: var(--gap-lg) var(--gap-lg) var(--gap-xl);
  max-width: 960px;
  margin: 0 auto;
}

/* ── Header ───────────────────────────────────────────────────────────────── */

.tcauth-header {
  margin-bottom: var(--gap-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 28px 32px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--gap-md);
}

.tcauth-header__title {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  flex: 1 1 100%;
}

.tcauth-header__subtitle {
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  color: var(--text-secondary);
  margin: 0;
  max-width: 65ch;
  line-height: 1.65;
  flex: 1 1 100%;
}

.tcauth-header__meta {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-muted);
  margin: 0;
  flex: 1 1 100%;
}

.tcauth-header__pills {
  display: flex;
  gap: var(--gap-xs);
  align-items: center;
  flex: 1 1 100%;
}

/* ── Status pills ─────────────────────────────────────────────────────────── */

.tcauth-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.pill--draft {
  background: color-mix(in srgb, var(--text-muted) 15%, transparent);
  color: var(--text-secondary);
  border-color: color-mix(in srgb, var(--text-muted) 30%, transparent);
}

.pill--review {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
}

.pill--approved {
  background: var(--success-subtle);
  color: var(--success);
  border-color: color-mix(in srgb, var(--success) 30%, transparent);
}

.pill--rejected {
  background: var(--error-subtle);
  color: var(--error);
  border-color: color-mix(in srgb, var(--error) 30%, transparent);
}

.pill--published {
  background: color-mix(in srgb, var(--accent) 25%, transparent);
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 50%, transparent);
}

/* ── Tabs ─────────────────────────────────────────────────────────────────── */

.tcauth-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border);
  margin-bottom: var(--gap-lg);
}

.tcauth-tab {
  background: none;
  border: none;
  padding: 0.6rem 1.25rem;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color var(--transition), border-color var(--transition);
}

.tcauth-tab:hover {
  color: var(--text-primary);
}

.tcauth-tab--active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* ── Metadata grid ────────────────────────────────────────────────────────── */

.tcauth-meta-form {
  margin-bottom: var(--gap-lg);
}

.tcauth-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--gap-md);
}

/* ── Form fields ──────────────────────────────────────────────────────────── */

.tcauth-field {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.tcauth-field__label {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}

.tcauth-field__input,
.tcauth-field__select {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 0.45rem 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  color: var(--text-primary);
  transition: border-color var(--transition);
}

.tcauth-field__input:focus,
.tcauth-field__select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 24%, transparent);
}

.tcauth-field__textarea {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-primary);
  resize: vertical;
  line-height: 1.6;
  transition: border-color var(--transition);
  width: 100%;
  box-sizing: border-box;
}

.tcauth-field__textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 24%, transparent);
}

/* ── Bundle textarea (JSON / prose) ──────────────────────────────────────── */

.tcauth-bundle-textarea {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.75rem;
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--text-primary);
  line-height: 1.6;
  resize: vertical;
  transition: border-color var(--transition);
  margin-bottom: var(--gap-sm);
}

.tcauth-bundle-textarea:focus {
  outline: none;
  border-color: var(--accent);
}

/* ── Code textarea ────────────────────────────────────────────────────────── */

.tcauth-code-textarea {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: color-mix(in srgb, var(--bg-primary) 70%, var(--bg-elevated));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.75rem;
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--text-primary);
  line-height: 1.55;
  resize: vertical;
  margin-bottom: var(--gap-sm);
  transition: border-color var(--transition);
}

.tcauth-code-textarea:focus {
  outline: none;
  border-color: var(--accent);
}

/* ── Section headers ──────────────────────────────────────────────────────── */

.tcauth-section {
  margin-bottom: var(--gap-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--gap-lg);
}

.tcauth-section-title {
  font-family: var(--font-serif);
  font-size: 1.1875rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 var(--gap-md);
  padding-bottom: var(--gap-xs);
  border-bottom: 1px solid var(--border-subtle);
}

/* ── Issue panel ──────────────────────────────────────────────────────────── */

.tcauth-issues {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--gap-md);
  margin-bottom: var(--gap-lg);
}

.tcauth-issue {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.35rem 0;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.tcauth-issue + .tcauth-issue {
  border-top: 1px solid var(--border-subtle);
}

.tcauth-issue--error { color: var(--error); }
.tcauth-issue--warning { color: var(--warning); }
.tcauth-issue--ok { color: var(--success); }

.tcauth-issue__badge {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.1rem 0.4rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, currentColor 15%, transparent);
  white-space: nowrap;
}

.tcauth-issue__path {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  opacity: 0.8;
}

/* ── Hint text ────────────────────────────────────────────────────────────── */

.tcauth-hint {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-muted);
  margin: var(--gap-xs) 0 var(--gap-md);
  line-height: 1.6;
}

/* ── File input ───────────────────────────────────────────────────────────── */

.tcauth-file-input {
  display: block;
  margin-bottom: var(--gap-xs);
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.tcauth-file-name {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin: 0 0 var(--gap-sm);
}

/* ── Actions row ──────────────────────────────────────────────────────────── */

.tcauth-actions {
  display: flex;
  gap: var(--gap-sm);
  align-items: center;
  padding-top: var(--gap-lg);
  border-top: 1px solid var(--border);
  margin-top: var(--gap-xl);
}

/* ── Editor top bar ───────────────────────────────────────────────────────── */

.tcauth-editor-topbar {
  display: flex;
  align-items: center;
  gap: var(--gap-md);
  flex-wrap: wrap;
  padding-bottom: var(--gap-lg);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--gap-lg);
}

.tcauth-editor-topbar__title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  flex: 1;
}

.tcauth-editor-topbar__actions {
  display: flex;
  gap: var(--gap-xs);
  align-items: center;
  flex-wrap: wrap;
}

/* ── Dashboard 3-column layout ────────────────────────────────────────────── */

.tcauth-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-lg);
  align-items: start;
}

.tcauth-col__title {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 var(--gap-sm);
}

.tcauth-col__empty {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-muted);
  font-style: italic;
}

/* ── Submission card ──────────────────────────────────────────────────────── */

.tcauth-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--gap-md);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--gap-sm);
  transition: box-shadow var(--transition), border-color var(--transition);
}

.tcauth-card:hover {
  box-shadow: var(--shadow-md, var(--shadow-sm));
  border-color: var(--border-hover, var(--border));
}

.tcauth-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-xs);
}

.tcauth-card__slug {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  color: var(--text-primary);
  font-weight: 600;
}

.tcauth-card__meta {
  display: flex;
  gap: var(--gap-sm);
  flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--text-muted);
}

/* ── Queue list ───────────────────────────────────────────────────────────── */

.tcauth-queue-list {
  display: flex;
  flex-direction: column;
  gap: var(--gap-sm);
}

.tcauth-queue-row {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--gap-md) var(--gap-lg);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-md);
  transition: box-shadow var(--transition);
}

.tcauth-queue-row:hover {
  box-shadow: var(--shadow-md, var(--shadow-sm));
}

.tcauth-queue-row__info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  flex: 1;
}

.tcauth-queue-row__slug {
  font-family: var(--font-mono);
  font-size: 0.9rem;
  color: var(--text-primary);
  font-weight: 600;
}

.tcauth-queue-row__meta {
  display: flex;
  gap: var(--gap-sm);
  flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.tcauth-queue-row__actions {
  display: flex;
  gap: var(--gap-xs);
  align-items: center;
}

/* ── Empty state ──────────────────────────────────────────────────────────── */

.tcauth-empty {
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  color: var(--text-muted);
  text-align: center;
  padding: var(--gap-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.tcauth-empty--error {
  color: var(--error);
}

/* ── List items (examples, drills, katas, srs, quiz) ──────────────────────── */

.tcauth-list {
  display: flex;
  flex-direction: column;
  gap: var(--gap-md);
}

.tcauth-example-item,
.tcauth-drill-item,
.tcauth-kata-item,
.tcauth-srs-item,
.tcauth-quiz-item {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--gap-md);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--gap-sm);
}

.tcauth-item-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-sm);
}

.tcauth-item-index {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── Kata toggle ──────────────────────────────────────────────────────────── */

.tcauth-kata-toggle {
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-secondary);
  padding: 0;
  flex: 1;
  transition: color var(--transition);
}

.tcauth-kata-toggle:hover {
  color: var(--text-primary);
}

.tcauth-kata-body {
  display: flex;
  flex-direction: column;
  gap: var(--gap-sm);
  padding-top: var(--gap-sm);
  border-top: 1px solid var(--border-subtle);
}

/* ── Bundle read-only view ────────────────────────────────────────────────── */

.tcauth-bundle-view {
  margin-bottom: var(--gap-xl);
}

.tcauth-view-section-title {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: var(--gap-lg) 0 var(--gap-sm);
}

.tcauth-view-block {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--gap-md);
  margin-bottom: var(--gap-sm);
}

.tcauth-view-block__title {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--gap-xs);
}

.tcauth-view-block__kind {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--gap-xs);
}

.tcauth-view-block__answer {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin: var(--gap-xs) 0 0;
}

.tcauth-view-block__options {
  padding-left: 1.25rem;
  margin: var(--gap-xs) 0;
}

.tcauth-view-block__options li {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--text-secondary);
  padding: 0.15rem 0;
}

.tcauth-view-option--correct {
  color: var(--success);
  font-weight: 600;
}

.tcauth-view-prose {
  font-family: var(--font-serif);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--text-secondary);
  white-space: pre-wrap;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--gap-md);
  margin-bottom: var(--gap-sm);
}

.tcauth-code-pre {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--text-primary);
  white-space: pre;
  overflow-x: auto;
  background: color-mix(in srgb, var(--bg-primary) 70%, var(--bg-elevated));
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--gap-sm) var(--gap-md);
  margin: var(--gap-xs) 0;
}

/* ── Verdict form ─────────────────────────────────────────────────────────── */

.tcauth-verdict-form {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--gap-lg);
  box-shadow: var(--shadow-sm);
  margin-top: var(--gap-xl);
}

.tcauth-verdict-actions {
  display: flex;
  gap: var(--gap-sm);
  align-items: center;
  flex-wrap: wrap;
  margin-top: var(--gap-md);
}

/* ── Reviews list ─────────────────────────────────────────────────────────── */

.tcauth-reviews-list {
  display: flex;
  flex-direction: column;
  gap: var(--gap-xs);
}

.tcauth-review-row {
  background: var(--bg-elevated);
  border-radius: var(--radius-sm);
  padding: var(--gap-sm) var(--gap-md);
  display: flex;
  align-items: baseline;
  gap: var(--gap-sm);
  flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: 0.875rem;
}

.tcauth-review-row__alias {
  font-weight: 600;
  color: var(--text-primary);
}

.tcauth-review-row__verdict {
  text-transform: uppercase;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.tcauth-review-row--approve .tcauth-review-row__verdict {
  color: var(--success);
}
.tcauth-review-row--reject .tcauth-review-row__verdict,
.tcauth-review-row--rejected .tcauth-review-row__verdict {
  color: var(--error);
}
.tcauth-review-row--request_changes .tcauth-review-row__verdict {
  color: var(--accent);
}

.tcauth-review-row__date {
  color: var(--text-muted);
  margin-left: auto;
}

.tcauth-review-row__notes {
  flex: 1 1 100%;
  color: var(--text-secondary);
  margin: 0.25rem 0 0;
  line-height: 1.55;
}

/* ── Inline reject box ────────────────────────────────────────────────────── */

.tcauth-inline-reject {
  flex: 1 1 100%;
  margin-top: var(--gap-sm);
  display: flex;
  flex-direction: column;
  gap: var(--gap-xs);
}

/* ── Paste pane / zip pane ────────────────────────────────────────────────── */

.tcauth-paste-pane,
.tcauth-zip-pane {
  margin-bottom: var(--gap-lg);
}
