/* ============================================================
   RevealLab — settings page (routed full page)
   Scoped, prefixed classes. Tokens only — no hardcoded colors.
   ============================================================ */

/* ---- routed page visibility (shown only on the settings route) ---- */
#page-settings{display:none}
body[data-route="settings"] #page-settings{display:block}

.set-page{
  max-width:1080px;margin:0 auto;
  padding:26px 28px 40px;
  overflow:auto;
}

/* ---- page heading ---- */
.set-page__head{margin-bottom:20px}
.set-page__title{
  margin:0;font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--text);line-height:1.1;
}
.set-page__sub{margin:5px 0 0;font-size:13px}

/* ---- responsive 2-col grid of section cards ---- */
.set-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;align-items:start;
}
@media (max-width:860px){ .set-grid{grid-template-columns:1fr} }

/* ---- section card ---- */
.set-card{
  padding:0;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:box-shadow .16s ease,border-color .16s ease;
}
.set-card:hover{box-shadow:var(--shadow);border-color:var(--border-strong)}
.set-card__head{
  display:flex;align-items:center;gap:12px;
  padding:15px 17px;border-bottom:1px solid var(--border);
}
.set-card__heading{display:flex;flex-direction:column;gap:1px;min-width:0}
.set-card__title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.set-card__sub{font-size:11.5px;color:var(--text-3);font-weight:500}
.set-card__body{padding:6px 17px 16px}

/* ---- accent variants for the section icon chip ---- */
.set-ichip--brand{background:var(--brand-tint);color:var(--brand)}
.set-ichip--purple{background:var(--purple-tint);color:var(--purple)}
.set-ichip--up{background:var(--up-tint);color:var(--up)}
.set-ichip--amber{background:var(--amber-tint);color:var(--amber)}

/* ---- labelled row ---- */
.set-row{
  display:flex;align-items:center;gap:16px;
  padding:11px 0;border-bottom:1px solid var(--surface-2);
}
.set-row:last-child{border-bottom:0}
.set-row__label{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.set-row__label>span:first-child{font-size:12.5px;font-weight:600;color:var(--text)}
.set-row__help{font-size:11px}
.set-row__control{flex-shrink:0;display:flex;align-items:center;min-width:0}

/* full-width controls (key fields) stack the field under its label */
.set-card__body .set-row .field{min-width:230px}
@media (max-width:520px){
  .set-row{flex-direction:column;align-items:stretch;gap:7px}
  .set-row__control{justify-content:flex-start}
  .set-card__body .set-row .field{min-width:0;width:100%}
}

/* ---- selects share the .field look but get a caret ---- */
.set-select{
  -webkit-appearance:none;appearance:none;cursor:pointer;
  padding-right:30px;min-width:200px;font-weight:500;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238b95a7' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;
}

/* ---- static value display (universe, plan) ---- */
.set-static{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-2)}
.set-static b{color:var(--text);font-weight:700}
.set-static .pill{padding:3px 7px}
.set-static .pill svg{width:13px;height:13px}

/* ---- inline note + action strips ---- */
.set-note{
  display:flex;align-items:center;gap:7px;
  margin:10px 0 0;padding:9px 11px;
  background:var(--surface-2);border-radius:var(--r-sm);
  font-size:11.5px;line-height:1.4;
}
.set-note svg{flex-shrink:0;opacity:.8}
.set-actions{display:flex;align-items:center;gap:11px;margin-top:13px}
.set-actions--end{justify-content:flex-end;margin-top:14px}

/* ============================================================
   Toggle switch (checkbox + slider)
   ============================================================ */
.switch{display:inline-flex;cursor:pointer;-webkit-tap-highlight-color:transparent}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch__track{
  position:relative;width:42px;height:24px;border-radius:var(--r-pill);
  background:var(--border-strong);transition:background .18s ease;
}
.switch__thumb{
  position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;
  background:#fff;box-shadow:var(--shadow-sm);
  transition:transform .18s cubic-bezier(.34,1.4,.5,1);
}
.switch input:checked + .switch__track{background:var(--up)}
.switch input:checked + .switch__track .switch__thumb{transform:translateX(18px)}
.switch input:focus-visible + .switch__track{box-shadow:0 0 0 3px var(--up-tint)}

/* ============================================================
   Range slider (A+ grade cut) + live value bubble
   ============================================================ */
.rng{display:flex;align-items:center;gap:12px;min-width:230px}
.rng__input{
  -webkit-appearance:none;appearance:none;
  flex:1;height:6px;border-radius:var(--r-pill);
  background:linear-gradient(90deg,var(--brand) 0%,var(--brand) 80%,var(--surface-3) 80%);
  cursor:pointer;
}
.rng__input::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:var(--surface);border:2px solid var(--brand);
  box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s ease;
}
.rng__input::-webkit-slider-thumb:hover{transform:scale(1.12)}
.rng__input::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:var(--surface);border:2px solid var(--brand);
  box-shadow:var(--shadow-sm);cursor:pointer;
}
.rng__input::-moz-range-track{height:6px;border-radius:var(--r-pill);background:var(--surface-3)}
.rng__input:focus-visible{outline:none;box-shadow:0 0 0 3px var(--brand-tint);border-radius:var(--r-pill)}
.rng__bubble{min-width:40px;justify-content:center;font-size:12px}

/* ============================================================
   Honest-engine CORE row (sealed reveal — locked)
   ============================================================ */
.set-core{
  display:flex;align-items:flex-start;gap:12px;
  margin-top:13px;padding:13px 14px;
  background:var(--up-tint);
  border:1px solid #bfe6cd;border-radius:var(--r);
}
.set-core__icon{
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  width:30px;height:30px;border-radius:8px;
  background:var(--surface);color:var(--up);box-shadow:var(--shadow-sm);
}
.set-core__icon svg{width:16px;height:16px}
.set-core__text{min-width:0}
.set-core__title{
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;
  font-size:12.5px;font-weight:700;color:var(--text);
}
.set-core__sub{font-size:11.5px;margin-top:2px;line-height:1.4}

/* ============================================================
   Billing — runs-left progress bar
   ============================================================ */
.set-runs{min-width:220px}
.set-runs__top{font-size:12.5px;margin-bottom:6px}
.set-runs__top b{font-size:15px;font-weight:800;color:var(--text)}
.set-runs__bar{
  height:6px;border-radius:var(--r-pill);background:var(--surface-3);overflow:hidden;
}
.set-runs__bar span{
  display:block;height:100%;border-radius:var(--r-pill);
  background:linear-gradient(90deg,var(--amber),#e9a93a);
  transition:width .3s ease;
}
