/* ============================================================
   components.css — All UI components
   ============================================================ */


/* ══════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  line-height: 1;
  letter-spacing: 0.01em;
  padding: 0.5rem 1rem;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  background-color: var(--color-bg-elevated);
  color: var(--color-text);
  transition:
    background-color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}
.btn:hover {
  background-color: var(--color-surface-hover);
  color: var(--color-text);
  text-decoration: none;
}
.btn:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
/* Lock color against a:visited specificity (0-1-1 beats 0-1-0) */
.btn:visited { color: var(--color-text); text-decoration: none; }

.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

/* Primary */
.btn--primary {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-accent-contrast);
}
.btn--primary:hover {
  background-color: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
  color: var(--color-accent-contrast);
}
.btn--primary:visited { color: var(--color-accent-contrast); }

/* Secondary — accented border, muted bg */
.btn--secondary {
  background-color: var(--color-bg-elevated);
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.btn--secondary:hover {
  background-color: var(--color-accent-soft);
  border-color: var(--color-accent-hover);
  color: var(--color-accent-hover);
}
.btn--secondary:visited { color: var(--color-accent); }

/* Ghost */
.btn--ghost {
  background-color: transparent;
  border-color: transparent;
  color: var(--color-link);
}
.btn--ghost:hover {
  background-color: var(--color-accent-soft);
  border-color: transparent;
  color: var(--color-link-hover);
}

/* Danger */
.btn--danger {
  background-color: var(--color-danger-soft);
  border-color: var(--color-danger-border);
  color: var(--color-danger);
}
.btn--danger:hover {
  background-color: var(--color-danger);
  border-color: var(--color-danger);
  color: var(--color-text-inverse);
}
.btn--danger:visited { color: var(--color-danger); }

/* Small */
.btn--sm {
  font-size: var(--fs-xs);
  padding: 0.3rem 0.65rem;
}

/* Icon only */
.btn--icon {
  padding: 0.45rem;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-md);
}

/* Text-only link button */
.btn-link {
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  color: var(--color-link);
  cursor: pointer;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
.btn-link:hover { color: var(--color-link-hover); }
.btn-link--danger { color: var(--color-danger); }
.btn-link--danger:hover { opacity: 0.8; }


/* ══════════════════════════════════════════════════════════════
   CARDS
   ══════════════════════════════════════════════════════════════ */

.card {
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
}
.card__header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  color: var(--color-heading);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.card__body  { padding: var(--space-4) var(--space-5); }
.card__footer {
  padding: var(--space-3) var(--space-5);
  background-color: var(--color-bg-sunken);
  border-top: 1px solid var(--color-border);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

/* Card modifiers */
.card--elevated { box-shadow: var(--shadow-md); }
.card--success  { border-left: 4px solid var(--color-success); background-color: var(--color-success-soft); }
.card--warning  { border-left: 4px solid var(--color-warning); background-color: var(--color-warning-soft); }
.card--danger   { border-left: 4px solid var(--color-danger);  background-color: var(--color-danger-soft);  }


/* ══════════════════════════════════════════════════════════════
   PILLS (status badges)
   ══════════════════════════════════════════════════════════════ */

.pill {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  padding: 0.2em 0.6em;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border-strong);
  background-color: var(--color-bg-sunken);
  color: var(--color-text-muted);
  line-height: 1.4;
  white-space: nowrap;
}

.pill--effective  { color: var(--color-status-effective);  background-color: var(--color-accent-soft);   border-color: var(--color-status-effective); }
.pill--superseded { color: var(--color-status-superseded); background-color: var(--color-bg-sunken);     border-color: var(--color-status-superseded); }
.pill--repealed   { color: var(--color-status-repealed);   background-color: var(--color-danger-soft);   border-color: var(--color-status-repealed); }
.pill--draft      { color: var(--color-status-draft);      background-color: var(--color-info-soft);     border-color: var(--color-status-draft); }
.pill--rfc        { color: var(--color-status-rfc);        background-color: var(--color-warning-soft);  border-color: var(--color-status-rfc); }
.pill--queued     { color: var(--color-status-queued);     background-color: var(--color-info-soft);     border-color: var(--color-status-queued); }
.pill--submitted  { color: var(--color-status-submitted);  background-color: var(--color-accent-soft);   border-color: var(--color-status-submitted); }
.pill--passed     { color: var(--color-status-passed);     background-color: var(--color-success-soft);  border-color: var(--color-status-passed); }
.pill--failed     { color: var(--color-status-failed);     background-color: var(--color-danger-soft);   border-color: var(--color-status-failed); }
.pill--adopted    { color: var(--color-status-adopted);    background-color: var(--color-success-soft);  border-color: var(--color-status-adopted); }
.pill--withdrawn  { color: var(--color-status-withdrawn);  background-color: var(--color-bg-sunken);     border-color: var(--color-status-withdrawn); }
.pill--motion     { color: var(--color-info);              background-color: var(--color-info-soft);     border-color: var(--color-info-border); }
.pill--convention { color: var(--color-warning);           background-color: var(--color-warning-soft);  border-color: var(--color-warning-border); }
.pill--warning    { color: var(--color-warning);           background-color: var(--color-warning-soft);  border-color: var(--color-warning-border); }


/* ══════════════════════════════════════════════════════════════
   ALERTS
   ══════════════════════════════════════════════════════════════ */

.alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-border-strong);
  font-size: var(--fs-sm);
  margin-bottom: var(--space-4);
  background-color: var(--color-bg-elevated);
  color: var(--color-text);
}
.alert--success, .alert-success {
  background-color: var(--color-success-soft);
  border-color: var(--color-success-border);
  border-left-color: var(--color-success);
  color: var(--color-success);
}
.alert--warning, .alert-warning {
  background-color: var(--color-warning-soft);
  border-color: var(--color-warning-border);
  border-left-color: var(--color-warning);
  color: var(--color-warning);
}
.alert--danger, .alert-danger, .alert-error, .alert--error {
  background-color: var(--color-danger-soft);
  border-color: var(--color-danger-border);
  border-left-color: var(--color-danger);
  color: var(--color-danger);
}
.alert--info, .alert-info {
  background-color: var(--color-info-soft);
  border-color: var(--color-info-border);
  border-left-color: var(--color-info);
  color: var(--color-info);
}
.alert-message {
  background-color: var(--color-info-soft);
  border-color: var(--color-info-border);
  border-left-color: var(--color-info);
  color: var(--color-info);
}


/* ══════════════════════════════════════════════════════════════
   TABLES
   ══════════════════════════════════════════════════════════════ */

.table-wrap {
  width: 100%;
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
.table th {
  background-color: var(--color-bg-sunken);
  color: var(--color-text-muted);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  padding: var(--space-2) var(--space-3);
  border-bottom: 2px solid var(--color-border-strong);
  white-space: nowrap;
}
.table td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
  color: var(--color-text);
}
.table tr:last-child td { border-bottom: none; }
.table tbody tr:hover td { background-color: var(--color-surface-hover); }

.table--zebra tbody tr:nth-child(even) td {
  background-color: var(--color-bg-sunken);
}
.table--zebra tbody tr:nth-child(even):hover td {
  background-color: var(--color-surface-hover);
}
.table--compact th,
.table--compact td { padding: var(--space-1) var(--space-3); }


/* ══════════════════════════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════════════════════════ */

.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
}

.field__label, label {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--color-text);
  display: block;
}
.field__hint  { font-size: var(--fs-xs); color: var(--color-text-subtle); line-height: var(--lh-snug); }
.field__error { font-size: var(--fs-xs); color: var(--color-danger); font-weight: var(--fw-medium); }

/* Generic input styling (covers Flask-Security macro outputs) */
.input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="url"],
input[type="number"],
input[type="search"],
input[type="date"],
input[type="time"] {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  color: var(--color-text);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  width: 100%;
  max-width: var(--measure);
  transition:
    border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
  appearance: none;
}
.input:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="url"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="date"]:focus,
input[type="time"]:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: var(--shadow-focus);
}
input::placeholder { color: var(--color-text-subtle); }

.select, select {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  color: var(--color-text);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  padding-right: calc(var(--space-3) * 2 + 12px);
  width: 100%;
  max-width: var(--measure);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A4F4C' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  transition:
    border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}
.select:focus, select:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: var(--shadow-focus);
}

.textarea, textarea {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  color: var(--color-text);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  width: 100%;
  max-width: var(--measure);
  min-height: 6rem;
  resize: vertical;
  line-height: var(--lh-normal);
  transition:
    border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}
.textarea:focus, textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: var(--shadow-focus);
}

.checkbox, .radio {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  font-size: var(--fs-sm);
  cursor: pointer;
  margin-bottom: var(--space-2);
}
.checkbox input, .radio input {
  width: auto;
  accent-color: var(--color-accent);
  cursor: pointer;
  max-width: none;
}

.radio-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* Submit / action buttons generated by Flask forms */
input[type="submit"],
input[type="button"] {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  padding: var(--space-2) var(--space-5);
  background-color: var(--color-accent);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-md);
  color: var(--color-accent-contrast);
  cursor: pointer;
  max-width: none;
  width: auto;
  transition:
    background-color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out);
}
input[type="submit"]:hover, input[type="button"]:hover {
  background-color: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
}
input[type="submit"]:focus-visible, input[type="button"]:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}


/* ══════════════════════════════════════════════════════════════
   SIDE NAV (sidebar navigation)
   ══════════════════════════════════════════════════════════════ */

.side-nav__section { margin-bottom: var(--space-5); }
.side-nav__section + .side-nav__section {
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border);
}

.side-nav__label {
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-2);
  display: block;
}

.side-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.side-nav__link,
.side-nav__list a {
  display: block;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border-left: 2px solid transparent;
  transition:
    color var(--dur-fast) var(--ease-out),
    background-color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out);
}
.side-nav__link:hover,
.side-nav__list a:hover {
  color: var(--color-text);
  background-color: var(--color-surface-hover);
  text-decoration: none;
}
.side-nav__link--active,
.side-nav__list a[aria-current="page"] {
  color: var(--color-accent);
  font-weight: var(--fw-medium);
  border-left-color: var(--color-accent);
  background-color: var(--color-accent-soft);
}

/* Game status widget in sidebar */
.game-status {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
  padding: var(--space-3);
  background-color: var(--color-bg-sunken);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}
.game-status a {
  color: var(--color-heading);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  display: block;
  margin-bottom: var(--space-1);
}
.game-status a:hover { color: var(--color-accent); }
.game-status__detail {
  font-size: var(--fs-xs);
  color: var(--color-text-subtle);
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-1);
}
.game-status__indicator {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-text-subtle);
  flex-shrink: 0;
}
.game-status__indicator--active     { background-color: var(--color-success); }
.game-status__indicator--ended      { background-color: var(--color-text-subtle); }
.game-status__indicator--convention { background-color: var(--color-warning); }

/* User block in sidebar */
.side-nav__user { margin-bottom: var(--space-4); }
.side-nav__user-name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  text-decoration: none;
  display: block;
  margin-bottom: var(--space-2);
}
.side-nav__user-name:hover { color: var(--color-accent); }


/* ══════════════════════════════════════════════════════════════
   BREADCRUMBS
   ══════════════════════════════════════════════════════════════ */

.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  font-size: var(--fs-sm);
  color: var(--color-text-subtle);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}
.breadcrumb__item { display: flex; align-items: center; gap: var(--space-1); }
.breadcrumb__item a { color: var(--color-text-muted); text-decoration: none; font-weight: var(--fw-medium); }
.breadcrumb__item a:hover { color: var(--color-link); }
.breadcrumb__item:last-child { color: var(--color-text); font-weight: var(--fw-medium); }
.breadcrumb__sep { color: var(--color-border-strong); user-select: none; }


/* ══════════════════════════════════════════════════════════════
   PAGINATION
   ══════════════════════════════════════════════════════════════ */

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  margin-top: var(--space-5);
  flex-wrap: wrap;
}
.pagination__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 var(--space-2);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-bg-elevated);
  transition: all var(--dur-fast) var(--ease-out);
}
.pagination__link:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
  background-color: var(--color-accent-soft);
  text-decoration: none;
}
.pagination__current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 var(--space-2);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-accent-contrast);
  background-color: var(--color-accent);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-md);
}


/* ══════════════════════════════════════════════════════════════
   DISCLOSURE (generic <details>)
   ══════════════════════════════════════════════════════════════ */

.disclosure {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-3);
}
.disclosure > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  color: var(--color-heading);
  background-color: var(--color-bg-elevated);
  list-style: none;
  transition: background-color var(--dur-fast) var(--ease-out);
}
.disclosure > summary:hover { background-color: var(--color-surface-hover); }
.disclosure > summary::after {
  content: "›";
  font-size: var(--fs-lg);
  color: var(--color-text-subtle);
  transition: transform var(--dur-med) var(--ease-out);
  flex-shrink: 0;
}
.disclosure[open] > summary::after { transform: rotate(90deg); }
.disclosure__body {
  padding: var(--space-4);
  border-top: 1px solid var(--color-border);
  background-color: var(--color-bg);
}


/* ══════════════════════════════════════════════════════════════
   EMPTY STATE
   ══════════════════════════════════════════════════════════════ */

.empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-8) var(--space-5);
  color: var(--color-text-subtle);
}
.empty__icon  { font-size: 2.5rem; margin-bottom: var(--space-4); opacity: 0.4; line-height: 1; }
.empty__title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--color-text-muted); margin-bottom: var(--space-2); }
.empty__body  { font-size: var(--fs-sm); color: var(--color-text-subtle); max-width: 40ch; line-height: var(--lh-relaxed); }


/* ══════════════════════════════════════════════════════════════
   PROGRESS BAR
   ══════════════════════════════════════════════════════════════ */

.progress {
  height: 6px;
  background-color: var(--color-border);
  border-radius: var(--radius-pill);
  overflow: hidden;
  width: 100%;
}
.progress__bar {
  height: 100%;
  background-color: var(--color-accent);
  border-radius: var(--radius-pill);
  transition: width var(--dur-med) var(--ease-out);
  min-width: 2px;
}


/* ══════════════════════════════════════════════════════════════
   AVATAR (CSS-only initials circle)
   ══════════════════════════════════════════════════════════════ */

.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: var(--color-accent-soft);
  color: var(--color-accent);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  flex-shrink: 0;
  border: 1px solid var(--color-accent);
  user-select: none;
  text-decoration: none;
}
.avatar--sm { width: 1.5rem; height: 1.5rem; font-size: var(--fs-xs); }
.avatar--lg { width: 3rem;   height: 3rem;   font-size: var(--fs-lg); }


/* ══════════════════════════════════════════════════════════════
   DIFF BLOCK
   ══════════════════════════════════════════════════════════════ */

.diff,
.proposal-diff {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
  white-space: pre-wrap;
  word-break: break-word;
  background-color: var(--color-bg-sunken);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  overflow-x: auto;
}
.diff ins,
.proposal-diff ins {
  display: block;
  background-color: var(--color-diff-ins-bg);
  color: var(--color-diff-ins-text);
  text-decoration: none;
  padding: 0 var(--space-1);
  border-radius: 2px;
}
.diff del,
.proposal-diff del {
  display: block;
  background-color: var(--color-diff-del-bg);
  color: var(--color-diff-del-text);
  padding: 0 var(--space-1);
  border-radius: 2px;
}


/* ══════════════════════════════════════════════════════════════
   VOTE BOX
   ══════════════════════════════════════════════════════════════ */

.vote-box {
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  margin-block: var(--space-5);
}
.vote-box__heading {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  margin-bottom: var(--space-4);
}


/* ══════════════════════════════════════════════════════════════
   RULE CARD (the hero component)
   ══════════════════════════════════════════════════════════════ */

.rule-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-3);
  background-color: var(--color-bg-elevated);
  box-shadow: var(--shadow-xs);
  scroll-margin-top: var(--space-7);
  transition:
    border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
  overflow: hidden;
}
.rule-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}
.rule-card[open] {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}

/* Status modifiers (left accent border + muted text) */
.rule-card[data-status="superseded"] {
  border-left: 3px solid var(--color-status-superseded);
}
.rule-card[data-status="repealed"] {
  border-left: 3px solid var(--color-status-repealed);
}
.rule-card[data-status="superseded"] .rule-card__title {
  color: var(--color-text-muted);
  opacity: 0.7;
}
.rule-card[data-status="repealed"] .rule-card__title {
  color: var(--color-text-muted);
  opacity: 0.6;
}

/* :target (anchor link lands on this card) */
.rule-card:target {
  border-left: 4px solid var(--color-accent);
  background-color: var(--color-accent-soft);
  box-shadow: var(--shadow-md);
}

/* Summary row */
.rule-card__summary {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  list-style: none;
  transition: background-color var(--dur-fast) var(--ease-out);
}
.rule-card__summary:hover { background-color: var(--color-surface-hover); }

/* Rule number (mono, accent color) */
.rule-card__number {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-accent);
  white-space: nowrap;
  min-width: 3.5rem;
  flex-shrink: 0;
}

/* Rule title */
.rule-card__title {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  flex: 1;
  line-height: var(--lh-snug);
}

/* Chevron — rotates when [open] */
.rule-card__chev {
  color: var(--color-text-subtle);
  font-size: var(--fs-md);
  transition: transform var(--dur-med) var(--ease-out);
  flex-shrink: 0;
  line-height: 1;
  display: inline-block;
}
.rule-card[open] > .rule-card__summary .rule-card__chev {
  transform: rotate(90deg);
}

/* Rule body (the typographic heart of the app) */
.rule-card__body {
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--color-text);
  max-width: var(--measure);
  padding: var(--space-4) var(--space-5) var(--space-5);
  border-top: 1px solid var(--color-border);
}
.rule-card__body p { max-width: none; line-height: var(--lh-relaxed); }
.rule-card__body p + p { margin-top: var(--space-4); }

/* Book section heading */
.book-section { margin-top: var(--space-7); margin-bottom: var(--space-4); }
.book-section:first-child { margin-top: 0; }
.book-section__heading {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-tight);
  color: var(--color-heading);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-accent);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}
.book-section__meta {
  font-size: var(--fs-sm);
  font-weight: var(--fw-regular);
  color: var(--color-text-muted);
  letter-spacing: 0;
}

/* Rules page controls bar */
.rules-controls {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}


/* ══════════════════════════════════════════════════════════════
   RULES TABLE OF CONTENTS
   ══════════════════════════════════════════════════════════════ */

.rules-toc { font-size: var(--fs-sm); color: var(--color-text-muted); }
.rules-toc__heading {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-2);
}
.rules-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.rules-toc__list a {
  display: block;
  color: var(--color-text-muted);
  text-decoration: none;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border-left: 2px solid transparent;
  transition: all var(--dur-fast) var(--ease-out);
}
.rules-toc__list a:hover {
  color: var(--color-accent);
  border-left-color: var(--color-accent);
  background-color: var(--color-accent-soft);
}


/* ══════════════════════════════════════════════════════════════
   FORUM POSTS & COMMENTS
   ══════════════════════════════════════════════════════════════ */

.post-card {
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
  overflow: hidden;
}
/* Motion post variant — left accent border in info color */
.post-card--motion {
  border-left: 3px solid var(--color-info-border);
}

.post-card__header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  background-color: var(--color-bg-sunken);
}
.post-card__author { font-weight: var(--fw-semibold); font-size: var(--fs-sm); color: var(--color-heading); }
.post-card__meta   { font-size: var(--fs-xs); color: var(--color-text-subtle); margin-left: auto; }
.post-card__body   { padding: var(--space-3) var(--space-4); font-size: var(--fs-base); line-height: var(--lh-normal); color: var(--color-text); }
.post-card__body p { max-width: none; }
.post-card__footer {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-top: 1px solid var(--color-border);
  background-color: var(--color-bg-sunken);
}

/* Thread depth */
.post-replies {
  margin-left: var(--space-5);
  border-left: 2px solid var(--color-border);
  padding-left: var(--space-4);
  margin-top: var(--space-2);
}
.post-replies .post-card { border-radius: var(--radius-sm); }

/* Motion badge */
.motion-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--color-info);
  background-color: var(--color-info-soft);
  border: 1px solid var(--color-info-border);
  border-radius: var(--radius-pill);
  padding: 0.15em 0.55em;
}

/* Comment card */
.comment-card {
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
  font-size: var(--fs-sm);
  overflow: hidden;
}
.comment-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  padding: var(--space-2) var(--space-3);
  background-color: var(--color-bg-sunken);
  border-bottom: 1px solid var(--color-border);
}
.comment-card__author { font-weight: var(--fw-semibold); color: var(--color-heading); }
.comment-card__meta   { font-size: var(--fs-xs); color: var(--color-text-subtle); margin-left: auto; }
.comment-card__body   { padding: var(--space-3); line-height: var(--lh-normal); color: var(--color-text); }
.comment-card__body p { max-width: none; }
.comment-card__footer {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-top: 1px solid var(--color-border);
}

.comment-card--outdated {
  opacity: 0.65;
  border-style: dashed;
}
.comment-card--outdated .comment-card__body::before {
  content: "⚠ Posted on an older revision.";
  display: block;
  font-size: var(--fs-xs);
  color: var(--color-warning);
  font-style: italic;
  margin-bottom: var(--space-2);
}

/* Comment threading */
.comment-replies {
  margin-left: var(--space-4);
  border-left: 2px solid var(--color-border);
  padding-left: var(--space-3);
  margin-top: var(--space-2);
}
.comment-replies .comment-replies { opacity: 0.92; }
