/* =============================================================================
   PROSPECTOR auth + landing styles.
   Companion to dossier.css. Loaded only on unauthed public pages
   (landing, login, error). Builds the "intelligence terminal" feel:
   wordmark, blinking cursor, scanlines, monospaced metric grid.
   ============================================================================= */

/* ---- BODY OVERLAYS: scanlines + vignette ---- */
.body-public {
  background:
    radial-gradient(ellipse at top, rgba(80, 50, 30, 0.10), transparent 60%),
    radial-gradient(ellipse at bottom, rgba(20, 30, 25, 0.08), transparent 60%),
    var(--bg);
}
.body-public::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: repeating-linear-gradient(
    0deg,
    rgba(232, 228, 220, 0.025) 0px,
    rgba(232, 228, 220, 0.025) 1px,
    transparent 1px,
    transparent 3px
  );
  z-index: 1;
  mix-blend-mode: overlay;
}
.app-public {
  position: relative;
  z-index: 2;
  max-width: 1200px;
  margin: 0 auto;
  padding: 14px 24px;
}

/* ---- BOOT STRIP ---- */
.boot-strip {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin: 14px 0 6px 0;
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  animation: boot-fade-in 0.6s ease-out 0.1s forwards;
}
.boot-line { line-height: 1.5; }
.boot-line.boot-ok { color: var(--dossier-olive); font-weight: 700; }
@keyframes boot-fade-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 0.85; transform: translateY(0); }
}

/* ---- WORDMARK ---- */
.landing-wordmark {
  font-family: var(--mono);
  font-weight: 700;
  font-size: clamp(48px, 10vw, 110px);
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--bone);
  text-align: center;
  margin: 30px 0 12px 0;
}
.landing-wordmark .wm-bracket {
  color: var(--dossier-red);
  margin: 0 0.05em;
}
.landing-wordmark .wm-text {
  background: linear-gradient(180deg, var(--bone) 0%, #b5b1a8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 18px rgba(232, 228, 220, 0.08);
}

/* ---- TAGLINE WITH CURSOR ---- */
.landing-tagline {
  font-size: clamp(13px, 1.8vw, 17px);
  text-align: center;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dossier-amber);
  margin-bottom: 18px;
  font-weight: 600;
}
.tagline-prompt { color: var(--dossier-red); margin-right: 8px; }
.cursor-blink {
  display: inline-block;
  margin-left: 1px;
  animation: cursor 1.05s steps(2) infinite;
  color: var(--dossier-amber);
  font-weight: 700;
}
@keyframes cursor { 50% { opacity: 0; } }

.landing-sub {
  max-width: 720px;
  margin: 0 auto 36px auto;
  text-align: center;
  font-family: var(--typewriter);
  font-size: 15px;
  line-height: 1.75;
  color: var(--bone);
  opacity: 0.85;
  padding: 0 12px;
}

.landing-hero {
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  padding: 28px 12px 32px 12px;
  margin-bottom: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.012) 0%, transparent 100%);
}

/* ---- LIVE METRICS GRID ---- */
.landing-metrics {
  margin: 24px 0;
}
.metric-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--muted);
  text-transform: uppercase;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--hair);
  margin-bottom: 14px;
}
.metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 18px;
}
.metric-cell {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-left: 2px solid var(--dossier-olive);
  padding: 14px 16px;
  min-width: 0;
}
.metric-cell:nth-child(3n+2) { border-left-color: var(--dossier-amber); }
.metric-cell:nth-child(3n+3) { border-left-color: var(--dossier-red); }
.metric-value {
  font-family: var(--mono);
  font-size: 26px;
  font-weight: 700;
  color: var(--bone);
  line-height: 1.1;
  letter-spacing: 0.02em;
}
.metric-value.accent-amber { color: var(--dossier-amber); }
.metric-value.accent-red { color: var(--dossier-red); }
.metric-name {
  margin-top: 6px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ---- METHODOLOGY 3-COLUMN ---- */
.landing-method {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
  margin: 40px 0;
  padding-top: 28px;
  border-top: 1px solid var(--hair);
}
.method-col {
  padding: 4px 4px;
  min-width: 0;
}
.method-tag {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--dossier-red);
  margin-bottom: 8px;
}
.method-h {
  font-family: var(--display);
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.08em;
  margin: 0 0 10px 0;
  color: var(--bone);
}
.method-col p {
  font-family: var(--typewriter);
  font-size: 13px;
  line-height: 1.65;
  color: var(--bone);
  opacity: 0.85;
  margin: 0;
}

/* ---- ACCESS / CTA ---- */
.landing-access {
  text-align: center;
  margin: 56px 0 32px 0;
  padding-top: 28px;
  border-top: 1px solid var(--hair);
}
.access-divider {
  font-size: 11px;
  letter-spacing: 0.32em;
  margin-bottom: 18px;
  text-transform: uppercase;
}
.access-cta-row {
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.btn.btn-cta {
  display: inline-block;
  padding: 14px 32px;
  border: 1px solid var(--bone);
  background: transparent;
  color: var(--bone);
  font-family: var(--mono);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  border-radius: 2px;
  transition: background 120ms, color 120ms, border-color 120ms, box-shadow 120ms;
  position: relative;
}
.btn.btn-cta::before {
  content: "";
  position: absolute;
  inset: -2px;
  border: 1px solid transparent;
  pointer-events: none;
  transition: border-color 120ms;
}
.btn.btn-cta:hover {
  background: var(--bone);
  color: var(--bg);
  box-shadow: 0 0 22px rgba(232, 228, 220, 0.18);
}
.btn.btn-cta:hover::before {
  border-color: var(--dossier-red);
}
.access-note {
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--dossier-amber);
}
.access-fineprint {
  font-size: 10px;
  letter-spacing: 0.12em;
  margin-top: 10px;
  opacity: 0.7;
}

/* ===========================================================================
   LOGIN PAGE
   =========================================================================== */
.login-stage {
  min-height: calc(100vh - 240px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 12px;
}
.login-card {
  width: 100%;
  max-width: 440px;
}
.login-card-frame {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--hair-2);
  padding: 38px 30px 28px 30px;
  border-radius: 2px;
  box-shadow:
    0 0 0 1px rgba(232, 228, 220, 0.02),
    0 18px 50px rgba(0, 0, 0, 0.55),
    inset 0 0 30px rgba(232, 228, 220, 0.018);
}
.frame-corner {
  position: absolute;
  font-family: var(--mono);
  font-size: 16px;
  color: var(--dossier-amber);
  opacity: 0.6;
}
.frame-corner.tl { top: 4px;    left: 6px; }
.frame-corner.tr { top: 4px;    right: 6px; }
.frame-corner.bl { bottom: 4px; left: 6px; }
.frame-corner.br { bottom: 4px; right: 6px; }

.login-card-header {
  text-align: center;
  margin-bottom: 24px;
}
.login-wordmark {
  font-family: var(--mono);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: 0.12em;
  margin-bottom: 8px;
  color: var(--bone);
}
.login-wordmark .wm-bracket { color: var(--dossier-red); }
.login-prompt {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dossier-amber);
}

.login-error {
  border: 1px solid var(--dossier-red);
  background: rgba(200, 57, 42, 0.07);
  padding: 10px 12px;
  margin-bottom: 18px;
  font-size: 12px;
  display: flex;
  gap: 10px;
  align-items: baseline;
}
.err-tag {
  font-weight: 700;
  color: var(--dossier-red);
  letter-spacing: 0.14em;
  white-space: nowrap;
}
.err-msg { color: var(--bone); }

.login-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 18px;
}
.login-field { display: flex; flex-direction: column; gap: 6px; }
.login-label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}
.login-input {
  background: var(--bg);
  border: 1px solid var(--hair-2);
  color: var(--bone);
  font-family: var(--mono);
  font-size: 14px;
  padding: 11px 12px;
  border-radius: 2px;
  caret-color: var(--dossier-amber);
  letter-spacing: 0.04em;
  outline: none;
  transition: border-color 100ms, box-shadow 100ms, background 100ms;
}
.login-input::placeholder { color: var(--muted); }
.login-input:focus {
  border-color: var(--dossier-amber);
  box-shadow: 0 0 0 1px rgba(212, 167, 61, 0.4), 0 0 16px rgba(212, 167, 61, 0.12);
  background: #0a0c10;
}

.btn.login-submit {
  margin-top: 6px;
  width: 100%;
  padding: 12px 18px;
  font-size: 12px;
}

.login-meta {
  display: flex;
  gap: 8px;
  justify-content: center;
  font-size: 10px;
  letter-spacing: 0.1em;
  margin-bottom: 14px;
  opacity: 0.7;
}

.login-back {
  display: block;
  text-align: center;
  font-size: 11px;
  text-decoration: none;
  padding-top: 12px;
  border-top: 1px dashed var(--hair);
  letter-spacing: 0.08em;
}
.login-back:hover { color: var(--bone); }

/* ===========================================================================
   AUTHED-USER CHIP IN BASE HEADER
   =========================================================================== */
.user-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
  padding: 4px 8px;
  border: 1px solid var(--hair-2);
  border-radius: 2px;
  letter-spacing: 0.06em;
}
.user-chip-name { color: var(--bone); }
.user-chip-role {
  padding: 1px 5px;
  border: 1px solid currentColor;
  border-radius: 2px;
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.user-chip-role.role-admin    { color: var(--dossier-red); }
.user-chip-role.role-operator { color: var(--dossier-amber); }
.user-chip-role.role-viewer   { color: var(--muted); }

.logout-form { display: inline-block; margin: 0; }
.btn.btn-logout {
  font-family: var(--mono);
  background: transparent;
  border: 1px solid var(--hair-2);
  color: var(--muted);
  padding: 4px 8px;
  font-size: 11px;
  letter-spacing: 0.06em;
  cursor: pointer;
  border-radius: 2px;
}
.btn.btn-logout:hover { color: var(--dossier-red); border-color: var(--dossier-red); }

/* ===========================================================================
   MINIMAL LANDING (post-2026-05-14 — hide data behind login)
   =========================================================================== */
.landing-hero-minimal {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
}
.landing-access-minimal {
  margin: 40px 0 24px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.landing-access-minimal .btn-cta {
  padding: 16px 48px;
  font-size: 14px;
  letter-spacing: 0.28em;
}
.landing-fineprint {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.55;
  margin-top: 16px;
}

/* ===========================================================================
   MOBILE
   =========================================================================== */
@media (max-width: 800px) {
  .landing-method { grid-template-columns: 1fr; gap: 20px; }
  .metric-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .metric-cell { padding: 10px 12px; }
  .metric-value { font-size: 22px; }
  .landing-wordmark { margin: 16px 0 8px 0; }
  .landing-hero { padding: 18px 8px 22px 8px; }
  .login-card-frame { padding: 30px 22px 22px 22px; }
}
@media (max-width: 460px) {
  .metric-grid { grid-template-columns: 1fr; }
  .app-public { padding: 10px 12px; }
}
