/* ── Stele Language Playground ────────────────────────────────────────────── */

.nav-active { color: var(--accent) !important; }

/* ── HEADER ───────────────────────────────────────────────────────────────── */
.lang-header {
  padding: 100px 24px 60px;
  border-bottom: 1px solid var(--border);
}
.lang-header-inner { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 20px; }
.lang-eyebrow { display: flex; gap: 10px; }
.lang-title { font-size: clamp(28px, 4vw, 48px); font-weight: 800; color: #fff; letter-spacing: -0.02em; }
.lang-sub { font-size: 18px; color: var(--text-muted); line-height: 1.7; max-width: 600px; }

/* ── PLAYGROUND ───────────────────────────────────────────────────────────── */
.playground { padding: 0; }
.playground-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  height: calc(100vh - 200px); min-height: 500px;
  border-bottom: 1px solid var(--border);
}

/* Panel */
.panel { display: flex; flex-direction: column; overflow: hidden; }
.panel--editor { border-right: 1px solid var(--border); }
.panel-header {
  background: var(--bg2); border-bottom: 1px solid var(--border);
  padding: 8px 14px; display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-shrink: 0;
}
.panel-title { font-family: var(--mono); font-size: 13px; color: var(--text-muted); }
.panel-actions { display: flex; gap: 8px; align-items: center; }

.tool-btn {
  background: var(--bg3); color: var(--text); border: 1px solid var(--border);
  padding: 5px 12px; border-radius: 6px; font-size: 12px; font-family: var(--mono);
  cursor: pointer; transition: all 0.15s;
}
.tool-btn:hover { border-color: var(--accent); color: var(--accent); }
.tool-btn--primary {
  background: var(--accent); color: #000; border-color: var(--accent);
  font-weight: 700;
}
.tool-btn--primary:hover { background: #00bfa0; color: #000; }

/* Editor */
.stele-editor {
  flex: 1; width: 100%; resize: none; border: none; outline: none;
  background: var(--bg); color: var(--text);
  font-family: var(--mono); font-size: 14px; line-height: 1.8;
  padding: 20px 24px; tab-size: 2;
}

/* Output tabs */
.output-tabs { display: flex; gap: 2px; }
.tab {
  background: transparent; color: var(--text-muted);
  border: none; padding: 6px 14px; border-radius: 6px;
  font-size: 13px; cursor: pointer; font-family: var(--sans);
  transition: all 0.12s;
}
.tab:hover { color: var(--text); }
.tab.active { background: var(--bg3); color: #fff; }

.output-panels { flex: 1; overflow: auto; }
.output-panel { display: none; padding: 20px 24px; }
.output-panel.active { display: block; }
.output-placeholder { color: var(--text-muted); font-size: 14px; font-style: italic; padding: 40px 0; text-align: center; }

/* Result blocks inside output panels */
.result-block { margin-bottom: 20px; }
.result-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-muted); margin-bottom: 8px;
}
.result-ok    { color: var(--green); font-family: var(--mono); font-size: 13px; line-height: 1.7; }
.result-err   { color: var(--red);   font-family: var(--mono); font-size: 13px; line-height: 1.7; }
.result-warn  { color: var(--gold);  font-family: var(--mono); font-size: 13px; line-height: 1.7; }
.result-code  {
  background: var(--bg2); border: 1px solid var(--border); border-radius: 8px;
  padding: 16px; font-family: var(--mono); font-size: 13px; line-height: 1.7;
  white-space: pre; overflow-x: auto; color: var(--text);
}
.result-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 13px;
}
.result-badge--pass { color: var(--green); }
.result-badge--fail { color: var(--red); }

.claim-list { display: flex; flex-direction: column; gap: 8px; }
.claim-item {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 8px; padding: 12px 16px;
  display: flex; align-items: flex-start; gap: 12px;
}
.claim-item--pass { border-left: 3px solid var(--green); }
.claim-item--fail { border-left: 3px solid var(--red); }
.claim-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.claim-msg  { font-family: var(--mono); font-size: 12px; color: var(--text); line-height: 1.5; }
.claim-name { color: var(--text-muted); font-size: 11px; margin-top: 4px; }

.score-bar {
  height: 8px; background: var(--bg3); border-radius: 4px; overflow: hidden; margin: 8px 0;
}
.score-fill { height: 100%; border-radius: 4px; transition: width 0.5s ease; }
.score-fill--high { background: var(--green); }
.score-fill--mid  { background: var(--gold); }
.score-fill--low  { background: var(--red); }

/* ── REFERENCE ────────────────────────────────────────────────────────────── */
.ref-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.ref-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 28px;
}
.ref-card--wide { grid-column: 1 / -1; }
.ref-card h3 { color: #fff; font-size: 16px; margin-bottom: 16px; }

.ref-code {
  font-family: var(--mono); font-size: 12px; line-height: 1.7;
  color: var(--text); white-space: pre; overflow-x: auto;
}

.ref-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.ref-table th {
  text-align: left; font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-muted);
  border-bottom: 1px solid var(--border); padding: 8px 12px;
}
.ref-table td {
  padding: 8px 12px; border-bottom: 1px solid rgba(30,45,61,0.5);
  color: var(--text);
}
.ref-table td code {
  font-family: var(--mono); font-size: 12px;
  color: var(--accent2);
}
.ref-table td:last-child { color: var(--text-muted); font-size: 12px; }

.lvl-tag {
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  padding: 2px 8px; border-radius: 20px;
}
.lvl-tag.l0 { background: rgba(107,118,137,0.2); color: var(--text-muted); }
.lvl-tag.l1 { background: rgba(63,185,80,0.2); color: var(--green); }
.lvl-tag.l2 { background: rgba(79,142,247,0.2); color: var(--accent2); }
.lvl-tag.l3 { background: rgba(185,124,249,0.2); color: var(--accent3); }

.example-list { display: flex; gap: 12px; flex-wrap: wrap; }
.example-btn {
  background: var(--bg3); color: var(--text); border: 1px solid var(--border);
  padding: 8px 18px; border-radius: 8px; font-size: 13px; cursor: pointer;
  transition: all 0.15s; font-family: var(--sans);
}
.example-btn:hover { border-color: var(--accent3); color: var(--accent3); }

/* ── RESPONSIVE ───────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .playground-inner { grid-template-columns: 1fr; height: auto; }
  .panel--editor { height: 400px; border-right: none; border-bottom: 1px solid var(--border); }
  .panel--output { height: 400px; }
  .ref-grid { grid-template-columns: 1fr; }
  .ref-card--wide { grid-column: 1; }
}
