/* Sidereal — a dark sky with quiet stars. Vanilla CSS, no framework. */

:root {
  --ink: #e8e6f0;
  --ink-dim: #9b97ad;
  --gold: #d4b46a;
  --gold-dim: #8a7847;
  --night: #0b0c14;
  --night-raised: #14162275;
  --night-border: #2a2d42;
  --alert: #c96a6a;
  font-size: 16px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.6;
  background-color: var(--night);
  background-image:
    radial-gradient(1px 1px at 12% 22%, #fff8 0, transparent 100%),
    radial-gradient(1px 1px at 28% 64%, #fff5 0, transparent 100%),
    radial-gradient(1.5px 1.5px at 41% 12%, #ffefc77a 0, transparent 100%),
    radial-gradient(1px 1px at 55% 44%, #fff6 0, transparent 100%),
    radial-gradient(1px 1px at 63% 81%, #fff4 0, transparent 100%),
    radial-gradient(1.5px 1.5px at 74% 27%, #cfd8ff7d 0, transparent 100%),
    radial-gradient(1px 1px at 86% 58%, #fff7 0, transparent 100%),
    radial-gradient(1px 1px at 93% 9%, #fff5 0, transparent 100%),
    radial-gradient(1px 1px at 7% 88%, #fff5 0, transparent 100%),
    radial-gradient(ellipse at 50% -20%, #1c1f33 0, var(--night) 60%);
  background-attachment: fixed;
}

h1, h2, h3 { font-weight: normal; letter-spacing: 0.02em; }
h1 { font-size: 1.9rem; color: var(--gold); margin: 0 0 0.25rem; }
h2 { font-size: 1.3rem; color: var(--gold); }
a { color: var(--gold); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Masthead */
.masthead {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 1rem 2rem;
  border-bottom: 1px solid var(--night-border);
}
.masthead__wordmark {
  font-size: 1.2rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold);
}
.masthead__links { display: flex; gap: 1.5rem; align-items: baseline; }
.masthead__links a { color: var(--ink-dim); }
.masthead__links a:hover { color: var(--ink); text-decoration: none; }
.masthead__signout {
  background: none; border: none; padding: 0;
  color: var(--ink-dim); font: inherit; font-size: 0.85rem; cursor: pointer;
}
.masthead__signout:hover { color: var(--ink); }

/* Page scaffold */
.page { max-width: 46rem; margin: 0 auto; padding: 2.5rem 1.5rem 5rem; }
.page--wide { max-width: 64rem; }
.page__header { margin-bottom: 2rem; }
.page__header p { color: var(--ink-dim); margin: 0; }

.flash {
  max-width: 46rem; margin: 1rem auto 0; padding: 0.5rem 1.5rem;
  color: var(--gold); font-style: italic; text-align: center;
}
.flash--alert { color: var(--alert); }

/* Sign in / sign up veil */
.veil { max-width: 22rem; margin: 14vh auto 0; text-align: center; }
.veil__title {
  font-size: 2rem; letter-spacing: 0.45em; text-transform: uppercase;
  margin-bottom: 0;
}
.veil__tagline { color: var(--ink-dim); font-style: italic; margin-top: 0.25rem; }
.veil__alt { color: var(--ink-dim); font-size: 0.9rem; margin-top: 1.5rem; }
.veil .card { text-align: left; margin-top: 2rem; }

/* Cards & forms */
.card {
  background: var(--night-raised);
  border: 1px solid var(--night-border);
  border-radius: 6px;
  padding: 1.5rem;
}

.form label { display: block; margin: 1rem 0 0.2rem; color: var(--ink-dim); font-size: 0.9rem; }
.form label:first-child { margin-top: 0; }
.form input[type="text"], .form input[type="email"], .form input[type="password"],
.form input[type="number"], .form input[type="datetime-local"],
.form select, .form textarea {
  width: 100%;
  padding: 0.5rem 0.65rem;
  background: var(--night);
  border: 1px solid var(--night-border);
  border-radius: 4px;
  color: var(--ink);
  font: inherit;
}
.form input:focus, .form select:focus, .form textarea:focus {
  outline: none;
  border-color: var(--gold-dim);
}
.form input[type="submit"], .button {
  margin-top: 1.5rem;
  padding: 0.55rem 1.4rem;
  background: transparent;
  border: 1px solid var(--gold);
  border-radius: 4px;
  color: var(--gold);
  font: inherit;
  letter-spacing: 0.08em;
  cursor: pointer;
}
.form input[type="submit"]:hover, .button:hover { background: var(--gold); color: var(--night); }
.button--small { margin-top: 0.5rem; padding: 0.25rem 0.8rem; font-size: 0.85rem; }
.form__row { display: flex; gap: 1rem; }
.form__row > div { flex: 1; }
.form__hint { color: var(--ink-dim); font-size: 0.85rem; font-style: italic; margin: 0.3rem 0 0; }
.form__errors { color: var(--alert); font-size: 0.9rem; margin-bottom: 1rem; }
.form__errors p { margin: 0.2rem 0; }

/* Consultations */
.consult { display: flex; gap: 2.5rem; align-items: flex-start; }
.consult__sidebar { flex: 0 0 14rem; position: sticky; top: 1rem; }
.consult__sidebar h2 { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-dim); }
.consult__list { list-style: none; padding: 0; margin: 0; }
.consult__list li { margin: 0.4rem 0; font-size: 0.92rem; }
.consult__list a { color: var(--ink-dim); }
.consult__list .consult__current a, .consult__list a:hover { color: var(--gold); }
.consult__thread { flex: 1; min-width: 0; }

.utterance { margin: 1.25rem 0; }
.utterance__speaker {
  font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--ink-dim); margin-bottom: 0.2rem;
}
.utterance--seer .utterance__speaker { color: var(--gold-dim); }
.utterance--seeker .utterance__body { color: var(--ink); }
.utterance--seer .utterance__body { color: #d8d4e8; }
.utterance__body p { margin: 0 0 0.75rem; }
.utterance__body strong { color: var(--gold); font-weight: normal; }
.utterance__body em { color: var(--ink); }
.utterance__body h1, .utterance__body h2, .utterance__body h3 {
  font-size: 1.05rem; color: var(--gold); margin: 1.25rem 0 0.4rem;
}
.utterance__body ul, .utterance__body ol { margin: 0 0 0.75rem; padding-left: 1.4rem; }
.utterance__body li { margin: 0.25rem 0; }
.utterance__body hr { border: none; border-top: 1px solid var(--night-border); margin: 1.25rem 0; }
.utterance__body blockquote {
  margin: 0 0 0.75rem; padding-left: 1rem;
  border-left: 2px solid var(--gold-dim); color: var(--ink-dim);
}
.utterance__body code { font-size: 0.9em; color: var(--gold); }
.utterance--streaming { white-space: pre-wrap; color: #d8d4e8; }
.utterance--streaming:empty { display: none; }
.utterance--noted { color: var(--gold-dim); font-style: italic; font-size: 0.9rem; }

.consult__ask { margin-top: 2rem; }
.consult__ask textarea { width: 100%; }

.form__tags { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 0.3rem; }
.form__tag { display: flex; gap: 0.4rem; align-items: center; font-size: 0.95rem; }

/* Tables (placements, aspects, synastry) */
.ledger { width: 100%; border-collapse: collapse; margin: 1rem 0 2rem; }
.ledger th {
  text-align: left; font-weight: normal; color: var(--ink-dim);
  font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.1em;
  padding: 0.4rem 0.75rem; border-bottom: 1px solid var(--night-border);
}
.ledger td { padding: 0.45rem 0.75rem; border-bottom: 1px solid #1c1e2e; }
.ledger td:first-child { color: var(--gold); }
.ledger .ledger__dim { color: var(--ink-dim); }

/* Staff */
.staff-totals {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin: 0 0 1.5rem;
  border: 1px solid var(--night-border);
  background: var(--night-border);
}
.staff-total {
  padding: 1rem;
  background: var(--night);
}
.staff-total span {
  display: block;
  color: var(--ink-dim);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.staff-total strong {
  display: block;
  margin-top: 0.25rem;
  color: var(--gold);
  font-size: 1.45rem;
  font-weight: normal;
}
.staff-users {
  min-width: 58rem;
}
.staff-badge {
  display: inline-block;
  margin-left: 0.45rem;
  color: var(--ink-dim);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

@media (max-width: 760px) {
  .masthead {
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem;
  }
  .masthead__links {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem 1rem;
  }
  .consult {
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }
  .consult__thread {
    order: 1;
    width: 100%;
  }
  .consult__sidebar {
    order: 2;
    position: static;
    flex: none;
    width: 100%;
    padding-top: 1.25rem;
    border-top: 1px solid var(--night-border);
  }
  .consult__sidebar h2 {
    margin-top: 1.25rem;
  }
  .consult__list {
    max-height: 12rem;
    overflow-y: auto;
  }
  .consult__list li {
    margin: 0;
    border-bottom: 1px solid #1c1e2e;
  }
  .consult__list a {
    display: block;
    padding: 0.55rem 0;
  }
  .staff-totals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ledger {
    display: block;
    overflow-x: auto;
  }
}
