/************************************************************************************/
/******************************** BLOCK *********************************************/
/************************************************************************************/

.nav-layout > :first-child {
  --vnav-bg-color: var(--bg-primary);
  --vnav-color: var(--text-on-primary);
  --vnav-font-family: var(--ff-normal); /* no such var */
  --vnav-font-size: var(--fs-500);
  --vnav-font-weight: var(--fw-300);
  --vnav-bg-highlight: var(--bg-accent);
  --vnav-text-highlight: var(--text-on-accent);
  --vnav-font-weight-highlight: var(--fw-400);
  --vnav-active-bg-color: var(--bg-secondary);
  --vnav-active-color: var(--text-on-secondary);
  --vnav-min-width: 10rem;

  min-width: var(--vnav-min-width);
  background-color: var(--vnav-bg-color);
  color: var(--vnav-color);
  margin: 0;
  font-family: var(--vnav-font-family);
  font-size: var(--vnav-font-size);
  font-weight: var(--vnav-font-weight);
  padding-right: 0.1rem;

  ul {
    list-style: none;
    padding: 0;

    a {
      text-decoration: none;
      color: inherit;
      width: 100%;
      display: block;
      border-radius: 0.2rem;
      padding-inline: 1rem;
      margin: 0.1rem 0 0.1rem 0;

      &:visited {
        text-decoration: none;
      }

      &:hover {
        background-color: var(--vnav-bg-highlight);
        color: var(--vnav-text-highlight);
        font-weight: var(--vnav-font-weight-highlight);
      }
    }

    a.active {
      background-color: var(--vnav-active-bg-color);
      color: var(--vnav-active-color);

      &:hover {
        background-color: var(--vnav-active-bg-color);
        color: var(--vnav-active-color);
        font-weight: inherit;
      }
    }
  }
}

.card {
  box-shadow: 0px 0px 4px darkgray;
  border-radius: 0.2rem;
  background-color: white;

  .card-header {
    padding: 0.3rem;
    background-color: hsl(0, 0%, 94%);
    flex-basis: 30%;
    overflow: hidden;

    &.header--ready {
      /*background-color: hsl(80, 70%, 80%);*/
    }

    &.header--not-ready {
      /*background-color: hsl(20, 70%, 80%);*/
    }
  }


  .card-body {
    flex-grow: 999;
    background-color: transparent;

    .description {
      height: 6rem;
      overflow-y: auto;
      overflow-x: auto;
      scrollbar-width: none;
    }
  }

  .card-title {
  }

  .card-footer {
    width: 100%;
    background-color: var(--bg-tertiary);
    flex-basis: 30%;
  }
}

.card--square {
  aspect-ratio: 1;
}

.card--project {
  .card-footer {
    display: flex;
    align-items: end;

    .buttons {
      margin-inline: auto;
      margin-bottom: 2rem;
      display: flex;
      flex-direction: row;
      gap: 1rem;

      button {
        padding: 1rem;
      }

      .open-project-button {
      }
    }
  }

  .card-title {
    a {
      text-decoration: none;
    }
  }
}

.card--create-new {
  .card-content {
    border: 2px dashed gray;
    background-color: transparent;
  }

}

.projects-grid {
  --ag-cell-size: 22rem;
}

.navbar-brand {
  font-weight: var(--fw-600);
  font-size: var(--fs-400);
  width: 10rem;
  background-color: var(--bg-primary);
  color: var(--text-on-primary);
  letter-spacing: 0.31rem;

  &::first-letter {
    font-size: var(--fs-800);
  }
}

header {
  font-size: var(--header-font-size);
  background: var(--clr-gray-200);

  .header-page {
    color: var(--clr-bg-primary-darker);
    /*margin-left: 1rem;*/
  }

  .header-item {
    flex-grow: 0;
    align-items: center;
    display: flex;
    padding-inline: 0.1rem;
  }

  .header-logo {
    margin-block: 0.1rem;
    margin-inline: 1rem;

    img {
      height: 2rem;
    }
  }
}

.menu-items {
    font-size: var(--fs-400);
    border: 1px solid gray;
    background-color: var(--clr-bg-secondary);
    color: var(--clr-secondary);
    padding-block: 0.3rem;
    padding-inline: 0.5rem;
    ul {
      list-style: none;
    }

    li:hover {
      background-color: var(--clr-bg-highlight);
      color: var(--clr-highlight);
    }
}

.account-container {
  font-size: 2rem;
  margin-right: 0.3rem;
  &:hover {
    color: var(--clr-highlight);
    cursor: pointer;
  }
  .account-menu-items {
    position: absolute;
    top: var(--header-height, 3rem);
    right: 1rem;
  }
}

.project-main {
  overflow: hidden;

  nav.vertical-sidebar {
    /* width: 4.5rem; */
    flex-grow: 0;
    flex-shrink: 0;
    align-self: stretch;
    /*color: var(--clr-secondary);*/
    background-color: var(--clr-gray-200);
    color: var(--clr-neutral);
    font-family: var(--ff-secondary);
    font-weight: var(--fw-400);
    font-size: var(--fs-500);
/*
    border-right: 1px solid var(--clr-neutral-lighter);
*/
    position: relative; /* because of the collapse button's absolute position */

    ul {
      list-style: none;
    }

    li:hover {
      color: var(--clr-highlight);
      background-color: var(--clr-bg-highlight);
      border-radius: 0.3rem;
    }

    li {
      display: grid;
      min-height: 3rem;
    }

    a {
      width: 100%;
      align-content: center;
    }

    li:has(> a.active) {
      border-radius: 0.3rem;
      background-color: var(--clr-gray-600);
/*
      background: linear-gradient(to right,
           var(--clr-bg-primary) 50%,
           white 100%);
*/
    }

    a.active {
      color: var(--clr-primary);
/*
      background-color: var(--clr-bg-primary);
*/
      /*font-weight: var(--fw-600);*/
      border-radius: 0.3rem;
    }

    a span {
      transition: width 200ms ease;
      transition-delay: 300ms;
    }

    li i {
      padding-inline: 0.3rem;
      font-size: var(--fs-600);
    }

  }

  nav.vertical-sidebar[aria-expanded="false"] {
    width: 4rem;
    transition: width 250ms ease-in-out;

    .vertical-sidebar-collapse button::before {
      content: '>';
    }
  }

  nav.vertical-sidebar[aria-expanded="true"] {
    width: var(--header-logo-width, 10rem);
    transition: width 250ms ease-in-out;

    .vertical-sidebar-collapse button::before {
      content: '<';
    }
  }

  .vertical-sidebar-collapse {
    position: absolute;
    bottom: 1rem;
    right: -1rem;

    button {
      width: 2rem;
      aspect-ratio: 1;
      border: 1px dotted gray;
      border-radius: 20rem;
      color: gray;
      background-color: var(--clr-bg-neutral-dark);
      opacity: 0.5;

      &:hover {
        color: var(--clr-neutral);
      }
    }
  }
}

/* Setup page: turbo-frame anchors to viewport height */
turbo-frame.setup-frame {
  display: flex;
  flex-direction: column;
  height: calc(100vh - var(--header-height, 3rem));
  overflow: hidden;
  padding-bottom: 0.75rem;
}

.setup-frame {
  .status-container {
    width: fit-content;
    grid-area: status;
    margin-bottom: 1rem;

    > div {
      gap: 2rem;
      padding: 0.2rem;
      border-radius: 0.3rem;
      font-family: var(--ff-mono);
      align-items: center;

      .error {
        color: red;
      }

      .ok {
        color: green;
      }

      .warning {
        color: orange;
      }
    }
  }

  .field-mapping-container {
    flex: 1;
    min-height: 0;
    display: flex;
    overflow: hidden;
  }
}

.column-mapping-container {
  align-items: stretch;
  flex: 1;
  min-height: 0;
  width: 100%;
  display: flex;
  flex-direction: column;

  &[data-mode="edit"] {
    input, select {
      /* common styling for input fields */
    }
    select:invalid {
      border: 2px solid var(--clr-error);
    }
  }

  .help {
    border-left: 4px solid rgba(200, 200, 200, 0.7);
    padding-left: 1rem;
    color: var(--clr-neutral-light);

    ul {
      list-style: none;
      padding-left: 0.3rem;
    }
  }

  .controls {
    label {
      font-weight: var(--fw-600);
      font-size: var(--fs-300);
    }
  }

  .title {
    grid-area: title;
  }

  .controls-url {
    grid-area: controls-url;
  }

  .help-url {
    grid-area: help-url;
  }

  .controls-sheet {
    grid-area: controls-sheet;
  }

  .help-sheet {
    grid-area: help-sheet;
  }

  .field-mapping-title {
    grid-area: field-mapping-title;
  }

  .controls-data-range {
    grid-area: controls-data-range;
  }

  .help-data-range {
    grid-area: help-data-range
  }

  .controls-field-mapping {
    grid-area: controls-field-mapping;
  }

  .help-field-mapping {
    grid-area: help-field-mapping;
  }

  .preview-title {
    grid-area: preview-title;
  }

  .controls-preview {
    grid-area: controls-preview;
  }

  .help-preview {
    grid-area: help-preview;
  }

  .edit-validation-messages {
    grid-area: edit-validation-messages;
  }

  .help-edit-validation-messages {
    grid-area: help-edit-validation-messages;
  }

  .buttons {
    grid-area: buttons;
  }

  .column-mapping--preview .column-mapping--card {
      width: calc(var(--config-node-width) * 1px);
      max-width: calc(var(--config-node-width) * 1px);
  }

  .mapping-form-container {
    flex: 1;
    display: flex;
    flex-direction: row;
    min-height: 0;
  }

  .controls-container {
    flex: 0 0 auto;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.5rem;
    padding-bottom: 1.5rem;
  }

  .chart-preview-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    #preview-chart {
      flex: 1;
      min-height: 0;
      display: flex;
      flex-direction: column;
      overflow: hidden;
      > .chart-container { /* org-chart controller element */
        flex: 1;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        .chart-container--config { /* d3 render target */
          flex: 1;
          min-height: 0;
          overflow: hidden;
        }
      }
    }
  }

  /* Global customize-panel styles - used by both column-mapping and visual-layers */
  .customize-panel {
    background-color: var(--clr-bg-neutral);
    color: var(--clr-neutral);
    border: 1px solid var(--clr-gray-300);
    border-radius: 0.3rem;
    padding: 0.75rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    z-index: 100;
    min-width: 280px;
    align-items: left;

    .customize-panel-content {
      .title {
          text-align: left;
      }

      .panel-container {
          /*justify-items: baseline;
          align-items: stretch;
          grid-auto-rows: 1fr;*/
          text-align: left;
      }
    }

    label {
      font-weight: var(--fw-600);
      font-size: var(--fs-300);
    }

    input[type="text"]:disabled {
      background-color: var(--clr-gray-100);
      cursor: not-allowed;
    }
  }

  .column-mapping--card-container, .column-mapping--preview {
    margin: auto;
    padding-block: 0.3rem;
    min-width: 50%;

    label {
      font-weight: var(--fw-600);
      font-size: var(--fs-300);
    }

    .column-mapping--card {
      margin-top: 3rem;
      margin-inline: auto;
      position: relative;

      .field {
        text-wrap: nowrap;

        .field-label {
          font-size: var(--fs-400);
          font-weight: 600;
        }
      }
    }

    .additional-field-row {
      position: relative;
      margin-bottom: 0.5rem;
    }

    .customize-field-button {
      color: var(--config-node-fg-color);

      &:hover {
        color: var(--clr-highlight);
      }

      &:disabled {
        background: transparent;
        color: var(--clr-gray-500);
      }
    }

    .icon-selector-container {
      display: flex;
      align-items: flex-start;
      gap: 0.5rem;

      .icon-display {
        display: flex;
        align-items: center;
        min-width: 3rem;
        font-size: 1.5rem;
        flex-shrink: 0;
      }

      .icon-chooser-dropdown {
        flex: 1;
        position: relative;

        .icon-search-input {
          width: 100%;
          padding: 0.35rem;
          border: 1px solid var(--clr-gray-300);
          border-radius: 0.2rem;
          font-size: 0.875rem;

          &:focus {
            outline: none;
            border-color: var(--clr-bg-primary);
            box-shadow: 0 0 0 2px rgba(var(--clr-bg-primary-hue), var(--clr-bg-primary-sat), 48%, 0.1);
          }

          &:disabled {
            background-color: var(--clr-gray-100);
            cursor: not-allowed;
          }
        }

        .icon-list {
          position: absolute;
          top: 100%;
          left: 0;
          right: 0;
          background: white;
          border: 1px solid var(--clr-gray-300);
          border-top: none;
          border-radius: 0 0 0.2rem 0.2rem;
          max-height: 200px;
          overflow-y: auto;
          z-index: 100;
          display: grid;
          grid-template-columns: repeat(auto-fill, minmax(60px, 1fr));
          gap: 0.25rem;
          padding: 0.25rem;

          &:not(.visually-hidden) {
            display: grid;
          }
        }
      }
    }
  }

  .unmapped {
    opacity: 0.5;
  }

  .reportsTo-field {
    min-height: 1.5rem; /* because line-height: 1.5 */
    text-align: end;
    padding-inline: 0.5rem;
    position: absolute;
    top: -3rem;
    border: 1px solid var(--clr-neutral-darker);
    border-radius: 0.3rem;
    background-color: var(--clr-gray-200);
    color: var(--clr-gray-800);
    min-width: 100%;
    max-width: 500px;
    text-align: center;

    &::after {
      content: '';
      border: 1px solid var(--clr-neutral-darker);
      height: 3rem;
      z-index: -1;
      position: absolute;
      border-left: none;
      border-bottom: none;
      width: 50%;
      top: 0.6rem;
      left: 0;
    }
  }

  .mapping-fields {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 0.75rem;
    border: 1px solid var(--clr-gray-300);
    border-radius: 0.25rem;
    background-color: var(--clr-bg-neutral);
    font-family: var(--ff-secondary);

    .field {
      text-wrap: nowrap;

      &.reportsTo-field {
        position: absolute;
        top: -3rem;
        left: 0;
        right: 0;
        margin: 0 auto;
      }

      &.id-field {
        display: flex;
        flex-direction: row;
        justify-content: end;
        gap: 0.3rem;
        font-size: 0.875rem;
      }

      &.name-field {
        display: flex;
        flex-direction: row;
        justify-content: end;
        gap: 0.3rem;
        font-size: 1.5rem;
      }
    }

    .additional-fields {
      display: flex;
      flex-direction: column;
    }
  }


  .column-mapping--card {
    .create-additional-field {
      display: flex;
      justify-content: center;
      margin-top: 0.5rem;
    }

    .add-field-button {
      background: var(--clr-gray-100);
      color: var(--clr-gray-700);
      border: 1px dotted var(--clr-gray-400);
      border-radius: 0.1rem;
      padding: 0.5rem 1rem;
      font-size: 0.875rem;
      width: auto;
      transition: all 0.2s;

      &:hover {
        border: 1px solid var(--clr-gray-700);
        background: var(--clr-gray-200);
      }
    }

    .delete-field-button {
      background: transparent;
      border: none;
      color: var(--config-node-fg-color);
      cursor: pointer;
      padding: 0.25rem 0.5rem;
      font-size: 1.2rem;
      line-height: 1;

      &:hover {
        color: var(--clr-error);
      }
    }

    .clear-icon-button {
      &:not([disabled]):hover {
        color: var(--clr-error);
      }

      &[disabled] {
        background: transparent;
        color: var(--clr-gray-500);
      }
    }

    .field, .reportsTo-field, .additional-field {
      select {
        max-width: 25%;
        font-size: var(--fs-400);
      }

      input[type="text"] {
        font-size: var(--fs-400);
      }
    }

    .additional-field {
      padding-top: 0.15rem;
      /* these are the inline styles additional-field because the additional-field gets removed in the setup page */
      min-height: 1.5rem;
      text-align: end;
      font-size: var(--fs-400);
      overflow: hidden;
      text-overflow: ellipsis;
      text-wrap: nowrap;

      .field-icon {
        margin-right: 0.25rem;
        flex-shrink: 0;
      }

      .field-label {
        font-size: var(--fs-200);
        font-weight: 300;
      }
    }
  }

  .validation-issue {
    padding-inline: 1rem;
    padding-block: 0.2rem;
    display: flex;
    flex-direction: row;
    border-left: 3px solid var(--clr-validation-issue-bg, var(--clr-success));
    background-color: rgba(from var(--clr-validation-issue-bg, var(--clr-success)) r g b / 0.1);
    color: var(--clr-validation-issue, var(--clr-body));
    margin-block: 1rem;

    .severity-icon-container {
      align-self: start;
      padding-right: 1rem;
      font-size: var(--fs-600);
    }

    &[data-severity="fail"] {
      --clr-validation-issue-bg: var(--clr-error);
    }

    &[data-severity="warn"] {
      --clr-validation-issue-bg: var(--clr-warn);
    }

    .main-message {
      font-size: var(--fs-400);
    }

    .help-message {
      font-size: var(--fs-300);
      color: var(--clr-neutral-lighter);
    }

    .impact-message {
      font-size: var(--fs-300);
      color: var(--clr-neutral-lighter);
    }

    .affected-rows {
      .row {
        display: grid;
        grid-template-columns: repeat(5, 1fr);
        font-size: var(--fs-200);
        padding: 0.5rem;
        gap: 0.5rem;
        overflow-x: auto;
        word-break: break-word;

        &.header {
          font-weight: bold;
          background-color: rgba(0, 0, 0, 0.05);
        }
      }
      .expandable {
        &::after {
          content: 'Expand';
          margin-left: 0.3rem;
          font-size: var(--fs-200);
          color: var(--clr-neutral-lighter);
        }
        +.affected-rows-content {
          display:none
        }
      }
      .expandable.expanded {
        &::after {
          content: 'Collapse';
        }
        +.affected-rows-content {
          display: block;
        }
      }
    }
  }
}

.chart-container {
  color: var(--clr-neutral);
}

.login-section {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.login-billboard {
  height: 100%;
  align-items: center;
  justify-content: center;
  border-left: 1px solid darkgray;
  display: flex;

  h1 {
    font-size: 3rem;
    font-family: var(--ff-heading-secondary);
    font-weight: 300;
    padding: 0.25rem;
    text-align: center;
  }

  img {
    align-self: center;
    justify-self: center;

  }
}

.inline-message-alert {
  display: flex;
  margin: 1rem;
  padding: 0.5rem;
  justify-content: center;
  border: var(--border-width, 1px) solid var(--clr-border, var(--clr-highlight));
  /* background-color: var(--clr-background, var(--clr-bg-neutral-dark)); */
  border-radius: 0.4rem;

  .title {
    font-weight: var(--fw-600);
  }

  .button {
    margin-right: 0.3rem;
  }
}

.create-project-container {
/*  transition: all 0.2s ease-in-out;
  opacity: 0;
  visibility: hidden;
  */
}

.create-project-container.showContainer {
  opacity: 1;
  visibility: visible;
}

.create-project-container.hideContainer {
  opacity: 0;
  visibility: hidden;
  display: none;
}

.welcome {
  & .welcome-toggle {
    cursor: pointer;
    color: inherit;
    margin-inline: 0.3rem;
    border: none;
    background: none;
    text-decoration: none;
/*    transition: transform 0.3s ease;  */
  }
}
/*  & .welcome-toggle[aria-expanded="true"] {
    i {
      transform: rotate(180deg);
    }
*/

.coming-soon {
  background-color: var(--clr-bg-primary-light);
  border: 1px solid var(--clr-bg-primary-light);
  border-radius: 0.3rem;
  padding-inline: 0.3rem;
  margin-right: 0.3rem;
}

.coming-soon::after {
  content: 'Coming Soon';
}

.pricing-container {
  display: grid;
  max-width: 72rem;
  margin-inline: auto;
  grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
  grid-gap: 1rem;
  padding-top: 1rem;
  justify-content: center;
}

.pricing-container-addendum {
  grid-column: 1 / -1; /* This makes it span the full row */
  justify-self: start; /* Align to left of cards */
}

.faq-container {
  grid-column: 1 / -1; /* This makes it span the full row */
  justify-self: start; /* Align to left of cards */
  summary {
    color: var(--clr-gray-600);
  }
  summary::marker {
    list-style-type: square;
  }
}

/* Inline Edit Support */
.editable-input {
    transition: background-color 0.2s ease;
    cursor: auto;
}

.editable-input:hover {
    background-color: var(--clr-gray-100);
    cursor: pointer;
}

.editable-input:focus {
    outline: 1px solid var(--clr-gray-300);
    cursor: auto;
}

.release-note-content {
    height: 15rem;
    overflow: auto;
}

/* Nav item hover behavior */
.navitem-hover-container {
    width: 4.5rem; /* Collapsed width */
    transition: width 0.3s ease;
}

.navitem-hover-container.expanded {
    width: 10rem; /* Expanded width */
}

.navitem-hover-container .navitem-text {
    opacity: 0;
    width: 0;
    pointer-events: none;   /* even with width: 0 this participates in hover */
    transition: opacity 0.3s ease;
    white-space: nowrap;
}

.navitem-hover-container.expanded .navitem-text {
    opacity: 1;
    width: 100%;
    pointer-events: auto;
}

.navitem-hover-container .navitem-link {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Icon Chooser Styles */
.icon-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  border: 2px solid transparent;
  border-radius: 0.2rem;
  cursor: pointer;
  transition: all 0.2s ease;
  background: white;
  min-width: 60px;

  i {
    font-size: 1.5rem;
    margin-bottom: 0.25rem;
    color: var(--clr-neutral);
  }

  .icon-name {
    font-size: var(--fs-200);
    text-align: center;
    word-break: break-word;
    color: var(--clr-gray-700);
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  &:hover {
    border-color: var(--clr-bg-primary);
    background-color: var(--clr-bg-primary-lighter);
    transform: scale(1.05);
  }

  &.selected {
    border-color: var(--clr-bg-primary);
    background-color: var(--clr-bg-primary-light);
    box-shadow: 0 0 0 2px var(--clr-bg-primary-lighter);

    i {
      color: var(--clr-bg-primary-darker);
    }

    .icon-name {
      color: var(--clr-bg-primary-darker);
      font-weight: var(--fw-600);
    }
  }
}

.chart-container--config {
    background1: var(--config-chart-bg-color, var(--clr-bg-neutral)) var(--config-chart-bg-image);
    color1: var(--config-chart-fg-color, var(--clr-neutral));
    --config-chart-highlight-color: #E27396;
    --config-chart-highlight-width: 10;
    --config-chart-line-color: var(--clr-gray-800);
    --config-chart-line-width: 2;

    /* these are all template vars */
    --config-chart-bg-color: var(--clr-bg-neutral);
    --config-chart-bg-image: ;
    --config-chart-bg-size: cover;
    --config-chart-bg-position: center;
    --config-chart-bg-repeat: no-repeat;
    --config-chart-fg-color: var(--clr-neutral);
    --config-chart-fg-ff: var(--ff-secondary);
    --config-node-width: 300;
    --config-node-border-width: 1px;
    --config-node-border-style: solid;
    --config-node-border-color: var(--clr-neutral-darker);
    --config-node-border-radius: 0.3rem;
    --config-node-profile-image-border-width: 0px;
    --config-node-profile-image-border-style: solid;
    --config-node-profile-image-border-color: var(--clr-neutral-darker);
    --config-node-bg-color: var(--clr-white);
    --config-node-fg-color: var(--clr-gray-800);
    --config-node-fg-ff: var(--ff-secondary);
    --config-node-expander-border-width: 1px;
    --config-node-expander-border-style: solid;
    --config-node-expander-border-color: #E4E2E9;
    --config-node-expander-border-radius: 3px;
    --config-node-expander-fg-color: #716E7B;
    --config-node-expander-bg-color: var(--clr-white);
    --config-node-expander-bg-image: url();
    --config-node-link-fg-color: var(--config-node-fg-color);
}

.node--config1 {
    border: var(--config-node-border-width, 1px) var(--config-node-border-style, solid) var(--config-node-border-color, var(--clr-neutral-darker));
    border-radius: var(--config-node-border-radius, 5px);
    background: var(--config-node-bg-color, var(--clr-white));
    color: var(--config-node-fg, var(--clr-gray-800));
    padding: 0.5rem;
    padding-right: 0.65rem;
}

.preset-popup {
    background: var(--clr-bg-primary-lighter);
    color: var(--clr-primary-darker);
    font-weight: 500;
    margin: 0.3rem;
    border-radius: 0.3rem;
    border: 1px solid var(--clr-bg-highlight);
    cursor: pointer;
    z-index: 100;
}

/* Additional Field Links Styling */
.additional-field-link {
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
  text-underline-position: auto !important;    /* override the a.* one because it doesn't show in the chart */

  &:hover {
    text-decoration: underline;
    color: color-mix( in oklab, var(--config-node-link-fg-color) 85%, white 15% );
  }

  &:visited {
    color: color-mix( in oklab, var(--config-node-link-fg-color) 85%, white 15% );
  }

  &:active {
    color: color-mix( in oklab, var(--config-node-link-fg-color) 85%, white 15% );
  }
}

.additional-field-label {
  text-decoration: none;
  cursor: pointer;
}

/************************************************************************************/
/******************************* VISUAL LAYERS *************************************/
/************************************************************************************/

/* Floating Button - positioned fixed at bottom right */
.visual-layers-button {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1000;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background-color: var(--clr-bg-secondary);
    color: var(--clr-secondary);
    border: none;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    transition: all 0.2s ease;
}

.visual-layers-button:hover {
    background-color: var(--clr-bg-highlight);
    color: var(--clr-highlight);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.visual-layers-button:active {
    transform: scale(0.95);
}

/* Expandable Panel */
.visual-layers-panel {
    position: fixed;
    bottom: 90px;
    right: 20px;
    z-index: 999;
    width: 320px;
    max-height: 600px;
    background: white;
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    border: 1px solid #E0E0E0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: all 0.3s ease;
}

.visual-layers-panel--hidden {
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    pointer-events: none;
}

.visual-layers-panel--visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

/* Panel Header */
.visual-layers-panel-header {
    padding: 0.5rem;
    border-bottom: 1px solid #E0E0E0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}

.visual-layers-panel-header h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #202124;
}

.visual-layers-panel-header .btn-close {
    background: none;
    border: none;
    cursor: pointer;
    color: #5F6368;
    font-size: 20px;
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s ease;
}

.visual-layers-panel-header .btn-close:hover {
    color: #202124;
}

/* Panel Content */
.visual-layers-panel-content {
    flex: 1;
    overflow-y: auto;
    /* padding: 12px 0; */
}

/* Layer List */
.visual-layers-list {
    display: flex;
    flex-direction: column;
}

.visual-layers-item {
    border-bottom: 1px solid #F0F0F0;
    display: flex;
    flex-direction: column;
}

.visual-layers-item:last-child {
    border-bottom: none;
}

.visual-layers-item-header {
    /* padding: 12px 16px; */
    padding: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.8rem;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.visual-layers-item-header:hover {
    background-color: #F8F9FA;
}

.visual-layers-legend-toggle {
    background: none;
    border: none;
    cursor: pointer;
    color: #5F6368;
    font-size: 18px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, color 0.2s ease;
    margin-left: auto;
}

.visual-layers-legend-toggle:hover {
    color: #202124;
}

.visual-layers-legend-toggle--expanded {
    transform: rotate(180deg);
}

.visual-layers-checkbox {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: #4285F4;
}

.visual-layers-label {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    cursor: pointer;
}

.visual-layers-name {
    font-size: 14px;
    font-weight: 500;
    color: #202124;
}

.visual-layers-channel {
    font-size: 12px;
    color: #80868B;
}

.visual-layers-empty {
    padding: 16px;
    text-align: center;
    color: #5F6368;
    font-size: 14px;
    margin: 0;
}

/* Inline Legend Section (Collapsible) */
.visual-layers-legend-section {
    max-height: 400px;
    overflow: hidden;
    transition: max-height 0.2s ease, opacity 0.2s ease;
    opacity: 1;
}

.visual-layers-legend-section--collapsed {
    max-height: 0;
    opacity: 0;
    transition: max-height 0.2s ease, opacity 0.1s ease 0.1s;
}

.visual-layers-legend-section--expanded {
    max-height: 400px;
    opacity: 1;
}

.visual-layers-legend-section {
    padding: 0 16px 12px 16px;
    border-top: 1px solid #F0F0F0;
    background-color: #FAFAFA;
}

.visual-layers-legend-empty {
    padding: 8px 0;
    font-size: 12px;
    color: #80868B;
    margin: 0;
}

.visual-layers-legend {
    margin: 0;
}

.visual-layers-legend-title {
    font-size: 12px;
    font-weight: 600;
    color: #202124;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.visual-layers-legend-entries {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.visual-layers-legend-entry {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #5F6368;
}

.visual-layers-swatch {
    flex-shrink: 0;
}

.visual-layers-legend-label {
    display: flex;
    gap: 4px;
    flex: 1;
    min-width: 0;
}

.visual-layers-entry-label {
    color: #202124;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.visual-layers-entry-count {
    color: #80868B;
    flex-shrink: 0;
}

/* Responsive adjustments for small screens */
@media (max-width: 600px) {
    .visual-layers-button {
        bottom: 16px;
        right: 16px;
        width: 48px;
        height: 48px;
        font-size: 20px;
    }

    .visual-layers-panel {
        bottom: 80px;
        right: 16px;
        width: calc(100% - 32px);
        max-width: 320px;
        max-height: 50vh;
    }
}

/* Scrollbar styling */
.visual-layers-panel-content::-webkit-scrollbar {
    width: 6px;
}

.visual-layers-panel-content::-webkit-scrollbar-track {
    background: transparent;
}

.visual-layers-panel-content::-webkit-scrollbar-thumb {
    background: #D3D3D3;
    border-radius: 3px;
}

.visual-layers-panel-content::-webkit-scrollbar-thumb:hover {
    background: #A0A0A0;
}

/* Exact Value Configuration - Manual Value Management UI */
.exact-value-config {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* Value Mappings List */
.value-mappings-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-height: 400px;
    overflow-y: auto;
}

.value-mapping-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.3rem;

    input {
      margin-left: 0.3rem;
    }
}

.value-mapping-row:hover {
    background-color: #f0f0f0;
}

.value-mapping-row .value-selector {
    flex: 1;
    min-width: 150px;
    padding: 0.5rem;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 0.875rem;
    background-color: white;
}

.value-mapping-row .value-selector:focus {
    outline: none;
    border-color: #4285F4;
    box-shadow: 0 0 0 2px rgba(66, 133, 244, 0.1);
}

.value-mapping-row .value-selector::placeholder {
    color: #999;
}

/* Color Picker */
.value-mapping-row .color-picker {
    width: 60px;
    height: 36px;
    border: 1px solid #ccc;
    border-radius: 4px;
    cursor: pointer;
    padding: 2px;
    background: white;
}

.value-mapping-row .color-picker:hover {
    border-color: #999;
}

/* Style Selector (for border-style) */
.value-mapping-row .style-selector {
    width: 120px;
    padding: 0.5rem;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 0.875rem;
    background-color: white;
    cursor: pointer;
}

.value-mapping-row .style-selector:focus {
    outline: none;
    border-color: #4285F4;
    box-shadow: 0 0 0 2px rgba(66, 133, 244, 0.1);
}

/* Width Spinner (for border-width) */
.value-mapping-row .width-spinner {
    width: 50px;
    padding: 0.5rem;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 0.875rem;
    background-color: white;
}

.value-mapping-row .width-spinner:focus {
    outline: none;
    border-color: #4285F4;
    box-shadow: 0 0 0 2px rgba(66, 133, 244, 0.1);
}

.value-mapping-row .width-unit {
    font-size: 0.875rem;
    color: #666;
    margin-left: -0.25rem;
}

/* Value mapping remove button - styled with page's button class */
.value-mapping-row .button {
    width: auto;
    padding: 0.25rem 0.5rem;
    font-size: 1rem;
    line-height: 1;
    flex-shrink: 0;
}

/* Add Value Mapping Button section */
/* Panel Container - tighter grid for form fields */
.panel-container {
    column-gap: 0.5rem !important;
}

.exact-value-footer {
    display: flex;
    justify-content: center;
    padding-top: 0.5rem;
    margin-top: 0.5rem;
    border: none;
}

.exact-value-footer .add-value-mapping-button {
    background: var(--clr-gray-100);
    color: var(--clr-gray-700);
    border: 1px dotted var(--clr-gray-400);
    border-radius: 0.1rem;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    width: auto;
    transition: all 0.2s;
}

.exact-value-footer .add-value-mapping-button:hover {
    border: 1px solid var(--clr-gray-700);
    background: var(--clr-gray-200);
}

/************************************************************************************/
/****** APPEARANCE SECTION - Theme Panel and Visual Layers Collapsible *****/
/************************************************************************************/

/* Appearance Section Layout */
.appearance-section {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    background-color: var(--clr-bg-neutral);
}

/* Theme Line with Gear Icon */
.appearance-theme-line {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-left: 0.3rem;
}

.appearance-theme-line .button {
    padding: 0.25rem 0.5rem;
    font-size: 1rem;
}

/* Customize Panel Styling - Floating Overlay */
.customize-panel {
    background-color: transparent;
    border: none;
    border-radius: 0.2rem;
    box-shadow: none;
    max-height: 80vh;
    overflow-y: auto;
    z-index: 1000;
    /* Position and visibility handling */
    display: none;
    pointer-events: none;
    /* Ensure proper stacking context and prevent affecting parent layout */
    margin: 0;
    padding: 0;
}

.customize-panel:not(.visually-hidden) {
    display: block;
    pointer-events: auto;
}

.customize-panel::-webkit-scrollbar {
    width: 6px;
}

.customize-panel::-webkit-scrollbar-thumb {
    background: var(--clr-gray-400);
    border-radius: 3px;
}

.customize-panel::-webkit-scrollbar-track {
    background: transparent;
}

/* Visual Layer Configuration Form - Tightened layout */
.customize-panel-content {
    padding: 0;
    background-color: transparent;
}

.customize-panel-content .title {
    margin: 0 0 0.5rem 0;
    padding: 0;
    font-size: 0.875rem;
    font-weight: 600;
}

.customize-panel-content .panel-container {
    padding: 0;
    background-color: transparent;
    border: none;
}

.customize-panel-content .panel-container label {
    font-weight: 500;
    font-size: 0.875rem;
    white-space: nowrap;
    padding-right: 0.5rem;
}

.customize-panel-content .panel-container input[type="text"],
.customize-panel-content .panel-container select {
    /* padding: 0.375rem 0.5rem; */
    font-size: 0.875rem;
}

/* Value Mapping Configuration */
.mode-config-section {
    background-color: transparent;
    padding: 0;
    border: none;
}

.exact-value-config {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.value-mappings-list {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.value-mapping-row {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    padding: 0.25rem 0;
}

.value-mapping-row .value-selector {
    flex: 1;
    background-color: white;
    border: 1px solid var(--clr-gray-300);
    padding: 0.375rem 0.5rem;
    font-size: 0.875rem;
    border-radius: 0.2rem;
}

.value-mapping-row .color-picker {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border: 1px solid var(--clr-gray-300);
    border-radius: 0.2rem;
    cursor: pointer;
}

.value-mapping-row .style-selector {
    flex: 0 0 150px;
    padding: 0.375rem 0.5rem;
    font-size: 0.875rem;
}

.value-mapping-row .width-spinner {
    flex-shrink: 0;
    width: 60px;
    padding: 0.375rem 0.5rem;
    font-size: 0.875rem;
}

.value-mapping-row .button {
    flex-shrink: 0;
    padding: 0.25rem 0.5rem;
    background: transparent;
    border: none;
    color: var(--config-node-fg-color);
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
    display: flex;
    align-items: center;
}

.value-mapping-row .button:hover {
    color: var(--clr-error);
}

.add-value-mapping-button {
    align-self: flex-start;
}

/* Visual Layers Collapsible Section */
.visual-layers-section {
    padding-left: 0.3rem;
}

.visual-layers-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    padding: 0.25rem 0 0.25rem 0;
    transition: background-color 0.2s ease;
}

.visual-layers-header .chevron-toggle {
    margin-left: auto;
}

.visual-layers-header:hover {
    background-color: var(--clr-gray-100);
    border-radius: 0.2rem;
}

.visual-layers-header .chevron-toggle {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    margin-right: 0.25rem;
    transition: transform 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.visual-layers-header .chevron-toggle i {
    font-size: 1rem;
    color: var(--clr-gray-600);
}

/* Content Container - Expansion/Collapse Animation */
.visual-layers-content {
    max-height: 2000px;
    overflow: visible;
    transition: max-height 0.3s ease, opacity 0.3s ease;
    opacity: 1;
    padding-left: 0.3rem;
}

.visual-layers-content.visual-layers-section--collapsed {
    max-height: 0;
    opacity: 0;
    transition: max-height 0.3s ease, opacity 0.2s ease 0.1s;
}

/* Chevron Rotation based on Content Collapsed State */
/* When content has collapsed class, chevron points down (0deg) */
.visual-layers-section:has(.visual-layers-content.visual-layers-section--collapsed) .chevron-toggle {
    transform: rotate(0deg);
}

/* When content doesn't have collapsed class, chevron points up (180deg) */
.visual-layers-section:not(:has(.visual-layers-content.visual-layers-section--collapsed)) .chevron-toggle {
    transform: rotate(180deg);
}

/************************************************************************************/
/******************************** EXCEPTION *****************************************/
/************************************************************************************/

/************************************************************************************/
/****************************** SEARCH SIDEBAR *************************************/
/************************************************************************************/

/* Floating panel for search - positioned absolutely within chart area, below toolbar */
.search-sidebar {
    position: absolute;
    top: 3.25rem;
    left: 0.75rem;
    width: 340px;
    max-height: calc(100% - 1.5rem);
    display: flex;
    flex-direction: column;
    background: var(--bg-primary, #ffffff);
    border: 1px solid var(--clr-gray-200, #e8e8e8);
    border-radius: 0.5rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 100;
    overflow: hidden;
    opacity: 1;
    transition: opacity 0.3s ease-out, transform 0.3s ease-out;
    pointer-events: auto;
    transform: scale(1);
}

/* Hidden state with fade-out transition */
.search-sidebar.d-none {
    opacity: 0;
    pointer-events: none;
    transform: scale(0.95);
    /* Do NOT use display: none - it blocks transitions.
       Use visibility: hidden after animation completes (handled in JS) */
}

/* Panel header with close button */
.search-sidebar__header {
    flex: 0 0 auto;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--clr-gray-100, #f5f5f5);
    font-weight: 600;
    font-size: var(--fs-500, 0.9375rem);
    color: var(--text-primary, #333);
}

/* Close button styling */
.search-sidebar__close {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary, #666);
    transition: color 0.2s ease;
    font-size: 1rem;
}

.search-sidebar__close:hover {
    color: var(--text-primary, #333);
}

/* Input wrapper with padding */
.search-sidebar__input-wrap {
    flex: 0 0 auto;
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--clr-gray-100, #f5f5f5);
}

/* Search input styling */
.search-sidebar__input {
    width: 100%;
    padding: 0.625rem 0.75rem;
    border: 1px solid var(--clr-gray-200, #e0e0e0);
    border-radius: 0.375rem;
    font-size: var(--fs-400, 0.875rem);
    font-family: inherit;
    background: var(--clr-gray-50, #fafafa);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.search-sidebar__input:focus {
    outline: none;
    background: #ffffff;
    border-color: var(--clr-primary, #0066cc);
    box-shadow: 0 0 0 2px rgba(0, 102, 204, 0.1);
}

.search-sidebar__input::placeholder {
    color: var(--text-tertiary, #999);
}

/* Results container - scrollable within panel */
.search-sidebar__results {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0.5rem;
}

/* Section labels (e.g., "Individuals", "Groups") */
.search-sidebar__section-label {
    font-size: var(--fs-300, 0.8125rem);
    font-weight: 600;
    text-transform: uppercase;
    color: var(--text-tertiary, #999);
    letter-spacing: 0.05em;
    padding: 0.75rem 0.5rem 0.25rem 0.5rem;
    margin-top: 0.5rem;
}

.search-sidebar__section-label:first-of-type {
    margin-top: 0;
}

/* Navigation help text */
.search-sidebar__help-text {
    font-size: var(--fs-300, 0.8125rem);
    color: var(--text-secondary, #666);
    padding: 0.25rem 0.25rem 0.25rem 0.5rem;
    margin: 0.25rem 0;
    line-height: 1.4;
    border-left: 2px solid var(--clr-primary, #007bff);
}

/* Empty state message */
.search-sidebar__empty {
    padding: 1.5rem 0.5rem;
    color: var(--text-tertiary, #999);
    font-style: italic;
    text-align: center;
    font-size: var(--fs-300, 0.8125rem);
}

/* Individual search result item - matches chart node layout */
.search-result-item {
    display: flex;
    flex-direction: column;
    padding: 0.5rem 0.65rem;
    margin-bottom: 0.5rem;
    border-radius: 0.3rem;
    border: 1px solid var(--clr-gray-300, #e8e8e8);
    cursor: pointer;
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
    background: var(--clr-gray-50, #fafafa);
    user-select: none;
    gap: 0;
    font-family: var(--config-node-fg-ff, inherit);
}

.search-result-item:hover {
    background-color: #F8F9FA;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
    cursor: pointer;
}

.search-result-item.search-result-item--active {
    border: 2px solid var(--search-highlight-color, var(--clr-primary, #0066cc));
    font-weight: 500;
    box-shadow: 0 2px 6px rgba(0, 102, 204, 0.15);
}

/* Result item ID (top, right-aligned, small - matches chart node) */
.search-result-item__id {
    color: var(--text-tertiary, #999);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: var(--fs-300);
    text-align: end;
    min-height: 1.5rem;
    line-height: 1.5;
}

/* Result item name (prominent, right-aligned - matches chart node) */
.search-result-item__name {
    font-weight: 400;
    color: var(--text-primary, #333);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: var(--fs-400);
    text-align: end;
    min-height: 1.5rem;
    line-height: 1.5;
}

/* Result item footer row - HIDDEN */
.search-result-item__footer {
    display: none;
}

/* ID row container - left align badge, right align ID */
.search-result-item__id-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
}

/* Ancestor badge - star icon only */
.search-result-ancestor-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    color: var(--clr-warning, #ff9900);
    flex: 0 0 auto;
}

.search-result-ancestor-badge i {
    font-size: 0.9rem;
}

/* ID remains right-aligned, grows to fill space */
.search-result-item__id-row .search-result-item__id {
    flex: 1;
    text-align: end;
}

/* Group accordion item */
.search-group-item {
    border-radius: 0.2rem;
    margin-bottom: 0.25rem;
    overflow: hidden;
}

/* Group header (clickable accordion trigger) */
.search-group-item__header {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0.5rem;
    cursor: pointer;
    transition: background-color 0.15s ease;
    background: transparent;
    border: 1px solid var(--clr-gray-300, #e8e8e8);
    border-left: 3px solid var(--clr-gray-400, #ccc);
    border-radius: 0.2rem;
    user-select: none;
    font-size: var(--fs-400, 0.875rem);
}

.search-group-item__header:hover {
    background-color: #F8F9FA;
    cursor: pointer;
}

.accordion--expanded.search-group-item .search-group-item__header {
    background-color: var(--clr-gray-100, #f9f9f9);
}

/* Group node name */
.search-group-item__name {
    flex: 1;
    font-weight: 500;
    color: var(--text-primary, #333);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

/* Icon in group name */
.search-group-item__name i {
    flex-shrink: 0;
    font-size: var(--fs-500, 0.9375rem);
    color: var(--text-secondary, #666);
    margin-right: 0.3rem;
}

/* Label text in group name */
.search-group-item__label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Group match count badge */
.search-group-item__count {
    flex: 0 0 auto;
    background: var(--clr-gray-300, #ddd);
    color: var(--text-primary, #333);
    border-radius: 0.8rem;
    padding: 0.15rem 0.5rem;
    font-size: var(--fs-300, 0.8125rem);
    font-weight: 600;
    margin-left: 0.5rem;
}

/* Accordion chevron icon */
.search-group-item__chevron {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1rem;
    height: 1rem;
    margin-left: 0.25rem;
    font-size: var(--fs-400, 0.875rem);
    color: var(--text-tertiary, #666);
    transform: rotate(0deg);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Chevron rotation when expanded */
.accordion--expanded.search-group-item .search-group-item__chevron {
    transform: rotate(90deg);
}

/* Children list (hidden by default) */
.search-group-item__children {
    display: none;
    max-height: 0;
    opacity: 0;
    padding: 3px 0 0 0.5rem;
    overflow: hidden;
    position: relative;
    transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Left border indicator for group children - aligns with item bounds */
.search-group-item__children::before {
    content: '';
    position: absolute;
    left: 0;
    top: 3px;
    bottom: 0;
    width: 2px;
    background-color: var(--clr-gray-300, #e0e0e0);
}

/* Show children when group is expanded */
.accordion--expanded.search-group-item .search-group-item__children {
    display: block;
    max-height: 1000px;
    opacity: 1;
}

/* Add gap below expanded groups to separate from next individual result */
.accordion--expanded.search-group-item {
    margin-bottom: 1rem;
}

/* Child result items inside groups */
.search-group-item__children .search-result-item {
    padding: 0.4rem 0.5rem;
    margin-bottom: 0.2rem;
    font-size: var(--fs-400, 0.875rem);
}

/* Chart area container - now fills entire space since sidebar is floating */
.search-chart-area {
    flex: 1;
    min-width: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Pulse animation for highlighted nodes */
@keyframes search-node-pulse {
    0% {
        filter: drop-shadow(0 0 0 rgba(0, 102, 204, 0.5));
    }
    50% {
        filter: drop-shadow(0 0 8px rgba(0, 102, 204, 0.6));
    }
    100% {
        filter: drop-shadow(0 0 0 rgba(0, 102, 204, 0.3));
    }
}

/* Apply pulse animation to highlighted node body */
.search-highlight-pulse {
    animation: search-node-pulse 0.8s ease-out 1;
}

/* Accordion expanded state class (generic) */
.accordion--expanded {
    /* Used by AccordionItemController for toggle state */
}


/* Match reason badge */
.search-result-match-reason {
    margin-top: 0.35rem;
    margin-bottom: 0.1rem;
    font-size: 0.7rem;
}

.search-result-match-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: #4a90e2;
    color: white;
    padding: 0.2rem 0.5rem;
    border-radius: 0.2rem;
    font-weight: 600;
    font-size: 0.75rem;
    letter-spacing: 0.3px;
    word-break: break-word;
    flex: 1;
    min-width: 0;
    cursor: help;
}

.search-result-match-count {
    display: inline-block;
    background: rgba(255, 255, 255, 0.3);
    padding: 0 0.3rem;
    border-radius: 0.1rem;
    font-size: 0.65rem;
    font-weight: 700;
    margin-left: 0.2rem;
    white-space: nowrap;
}


/* All fields display */
.search-result-fields {
    margin-top: 0.4rem;
    padding-top: 0.4rem;
    border-top: 1px solid var(--clr-gray-200, #f0f0f0);
    font-size: 0.75rem;
}

.search-result-field {
    display: flex;
    margin-bottom: 0.2rem;
    color: var(--text-secondary, #666);
}

.search-result-field-label {
    font-weight: 500;
    color: var(--text-primary, #333);
    flex: 0 0 auto;
    min-width: 60px;
}

.search-result-field-value {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-left: 0.3rem;
    color: var(--text-secondary, #666);
}

