/*
* demo.css
* File include item demo only specific css only
******************************************************************************/

.menu .app-brand.demo {
  height: 64px;
}

.app-brand-logo.demo svg {
  width: 34px;
  height: 24px;
}

.app-brand-text.demo {
  font-size: 1.375rem;
}

/* ! For .layout-navbar-fixed added fix padding top to .layout-page */
/* Default navbar */
.layout-navbar-fixed .layout-wrapper:not(.layout-without-menu) .layout-page {
  padding-top: 64px !important;
}
.layout-navbar-fixed
  .layout-wrapper:not(.layout-horizontal):not(.layout-without-menu)
  .layout-page {
  padding-top: 72px !important;
}
/* Navbar page z-index issue solution */
.content-wrapper .navbar {
  z-index: auto;
}

/*
* Content
******************************************************************************/

.demo-blocks > * {
  display: block !important;
}

.demo-inline-spacing > * {
  margin: 1rem 0.375rem 0 0 !important;
}

/* ? .demo-vertical-spacing class is used to have vertical margins between elements. To remove margin-top from the first-child, use .demo-only-element class with .demo-vertical-spacing class. For example, we have used this class in forms-input-groups.html file. */
.demo-vertical-spacing > * {
  margin-top: 1rem !important;
  margin-bottom: 0 !important;
}
.demo-vertical-spacing.demo-only-element > :first-child {
  margin-top: 0 !important;
}

.demo-vertical-spacing-lg > * {
  margin-top: 1.875rem !important;
  margin-bottom: 0 !important;
}
.demo-vertical-spacing-lg.demo-only-element > :first-child {
  margin-top: 0 !important;
}

.demo-vertical-spacing-xl > * {
  margin-top: 5rem !important;
  margin-bottom: 0 !important;
}
.demo-vertical-spacing-xl.demo-only-element > :first-child {
  margin-top: 0 !important;
}

/* Dropdown buttons going out of small screens */
@media (max-width: 576px) {
  #dropdown-variation-demo .btn-group .text-truncate {
    width: 254px;
    position: relative;
  }
  #dropdown-variation-demo .btn-group .text-truncate::after {
    position: absolute;
    top: 45%;
    right: 0.65rem;
  }
}

/*
* Layout demo
******************************************************************************/

.layout-demo-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-top: 1rem;
}
.layout-demo-placeholder img {
  width: 900px;
}
.layout-demo-info {
  text-align: center;
  margin-top: 1rem;
}

/* testcases CSS */

.rotate-180 {
  transform: rotate(180deg);
  transition: transform 0.2s ease;
}

/* 전체 높이 계산: 100vh - 네비게이션(70px) - 상하여백(32px) - 푸터(54px) = 100vh - 156px */
:root {
  --nav-footer-total: 150px;
  --evaluation-height: 210px;
  --gap: 1rem;

  /* 좌측 트리 높이 */
  --total-height: calc(100vh - var(--nav-footer-total));

  /* 우측 상세+채팅 높이 = 전체 - 평가 - 간격 */
  --content-height: calc(var(--total-height) - var(--evaluation-height) - var(--gap));
}

/* 좌측 트리 카드 높이 */
.tree-wrap {
  position: sticky !important;
  top: 1rem !important;
  height: var(--total-height) !important;
  max-height: var(--total-height) !important;
  display: flex !important;
  flex-direction: column !important;
}

.tree-wrap .card-header {
  flex-shrink: 0 !important;
}

.tree-wrap .card-body.case-tree {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  min-height: 0 !important;
}

/* 우측 상세 + 채팅 영역 */
.right-content-wrap {
  height: var(--content-height) !important;
  max-height: var(--content-height) !important;
  margin-bottom: var(--gap) !important;
}

.right-content-wrap > .col-lg-7,
.right-content-wrap > .col-lg-5 {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

.right-content-wrap .card {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.right-content-wrap .card-header {
  flex-shrink: 0 !important;
}

.right-content-wrap .card-body {
  flex: 1 1 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  min-height: 0 !important;
}

/* 채팅 카드 특별 처리 */
.chat-wrap .card-body {
  display: flex !important;
  flex-direction: column !important;
}

.chat-area {
  flex: 1 1 0 !important;
  overflow-y: auto !important;
  min-height: 0 !important;
  margin-bottom: 1rem !important;
}

/* 평가 카드 높이 고정 */
.evaluation-card {
  height: 210px !important;
  margin-top: 31px !important;
}

/* 스크롤바 스타일링 */
.case-tree::-webkit-scrollbar,
.detail-content::-webkit-scrollbar,
.chat-area::-webkit-scrollbar {
  width: 6px;
}

.case-tree::-webkit-scrollbar-track,
.detail-content::-webkit-scrollbar-track,
.chat-area::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 10px;
}

.case-tree::-webkit-scrollbar-thumb,
.detail-content::-webkit-scrollbar-thumb,
.chat-area::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 10px;
}

.case-tree::-webkit-scrollbar-thumb:hover,
.detail-content::-webkit-scrollbar-thumb:hover,
.chat-area::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}

.bubble {
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  margin-bottom: 0.75rem;
  background: #f5f5f9;
}

.bubble.me {
  background: #e1f5fe;
}

.readbox {
  background: #fafafa;
  border: 1px solid #e3e6eb;
  padding: 0.75rem;
  border-radius: 0.5rem;
  min-height: 48px;
}
