/************************************************************************************/
/******************************** 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-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;
      }
    }
  }

  .column-mapping-container {
    align-items: stretch;
    padding-bottom: 3rem;

    &[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);
    }

    /* 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);
      }

/*        select, input[type="text"] {
  font-size: var(--fs-300);
  padding: 0.25rem 0.3rem;
  border: 1px solid var(--clr-gray-300);
  border-radius: 0.2rem;
  max-width: 100% !important;
}
*/
      input[type="text"]:disabled {
        background-color: var(--clr-gray-100);
        cursor: not-allowed;
      }
    }

    .column-mapping--card-container, .column-mapping--preview {
      margin: auto;
      padding-block: 2rem;
      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 *****************************************/
/************************************************************************************/
