/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */

.form-control-blend {
  background-color: rgba(var(--bs-body-bg-rgb), 0.65);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.15);
  border-radius: var(--bs-border-radius);
  box-shadow: none;
  color: inherit;
  padding: var(--bs-form-control-padding-y, 0.5rem)
    var(--bs-form-control-padding-x, 0.75rem);
  transition: background-color 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.form-control-blend:hover {
  background-color: rgba(var(--bs-body-bg-rgb), 0.75);
  border-color: rgba(var(--bs-body-color-rgb), 0.25);
}

.form-control-blend:focus {
  background-color: rgba(var(--bs-body-bg-rgb), 0.85);
  border-color: rgba(var(--bs-primary-rgb), 0.4);
  box-shadow: inset 0 -2px 0 0 var(--bs-primary);
  outline: none;
}

.form-control-blend::placeholder {
  color: rgba(var(--bs-body-color-rgb), 0.5);
}

textarea.form-control-blend {
  overflow: hidden;
  resize: none;
}

.form-select-blend {
  background-color: rgba(var(--bs-body-bg-rgb), 0.65);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.15);
  border-radius: var(--bs-border-radius);
  box-shadow: none;
  color: inherit;
  min-height: calc(var(--bs-body-line-height) + (var(--bs-border-width) * 2) +
      (var(--bs-form-select-padding-y, 0.375rem) * 2));
  padding: var(--bs-form-select-padding-y, 0.375rem)
    var(--bs-form-select-padding-x, 0.75rem);
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-select-blend:hover {
  background-color: rgba(var(--bs-body-bg-rgb), 0.75);
  border-color: rgba(var(--bs-body-color-rgb), 0.25);
}

.form-select-blend:focus {
  background-color: rgba(var(--bs-body-bg-rgb), 0.85);
  border-color: rgba(var(--bs-primary-rgb), 0.4);
  box-shadow: inset 0 -2px 0 0 var(--bs-primary);
  outline: none;
}

.drag-handle {
  cursor: grab;
}

.drag-handle:active {
  cursor: grabbing;
}

.btn-align-input {
  padding-bottom: var(--bs-form-control-padding-y, 0.5rem);
  padding-top: var(--bs-form-control-padding-y, 0.5rem);
}

.kanban-column {
  min-height: 12rem;
  padding: 0.25rem;
}

.kanban-empty {
  border: 1px dashed rgba(var(--bs-body-color-rgb), 0.2);
  border-radius: var(--bs-border-radius);
  background-color: rgba(var(--bs-body-bg-rgb), 0.65);
}

.kanban-card {
  cursor: grab;
}

.kanban-card:active {
  cursor: grabbing;
}

.kanban-backlog-item {
  cursor: grab;
}

.kanban-backlog-item:active {
  cursor: grabbing;
}

.kanban-filter-menu {
  position: relative;
}

.kanban-filter-menu__button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.kanban-filter-menu__panel {
  background-color: var(--bs-body-bg);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.12);
  border-radius: var(--bs-border-radius);
  box-shadow: var(--bs-box-shadow-lg);
  left: 0;
  min-width: min(22rem, 100%);
  opacity: 0;
  padding: 1rem;
  pointer-events: none;
  position: absolute;
  top: 100%;
  width: 100%;
  transition: opacity 0.2s ease;
  z-index: 1055;
}

.kanban-filter-menu:hover .kanban-filter-menu__panel,
.kanban-filter-menu:focus-within .kanban-filter-menu__panel {
  opacity: 1;
  pointer-events: auto;
}

.markdown-content {
  color: inherit;
  line-height: 1.7;
}

.markdown-content p:last-child {
  margin-bottom: 0;
}

.markdown-content pre {
  background-color: rgba(var(--bs-body-bg-rgb), 0.85);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.15);
  border-radius: var(--bs-border-radius-sm);
  padding: 0.75rem;
  overflow-x: auto;
}

.markdown-content code {
  background-color: rgba(var(--bs-body-bg-rgb), 0.85);
  border-radius: var(--bs-border-radius-sm);
  font-size: 85%;
  padding: 0.125rem 0.25rem;
}

.ticket-tree__node:last-child {
  margin-bottom: 0;
}

.ticket-tree__toggle,
.ticket-tree__toggle-placeholder {
  align-items: center;
  display: inline-flex;
  height: 2rem;
  justify-content: center;
  min-width: 2rem;
}

.ticket-tree__toggle-icon {
  transition: transform 0.2s ease;
}

.ticket-tree__toggle[aria-expanded="true"] .ticket-tree__toggle-icon {
  transform: rotate(90deg);
}

.ticket-tree__children {
  border-left: 1px solid rgba(var(--bs-body-color-rgb), 0.1);
  margin-left: 1.5rem;
  padding-left: 1rem;
}

.mind-map {
  --mind-map-depth-0: #e6f0ff;
  --mind-map-depth-1: #ffe7d9;
  --mind-map-depth-2: #f4e9ff;
  --mind-map-depth-3: #ffeecf;
  --mind-map-depth-4: #d7f7e5;
  background: radial-gradient(circle at 30% 20%, rgba(112, 173, 255, 0.08), transparent 35%),
    radial-gradient(circle at 70% 40%, rgba(255, 202, 145, 0.12), transparent 38%),
    #fdf7f3;
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.08);
  border-radius: 1.5rem;
  overflow-x: auto;
  padding: 2rem;
}

.mind-map__branches {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
  position: relative;
}

.mind-map__node {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: min(19rem, 100%);
  position: relative;
}

.mind-map__node::before {
  background: rgba(var(--bs-body-color-rgb), 0.18);
  border-radius: 999px;
  content: "";
  height: 0.5rem;
  left: -1.25rem;
  position: absolute;
  top: 1.25rem;
  width: 1.75rem;
}

.mind-map__node[data-depth="0"]::before {
  display: none;
}

.mind-map__node::after {
  border: 2px solid rgba(var(--bs-body-color-rgb), 0.12);
  border-radius: 0.75rem;
  content: "";
  inset: 0.35rem -0.35rem -0.35rem 0.35rem;
  position: absolute;
  z-index: 0;
}

.mind-map__card {
  overflow: hidden;
  position: relative;
  width: 100%;
  z-index: 1;
}

.mind-map__card .kanban-card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.82));
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.08);
  border-radius: 1rem;
  box-shadow: 0 18px 35px rgba(17, 24, 39, 0.08);
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.mind-map__card .kanban-card:hover {
  box-shadow: 0 20px 40px rgba(17, 24, 39, 0.12);
  transform: translateY(-3px);
}

.mind-map__card .kanban-card::before {
  content: "";
  inset: 0;
  position: absolute;
  z-index: 0;
}

.mind-map__node[data-depth="0"] .mind-map__card .kanban-card::before {
  background: radial-gradient(circle at 20% 20%, rgba(104, 140, 255, 0.18), transparent 45%),
    radial-gradient(circle at 80% 70%, rgba(187, 129, 255, 0.16), transparent 48%);
}

.mind-map__node[data-depth="1"] .mind-map__card .kanban-card::before {
  background: radial-gradient(circle at 80% 20%, rgba(255, 169, 133, 0.22), transparent 52%),
    radial-gradient(circle at 25% 75%, rgba(255, 220, 178, 0.2), transparent 45%);
}

.mind-map__node[data-depth="2"] .mind-map__card .kanban-card::before {
  background: radial-gradient(circle at 70% 20%, rgba(180, 142, 255, 0.22), transparent 48%),
    radial-gradient(circle at 20% 70%, rgba(236, 209, 255, 0.2), transparent 45%);
}

.mind-map__node[data-depth="3"] .mind-map__card .kanban-card::before {
  background: radial-gradient(circle at 25% 25%, rgba(255, 205, 96, 0.2), transparent 50%),
    radial-gradient(circle at 80% 75%, rgba(255, 230, 171, 0.22), transparent 50%);
}

.mind-map__node[data-depth="4"] .mind-map__card .kanban-card::before,
.mind-map__node[data-depth="5"] .mind-map__card .kanban-card::before {
  background: radial-gradient(circle at 65% 35%, rgba(111, 207, 151, 0.2), transparent 50%),
    radial-gradient(circle at 30% 75%, rgba(210, 243, 226, 0.2), transparent 55%);
}

.mind-map__card .kanban-card .card-body {
  position: relative;
  z-index: 1;
}

.mind-map__card .kanban-card .btn {
  position: relative;
  z-index: 2;
}

.mind-map__card .kanban-card h2 {
  color: rgba(var(--bs-body-color-rgb), 0.92);
  font-weight: 700;
}

.mind-map__card .kanban-card .badge {
  border: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
  color: rgba(var(--bs-body-color-rgb), 0.9);
  font-weight: 600;
}

.mind-map__card .kanban-card .btn-outline-secondary {
  background-color: rgba(var(--bs-body-bg-rgb), 0.8);
  border-color: rgba(var(--bs-body-color-rgb), 0.15);
  color: rgba(var(--bs-body-color-rgb), 0.7);
}

.mind-map__actions {
  background-color: rgba(var(--bs-body-bg-rgb), 0.92);
  border-radius: 0 0 1rem 1rem;
  position: relative;
  z-index: 1;
}

.mind-map__actions .btn-sm {
  font-weight: 600;
}

.mind-map__inline-forms {
  max-width: 26rem;
}

.mind-map__inline-form .card-body {
  background: rgba(var(--bs-body-bg-rgb), 0.95);
}

.mind-map__inline-form {
  position: relative;
  z-index: 2;
}

.mind-map__inline-form .form-control {
  border-radius: 0.75rem;
}

.mind-map__inline-form .btn-primary {
  min-width: 7rem;
}

.mind-map__children {
  border-left: 2px dashed rgba(var(--bs-body-color-rgb), 0.16);
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin-left: 2rem;
  padding-left: 1.5rem;
  position: relative;
}

.mind-map__children::before {
  content: "";
  height: 100%;
  left: -2rem;
  position: absolute;
  top: 1.25rem;
  width: 2rem;
}
