/*
  Scarecrow Deterrence Assessment
  Southern Colorado Obscura
  Full-viewport character-creator layout — no page scroll needed
*/

/* ── Page chrome ─────────────────────────────────────────────────────────── */
.sc-main {
  display: flex;
  flex-direction: column;
}

/* Compact title strip replaces the large section header */
.sc-masthead-strip {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  padding: 0.35rem 0 0.3rem;
  border-top: 3px double var(--ink, #000);
  border-bottom: 1px solid rgba(0,0,0,0.18);
  margin-bottom: 0.5rem;
  flex-shrink: 0;
}
.sc-strip-title {
  font-family: "IMFellEnglishSmallCapsLocal", "IMFellEnglishLocal", serif;
  font-size: clamp(1rem, 2.2vw, 1.55rem);
  font-weight: 400;
  margin: 0;
  line-height: 1;
}
.sc-strip-sub {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.58rem;
  color: #888;
  letter-spacing: 0.06em;
  margin: 0;
  text-transform: uppercase;
}

/* ── Main app layout ────────────────────────────────────────────────────── */
/*
  Height = viewport minus masthead (≈110px) minus top-nav (≈36px)
  minus title strip (≈38px) minus body padding (≈24px)
  → approx 208px total overhead; use 215px with a safe floor.
*/
.sc-app {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.9rem;
  height: calc(100dvh - 215px);
  min-height: 480px;
  max-height: 820px;
}

/* ── Left column: canvas only ───────────────────────────────────────────── */
.sc-stage-col {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.sc-visual-stage {
  height: 100%;
  aspect-ratio: 2 / 3;
  background: #0d0d0a;
  border: 1px solid rgba(200,164,90,0.22);
  box-shadow:
    0 0 50px rgba(200,164,90,0.04),
    inset 0 0 60px rgba(0,0,0,0.55);
  overflow: hidden;
  flex-shrink: 0;
}

#scCanvas {
  display: block;
  width: 100%;
  height: 100%;
}

/* ── Right column: panel ────────────────────────────────────────────────── */
.sc-parts-panel {
  height: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(0,0,0,0.18);
  background: #f5f2ec;
  overflow: hidden;
}

/* Panel header */
.sc-panel-header {
  flex-shrink: 0;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.4rem 0.65rem 0.32rem;
  background: rgba(0,0,0,0.045);
  border-bottom: 2px double rgba(0,0,0,0.3);
}
.sc-panel-title {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.63rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #111;
}
.sc-panel-hint {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.52rem;
  color: #aaa;
  letter-spacing: 0.05em;
}

/* Scrollable slot list */
.sc-parts-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
}
.sc-parts-scroll::-webkit-scrollbar { width: 4px; }
.sc-parts-scroll::-webkit-scrollbar-track { background: transparent; }
.sc-parts-scroll::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.18); border-radius: 2px; }

/* ── Compact part row ───────────────────────────────────────────────────── */
.sc-part-row {
  border-bottom: 1px solid rgba(0,0,0,0.07);
}

/* Top line: label + select on same row */
.sc-part-top {
  display: grid;
  grid-template-columns: 5.8rem 1fr;
  align-items: center;
  gap: 0.4rem;
  padding: 0.18rem 0.55rem;
}

.sc-part-label {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #666;
  white-space: nowrap;
  cursor: default;
  user-select: none;
}

.sc-part-select {
  width: 100%;
  padding: 0.22rem 0.4rem;
  border: 1px solid rgba(0,0,0,0.25);
  border-radius: 0.1rem;
  background: #fff;
  font-family: "IMFellEnglishLocal", Georgia, serif;
  font-size: 0.8rem;
  color: #111;
  cursor: pointer;
  height: 26px;
}
.sc-part-select:focus {
  outline: 2px solid rgba(200,164,90,0.6);
  outline-offset: 1px;
}

/* ── Adjust section (slides in when a part is chosen) ───────────────────── */
.sc-part-adjust {
  display: none;
  padding: 0.2rem 0.55rem 0.35rem 6.8rem; /* indent to align under select */
  background: rgba(200,164,90,0.04);
  border-top: 1px dashed rgba(0,0,0,0.1);
}
.sc-part-adjust.visible { display: block; }

.sc-slider-row {
  display: grid;
  grid-template-columns: 2.5rem 1fr 2.8rem;
  align-items: center;
  gap: 0.25rem;
  margin-bottom: 0.18rem;
}
.sc-slider-name {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.52rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #888;
  white-space: nowrap;
}
.sc-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 2px;
  background: rgba(0,0,0,0.15);
  border-radius: 1px;
  outline: none;
  cursor: pointer;
}
.sc-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: rgba(200,164,90,0.95);
  border: 1px solid rgba(140,110,55,0.5);
  cursor: pointer;
}
.sc-slider::-moz-range-thumb {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: rgba(200,164,90,0.95);
  border: 1px solid rgba(140,110,55,0.5);
  cursor: pointer;
}
.sc-slider-val {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.54rem;
  font-weight: 700;
  color: #555;
  text-align: right;
  font-feature-settings: "tnum";
}
.sc-reset-btn {
  margin-top: 0.15rem;
  padding: 0.15rem 0.4rem;
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 0.1rem;
  background: transparent;
  font-family: var(--typewriter-stack, serif);
  font-size: 0.5rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #999;
  cursor: pointer;
}
.sc-reset-btn:hover { background: rgba(0,0,0,0.06); color: #444; }

/* ── Bottom action buttons ──────────────────────────────────────────────── */
.sc-panel-actions {
  flex-shrink: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.4rem;
  padding: 0.45rem 0.55rem;
  border-top: 2px double rgba(0,0,0,0.3);
  background: rgba(0,0,0,0.03);
}

.sc-build-btn {
  padding: 0.45rem 0.4rem;
  border: 1px solid rgba(0,0,0,0.55);
  border-radius: 0.12rem;
  background: linear-gradient(180deg, #2a2a2a, #111);
  color: #f0ece4;
  font-family: var(--typewriter-stack, serif);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 120ms;
  white-space: nowrap;
}
.sc-build-btn:hover:not(:disabled) { background: linear-gradient(180deg, #3a3a3a, #1c1c1c); }
.sc-build-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.sc-export-btn {
  padding: 0.45rem 0.4rem;
  border: 1px solid rgba(0,0,0,0.28);
  border-radius: 0.12rem;
  background: linear-gradient(180deg, #f2efe8, #e4ded4);
  color: #222;
  font-family: var(--typewriter-stack, serif);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 120ms, color 120ms;
  white-space: nowrap;
}
.sc-export-btn:hover:not(:disabled) {
  background: linear-gradient(180deg, #1a1a1a, #0a0a0a);
  color: #f0ece4;
}
.sc-export-btn:disabled { opacity: 0.3; cursor: not-allowed; }

/* ── Results panel (full-width, below builder, requires scroll) ─────────── */
.sc-results-panel {
  margin-top: 1.5rem;
  border-top: 3px double rgba(0,0,0,0.4);
  padding-top: 1rem;
}
.sc-results-heading {
  font-family: var(--typewriter-stack, serif);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #111;
  margin: 0 0 0.9rem;
  padding: 0.22rem 0;
  border-bottom: 1px solid rgba(0,0,0,0.22);
}
.sc-meters { display: flex; flex-direction: column; gap: 0.55rem; margin-bottom: 1.2rem; }
.sc-meter-row { display: grid; grid-template-columns: 8.5rem 1fr 2.5rem; align-items: center; gap: 0.5rem; }
.sc-meter-label { font-family: var(--typewriter-stack, serif); font-size: 0.62rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #444; }
.sc-meter-track { height: 10px; background: #ddd; border: 1px solid rgba(0,0,0,0.2); border-radius: 1px; overflow: hidden; }
.sc-meter-fill { height: 100%; background: #111; transition: width 500ms ease; }
.sc-meter-fill--stability { background: #555; }
.sc-meter-value { font-family: var(--typewriter-stack, serif); font-size: 0.65rem; font-weight: 700; text-align: right; }
.sc-results-subhead { font-family: var(--typewriter-stack, serif); font-size: 0.64rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: #111; margin: 1rem 0 0.4rem; padding: 0.2rem 0; border-top: 3px double rgba(0,0,0,0.4); border-bottom: 1px solid rgba(0,0,0,0.18); }
.sc-creature-table { width: 100%; border-collapse: collapse; font-family: var(--typewriter-stack, serif); font-size: 0.66rem; margin-bottom: 0.5rem; }
.sc-creature-table th { text-align: left; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.58rem; color: #555; padding: 0.25rem 0.4rem 0.25rem 0; border-bottom: 1px solid rgba(0,0,0,0.25); }
.sc-th-pct, .sc-td-pct { text-align: right; padding-right: 0.5rem; white-space: nowrap; }
.sc-th-bar, .sc-td-bar { width: 40%; }
.sc-creature-table td { padding: 0.28rem 0.4rem 0.28rem 0; border-bottom: 1px solid rgba(0,0,0,0.07); vertical-align: middle; }
.sc-td-name { font-family: "IMFellEnglishLocal", Georgia, serif; font-size: 0.82rem; color: #111; }
.sc-bar-fill { display: block; height: 7px; background: #222; transition: width 400ms ease; }
.sc-anomaly-block { margin-top: 0.5rem; }
.sc-anomaly-text { font-family: "IMFellEnglishLocal", Georgia, serif; font-style: italic; font-size: 0.85rem; color: #222; line-height: 1.5; margin: 0; padding: 0.5rem 0.6rem; border-left: 2px solid rgba(0,0,0,0.3); background: rgba(0,0,0,0.03); }
.sc-persistent-notice { margin-top: 1rem; padding: 0.6rem 0.75rem; border: 1px solid #111; background: #f5f0e8; }
.sc-persistent-label { font-family: var(--typewriter-stack, serif); font-size: 0.66rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; margin: 0 0 0.3rem; }
.sc-persistent-body { font-family: "IMFellEnglishLocal", Georgia, serif; font-size: 0.82rem; line-height: 1.45; margin: 0; color: #222; }

/* ── Loading / error ────────────────────────────────────────────────────── */
.sc-loading, .sc-error { font-family: var(--typewriter-stack, serif); font-size: 0.72rem; color: #888; font-style: italic; margin: 1rem 0.6rem; }
.sc-error { color: #7a0000; }

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 700px) {
  .sc-app {
    grid-template-columns: 1fr;
    height: auto;
  }
  .sc-visual-stage {
    height: 55vw;
    aspect-ratio: unset;
    width: 100%;
  }
  .sc-parts-panel {
    height: auto;
    max-height: 60vh;
  }
  .sc-masthead-strip {
    flex-direction: column;
    gap: 0.1rem;
  }
}
