/* ==========================================================================
   Motion Desk -- formal proposal venue.
   Shares the dark Tenets / Amendments aesthetic (Cardo + Cormorant SC).
   Form vocabulary borrowed from the rest of the site (rc-* tokens) so
   inputs read as part of RC rather than a transplanted form.
   ========================================================================== */

:root {
  /* Cream/brown deliberation palette. Mirrors the tenets dark theme
     but inverted for the venue surfaces (motion desk, amendments,
     chamber). Tenets stay dark on purpose -- the constitution and its
     deliberation room are visually distinct. */
  --md-bg: #f0e6cc;            /* page background (warm cream) */
  --md-bg-soft: #e6dcbf;       /* card / panel surfaces */
  --md-bg-input: #f7efd8;      /* form inputs, raised surfaces */
  --md-ink: #3d2a18;           /* body text (rich brown) */
  --md-ink-bright: #2a1c0e;    /* headings, labels (deep brown) */
  --md-ink-dim: #7a5a3a;       /* chrome (faded brown) */
  --md-rule: #b09269;          /* borders (warm tan) */
  --md-rule-soft: #d4c39b;     /* subtle dividers */
  --md-gold: #a07a2a;          /* gold accent deepened for cream contrast */
  --md-accent: #00a888;        /* teal accent deepened for cream */
  --md-status-filed: #966619;
  --md-status-in-deliberation: #1e5fb0;
  --md-status-ratified: #1f8a3a;
  --md-status-covered: #6f5635;
  --md-status-rejected: #b02824;
  --md-status-challenge: #6a2c9e;

  /* Type stacks. Cormorant SC is reserved for actual heading titles
     only (page H1s, section labels, gate H2, motion / door H3). All
     other chrome -- labels, badges, buttons, tabs, eyebrows, status
     chips -- uses the system sans stack for a quieter read. */
  --md-font-title: 'Cormorant SC', serif;
  --md-font-chrome: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--md-bg);
  color: var(--md-ink);
}

body {
  font-family: 'Cardo', Georgia, 'Times New Roman', serif;
  font-size: 18px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: geometricPrecision;
}

.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

.skip-nav {
  position: absolute; top: -40px; left: 0;
  background: var(--md-ink-bright); color: var(--md-bg);
  padding: 8px 16px; z-index: 100;
  text-decoration: none;
  font-family: var(--md-font-chrome);
  letter-spacing: 0.08em;
}
.skip-nav:focus { top: 0; }

/* ----- Main layout ----- */

.md-main {
  max-width: 980px;
  margin: 0 auto;
  padding: 80px 32px 120px;
}

/* ----- Hero ----- */

.md-hero {
  max-width: 720px;
  margin: 0 auto 80px;
  text-align: center;
}

.md-title {
  font-family: var(--md-font-title);
  font-weight: 500;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  letter-spacing: 0.16em;
  color: var(--md-ink-bright);
  margin: 0 0 12px;
  line-height: 1.1;
}

.md-kicker {
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--md-ink-dim);
  margin: 0 0 28px;
  letter-spacing: 0.02em;
}

/* Small label above the H1 on sub-pages -- breadcrumb-style back link. */
.md-eyebrow {
  font-family: var(--md-font-chrome);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--md-ink-dim);
  margin: 0 0 14px;
}
.md-eyebrow a {
  color: var(--md-ink-dim);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}
.md-eyebrow a:hover {
  color: var(--md-gold);
  border-bottom-color: var(--md-gold);
}

.md-preamble {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--md-ink);
  margin: 0 auto;
  max-width: 620px;
  text-align: left;
}

.md-preamble a, .md-record-help a, .md-form-help a, .footer-note a {
  color: var(--md-gold);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s;
}
.md-preamble a:hover, .md-record-help a:hover, .md-form-help a:hover, .footer-note a:hover {
  border-bottom-color: var(--md-gold);
}

/* ----- Section labels ----- */

.md-section-label {
  font-family: var(--md-font-title);
  font-weight: 600;
  font-size: clamp(1.3rem, 2.2vw, 1.7rem);
  letter-spacing: 0.18em;
  color: var(--md-ink-bright);
  margin: 0 0 24px;
  text-transform: uppercase;
}

/* ----- Guardrails ----- */

.md-guardrails {
  margin: 0 0 80px;
}

.md-guard-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr;
  gap: 18px;
}

.md-guard {
  padding: 22px 22px 20px;
  background: var(--md-bg-soft);
  border: 1px solid var(--md-gold);
  border-radius: 2px;
}
.md-guard h3 {
  font-family: var(--md-font-chrome);
  font-size: 0.92rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-gold);
  margin: 0 0 8px;
  font-weight: 600;
}
.md-guard p {
  font-family: 'Cardo', serif;
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--md-ink);
  margin: 0;
}
.md-guard-alt {
  border-color: var(--md-rule);
}
.md-guard-alt h3 {
  color: var(--md-ink-dim);
}
.md-guard a {
  color: var(--md-accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.md-guard a:hover { border-bottom-color: var(--md-accent); }

/* ----- Gate (auth state aware) ----- */

.md-gate {
  max-width: 720px;
  margin: 0 auto 60px;
  padding: 28px 26px;
  background: var(--md-bg-soft);
  border: 1px solid var(--md-rule);
  border-radius: 2px;
  text-align: left;
}

.md-loading {
  font-family: 'Cardo', serif;
  font-style: italic;
  color: var(--md-ink-dim);
  margin: 0;
}

.md-gate-title {
  font-family: var(--md-font-title);
  font-size: 1rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--md-ink-bright);
  margin: 0 0 8px;
  font-weight: 600;
}

.md-gate-body {
  font-family: 'Cardo', serif;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--md-ink);
  margin: 0 0 16px;
}
.md-gate-body a {
  color: var(--md-gold);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.md-gate-body a:hover { border-bottom-color: var(--md-gold); }

.md-gate-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  background: transparent;
  border: 1px solid var(--md-gold);
  border-radius: 2px;
  color: var(--md-gold);
  text-decoration: none;
  font-family: var(--md-font-chrome);
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: background 0.2s, color 0.2s;
}
.md-gate-cta:hover {
  background: var(--md-ink-bright);
  color: var(--md-bg);
  border-color: var(--md-ink-bright);
}

.md-gate-meta {
  font-family: 'Cardo', serif;
  font-size: 0.88rem;
  font-style: italic;
  color: var(--md-ink-dim);
  margin: 14px 0 0;
}

/* ----- Filing surface ----- */

.md-file {
  max-width: 760px;
  margin: 0 auto 80px;
}

.md-tabbar {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--md-rule);
  margin-bottom: 28px;
}

.md-tab {
  flex: 0 0 auto;
  padding: 12px 18px;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--md-ink-dim);
  font-family: var(--md-font-chrome);
  font-weight: 500;
  font-size: 0.85rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  margin-bottom: -1px;
  transition: color 0.2s, border-color 0.2s;
  text-decoration: none;        /* anchors */
}
.md-tab:hover { color: var(--md-ink); }
.md-tab.active {
  color: var(--md-gold);
  border-bottom-color: var(--md-gold);
}

/* Cross-page tabbar: same look, centered under the hero. */
.md-tabbar-routed {
  max-width: 820px;
  margin: 0 auto 36px;
  justify-content: center;
}

.md-form {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.md-form-help {
  font-family: 'Cardo', serif;
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--md-ink-dim);
  margin: 0;
  padding: 14px 18px;
  background: var(--md-bg-soft);
  border-left: 2px solid var(--md-gold);
  border-radius: 0 2px 2px 0;
}
.md-form-help em {
  color: var(--md-ink);
  font-style: italic;
}

.md-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.md-field[hidden] {
  display: none;
}

.md-field label {
  font-family: var(--md-font-chrome);
  font-size: 1.17rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--md-ink-bright);
  font-weight: 600;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.md-field .md-counter {
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  color: var(--md-ink-dim);
  text-transform: none;
  font-weight: 400;
}
.md-field .md-counter.under {
  color: var(--md-status-rejected);
}

.md-optional {
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  color: var(--md-ink-dim);
  text-transform: none;
  font-weight: 400;
}
.md-optional a {
  color: var(--md-accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.md-optional a:hover { border-bottom-color: var(--md-accent); }

.md-field input[type="text"],
.md-field input[type="search"],
.md-field textarea,
.md-field select {
  width: 100%;
  padding: 11px 14px;
  background: var(--md-bg-input);
  color: var(--md-ink-bright);
  border: 1px solid var(--md-rule);
  border-radius: 2px;
  font-family: 'Cardo', serif;
  font-size: 1rem;
  line-height: 1.55;
  outline: none;
  transition: border-color 0.2s;
}
.md-field textarea {
  resize: vertical;
  min-height: 80px;
}
.md-field input:focus,
.md-field textarea:focus,
.md-field select:focus {
  border-color: var(--md-gold);
}

/* ----- Song search dropdown ----- */

.md-search-results {
  position: relative;
  background: var(--md-bg-input);
  border: 1px solid var(--md-rule);
  border-top: none;
  max-height: 260px;
  overflow-y: auto;
  margin-top: -4px;
}
.md-search-result {
  padding: 9px 14px;
  font-family: 'Cardo', serif;
  font-size: 0.95rem;
  color: var(--md-ink);
  cursor: pointer;
  border-bottom: 1px solid var(--md-rule-soft);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.md-search-result:last-child { border-bottom: none; }
.md-search-result:hover, .md-search-result.focused {
  background: var(--md-rule-soft);
  color: var(--md-ink-bright);
}
.md-search-result .meta {
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 0.82rem;
  color: var(--md-ink-dim);
}
.md-search-empty {
  padding: 10px 14px;
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 0.9rem;
  color: var(--md-ink-dim);
}

.md-selected-song {
  margin-top: 6px;
  padding: 10px 14px;
  background: var(--md-bg-input);
  border: 1px solid var(--md-gold);
  border-radius: 2px;
  font-family: 'Cardo', serif;
  font-size: 0.95rem;
  color: var(--md-ink-bright);
  display: flex;
  align-items: center;
  gap: 10px;
}
.md-selected-label {
  font-family: var(--md-font-chrome);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-gold);
  font-weight: 600;
}
.md-selected-text { flex: 1; }
.md-selected-clear {
  background: transparent;
  border: none;
  color: var(--md-ink-dim);
  font-size: 1.4rem;
  line-height: 1;
  padding: 0 2px;
  cursor: pointer;
}
.md-selected-clear:hover { color: var(--md-status-rejected); }

/* ----- Submit button + status ----- */

.md-form-actions {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.md-submit {
  padding: 12px 26px;
  background: transparent;
  border: 1px solid var(--md-gold);
  border-radius: 2px;
  color: var(--md-gold);
  font-family: var(--md-font-chrome);
  font-weight: 500;
  font-size: 0.95rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.md-submit:hover:not(:disabled) {
  background: var(--md-ink-bright);
  color: var(--md-bg);
  border-color: var(--md-ink-bright);
}
.md-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.md-form-status {
  font-family: 'Cardo', serif;
  font-size: 0.92rem;
  margin: 0;
  flex: 1;
  min-width: 0;
}
.md-form-status.success { color: var(--md-status-ratified); }
.md-form-status.error { color: var(--md-status-rejected); }

/* ----- Public record list ----- */

.md-record {
  max-width: 820px;
  margin: 0 auto;
}

.md-record-help {
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 0.98rem;
  color: var(--md-ink-dim);
  margin: 0 0 24px;
}

.md-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 14px;
}

.md-filter {
  padding: 6px 14px;
  background: transparent;
  border: 1px solid var(--md-rule);
  border-radius: 2px;
  color: var(--md-ink-dim);
  font-family: var(--md-font-chrome);
  font-weight: 500;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
}
.md-filter:hover {
  border-color: var(--md-gold);
  color: var(--md-gold);
}
.md-filter.active {
  border-color: var(--md-gold);
  color: var(--md-gold);
}

.md-record-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 22px;
}

.md-motion {
  padding: 20px 22px;
  background: var(--md-bg-soft);
  border: 1px solid var(--md-rule);
  border-left: 3px solid var(--md-status-color, var(--md-rule));
  border-radius: 2px;
}

.md-motion-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  font-family: var(--md-font-chrome);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.md-motion-type {
  color: var(--md-status-color, var(--md-ink-dim));
  font-weight: 700;
}
.md-motion-status {
  padding: 2px 8px;
  background: var(--md-bg-input);
  border: 1px solid var(--md-status-color, var(--md-rule));
  color: var(--md-status-color, var(--md-ink-dim));
  border-radius: 2px;
  letter-spacing: 0.12em;
}
.md-motion-filer {
  color: var(--md-ink);
  font-family: 'Cardo', serif;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  font-style: italic;
  text-transform: none;
}
.md-motion-verified {
  font-family: var(--md-font-chrome);
  font-weight: 600;
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  background: var(--md-accent);
  color: var(--md-bg);
  padding: 1px 6px;
  border-radius: 2px;
}
.md-motion-date {
  color: var(--md-ink-dim);
  font-family: 'Cardo', serif;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  text-transform: none;
  margin-left: auto;
}

.md-motion-claim {
  font-family: var(--md-font-title);
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--md-ink-bright);
  margin: 0 0 8px;
  line-height: 1.3;
  letter-spacing: 0.02em;
}

.md-motion-target {
  font-family: 'Cardo', serif;
  font-size: 0.92rem;
  color: var(--md-ink-dim);
  margin: 0 0 10px;
}
.md-motion-target b { color: var(--md-ink); font-weight: 700; }
.md-motion-target code {
  font-family: 'Courier New', monospace;
  color: var(--md-gold);
  background: var(--md-bg-input);
  padding: 1px 6px;
  border-radius: 2px;
  font-size: 0.88rem;
}

.md-motion-reasoning {
  font-family: 'Cardo', serif;
  font-size: 0.98rem;
  line-height: 1.65;
  color: var(--md-ink);
  margin: 6px 0 0;
  white-space: pre-wrap;
  word-wrap: break-word;
  max-height: 6em;
  overflow: hidden;
  position: relative;
}
.md-motion-reasoning.expanded { max-height: none; }
.md-motion-reasoning.collapsed::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1.6em;
  background: linear-gradient(180deg, transparent, var(--md-bg-soft));
  pointer-events: none;
}

.md-motion-expand {
  background: transparent;
  border: none;
  color: var(--md-gold);
  font-family: var(--md-font-chrome);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  margin-top: 6px;
  padding: 0;
}

.md-motion-citations {
  margin: 10px 0 0;
  font-family: 'Cardo', serif;
  font-size: 0.88rem;
  color: var(--md-ink-dim);
}
.md-motion-citations a {
  color: var(--md-accent);
  text-decoration: none;
  word-break: break-all;
}
.md-motion-citations a:hover { text-decoration: underline; }
.md-motion-citations .label {
  font-family: var(--md-font-chrome);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-ink-dim);
  margin-right: 6px;
}

.md-motion-resolution {
  margin: 12px 0 0;
  padding: 10px 14px;
  background: var(--md-bg-input);
  border-left: 2px solid var(--md-status-color, var(--md-gold));
}
.md-motion-resolution .label {
  display: block;
  font-family: var(--md-font-chrome);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-status-color, var(--md-ink-dim));
  margin-bottom: 4px;
  font-weight: 600;
}
.md-motion-resolution p {
  font-family: 'Cardo', serif;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--md-ink);
  margin: 0;
}

.md-motion-chamber-link {
  display: inline-block;
  margin-top: 12px;
  font-family: var(--md-font-chrome);
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--md-gold);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s;
}
.md-motion-chamber-link:hover { border-bottom-color: var(--md-gold); }

.md-empty {
  font-family: 'Cardo', serif;
  font-style: italic;
  font-size: 0.95rem;
  color: var(--md-ink-dim);
  padding: 12px 0;
  margin: 0;
}

/* ----- Footer ----- */

.md-footer {
  margin: 120px auto 0;
  padding-top: 40px;
  border-top: 1px solid var(--md-rule);
  text-align: center;
  max-width: 820px;
}

.footer-note {
  font-family: var(--md-font-chrome);
  font-size: 1rem;
  letter-spacing: 0.18em;
  color: var(--md-ink-dim);
  margin: 0;
}

/* ----- Landing page: two doors ----- */

.md-doors {
  max-width: 900px;
  margin: 0 auto 60px;
}

.md-door-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}

.md-door {
  display: flex;
  flex-direction: column;
  padding: 32px 30px 28px;
  background: var(--md-bg-soft);
  border: 1px solid var(--md-rule);
  border-radius: 4px;
  text-decoration: none;
  color: var(--md-ink);
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.md-door:hover {
  border-color: var(--md-gold);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.md-door-title {
  font-family: var(--md-font-title);
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-ink-bright);
  margin: 0 0 12px;
  line-height: 1.1;
}

.md-door-body {
  font-family: 'Cardo', serif;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--md-ink);
  margin: 0 0 22px;
  flex: 1;
}

.md-door-cta {
  font-family: var(--md-font-chrome);
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-gold);
}
.md-door:hover .md-door-cta {
  color: var(--md-ink-bright);
}

@media (max-width: 760px) {
  .md-door-grid { grid-template-columns: 1fr; }
  .md-door { padding: 26px 22px 22px; }
}

/* ----- File-a-motion: subtle panel emphasis ----- */

.md-file {
  /* Slightly deeper cream than the page background so the form area
     reads as its own room. No inversion needed -- the whole page is
     already cream. */
  background: #e8ddc0;
  padding: 36px 36px 40px;
  border-radius: 4px;
  border: 1px solid var(--md-rule-soft);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

/* The form-help banner inside .md-file goes one shade deeper still
   so it sits visibly above the panel surface. */
.md-file .md-form-help {
  background: #ddcfaa;
}

/* ----- Mobile ----- */

@media (max-width: 760px) {
  .md-main { padding: 56px 20px 80px; }
  .md-hero { margin-bottom: 56px; }
  .md-guard-grid { grid-template-columns: 1fr; }
  .md-file { margin-bottom: 56px; }
  .md-motion-date { margin-left: 0; }
}
