/* ===================================================
   JSON Editor → DaisyUI form styling (compact)
   Maps @json-editor/json-editor (html theme) elements
   to look like standard DaisyUI form components.
   =================================================== */

/* ── Root container ──────────────────────────────── */
.hb-json-editor {
  font-family: inherit;
  color: oklch(var(--bc));
  font-size: 0.875rem;
}

/* ── Labels ──────────────────────────────────────── */
.hb-json-editor label,
.hb-json-editor .je-form-input-label,
.hb-json-editor .control-label {
  display: block;
  padding: 0.25rem 0.125rem 0.125rem;
  font-size: 0.8rem;
  font-weight: 400;
  color: oklch(var(--bc) / 0.7);
}

/* ── Inputs / Selects / Textareas ────────────────── */
.hb-json-editor input[type="text"],
.hb-json-editor input[type="number"],
.hb-json-editor input[type="password"],
.hb-json-editor input[type="search"],
.hb-json-editor input[type="url"],
.hb-json-editor input[type="email"],
.hb-json-editor textarea,
.hb-json-editor select {
  width: 100%;
  height: 2.25rem;
  padding: 0.25rem 0.625rem;
  font-size: 0.8rem;
  line-height: 1.4;
  color: oklch(var(--bc));
  background-color: oklch(var(--b1));
  border: 1px solid oklch(var(--bc) / 0.2);
  border-radius: var(--rounded-btn, 0.5rem);
  outline: none;
  transition: border-color 0.2s, outline 0.15s;
  box-sizing: border-box;
}

.hb-json-editor textarea {
  height: auto;
  min-height: 3.5rem;
  resize: vertical;
}

.hb-json-editor select {
  cursor: pointer;
}

/* Bool select accent: value-driven underline (true=success, false=error) */
.hb-json-editor [data-schematype="boolean"] select,
.hb-json-editor [data-schematype="boolean"] .je-form-control > select,
.hb-json-editor [data-schematype="boolean"] .form-control > select {
  border-bottom-width: 2px;
  border-bottom-color: oklch(var(--bc) / 0.25);
  background-repeat: no-repeat;
  background-size: 100% 2px;
  background-position: left bottom;
}

.hb-json-editor [data-schematype="boolean"] select.hb-bool-true {
  border-bottom-color: oklch(var(--su));
  background-image: linear-gradient(to top, oklch(var(--su) / 0.16), oklch(var(--su) / 0.16));
}

.hb-json-editor [data-schematype="boolean"] select.hb-bool-false {
  border-bottom-color: oklch(var(--er));
  background-image: linear-gradient(to top, oklch(var(--er) / 0.14), oklch(var(--er) / 0.14));
}

.hb-json-editor [data-schematype="boolean"] select.hb-bool-true:focus {
  outline: 2px solid oklch(var(--su) / 0.25);
  box-shadow: 0 0 0 2px oklch(var(--su) / 0.1);
}

.hb-json-editor [data-schematype="boolean"] select.hb-bool-false:focus {
  outline: 2px solid oklch(var(--er) / 0.25);
  box-shadow: 0 0 0 2px oklch(var(--er) / 0.1);
}

.hb-json-editor input:focus,
.hb-json-editor textarea:focus,
.hb-json-editor select:focus {
  border-color: oklch(var(--p));
  outline: 2px solid oklch(var(--p) / 0.2);
  outline-offset: 2px;
}



/* ── Form groups (inline: label + input in one row) ─ */
.hb-json-editor .form-control,
.hb-json-editor .je-form-control {
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.375rem;
}

.hb-json-editor .form-control>div:empty,
.hb-json-editor .je-form-control>div:empty {
  display: none;
}

.hb-json-editor .form-control>label,
.hb-json-editor .form-control>.je-form-input-label,
.hb-json-editor .je-form-control>label,
.hb-json-editor .je-form-control>.je-form-input-label {
  display: inline-flex;
  font-weight: bold;
  gap: 0.5rem;
  min-width: 8rem;
  padding: 0;
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  order: 0;
  /* label always first */
}

.hb-json-editor .form-control>input,
.hb-json-editor .form-control>select,
.hb-json-editor .form-control>textarea,
.hb-json-editor .je-form-control>input,
.hb-json-editor .je-form-control>select,
.hb-json-editor .je-form-control>textarea {
  flex: 1;
  min-width: 0;
  order: 1;
}

/* ── Panels / Object containers ──────────────────── */
/* We style the whole [data-schematype="object"] so border wraps header + body */
.hb-json-editor [data-schematype="object"],
.hb-json-editor [data-schematype="array"] {
  background-color: oklch(var(--b2));
  border: 1px solid oklch(var(--bc) / 0.1);
  border-radius: var(--rounded-box, 1rem);
  padding: 0.625rem;
  margin-bottom: 0.5rem;
}

/* Nested panels inside objects — no double-border */
.hb-json-editor .je-indented-panel,
.hb-json-editor .well,
.hb-json-editor .well.well-sm {
  background-color: transparent;
  border: none;
  border-radius: 0;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none;
}

.hb-json-editor .je-indented-panel {
  border: none !important;
  box-shadow: none !important;
}

/* Keep root level itself clean (no border on root object) */
.hb-json-editor>[data-schemapath="root"],
.hb-json-editor>div>[data-schemapath="root"] {
  background-color: transparent;
  border: none;
  padding: 0;
}

/* ── Titles (h3, h4 from json-editor) ────────────── */
.hb-json-editor h3,
.hb-json-editor .je-object__title,
.hb-json-editor .je-array__title {
  font-size: 0.9rem;
  font-weight: 700;
  color: oklch(var(--bc));
  margin: 0 0 0.25rem 0;
}

.hb-json-editor h4 {
  font-size: 0.85rem;
  font-weight: 600;
  color: oklch(var(--bc));
  margin: 0 0 0.125rem 0;
}

/* ── Descriptions / Help text ────────────────────── */
.hb-json-editor .help-block,
.hb-json-editor .description,
.hb-json-editor p.help,
.hb-json-editor .je-form-input-label+small,
.hb-json-editor label>small,
.hb-json-editor .je-field-description,
.hb-json-editor .je-description,
.hb-json-editor .je-help,
.hb-json-editor small.form-text,
.hb-json-editor p.je-form-input-label[id$="-description"] {
  font-size: 0.7rem;
  color: oklch(var(--bc) / 0.5);
  margin-top: 0.125rem;
  display: none !important;
  /* hidden by default; toggled by hint button */
}

/* Hint toggle button (small info icon) */
.hb-json-editor .hb-hint-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  min-width: 1.25rem;
  margin-left: auto;
  padding: 0;
  font-size: 0.75rem;
  line-height: 1;
  border-radius: 0.25rem;
  border: 1px solid transparent;
  background: oklch(var(--b2));
  color: oklch(var(--bc) / 0.6);
  cursor: pointer;
  vertical-align: middle;
  order: 2;
  flex-shrink: 0;
}

.hb-json-editor .hb-hint-toggle.hb-hint-open {
  background: oklch(var(--b3));
  border-color: oklch(var(--bc) / 0.12);
  color: oklch(var(--bc));
}

.hb-json-editor .hb-hint-toggle.hb-hint-inline {
  order: 2;
  margin-left: 0;
  margin-right: 0;
  flex-shrink: 0;
}

/* Popup for hint text shown on click */
.hb-hint-popover {
  position: fixed;
  z-index: 12000;
  max-width: min(28rem, calc(100vw - 24px));
  padding: 0.5rem 0.625rem;
  border-radius: 0.5rem;
  border: 1px solid oklch(var(--bc) / 0.2);
  background: oklch(var(--b1));
  color: oklch(var(--bc));
  font-size: 0.75rem;
  line-height: 1.35;
  box-shadow: 0 10px 30px oklch(var(--bc) / 0.2);
  white-space: normal;
  overflow-wrap: anywhere;
}

/* ── Buttons ─────────────────────────────────────── */
.hb-json-editor button,
.hb-json-editor .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  height: 1.625rem;
  min-height: 1.625rem;
  padding: 0 0.5rem;
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1;
  text-transform: none;
  border: 1px solid oklch(var(--bc) / 0.2);
  border-radius: var(--rounded-btn, 0.5rem);
  background-color: oklch(var(--b1));
  color: oklch(var(--bc));
  cursor: pointer;
  transition: background-color 0.2s, border-color 0.2s;
  white-space: nowrap;
}

.hb-json-editor button:hover:not(:disabled) {
  background-color: oklch(var(--b3));
  border-color: oklch(var(--bc) / 0.3);
}

.hb-json-editor button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Add button → primary */
.hb-json-editor button.json-editor-btntype-add,
.hb-json-editor .btn-primary {
  background-color: oklch(var(--p));
  border-color: oklch(var(--p));
  color: oklch(var(--pc));
}

.hb-json-editor button.json-editor-btntype-add:hover:not(:disabled),
.hb-json-editor .btn-primary:hover:not(:disabled) {
  background-color: oklch(var(--p) / 0.85);
  border-color: oklch(var(--p) / 0.85);
}

/* Delete button → error */
.hb-json-editor button.json-editor-btntype-delete,
.hb-json-editor .btn-danger {
  background-color: oklch(var(--er));
  border-color: oklch(var(--er));
  color: oklch(var(--erc));
}

.hb-json-editor button.json-editor-btntype-delete:hover:not(:disabled),
.hb-json-editor .btn-danger:hover:not(:disabled) {
  background-color: oklch(var(--er) / 0.85);
  border-color: oklch(var(--er) / 0.85);
}

/* ── Headers (collapse/expand row) ───────────────── */
.hb-json-editor .je-header {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  margin-bottom: 0.25rem;
  flex-wrap: wrap;
}

.hb-json-editor .je-header-button-holder,
.hb-json-editor .je-object__controls {
  display: none;
  gap: 0.25rem;
  flex-wrap: wrap;
  margin-left: auto;
}

/* ── Root element: hide Collapse & title ─────────── */
[data-schemapath="root"]>.je-header>.je-title,
[data-schemapath="root"]>.je-header>label,
[data-schemapath="root"]>.je-header>h3,
[data-schemapath="root"]>.je-header>h4,
[data-schemapath="root"]>.je-header>span,
[data-schemapath="root"]>.je-header>.json-editor-btntype-toggle,
[data-schemapath="root"]>h3,
[data-schemapath="root"]>label {
  display: none !important;
}

.hb-json-editor .hb-root-hidden {
  display: none !important;
}

/* ── Collapse/expand toggle: simple +/− button ───── */
.hb-json-editor .json-editor-btntype-toggle {
  width: 1.5rem;
  height: 1.5rem;
  min-height: 1.5rem;
  padding: 0;
  font-size: 0;
  line-height: 1;
  border-radius: 0.25rem;
  flex-shrink: 0;
  position: relative;
  cursor: pointer;
  background-color: oklch(var(--bc) / 0.08);
  border: 1px solid oklch(var(--bc) / 0.15);
  transition: background-color 0.15s, border-color 0.15s;
}

.hb-json-editor .json-editor-btntype-toggle:hover {
  background-color: oklch(var(--bc) / 0.15);
  border-color: oklch(var(--bc) / 0.25);
}

.hb-json-editor .json-editor-btntype-toggle::after {
  content: '+';
  font-size: 0.875rem;
  font-weight: 700;
  color: oklch(var(--bc) / 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.hb-json-editor .json-editor-btntype-toggle[data-hb-sign="-"]::after {
  content: '−';
}

.hb-json-editor .json-editor-btntype-toggle[data-hb-sign="+"]::after {
  content: '+';
}

/* ── Tabs for root-level objects ──────────────────── */
.hb-json-editor .hb-tabs-wrapper {
  margin-top: 0.5rem;
}

.hb-json-editor .hb-tabs-wrapper .tabs {
  gap: 0;
}

.hb-json-editor .hb-tab-panels {
  margin-top: 0.5rem;
}

.hb-json-editor .hb-tab-panel {
  animation: hb-fade-in 0.15s ease-out;
}

@keyframes hb-fade-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Hide toggle buttons inside tabbed objects (they're always expanded) */
.hb-json-editor .hb-tab-panel>[data-schemapath]>.je-header>.json-editor-btntype-toggle {
  display: none !important;
}

/* ── Child editor holders ────────────────────────── */
.hb-json-editor .je-child-editor-holder {
  margin-top: 0.125rem;
}

/* ── Schema type spacing ─────────────────────────── */
.hb-json-editor [data-schematype="object"],
.hb-json-editor [data-schematype="array"] {
  margin-bottom: 0.375rem;
}

/* ── Tables ──────────────────────────────────────── */
.hb-json-editor .je-table {
  width: 100%;
  border-collapse: collapse;
}

.hb-json-editor .je-table th,
.hb-json-editor .je-table td {
  padding: 0.25rem 0.5rem;
  border-bottom: 1px solid oklch(var(--bc) / 0.1);
  text-align: left;
  font-size: 0.8rem;
}

/* ── Error messages ──────────────────────────────── */
.hb-json-editor .errmsg {
  color: oklch(var(--er));
  font-size: 0.7rem;
  margin-top: 0.125rem;
}

/* ── Misc clean-up ───────────────────────────────── */
.hb-json-editor hr {
  border: 0;
  border-top: 1px solid oklch(var(--bc) / 0.1);
  margin: 0.5rem 0;
}

.hb-json-editor br {
  display: none;
}