/* Sidebar */
:root {
  --sidebar-inline-space: max(calc(var(--inline-space) * 1.5), 1vw);
  --sidebar-tools-height: calc(var(--block-space) + var(--btn-size) + (var(--block-space) * 2));
}

.sidebar__container {
  block-size: 100dvh;
  max-block-size: 100dvh;
  padding-block-end: var(--sidebar-tools-height);
}

.sidebar__tools {
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  inset: auto 0 0 0;
  padding-block: 0.75em;
  padding-inline: 0.75em;
  position: fixed;
  display: flex;
  align-items: center;
  gap: 0.5em;
  border-top: 1px solid rgba(255, 255, 255, 0.08);

  @media (min-width: 100ch) {
    inline-size: calc(var(--sidebar-width));
    inset-inline-start: auto;
  }
}

.sidebar__tool {
  display: flex;
  align-items: center;
  gap: 0.5em;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.7);
  padding: 0.25em;
  border-radius: 0.375em;

  &:hover {
    color: rgba(255, 255, 255, 0.9);
    background: rgba(255, 255, 255, 0.05);
  }

  .avatar {
    flex-shrink: 0;
    border: none !important;
    box-shadow: none !important;
  }
}

.sidebar__tool--profile {
  flex-grow: 1;
  min-width: 0;
}

.sidebar__tool-label {
  font-size: 0.85rem;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar__tool--settings {
  flex-shrink: 0;
  padding: 0.375em;
  border-radius: 0.375em;
  color: rgba(0, 0, 0, 0.4);
  opacity: 1;

  &:hover {
    color: rgba(0, 0, 0, 0.7);
  }
}

html[data-theme="dark"] .sidebar__tool--settings {
  color: rgba(255, 255, 255, 0.5);

  &:hover {
    color: rgba(255, 255, 255, 0.9);
  }
}

@media (prefers-color-scheme: dark) {
  html:not([data-theme="light"]) .sidebar__tool--settings {
    color: rgba(255, 255, 255, 0.5);

    &:hover {
      color: rgba(255, 255, 255, 0.9);
    }
  }
}

.sidebar--collapsed .sidebar__tool-label {
  display: none;
}

.sidebar--collapsed .sidebar__tools {
  flex-direction: column;
  align-items: center;
  padding-inline: 0.25em;
}

.sidebar__toggle {
  inset-block-start: var(--block-space-half);
  inset-inline-start: calc((var(--btn-size) + max(var(--inline-space), 1vw)) * -1);
  position: absolute;
  transition:
    inset-inline-start 300ms ease,
    border-color 300ms ease,
    background-color 300ms ease;
  z-index: 5;

  #sidebar:where(:not(.open):has(.unread)) & {
    &::after {
      --size: 1em;

      aspect-ratio: 1;
      background-color: var(--color-negative);
      block-size: var(--size);
      border-radius: calc(var(--size) * 2);
      content: "";
      flex-shrink: 0;
      inline-size: var(--size);
      inset-block-start: calc(var(--size) / -4);
      inset-inline-end: calc(var(--size) / -4);
      position: absolute;
    }
  }

  @media (min-width: 100ch) {
    display: none;
    inset-block-start: var(--block-space);
  }

  .open & {
    inset-block-start: var(--block-space);

    @media (max-width: 100ch) {
      inset-inline-start: var(--sidebar-inline-space);

      & img {
        filter: invert(0);
      }

      @media (prefers-color-scheme: dark) {
        html:not([data-theme="light"]):not([data-theme="dark"]) & img {
          filter: invert(100%);
        }
      }
    }
  }
}

@media (max-width: 100ch) {
  html[data-theme="dark"] .open .sidebar__toggle img {
    filter: invert(100%);
  }
}

/* Direct messsages */
.directs {
  --btn-border-color: var(--color-border-darker);
  --column-gap: calc(var(--inline-space) / 1.5);

  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  display: grid;
  grid-auto-columns: minmax(auto, max-content);
  grid-auto-flow: column;
  inset: 0 0 auto 0;
  justify-content: start;
  overscroll-behavior: auto;
  margin-block-end: var(--block-space-half);
  padding-block: var(--block-space) var(--block-space-half);
  padding-inline: var(--sidebar-inline-space) calc(var(--sidebar-inline-space) + var(--column-gap));
  position: sticky;
  z-index: 3;

  .open & {
    @media (max-width: 100ch) {
      -webkit-mask-image: linear-gradient(to left, oklch(0% 0 0 / 1) 85%, oklch(0% 0 0 / 0) 99%);
      mask-image: linear-gradient(to left, oklch(0% 0 0 / 1) 85%, oklch(0% 0 0 / 0) 99%);
      padding-inline-start: calc(var(--btn-size) + var(--sidebar-inline-space) + (var(--column-gap) * 2.5));
    }
  }

  &.directs--new {
    --column-gap: var(--inline-space);
    --row-gap: 2px;

    -webkit-mask-image: none;
    mask-image: none;
    padding-inline-end: var(--sidebar-inline-space);
  }
}

.directs--edit  {
  display: grid;
  gap: var(--inline-space);
  grid-template-columns: repeat(auto-fit, minmax(33%, 1fr));
  grid-template-rows: min-content;
  place-items: center;

  .member {
    aspect-ratio: 1;
    block-size: auto;
    inline-size: 100%;
    margin-inline: auto;
    place-content: center;
  }
}

.direct {
  border-radius: 0.3em;
  box-shadow: none;
  color: var(--color-text);
  display: grid;
  justify-items: center;
  position: relative;
  text-decoration: none;

  .avatar,
  .avatar__group {
    margin-inline: calc(var(--inline-space) / 1.5);

    .avatar {
      margin-inline: 0;
    }
  }

  @media (any-hover: hover) {
    &:where(:not(:active):hover) .avatar:not(.avatar--icon) {
      filter: brightness(0.7);
    }
  }

  &:focus-within,
  &:where(:not(:active)):focus-visible {
    outline: 0;
  }
}

.direct__new {
  margin-inline-end: var(--inline-space-half);

  .avatar {
    margin-inline: 0;
  }
}

.direct__author {
  --column-gap: 0.3ch;

  margin-block-start: 0.1em;

  .unread & {
    font-weight: 800;
    position: relative;

    &::after {
      --size: 0.6em;

      aspect-ratio: 1;
      background-color: var(--color-text);
      block-size: var(--size);
      border-radius: calc(var(--size) * 2);
      content: "";
      flex-shrink: 0;
      inline-size: var(--size);
      position: absolute;
      inset: 1.3em auto auto 50%;
      transform: translate(-50%);
    }
  }
}

/* Rooms */
.rooms {
  --column-gap: 0.5em;
  --row-gap: 0.5em;

  padding-inline: var(--sidebar-inline-space);
}

.rooms__new-btn {
  inset-block-end: calc((var(--sidebar-tools-height) * -1) + var(--block-space) * 1.5);
  position: sticky;
  z-index: 4;
}

.room {
  background-color: var(--color-text-reversed);
  color: var(--color-text);
  font-weight: normal;
  justify-content: start;
  margin-inline-end: auto;
  max-inline-size: 100%;

  .searches-list & {
    border-radius: 0.5em;
  }

  &.unread {
    --btn-border-color: var(--color-text);
    --hover-color: var(--color-text);

    font-weight: 600;

    &:not(:hover) {
      box-shadow: 0 0 0 1px var(--color-text);
    }
  }
}

.room--current {
  --btn-border-radius: 0.5em;
  --hover-filter: none;
  --num-buttons: 1;

  min-block-size: var(--btn-size);

  .room__contents {
    .account-has-logo & {
      --num-buttons: 2;
    }

    max-inline-size: calc(100dvw - (var(--btn-size) * var(--num-buttons)) - (var(--btn-size) + max(var(--inline-space), 1vw)) - ((var(--inline-space) + 1.8em) * 2) - var(--sidebar-width) - var(--inline-space) * var(--num-buttons));

    @media (max-width: 100ch) {
      --num-buttons: 2;

      .account-has-logo & {
        --num-buttons: 3;
      }
    }
  }
}

/* Searches */
.searches {
  #nav {
    align-items: start;
    column-gap: 0;
    padding-inline-end: 0;
  }

  .rooms {
    padding-block-start: var(--block-space);
  }

  .message--formatted .message__room {
    display: block;
    font-size: 0.8rem;
    font-weight: 400;
    overflow: hidden;
    text-overflow: ellipsis;
    visibility: visible;
    white-space: nowrap;

    &::before {
      content: "→";
    }

    .message--me & {
      &::after {
        content: "←";
      }

      &::before {
        content: "";
      }
    }
  }

  .message__actions {
    display: none !important;
    visibility: hidden !important;
  }
}

.searches__recents {
  --mask: linear-gradient(to left, oklch(0% 0 0 / 1) 97%, oklch(0% 0 0 / 0) 99%);

  -webkit-mask-image: var(--mask);
  display: none;
  mask-image: var(--mask);
  position: relative;

  @media (max-width: 100ch) {
    display: flex;
  }

  .room {
    max-inline-size: 20ch;

    &:first-child {
      margin-inline-start: var(--inline-space);
    }
  }

  .searches__btn {
    margin-inline-end: var(--inline-space-double);
  }
}

.searches__query {
  --btn-border-radius: 0.5em;

  min-block-size: var(--btn-size);
}

.searches__results {
  padding-block-start: var(--navbar-height);
}

.searches__input:required:invalid {
  ~ .searches__reset {
    display: none;
    visibility: hidden;
  }
}

/* Collapsible sidebar - icon rail */
.sidebar--collapsed {
  width: 48px !important;
  min-width: 48px !important;
  transition: width 0.2s ease, min-width 0.2s ease;
}

#sidebar {
  transition: width 0.2s ease, min-width 0.2s ease;
}

/* When sidebar is collapsed, shrink the grid column */
body:has(.sidebar--collapsed) {
  --sidebar-width: 48px !important;
}

.sidebar--collapsed .sidebar__container {
  overflow-x: hidden;
}

.sidebar--collapsed .rooms .room span,
.sidebar--collapsed .directs .direct__author,
.sidebar--collapsed .sidebar__tools .for-screen-reader,
.sidebar--collapsed .rooms__new-btn {
  display: none;
}

.sidebar--collapsed .rooms .room {
  justify-content: center;
  padding-inline: 0;
}

.sidebar--collapsed .directs {
  flex-direction: column;
  overflow-x: hidden;
  gap: 0.25em;
}

.sidebar--collapsed .directs .direct {
  justify-content: center;
}

.sidebar--collapsed .sidebar__tools {
  flex-direction: column;
  align-items: center;
}

.sidebar__collapse-icon {
  filter: invert(100%);
  opacity: 0.7;
  transition: transform 0.2s ease, opacity 0.15s ease;
}

.sidebar__collapse-toggle:hover .sidebar__collapse-icon {
  opacity: 1;
}

.sidebar--collapsed .sidebar__collapse-icon {
  transform: rotate(180deg);
}

.sidebar__collapse-toggle {
  --btn-border-radius: 0.375em;
  --btn-border-color: transparent;

  position: sticky;
  top: 0;
  z-index: 6;
  align-self: flex-start;
  margin: 0.75em 0 0.25em 0.75em;
  padding: 0.375em;
  background: rgba(255, 255, 255, 0.06);
  border: none;
  box-shadow: none;
  border-radius: 0.375em;
  transition: background 0.15s ease;

  &:hover {
    background: rgba(255, 255, 255, 0.12);
  }
}

.sidebar--collapsed .sidebar__collapse-toggle {
  align-self: center;
  margin-inline: auto;
}

/* Sidebar sections */
.sidebar__section {
  display: flex;
  flex-direction: column;
  gap: 0.125em;
  padding-block-start: 0.5em;
}

.sidebar__section + .sidebar__section {
  margin-block-start: 0.5em;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.sidebar__section-header {
  --btn-border-radius: 0.25em;

  display: flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.5em 0.75em;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  box-shadow: none;
}

.sidebar__section-header:hover {
  color: rgba(255, 255, 255, 0.8);
}

.sidebar__section-header:hover {
  opacity: 1;
}

.sidebar__section-arrow {
  font-size: 0.6em;
  transition: transform 0.15s ease;
}

.sidebar__section--collapsed .sidebar__section-arrow {
  transform: rotate(-90deg);
}

.sidebar__section-title {
  flex-grow: 1;
}

.sidebar__section-action {
  padding: 0.25em;
  opacity: 0.5;
}

.sidebar__section-action:hover {
  opacity: 1;
}

.sidebar__section-label {
  font-size: 0.8rem;
}

.sidebar__section-body {
  display: flex;
  flex-direction: column;
  gap: 0;

  .rooms__new-btn {
    --btn-border-color: transparent !important;
    --btn-border-radius: 0.375em;

    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    margin-inline: 0.5em;
    margin-block-start: 0.25em;
    opacity: 0.4;
    padding: 0.375em 0.5em;

    &:hover {
      opacity: 0.7;
      background: rgba(255, 255, 255, 0.05) !important;
    }
  }
}

.sidebar__section--collapsed .sidebar__section-body {
  /* Controlled by JS for unread peek-through */
}

/* Room wrapper with star on hover */
.sidebar__room-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  padding-inline: 0.5em;

  .room {
    --btn-border-radius: 0.375em;
    --btn-border-color: transparent;

    background: transparent;
    border-color: transparent;
    box-shadow: none;
    display: flex !important;
    align-items: center;
    padding: 0.375em 0.5em;
    gap: 0.5em;

    &:hover {
      background: rgba(255, 255, 255, 0.08);
    }

    &.unread {
      box-shadow: none;
      --btn-border-color: transparent;

      font-weight: 600;
    }

    .avatar {
      --avatar-size: 1.25em;

      flex-shrink: 0;
      border: none !important;
      box-shadow: none !important;
    }
  }
}

.sidebar__room-wrapper .room,
.sidebar__room-wrapper .direct {
  flex-grow: 1;
  min-width: 0;
}

.sidebar__star-btn {
  position: absolute;
  right: 1em;
  opacity: 0;
  padding: 0.25em 0.375em;
  font-size: 0.85rem;
  transition: opacity 0.15s ease;
  background: transparent;
  border: none;
  box-shadow: none;
  color: #e8c44a;
  cursor: pointer;
  border-radius: 0.25em;
}

.sidebar__room-wrapper:hover .sidebar__star-btn {
  opacity: 0.6;
}

.sidebar__star-btn:hover {
  opacity: 1 !important;
  background: rgba(255, 255, 255, 0.08);
}

.sidebar__star {
  font-size: 0.7rem;
  margin-left: auto;
  flex-shrink: 0;
}

.sidebar__star--active {
  color: #e8c44a;
}

/* Placeholder users in DMs section */
.sidebar__placeholders {
  opacity: 0.5;
  display: flex;
  flex-direction: column;
  gap: 0.125em;
}

.sidebar__placeholders:hover {
  opacity: 0.8;
}

/* Context menu */
.sidebar__context-menu {
  background: var(--color-surface);
  padding: 0.25em;
  min-width: 140px;
}

.sidebar__context-menu-item {
  width: 100%;
  text-align: left;
  padding: 0.5em 0.75em;
  font-size: 0.85rem;
  border-radius: 4px;
  cursor: pointer;
}

.sidebar__context-menu-item:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* Hide sections in collapsed sidebar */
.sidebar--collapsed .sidebar__section-header span:not(.sidebar__section-arrow),
.sidebar--collapsed .sidebar__section-action,
.sidebar--collapsed .sidebar__star-btn,
.sidebar--collapsed .sidebar__placeholders,
.sidebar--collapsed .sidebar__section-label {
  display: none;
}

/* Unread count pills */
.unread-pill {
  background-color: var(--unread-pill-color, #5b6eea);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 0.1em 0.45em;
  border-radius: 0.75em;
  min-width: 1.25em;
  text-align: center;
  line-height: 1.4;
  margin-left: auto;
  flex-shrink: 0;
}

/* DM rooms get orange pills */
.sidebar__room-wrapper .room[data-room-type="direct"] .unread-pill {
  --unread-pill-color: #e8815a;
}
