
  /* Compact jump strip */
  .jump-strip { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
  .jump-group { display:flex; align-items:center; gap:6px; }
  .jump-group select.form-control { max-width: 180px; padding: 4px 8px; height: 30px; }
  .jump-group .btn-link { padding:0; line-height:1; }
  .jump-hint { font-size:12px; color:#6c757d; margin:6px 0 0; }
.rhubarb-jump-nav .launch-card,
.launch-card {
  border: 1px solid #e5e5e5;
  border-radius: .5rem;
  padding: 12px;
  background: #fff;
}

.rhubarb-jump-nav .launch-card + .launch-card,
.launch-card + .launch-card {
  margin-top: 12px;
}

.rhubarb-jump-intro {
  margin: 0 0 12px;
}

.rhubarb-jump-block {
  margin-top: 0;
  max-width: none;
}

.jump-block {
  margin-top: 8px;
  max-width: none;
}
.jump-row {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) 30px 30px 30px;
  gap: 6px;
  align-items: center;
  margin-bottom: 8px;
}

.jump-row:last-child {
  margin-bottom: 0;
}

.jump-row .jump-label {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  color: #374151;
  letter-spacing: .01em;
}

.jump-row .jump-select {
  min-width: 0;
  width: 100%;
  height: 30px;
  padding: 4px 8px;
}
}

.jump-row .btn {
  height: 30px;
}

/* Compact one-character Open button. Gallery and plus buttons already have their own fixed sizing. */
.jump-row > button.btn {
  width: 30px;
  min-width: 30px;
  padding: 5px 0 !important;
  text-align: center;
  justify-content: center;
  overflow: hidden;
  font-size: 18px;
  line-height: 1;
}

.jump-plus-btn,
.jump-gallery-btn {
  width: 30px;
  min-width: 30px;
  padding: 5px 0 !important;
  position: relative;
}

.jump-plus-btn {
  width: 30px;
  min-width: 30px;
  height: 30px;
  padding: 0 !important;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  overflow: hidden;
  text-indent: -9999px;
}

.jump-gallery-btn {
  width: 30px;
  min-width: 30px;
  height: 30px;
  padding: 0 !important;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  overflow: hidden;
  text-indent: 0;
  font-weight: 700;
  text-align: center;
}

.jump-gallery-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -58%);
  font-size: 22px;
  line-height: 1.2;
  pointer-events: none;
}


.jump-plus-btn::before {
  content: "";
  position: absolute;
  inset: 5px;
  background-color: #fff;
  -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="M11 4h2v16h-2zM4 11h16v2H4z"/></svg>') no-repeat center / contain;
          mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="M11 4h2v16h-2zM4 11h16v2H4z"/></svg>') no-repeat center / contain;
}

.launch-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  width: 100%;
  overflow: hidden;
  -webkit-overflow-scrolling: auto;
  padding-bottom: 0;
  white-space: nowrap;
}

.launch-actions .btn {
  flex: 1 1 0;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 12px;
  padding: 5px 6px;
  line-height: 1.05;
}

.launch-actions .btn[data-plus]::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-color: #fff;
  -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="M11 4h2v16h-2zM4 11h16v2H4z"/></svg>') no-repeat center / contain;
          mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="M11 4h2v16h-2zM4 11h16v2H4z"/></svg>') no-repeat center / contain;
}

.rhubarb-helper-card,
.rhubarb-workflow-card {
  border-color: #dfe6ee;
  background:
    linear-gradient(180deg, rgba(79,127,184,0.06) 0%, rgba(79,127,184,0.02) 100%);
}

.rhubarb-helper-title,
.rhubarb-workflow-card h4 {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 700;
  color: #23364d;
}

.rhubarb-helper-copy {
  color: #52606f;
  line-height: 1.5;
}

.rhubarb-helper-copy p {
  margin: 0 0 10px;
}

.rhubarb-helper-copy p:last-child {
  margin-bottom: 0;
}

.rhubarb-helper-list,
.rhubarb-workflow-list {
  padding-left: 18px;
  margin: 0;
  line-height: 1.5;
}

.rhubarb-helper-list li + li,
.rhubarb-workflow-list li + li {
  margin-top: 6px;
}

.rhubarb-helper-note {
  margin-top: 10px !important;
  padding-top: 10px;
  border-top: 1px solid #e7edf4;
  color: #475467;
}

@media (max-width: 420px) {
  .launch-actions .btn {
    font-size: 10px;
    padding: 6px 6px;
  }

  .jump-row {
    grid-template-columns: 28px minmax(0, 1fr) 30px 30px 30px;
    gap: 4px;
  }

  .jump-row .jump-select,
  .jump-row .rhubarb-select,
  .jump-row .rhubarb-select-button {
    min-width: 0;
  }

  .jump-row .rhubarb-select-menu {
    min-width: 200px;
  }
}


.jump-save-duplicate-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  margin-top: 10px;
  width: 100%;
}

.jump-save-duplicate-actions .btn {
  width: 100%;
  min-width: 0;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  padding: 5px 6px;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Rhubarb soft action palette — clearer, brighter, still not loud */

.rhubarb-jump-nav .btn,
.panel-navigate .btn,
.launch-actions .btn {
  border-radius: .45rem;
  font-weight: 700;
  box-shadow: none;
  transition:
    background-color .14s ease,
    border-color .14s ease,
    color .14s ease,
    transform .08s ease;
}

.rhubarb-jump-nav .btn:hover,
.panel-navigate .btn:hover,
.launch-actions .btn:hover {
  transform: translateY(-1px);
}

/* Data buttons — clean teal-blue */
.rhubarb-jump-nav .btn-info,
.panel-navigate .btn-info,
.launch-actions .btn-info {
  background-color: #3f9fb2;
  border-color: #358da0;
  color: #fff;
}

.rhubarb-jump-nav .btn-info:hover,
.rhubarb-jump-nav .btn-info:focus,
.panel-navigate .btn-info:hover,
.panel-navigate .btn-info:focus,
.launch-actions .btn-info:hover,
.launch-actions .btn-info:focus {
  background-color: #358fa1;
  border-color: #2e7f90;
  color: #fff;
}

/* Viz buttons — distinct calm blue */
.rhubarb-jump-nav .btn-primary,
.panel-navigate .btn-primary,
.launch-actions .btn-primary {
  background-color: #4f7fb8;
  border-color: #456fa2;
  color: #fff;
}

.rhubarb-jump-nav .btn-primary:hover,
.rhubarb-jump-nav .btn-primary:focus,
.panel-navigate .btn-primary:hover,
.panel-navigate .btn-primary:focus,
.launch-actions .btn-primary:hover,
.launch-actions .btn-primary:focus {
  background-color: #426fa4;
  border-color: #3a628f;
  color: #fff;
}

/* Dashboard buttons — fresh sage green */
.rhubarb-jump-nav .btn-success,
.panel-navigate .jump-row .btn-success,
.launch-actions .btn-success {
  background-color: #6fa76f;
  border-color: #609760;
  color: #fff;
}

.rhubarb-jump-nav .btn-success:hover,
.rhubarb-jump-nav .btn-success:focus,
.panel-navigate .jump-row .btn-success:hover,
.panel-navigate .jump-row .btn-success:focus,
.launch-actions .btn-success:hover,
.launch-actions .btn-success:focus {
  background-color: #5f965f;
  border-color: #548754;
  color: #fff;
}

/* Save button — richer teal, clearly separate from dashboard */
.jump-save-duplicate-actions .btn-success {
  background-color: #258b82;
  border-color: #207a73;
  color: #fff;
}

.jump-save-duplicate-actions .btn-success:hover,
.jump-save-duplicate-actions .btn-success:focus {
  background-color: #207b74;
  border-color: #1b6b65;
  color: #fff;
}

/* Duplicate button — cool slate, distinct from save/dashboard */
.jump-save-duplicate-actions .btn-warning {
  background-color: #7b789d;
  border-color: #6c698c;
  color: #fff;
}

.jump-save-duplicate-actions .btn-warning:hover,
.jump-save-duplicate-actions .btn-warning:focus {
  background-color: #6c698c;
  border-color: #5f5c7c;
  color: #fff;
}

.jump-plus-btn::before,
.launch-actions .btn[data-plus]::before {
  background-color: #fff;
}

/* Lightweight custom dropdown for jump nav only.
   The real select remains in the DOM for forms and existing JS behavior. */
.jump-row .rhubarb-select {
  position: relative;
  min-width: 0;
  width: 100%;
}

.jump-row .rhubarb-select-native {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  min-width: 1px !important;
  min-height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  z-index: -1 !important;
}

.jump-row .rhubarb-select-button {
  width: 100%;
  height: 30px;
  min-width: 0px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;

  border: 1px solid #d1d5db;
  border-radius: .45rem;
  background: #fff;
  color: #111827;

  font-size: 12px;
  line-height: 1.1;
  text-align: left;

  padding: 4px 8px;
  box-shadow: none;
  cursor: pointer;
}

.jump-row .rhubarb-select-button:hover,
.jump-row .rhubarb-select-button:focus {
  border-color: #9ca3af;
  background: #fff;
  outline: none;
}

.jump-row .rhubarb-select-value {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.jump-row .rhubarb-select-placeholder {
  color: #6c757d;
}

.jump-row .rhubarb-select-chevron {
  flex: 0 0 auto;
  color: #6c757d;
  font-size: 12px;
  line-height: 1;
}

.jump-row .rhubarb-select.is-open .rhubarb-select-chevron {
  transform: rotate(180deg);
}

.jump-row .rhubarb-select-menu {
  position: absolute;
  z-index: 5000;
  top: calc(100% + 5px);
  left: 0;

  display: none;
  width: 100%;
  min-width: 230px;
  max-width: 320px;

  padding: 7px;
  border: 1px solid #d1d5db;
  border-radius: .5rem;
  background: #fff;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.14);
}

.jump-row .rhubarb-select.is-open .rhubarb-select-menu {
  display: block;
}

.jump-row .rhubarb-select-search {
  width: 100%;
  height: 28px;
  margin: 0 0 6px;
  border: 1px solid #e5e5e5;
  border-radius: .4rem;
  background: #fff;
  color: #111827;
  font-size: 12px;
  padding: 4px 7px;
  outline: none;
}

.jump-row .rhubarb-select-search:focus {
  border-color: #9ca3af;
}

.jump-row .rhubarb-select-options {
  max-height: 220px;
  overflow: auto;
}

.jump-row .rhubarb-select-option {
  width: 100%;
  display: block;
  border: 0;
  border-radius: .35rem;
  background: transparent;
  color: #111827;
  font-size: 12px;
  line-height: 1.2;
  text-align: left;
  padding: 7px 8px;
  cursor: pointer;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.jump-row .rhubarb-select-option:hover,
.jump-row .rhubarb-select-option.is-active {
  background: #f3f4f6;
}

.jump-row .rhubarb-select-option.is-selected {
  background: #eef2ff;
  font-weight: 700;
}

.jump-row .rhubarb-select-empty {
  display: none;
  color: #6c757d;
  font-size: 12px;
  padding: 7px 8px;
}