:root {
  --bg: #0f172a;
  --fg: #e2e8f0;
  --muted: #94a3b8;
  --panel: #1e293b;
  --panel-edge: #334155;
  --accent: #38bdf8;
  --accent-strong: #0284c7;
  --error: #f87171;
  --status-running: #34d399;
  --status-stopped: #fbbf24;
  --status-provisioned: #94a3b8;
}

[hidden] {
  display: none !important;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  line-height: 1.45;
}

.page-shell {
  max-width: 880px;
  margin: 0 auto;
  padding: 32px 24px 48px;
}

.page-header {
  margin-bottom: 24px;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 12px;
  color: var(--accent);
  margin: 0 0 4px;
}

.page-header h1 {
  font-size: 28px;
  margin: 4px 0 8px;
}

.lede {
  color: var(--muted);
  margin: 0;
}

.panel {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 20px;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 16px;
}

.panel h2 {
  font-size: 18px;
  margin: 0 0 6px;
}

.panel-help {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.field-label {
  font-size: 13px;
  color: var(--muted);
}

input[type="password"],
input[type="text"],
input[type="email"],
input[type="tel"],
textarea,
select {
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  color: var(--fg);
  padding: 10px;
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
}

input[type="password"] {
  font-family: monospace;
}

input:focus,
textarea:focus,
select:focus {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

input[type="checkbox"] {
  accent-color: var(--accent);
}

.muted-link {
  color: var(--accent);
  text-decoration: none;
}

.muted-link:hover {
  text-decoration: underline;
}

.banner {
  background: rgba(56, 189, 248, 0.1);
  border: 1px solid var(--accent);
  color: var(--fg);
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 13px;
  margin: 12px 0;
}

.banner.is-error {
  background: rgba(248, 113, 113, 0.1);
  border-color: var(--error);
}

.session-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 10px 16px;
  margin-bottom: 16px;
}

.session-bar-name {
  font-weight: 600;
}

.session-bar-nav {
  display: flex;
  gap: 12px;
  align-items: center;
}

.tab-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--panel-edge);
  padding-bottom: 8px;
}

.tab-bar button {
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted);
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
  font-weight: 500;
}

.tab-bar button.is-active {
  color: var(--fg);
  border-color: var(--panel-edge);
  background: var(--panel);
}

.tab-bar button:hover {
  color: var(--fg);
}

.account-section {
  display: none;
}

.account-section.is-active {
  display: block;
}

.session-row,
.fact-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--panel-edge);
  background: #0b1322;
  border-radius: 8px;
  margin-bottom: 8px;
  font-size: 13px;
}

.fact-row dt {
  color: var(--muted);
  margin: 0;
}

.fact-row dd {
  margin: 0;
  font-weight: 500;
}

.verify-badge {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--panel-edge);
  background: var(--panel);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.verify-badge.is-verified {
  color: var(--status-running);
  border-color: var(--status-running);
}

.primary-button,
.secondary-button {
  cursor: pointer;
  border-radius: 8px;
  font-size: 14px;
  padding: 8px 14px;
  font-weight: 600;
}

.primary-button {
  background: var(--accent-strong);
  color: white;
  border: 1px solid var(--accent-strong);
}

.primary-button:hover {
  background: var(--accent);
  border-color: var(--accent);
}

.secondary-button {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--panel-edge);
}

.secondary-button:hover {
  color: var(--fg);
  border-color: var(--accent);
}

.form-error {
  color: var(--error);
  margin: 12px 0 0;
  font-size: 13px;
}

.server-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.empty-row {
  color: var(--muted);
  font-size: 14px;
  padding: 12px 0;
  text-align: center;
}

.server-row {
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 14px 16px;
}

.server-row-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  gap: 8px;
}

.server-name {
  font-size: 16px;
}

.status-pill {
  font-size: 12px;
  padding: 2px 10px;
  border-radius: 999px;
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  color: var(--muted);
  text-transform: lowercase;
}

.status-pill.status-running {
  color: var(--status-running);
  border-color: var(--status-running);
}

.status-pill.status-stopped {
  color: var(--status-stopped);
  border-color: var(--status-stopped);
}

.status-pill.status-provisioned {
  color: var(--status-provisioned);
}

.server-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 4px 16px;
  margin: 0;
  font-size: 13px;
}

.server-meta dt {
  color: var(--muted);
}

.server-meta dd {
  margin: 0;
}

.page-footer {
  margin-top: 32px;
  color: var(--muted);
  font-size: 12px;
  text-align: center;
}

/* ---------- Checkout / order pages ---------- */
.checkout-price {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.price-num {
  font-size: 28px;
  font-weight: 700;
}
.price-suffix {
  color: var(--muted);
  font-size: 13px;
}
.price-strike {
  color: var(--muted);
  text-decoration: line-through;
  font-size: 13px;
}
.summary-list {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 6px 18px;
  margin: 12px 0 16px;
  font-size: 14px;
}
.summary-list dt {
  color: var(--muted);
}
.summary-list dd {
  margin: 0;
  font-family: ui-monospace, "SFMono-Regular", "Menlo", monospace;
  font-size: 13px;
}
.action-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 12px;
}
.form-flash {
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 14px;
  margin: 8px 0;
}
.form-flash-success {
  background: rgba(94, 226, 160, 0.1);
  color: var(--accent, #2bce81);
  border: 1px solid rgba(94, 226, 160, 0.3);
}
.pill.is-success {
  background: rgba(94, 226, 160, 0.15);
  color: #2bce81;
}

/* ---------- Portal plans browse page ---------- */
.portal-plans-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.portal-plan-card {
  position: relative;
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.portal-plan-sale {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(248, 113, 113, 0.15);
  color: var(--error);
  border: 1px solid var(--error);
  border-radius: 999px;
  padding: 2px 10px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.portal-plan-name {
  font-size: 18px;
  font-weight: 700;
}

.portal-plan-tagline {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.portal-plan-features {
  list-style: disc;
  padding-left: 20px;
  margin: 4px 0 8px;
  font-size: 13px;
  color: var(--fg);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.portal-plan-cta {
  margin-top: auto;
  text-align: center;
  text-decoration: none;
  display: inline-block;
}

/* Configure (PH-0119) — pre-checkout add-on selection. */
.configure-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap: 32px;
}
@media (max-width: 800px) {
  .configure-grid {
    grid-template-columns: 1fr;
  }
}
.configure-summary-list {
  display: grid;
  gap: 8px;
  margin: 12px 0 0;
}
.configure-summary-list div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.configure-summary-list dt {
  color: var(--muted);
}
.configure-summary-list dd {
  margin: 0;
}
.configure-total-row {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding-top: 10px;
}
.configure-addon-list {
  border: none;
  margin: 0;
  padding: 0;
}
.configure-addon-list legend {
  font-weight: 600;
  margin-bottom: 8px;
}
.configure-addon-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.configure-addon-row:last-child {
  border-bottom: none;
}
.configure-addon-stepper {
  display: flex;
  align-items: center;
  gap: 8px;
}
.configure-addon-stepper input {
  width: 64px;
  text-align: center;
}

/* ---------------------------------------------------------------------------
 * Configure page (rebuild) — scoped under .cfg-* so it does not collide with
 * the older .configure-* rules above. Append-only; do not reorder.
 * ------------------------------------------------------------------------- */

.page-shell-wide {
  max-width: 1080px;
}

.cfg-layout {
  display: grid;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

@media (max-width: 880px) {
  .cfg-layout {
    grid-template-columns: 1fr;
  }
}

.cfg-side {
  position: sticky;
  top: 16px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 22px;
}

@media (max-width: 880px) {
  .cfg-side {
    position: static;
  }
}

.cfg-plan {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cfg-plan-name {
  font-size: 22px;
  margin: 0;
  letter-spacing: -0.01em;
}

.cfg-plan-price {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 8px;
}

.cfg-price-now {
  font-size: 24px;
  font-weight: 700;
  color: var(--fg);
}

.cfg-price-now::after {
  content: "";
}

.price-strike {
  text-decoration: line-through;
  color: var(--muted);
  font-size: 14px;
}

/* Stat tiles row */
.cfg-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.cfg-stat {
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 12px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cfg-stat-label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0;
}

.cfg-stat-value {
  font-size: 22px;
  font-weight: 700;
  margin: 0;
  color: var(--fg);
  font-variant-numeric: tabular-nums;
  line-height: 1.15;
  word-break: break-word;
}

.cfg-stat-value.is-upgraded {
  color: var(--accent);
}

.cfg-stat.is-upgraded,
.cfg-stat:has(.cfg-stat-value.is-upgraded) {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.15);
}

.cfg-stat-base {
  margin: 0;
  font-size: 11px;
  color: var(--muted);
}

/* Server name block */
.cfg-server-name {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cfg-server-name .auth-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cfg-server-name .auth-field span {
  font-size: 13px;
  color: var(--muted);
}

/* Billing breakdown list */
.cfg-billing {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.cfg-billing-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  font-size: 14px;
}

.cfg-billing-row dt {
  margin: 0;
  color: var(--muted);
}

.cfg-billing-row dd {
  margin: 0;
  font-variant-numeric: tabular-nums;
}

.cfg-billing-total {
  margin-top: 6px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  font-size: 16px;
}

.cfg-billing-total dt {
  color: var(--fg);
  font-weight: 600;
}

.cfg-billing-total strong {
  font-size: 20px;
  color: var(--fg);
}

/* Right column main panel */
.cfg-main {
  padding: 22px;
}

.cfg-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 4px;
}

.cfg-addon-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cfg-addon-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 14px 16px;
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.cfg-addon-row.is-active {
  border-color: var(--accent);
  background: rgba(56, 189, 248, 0.06);
}

.cfg-addon-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.cfg-addon-name {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--fg);
}

.cfg-addon-meta {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

.cfg-stepper {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.cfg-stepper-btn {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  color: var(--fg);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  font-weight: 600;
  transition: border-color 0.15s ease, color 0.15s ease,
    background 0.15s ease;
}

.cfg-stepper-btn:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
}

.cfg-stepper-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.cfg-stepper-input {
  width: 52px;
  height: 32px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  padding: 4px;
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 8px;
  color: var(--fg);
  -moz-appearance: textfield;
  appearance: textfield;
}

.cfg-stepper-input::-webkit-outer-spin-button,
.cfg-stepper-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.cfg-empty {
  margin: 0;
  padding: 24px 16px;
  text-align: center;
  color: var(--muted);
  background: #0b1322;
  border: 1px dashed var(--panel-edge);
  border-radius: 10px;
}

/* Submit */
.cfg-submit {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 18px;
  font-size: 15px;
  margin-top: 4px;
}

.cfg-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.cfg-submit-spinner {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.4);
  border-top-color: white;
  animation: cfg-spin 0.7s linear infinite;
}

.cfg-submit-help {
  text-align: center;
  margin: 0;
}

@keyframes cfg-spin {
  to {
    transform: rotate(360deg);
  }
}

/* RCON opt-in toggle on the configure page */
.cfg-rcon-fieldset {
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  background: #0b1322;
  padding: 14px 16px;
  margin: 0 0 16px;
}
.cfg-rcon-legend {
  padding: 0 6px;
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.cfg-rcon-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  cursor: pointer;
}
.cfg-rcon-row input[type="checkbox"] {
  margin-top: 4px;
  width: 18px;
  height: 18px;
}
.cfg-rcon-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cfg-rcon-title {
  font-weight: 600;
}
.cfg-rcon-help {
  color: var(--muted);
  font-size: 13px;
}

/* Collapsible sections in the configurator. ``<details>`` already gives
 * us the collapse/expand affordance for free; we just style the wrapper
 * to look like the existing fieldsets and the summary as a clear header
 * with rotation for the marker. */
.cfg-collapsible {
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  background: #0b1322;
  padding: 0;
  margin: 0 0 16px;
}
.cfg-collapsible-summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
}
.cfg-collapsible-summary::-webkit-details-marker {
  display: none;
}
.cfg-collapsible-summary::after {
  content: "▸";
  position: absolute;
  right: 16px;
  top: 14px;
  color: var(--muted);
  transition: transform 0.15s ease-in-out;
}
.cfg-collapsible[open] > .cfg-collapsible-summary::after {
  transform: rotate(90deg);
}
.cfg-collapsible-title {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 12px;
  color: var(--muted);
}
.cfg-collapsible-help {
  font-size: 13px;
  color: var(--muted);
}
.cfg-collapsible-body {
  padding: 0 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cfg-collapsible-body .cfg-rcon-row + .cfg-rcon-row {
  margin-top: 0;
}
.cfg-port-note {
  border-top: 1px dashed var(--panel-edge);
  padding-top: 10px;
  margin: 4px 0 0;
}

/* "Server settings" — generic schema-driven form rows. */
.cfg-settings-body {
  gap: 10px;
}
.cfg-settings-group {
  border-top: 1px dashed var(--panel-edge);
  padding-top: 10px;
  margin-top: 6px;
}
.cfg-settings-group:first-child {
  border-top: 0;
  padding-top: 0;
  margin-top: 0;
}
.cfg-settings-group-title {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin: 0 0 8px;
}
.cfg-settings-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 6px 0;
}
.cfg-settings-row label {
  font-size: 13px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  color: var(--text-muted, #cbd5e1);
}
.cfg-settings-row input[type="number"],
.cfg-settings-row input[type="text"],
.cfg-settings-row select {
  background: #050913;
  border: 1px solid var(--panel-edge);
  border-radius: 6px;
  color: inherit;
  padding: 6px 8px;
  font: inherit;
  min-width: 140px;
}
.cfg-settings-row input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  justify-self: end;
}

/* Plan-switcher card grid at the top of the configure page's right pane.
 * Buttons (not labels) so keyboard focus + ARIA work without a wrapping
 * radio input. */
.cfg-plan-grid {
  display: grid;
  /* Always one row for the 4 plans — minmax(0, 1fr) lets cards shrink to fit
   * the available width on narrow viewports without wrapping to a 2nd row. */
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.cfg-plan-card {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 12px;
  border: 1px solid var(--panel-edge);
  border-radius: 8px;
  background: #0b1322;
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  font: inherit;
}
.cfg-plan-card:hover {
  border-color: var(--accent, #6aa9ff);
}
.cfg-plan-card.is-selected {
  border-color: var(--accent, #6aa9ff);
  background: #122036;
}
.cfg-plan-card-name {
  font-weight: 600;
}
.cfg-plan-card-price {
  color: var(--accent, #6aa9ff);
  font-size: 13px;
}
.cfg-plan-card-meta {
  list-style: none;
  /* ``margin-top: auto`` pins the stats list to the bottom of the flex
   * card so all four cards' stats line up at the same vertical anchor
   * even when one plan name wraps to two lines and others don't. */
  margin: auto 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  color: var(--muted);
  font-size: 11px;
}
.cfg-plan-card-meta li {
  margin: 0;
}

/* Billing-cadence radio cards on the configure page. Native radio inputs
 * are visually hidden; the surrounding label is the click target. */
.cfg-cadence-grid {
  display: grid;
  /* Always one row for the 4 cadences — minmax(0, 1fr) lets the cards
   * shrink to fit narrow viewports without wrapping to a second row. */
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}
.cfg-cadence-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid var(--panel-edge);
  border-radius: 8px;
  background: #0b1322;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.cfg-cadence-rate {
  /* Pin the bottom group (rate + savings badge) to the floor of the
   * card so all four cadence cards line up at a shared vertical anchor
   * even when "Every 12 months" wraps and "Monthly" doesn't. */
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.cfg-cadence-upfront {
  font-weight: 600;
  color: var(--text, inherit);
}
.cfg-cadence-permonth {
  font-size: 11px;
  color: var(--muted);
}
.cfg-cadence-card:hover {
  border-color: var(--accent, #6aa9ff);
}
.cfg-cadence-card input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.cfg-cadence-card:has(input[type="radio"]:checked) {
  border-color: var(--accent, #6aa9ff);
  background: #122036;
}
.cfg-cadence-title {
  font-weight: 600;
}
.cfg-cadence-rate {
  color: var(--muted);
  font-size: 12px;
}
.cfg-cadence-badge {
  display: inline-block;
  align-self: flex-start;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent, #6aa9ff);
  margin-top: 2px;
}

/* ---------------------------------------------------------------------------
 * Dashboard row footer (Manage link), shared RCON-password reveal row, and
 * server-detail page (sidebar tabs + Overview / Settings / RCON / Subscription
 * panes). All classes prefixed `portal-` per the worktree convention so they
 * never collide with admin styles.
 * ------------------------------------------------------------------------- */

.portal-row-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 14px;
}

.portal-manage-link {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  padding: 8px 18px;
}

.portal-rcon-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 8px 12px;
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 8px;
  font-size: 13px;
  flex-wrap: wrap;
}

.portal-rcon-label {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}

.portal-rcon-value {
  font-family: ui-monospace, "SFMono-Regular", "Menlo", monospace;
  font-size: 13px;
  color: var(--fg);
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 6px;
  padding: 4px 8px;
  flex-grow: 1;
  min-width: 0;
  overflow-wrap: anywhere;
}

.portal-icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--panel-edge);
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.portal-icon-button:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.portal-copy-hint {
  font-size: 12px;
  color: var(--status-running);
  font-weight: 600;
}

/* ---------- Server detail page (manage) ---------- */

.portal-detail-shell {
  max-width: 1080px;
}

.portal-detail-back {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 13px;
}

.portal-detail-layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

@media (max-width: 880px) {
  .portal-detail-layout {
    grid-template-columns: 1fr;
  }
}

.portal-tab-rail {
  position: sticky;
  top: 18px;
  display: grid;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  background: var(--panel);
  align-content: start;
}

@media (max-width: 880px) {
  .portal-tab-rail {
    position: static;
    grid-auto-flow: column;
    grid-auto-columns: minmax(120px, 1fr);
    overflow-x: auto;
  }
}

.portal-tab-button {
  display: block;
  text-align: left;
  width: 100%;
  padding: 10px 12px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

.portal-tab-button:hover {
  color: var(--fg);
  border-color: var(--panel-edge);
}

.portal-tab-button.is-active {
  background: rgba(56, 189, 248, 0.12);
  border-color: var(--accent);
  color: var(--fg);
}

.portal-tab-pane {
  display: grid;
  gap: 18px;
  align-content: start;
  min-width: 0;
}

.portal-tab-pane:not(.is-active) {
  display: none;
}

.portal-overview-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.portal-overview-title {
  margin: 0;
  font-size: 22px;
}

.portal-overview-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 6px 18px;
  font-size: 14px;
  margin: 0;
}

.portal-overview-meta dt {
  color: var(--muted);
}

.portal-overview-meta dd {
  margin: 0;
}

/* Polished action buttons row on the Overview tab. */
.portal-action-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.portal-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 120px;
  padding: 12px 22px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--panel-edge);
  background: var(--panel);
  color: var(--fg);
  transition: transform 0.12s ease, border-color 0.15s ease, background 0.15s ease,
    box-shadow 0.15s ease;
  font-family: inherit;
}

.portal-action-button:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: var(--accent);
  box-shadow: 0 4px 12px rgba(56, 189, 248, 0.18);
}

.portal-action-button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.portal-action-primary {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  color: white;
}

.portal-action-primary:hover:not(:disabled) {
  background: var(--accent);
  border-color: var(--accent);
}

.portal-action-danger {
  color: var(--error);
  border-color: rgba(248, 113, 113, 0.4);
}

.portal-action-danger:hover:not(:disabled) {
  border-color: var(--error);
}

/* Settings form layout — two columns on desktop, one on mobile. */
.portal-settings-form {
  display: grid;
  gap: 14px;
}

.portal-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.portal-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.portal-field-label {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}

.portal-field-help {
  font-size: 12px;
  color: var(--muted);
  margin: 0;
}

.portal-field-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 14px;
}

.portal-form-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}

.portal-form-flash {
  font-size: 13px;
  font-weight: 600;
}

.portal-form-flash.is-success {
  color: var(--status-running);
}

.portal-form-flash.is-error {
  color: var(--error);
  white-space: pre-wrap;
}

.portal-warnings {
  margin: 0;
  padding: 10px 14px;
  border: 1px solid rgba(251, 191, 36, 0.45);
  background: rgba(251, 191, 36, 0.1);
  color: var(--status-stopped);
  border-radius: 8px;
  font-size: 13px;
}

.portal-warnings ul {
  margin: 6px 0 0;
  padding-left: 20px;
}

.portal-empty {
  padding: 18px;
  border: 1px dashed var(--panel-edge);
  border-radius: 10px;
  color: var(--muted);
  text-align: center;
  background: #0b1322;
  font-size: 14px;
}

/* ---------------------------------------------------------------------------
 * Single-page dashboard rewrite — master-detail layout. The left rail lists
 * the customer's owned servers and the right pane renders one server's
 * tabs. Live updates arrive via the /portal/servers/stream WebSocket.
 * ------------------------------------------------------------------------- */

.portal-dashboard-shell {
  max-width: 1200px;
}

.session-bar-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.portal-conn-indicator {
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(251, 191, 36, 0.15);
  border: 1px solid rgba(251, 191, 36, 0.4);
  color: var(--status-stopped);
}

.portal-dashboard-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 22px;
  align-items: start;
  margin-top: 8px;
}

@media (max-width: 880px) {
  .portal-dashboard-layout {
    grid-template-columns: 1fr;
  }
}

.portal-server-rail {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: sticky;
  top: 18px;
  align-self: start;
  max-height: calc(100vh - 36px);
  overflow-y: auto;
}

@media (max-width: 880px) {
  .portal-server-rail {
    position: static;
    max-height: none;
  }
}

.portal-rail-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.portal-rail-title {
  margin: 0;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.portal-server-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.portal-rail-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.portal-rail-row:hover {
  border-color: var(--accent);
}

.portal-rail-row.is-active {
  border-color: var(--accent);
  background: rgba(56, 189, 248, 0.08);
}

.portal-rail-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--muted);
  flex-shrink: 0;
}

.portal-rail-dot.status-running {
  background: var(--status-running);
  box-shadow: 0 0 0 2px rgba(52, 211, 153, 0.25);
}

.portal-rail-dot.status-stopped,
.portal-rail-dot.status-archived,
.portal-rail-dot.status-failed {
  background: var(--status-stopped);
}

.portal-rail-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}

.portal-rail-name {
  font-size: 14px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.portal-rail-status {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.portal-rail-empty {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
}

.portal-detail-pane {
  min-width: 0;
}

.portal-empty-pane {
  border: 1px dashed var(--panel-edge);
  border-radius: 12px;
  padding: 48px 24px;
  text-align: center;
  color: var(--muted);
  background: #0b1322;
}

.portal-empty-pane p {
  margin: 4px 0;
}

.portal-detail-layout-inner {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.portal-detail-head h1 {
  margin: 0;
  font-size: 24px;
}

.portal-tab-rail-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  border-bottom: 1px solid var(--panel-edge);
  padding-bottom: 8px;
}

.portal-tab-rail-row .portal-tab-button {
  width: auto;
  text-align: center;
  padding: 8px 18px;
}

/* Settings: collapsible sections + grouped grid + inline labels for bools. */
.portal-settings-section {
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 0;
  background: #0b1322;
  overflow: hidden;
  margin-bottom: 12px;
}

.portal-settings-section[open] {
  background: var(--panel);
}

.portal-settings-summary {
  cursor: pointer;
  padding: 10px 14px;
  font-weight: 600;
  font-size: 14px;
  color: var(--fg);
  list-style: none;
  user-select: none;
}

.portal-settings-summary::-webkit-details-marker {
  display: none;
}

.portal-settings-summary::before {
  content: "▶";
  display: inline-block;
  margin-right: 8px;
  font-size: 10px;
  color: var(--muted);
  transition: transform 0.15s ease;
}

.portal-settings-section[open] .portal-settings-summary::before {
  transform: rotate(90deg);
}

.portal-settings-section .portal-settings-grid {
  padding: 8px 14px 16px;
}

.portal-field.portal-field-bool {
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding-top: 8px;
}

.portal-field-label-inline {
  font-size: 14px;
  color: var(--fg);
}

.portal-field.has-error input,
.portal-field.has-error select {
  border-color: var(--error);
  outline-color: var(--error);
}

.portal-action-button.portal-action-accent {
  background: rgba(56, 189, 248, 0.1);
  border-color: var(--accent);
  color: var(--accent);
}

.portal-action-button.portal-action-accent:hover:not(:disabled) {
  background: rgba(56, 189, 248, 0.2);
}

/* REST API tab — old-school server console. Two-pane layout: scrollable
 * command list on the left, command-detail + form + chat transcript on
 * the right. The transcript itself is a tail-following dark monospace
 * pane to feel like a real server console. */
.portal-rest-api-mount {
  display: block;
}

.portal-rest-api-console {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 14px;
  min-height: 460px;
}

.portal-rest-api-sidebar {
  display: flex;
  flex-direction: column;
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 10px 6px 10px 10px;
  max-height: 520px;
}

.portal-rest-api-sidebar-heading {
  margin: 0 0 6px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.portal-rest-api-command-list {
  list-style: none;
  margin: 0;
  padding: 0 4px 0 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.portal-rest-api-command {
  padding: 8px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-family: ui-monospace, "SFMono-Regular", "Menlo", monospace;
  color: var(--fg);
  border: 1px solid transparent;
  outline: none;
}
.portal-rest-api-command:hover {
  background: rgba(56, 189, 248, 0.06);
}
.portal-rest-api-command:focus-visible {
  border-color: var(--accent);
}
.portal-rest-api-command.is-selected {
  background: rgba(56, 189, 248, 0.16);
  border-color: var(--accent);
  color: var(--fg);
}

.portal-rest-api-main {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

.portal-rest-api-detail {
  background: #0b1322;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.portal-rest-api-detail-head {
  border-bottom: 1px dashed var(--panel-edge);
  padding-bottom: 10px;
}
.portal-rest-api-detail-title {
  margin: 0 0 4px;
  font-size: 15px;
}
.portal-rest-api-detail-desc {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.portal-rest-api-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.portal-rest-api-form-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.portal-rest-api-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: var(--muted);
}
.portal-rest-api-field input {
  background: #050913;
  border: 1px solid var(--panel-edge);
  color: var(--fg);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: ui-monospace, "SFMono-Regular", "Menlo", monospace;
  font-size: 13px;
}
.portal-rest-api-form-actions {
  display: flex;
  justify-content: flex-end;
}
.portal-rest-api-execute {
  min-width: 120px;
}

.portal-rest-api-transcript {
  background: #04070d;
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 10px 12px;
  flex: 1;
  min-height: 240px;
  max-height: 360px;
  overflow-y: auto;
  font-family: ui-monospace, "SFMono-Regular", "Menlo", monospace;
  font-size: 12.5px;
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.portal-rest-api-line {
  display: grid;
  grid-template-columns: 70px 14px 1fr;
  gap: 6px;
  align-items: flex-start;
}
.portal-rest-api-time {
  color: var(--muted);
  font-size: 11px;
  padding-top: 2px;
}
.portal-rest-api-arrow {
  color: var(--muted);
  text-align: center;
}
.portal-rest-api-line.is-sent .portal-rest-api-arrow {
  color: var(--accent);
}
.portal-rest-api-line.is-recv .portal-rest-api-arrow {
  color: var(--status-running);
}
.portal-rest-api-line.is-error .portal-rest-api-arrow,
.portal-rest-api-line.is-error .portal-rest-api-line-body {
  color: var(--error);
}
.portal-rest-api-line.is-pending .portal-rest-api-line-body::after {
  content: " …";
  color: var(--muted);
}
.portal-rest-api-line.is-failed {
  opacity: 0.75;
}
.portal-rest-api-line-body {
  margin: 0;
  white-space: pre;
  font-family: inherit;
  color: var(--fg);
  overflow-x: auto;
}

@media (max-width: 720px) {
  .portal-rest-api-console {
    grid-template-columns: 1fr;
  }
  .portal-rest-api-sidebar {
    max-height: 220px;
  }
}

/* Updates panel — sits at the bottom of the Overview tab. */
.portal-overview-updates {
  margin-top: 1rem;
}
.portal-updates-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--panel-edge, rgba(255, 255, 255, 0.12));
  border-radius: 10px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.portal-updates-head { display: flex; align-items: center; gap: 0.5rem; }
.portal-updates-title { margin: 0; font-size: 1rem; }
.portal-updates-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.25rem 0.75rem;
  margin: 0;
  font-size: 0.9rem;
}
.portal-updates-meta dt { font-weight: 600; color: var(--muted); }
.portal-updates-meta dd { margin: 0; font-family: ui-monospace, monospace; }
.portal-updates-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.portal-updates-help {
  font-size: 0.85rem;
  color: var(--muted);
  margin: 0;
  line-height: 1.4;
}

/* Mods tab — uploads + per-mod cards + UE4SS config.lua editor. */
.portal-mods-mount { display: block; }
.portal-mods-wrap { display: flex; flex-direction: column; gap: 1rem; }
.portal-mods-upload {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding: 0.75rem;
  border: 1px dashed var(--panel-edge, rgba(255, 255, 255, 0.15));
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.02);
}
.portal-mods-upload-label { display: flex; align-items: center; gap: 0.5rem; }
.portal-mods-list { display: flex; flex-direction: column; gap: 0.75rem; }
.portal-mod-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--panel-edge, rgba(255, 255, 255, 0.12));
  border-radius: 10px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.portal-mod-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.portal-mod-title { margin: 0; font-size: 1.05rem; }
.portal-mod-kind, .portal-mod-state {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.portal-mod-kind-pak { background: rgba(96, 165, 250, 0.15); color: #93c5fd; }
.portal-mod-kind-ue4ss { background: rgba(168, 85, 247, 0.15); color: #d8b4fe; }
.portal-mod-state.is-enabled { background: rgba(34, 197, 94, 0.15); color: #86efac; }
.portal-mod-state.is-disabled { background: rgba(148, 163, 184, 0.15); color: #cbd5e1; }
.portal-mod-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.25rem 0.75rem;
  margin: 0;
  font-size: 0.85rem;
  color: var(--muted);
}
.portal-mod-meta dt { font-weight: 600; color: var(--fg, #e2e8f0); }
.portal-mod-meta dd { margin: 0; }
.portal-mod-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.portal-mod-config {
  border-top: 1px solid var(--panel-edge, rgba(255, 255, 255, 0.1));
  padding-top: 0.75rem;
}
.portal-mod-config-title { margin: 0 0 0.5rem 0; font-size: 0.95rem; }
.portal-mod-config-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}
.portal-mod-config-row {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) 2fr auto;
  gap: 0.5rem;
  align-items: center;
}
.portal-mod-config-label { font-family: ui-monospace, monospace; font-size: 0.85rem; }
.portal-mod-config-input {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--panel-edge, rgba(255, 255, 255, 0.15));
  border-radius: 4px;
  padding: 0.4rem 0.6rem;
  color: var(--fg, #e2e8f0);
  font-family: ui-monospace, monospace;
}
.portal-mod-config-input[type="checkbox"] { width: auto; padding: 0; }

/* Stripe Checkout (ui_mode=elements) PaymentElement mount target.
   Stripe injects an iframe into ``#payment-element``; the iframe sizes
   itself but only if its parent is laid out (display: block + width).
   Without the min-height the iframe can momentarily render at 0px and
   clicks fall through to the surrounding panel. */
.payment-element-wrap {
  display: block;
  margin: 1rem 0 1.25rem;
}
.payment-element-wrap[hidden] {
  display: none;
}
#payment-element {
  display: block;
  width: 100%;
  min-height: 280px;
}
#payment-element iframe {
  width: 100% !important;
}

/* ===== Portal /plans game-tab selector ====================================
 * Above the grid, the customer picks which game's catalog to browse.
 * The two games have totally separate plan tiers, so mixing them in one
 * grid is confusing — tabs scope the view to one game at a time. */
.plans-game-tabs {
  display: flex;
  gap: 0.5rem;
  margin: 0 0 1.5rem;
  border-bottom: 1px solid var(--border, #1f2630);
}
.plans-game-tab {
  background: transparent;
  color: #aab2bf;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 0.6rem 1.1rem;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  border-radius: 0;
  margin-bottom: -1px;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.plans-game-tab:hover {
  color: #e8ecf3;
}
.plans-game-tab.is-selected {
  color: #ffb454;
  border-bottom-color: #ffb454;
}

/* ===== Configure page · Rust slider builder =================================
 * Build-your-own grid for Rust orders: one slider per resource axis
 * (slots, RAM, cores, disk), plus a mod-support checkbox. Replaces the
 * tier-picker cards that Palworld uses, because Rust has a single base
 * plan with everything scaled via add-ons. */
.cfg-rust-builder {
  display: grid;
  gap: 1.25rem;
}
.cfg-rust-slider-row {
  display: grid;
  gap: 0.5rem;
}
.cfg-rust-slider-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.cfg-rust-slider-title {
  font-weight: 600;
  color: #e8ecf3;
}
.cfg-rust-slider-value {
  font-family: "Space Grotesk", "Inter", system-ui, sans-serif;
  font-weight: 700;
  color: #ffb454;
  font-size: 1.05rem;
}
.cfg-rust-slider-input {
  width: 100%;
  accent-color: #ffb454;
}
.cfg-rust-slider-meta {
  color: #8b95a5;
  font-size: 0.85rem;
  margin: 0;
}
