/* ───────────────────────────────────────
   FILE: css/survey.css
   PURPOSE: Survey + auth shells, form fields/options, admin panels, survey result
            blocks, callsign rows, and the apply coming-soon status banner.
   PART OF: Sentinel website stylesheet (split from css/styles.css)
   LAST UPDATED: 2026-06-05
   ─────────────────────────────────────── */

/* AUTH PAGES */
.auth-page {
  min-height: 100vh;
  background: var(--bg);
}
.auth-shell {
  min-height: calc(100vh - 156px);
  display: grid;
  place-items: center;
  padding: 128px var(--gutter) 72px;
}
.auth-panel {
  width: min(100%, 560px);
  border: 1px solid var(--border);
  background: var(--card);
  padding: 42px;
}
.auth-kicker {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--accent);
  margin: 26px 0 14px;
}
.auth-title {
  font-family: var(--font-mono);
  font-size: clamp(28px, 5vw, 54px);
  line-height: 1;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 22px;
}
.auth-copy {
  max-width: 460px;
  color: var(--text-dim);
  font-size: 16px;
  line-height: 1.75;
  margin-bottom: 30px;
}
.auth-form {
  display: grid;
  gap: 18px;
}
.auth-submit {
  justify-content: center;
}
.auth-submit:disabled {
  cursor: wait;
  background: var(--border);
  color: var(--muted);
}
.auth-message {
  margin-top: 22px;
  border: 1px solid var(--border);
  padding: 14px 16px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  line-height: 1.5;
  color: var(--muted);
}
.auth-message.success {
  border-color: var(--green);
  color: var(--green);
}
.auth-message.error {
  border-color: var(--red);
  color: var(--red);
}
.auth-message.pending {
  border-color: var(--border);
  color: var(--muted);
}
.status-panel[data-status="accepted"] {
  border-color: var(--green);
}
.status-panel[data-status="rejected"],
.status-panel[data-status="error"] {
  border-color: var(--red);
}
.status-details {
  display: grid;
  border: 1px solid var(--border);
  margin-top: 28px;
}
.status-row {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 13px 16px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
}
.status-row:last-child {
  border-bottom: none;
}
.status-row span {
  color: var(--muted);
}
.status-row strong {
  color: var(--text);
  font-weight: 400;
  text-align: right;
}
.status-logout {
  margin-top: 24px;
}
/* SURVEY */
.survey-shell {
  align-items: start;
  padding-top: 118px;
}

.survey-panel {
  width: min(100%, 760px);
}

.survey-options {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.survey-options .option {
  display: grid;
  gap: 6px;
}

.survey-options input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.survey-options .option:has(input:checked) {
  background: var(--accent-bg);
}

.survey-options .option:has(input:checked)::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--accent);
}

.rating-options {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.rating-options .option {
  text-align: center;
}
/* ADMIN */
.admin-page {
  min-height: 100vh;
  background: var(--bg);
}
.admin-shell {
  padding: 116px var(--gutter) 70px;
  max-width: var(--max);
  margin: 0 auto;
}
.admin-head {
  display: grid;
  grid-template-columns: 1fr minmax(280px, 420px);
  gap: 28px;
  align-items: end;
  margin-bottom: 32px;
}
.admin-key-form,
.admin-build-form {
  display: grid;
  gap: 14px;
}
.admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.8fr);
  gap: 24px;
}
.admin-panel {
  border: 1px solid var(--border);
  background: var(--card);
  padding: 24px;
}
.admin-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  margin-bottom: 18px;
}
.admin-panel h2 {
  font-family: var(--font-mono);
  font-size: 15px;
  letter-spacing: 0.24em;
  color: var(--text);
}
.admin-panel select {
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-mono);
  padding: 10px 12px;
}
.admin-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 18px;
}
.admin-stats span {
  border: 1px solid var(--border);
  padding: 8px 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--muted);
}
.admin-list {
  display: grid;
  gap: 12px;
}
.admin-card {
  border: 1px solid var(--border);
  background: var(--bg2);
  padding: 16px;
}
.admin-card-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  font-family: var(--font-mono);
  letter-spacing: 0.12em;
  color: var(--text);
}
.admin-card-top span {
  color: var(--accent);
}
.admin-card p {
  color: var(--text-dim);
  line-height: 1.5;
  margin-top: 8px;
}
.admin-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.admin-card-actions button {
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  padding: 9px 10px;
  cursor: pointer;
}
.admin-card-actions button:hover {
  border-color: var(--accent);
  color: var(--accent);
}
/* SURVEY RESULT */
#survey-result {
  display: block;
  border: none;
  background: transparent;
  margin-top: 24px;
}
.result-block {
  border: 1px solid var(--border);
  background: var(--card);
  padding: 24px;
  margin-top: 16px;
}
.result-block:first-child { margin-top: 0; }
.result-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--accent);
  margin-bottom: 14px;
}
.result-archetype {
  font-family: var(--font-mono);
  font-size: clamp(24px, 4vw, 34px);
  letter-spacing: 0.04em;
  color: var(--text);
  line-height: 1.1;
  margin-bottom: 14px;
}
.result-description {
  font-size: 16px;
  color: var(--text-dim);
  line-height: 1.7;
}
.result-chief-message {
  font-size: 16px;
  color: var(--text);
  line-height: 1.7;
}
.result-note {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
  margin-top: 14px;
}
.result-block .status-row {
  border: 1px solid var(--border);
  border-bottom: none;
}
.result-block .status-row:last-of-type { border-bottom: 1px solid var(--border); }
.callsign-row { align-items: center; }
.callsign-tag {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--text);
}
.callsign-status {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
}
.callsign-status.available { color: var(--green); }
.callsign-status.taken { color: var(--red); }
.result-share-btn { margin-top: 18px; }

/* APPLY — COMING SOON GATE */
.status-banner {
  border: 1px solid var(--accent);
  background: var(--accent-bg);
  padding: 18px 20px;
  margin-bottom: 28px;
}
.status-banner > span {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent);
  margin-bottom: 8px;
}
.status-banner p {
  font-size: 14px;
  color: var(--text-dim);
  line-height: 1.6;
}

/* Apply holding banner — hidden until flags.js (APPLY_FORM) reveals it via CSSOM (CSP forbids inline style). */
#apply-holding { display: none; }
