/* Basic styling for the file navigation system */

/* Overall container */
.file-navigator {
  font-family: var(--bs-font-sand-serif);
  max-width: 100%;
  margin: 0;
  padding: 0;
  color: var(--bs-light);
  background-color: var(--bs-dark);
  /* border-radius: 0.375rem; */
  border: 1px solid var(--bs-gray-700);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

/* Tree structure */
.tree-node {
  margin: 0;
  padding: 0;
}

/* Header for directories */
.node-header {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  cursor: pointer;
  border-bottom: 1px solid var(--bs-gray-800);
  transition: background-color 0.2s;
}

.node-header:hover {
  background-color: var(--bs-gray-800);
}

.node-header.expanded {
  background-color: var(--bs-gray-700);
  font-weight: 500;
}

/* Icons */
.folder-icon {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  margin-right: 0.5rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23757575' d='M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8l-2-2z'/%3E%3C/svg%3E");
  background-size: contain;
  transition: transform 0.2s;
}

.node-header.expanded .folder-icon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%234285F4' d='M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8l-2-2z'/%3E%3C/svg%3E");
  transform: rotate(0);
}

.file-icon {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  margin-right: 8px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23757575' d='M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z'/%3E%3C/svg%3E");
  background-size: contain;
}

/* Directory content */
.node-content {
  display: none;
  padding: 0 0 0 1.25rem;
  background-color: var(--bs-dark);
}

.node-header.expanded + .node-content {
  display: block;
}

/* Directory name */
.directory-name {
  flex-grow: 1;
  font-weight: 500;
  color: var(--bs-light);
}

/* Item count */
.item-count {
  font-size: 0.8em;
  color: var(--bs-gray-800);
  margin-left: 0.75rem;
}

/* Files container */
.files-container {
  margin: 0.75rem 0;
}

.files-list {
  list-style-type: none;
  padding: 0;
  margin: 0;
}

/* File items */
.file-item {
  display: flex;
  align-items: center;
  padding: 0.5rem 0.75rem;
  /* border-radius: 0.25rem; */
  margin-bottom: 0.125rem;
  transition: background-color 0.2s;
}

.file-item:hover {
  background-color: var(--bs-gray-800);
}

/* File name */
.file-name {
  flex-grow: 1;
  color: var(--bs-gray-300);
}

/* File details */
.file-details {
  font-size: 0.8em;
  color: var(--bs-gray-500);
  white-space: nowrap;
}

.file-highlight {
  background-color: var(--bs-indigo);
  border-left: 3px solid var(--bs-purple);
}

.file-highlight .file-name {
  color: white;
  font-weight: 500;
}

.file-highlight:hover {
  background-color: var(--bs-indigo);
}

/* Responsive design */
/*
@media (max-width: 768px) {
  .node-header {
    padding: 12px 10px;
  }

  .file-details {
    display: none;
  }
}
*/

/* Animation for expanding/collapsing */
.node-content {
  transition: all 0.3s ease-out;
  overflow: hidden;
}

/* Top level header styling */
.file-navigator > .tree-node > .node-header {
  background-color: var(--bs-gray-800);
  /* border-top-left-radius: 0.375rem;
  border-top-right-radius: 0.375rem; */
  font-weight: 600;
}
