/* PaperTale - Main Styles */

:root {
  /* Item type colors */
  --color-bug: #dc3545;
  --color-task: #0d6efd;
  --color-epic: #6f42c1;
  --color-test: #198754;
  --color-test-plan: #fd7e14;

  /* Light theme colors */
  --bg-primary: #ffffff;
  --bg-secondary: #f8f9fa;
  --bg-tertiary: #e9ecef;
  --text-primary: #212529;
  --text-secondary: #6c757d;
  --border-color: #dee2e6;
  --card-shadow: rgba(0, 0, 0, 0.075);
  --card-shadow-hover: rgba(0, 0, 0, 0.15);
}

[data-theme="dark"] {
  /* Dark theme colors */
  --bg-primary: #1a1d23;
  --bg-secondary: #22252b;
  --bg-tertiary: #2b2f36;
  --text-primary: #e9ecef;
  --text-secondary: #adb5bd;
  --border-color: #495057;
  --card-shadow: rgba(0, 0, 0, 0.3);
  --card-shadow-hover: rgba(0, 0, 0, 0.5);

  /* Bootstrap overrides for dark mode */
  --bs-body-bg: #1a1d23;
  --bs-body-color: #e9ecef;
  --bs-link-color: #5ea3f7;
  --bs-link-hover-color: #8bbffa;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
}

/* Typography */
.mono {
  font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
}

/* Item type badges */
.badge-item-type {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.badge-bug {
  background-color: var(--color-bug);
}

.badge-task {
  background-color: var(--color-task);
}

.badge-epic {
  background-color: var(--color-epic);
}

.badge-test {
  background-color: var(--color-test);
}

.badge-test-plan,
.badge-test_plan {
  background-color: var(--color-test-plan);
}

/* Priority badges */
.badge-priority-critical {
  background-color: #dc3545;
}

.badge-priority-high {
  background-color: #fd7e14;
}

.badge-priority-medium {
  background-color: #ffc107;
  color: #000;
}

.badge-priority-low {
  background-color: #6c757d;
}

/* Status badges */
.badge-status {
  font-size: 0.75rem;
}

/* Cards */
.card {
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  transition: box-shadow 0.2s;
}

.card:hover {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.card-link {
  text-decoration: none;
  color: inherit;
}

.card-link:hover {
  color: inherit;
}

/* Tables */
.table-hover tbody tr {
  cursor: pointer;
}

/* Breadcrumbs */
.breadcrumb {
  background-color: transparent;
  padding-left: 0;
}

/* Navigation */
.navbar-brand i {
  font-size: 1.5rem;
}

.nav-link i {
  margin-right: 0.25rem;
}

.nav-link.active {
  font-weight: 600;
}

/* Footer */
footer a {
  color: #6c757d;
  text-decoration: none;
}

footer a:hover {
  color: #0d6efd;
  text-decoration: underline;
}

/* Loading states */
#loading {
  min-height: 200px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/* Markdown Editor */
.markdown-editor .nav-tabs {
  border-bottom: 0;
}

.markdown-editor .nav-link {
  color: #6c757d;
  border: 1px solid #dee2e6;
  border-bottom: 0;
  background-color: #f8f9fa;
}

.markdown-editor .nav-link.active {
  color: #495057;
  background-color: #fff;
  border-color: #dee2e6;
}

.markdown-editor .tab-content {
  background-color: #fff;
}

.markdown-editor textarea {
  border: 0;
  resize: vertical;
  font-size: 0.9rem;
}

.markdown-editor textarea:focus {
  outline: none;
  box-shadow: none;
}

.markdown-editor .btn-toolbar {
  border-bottom: 1px solid #dee2e6;
  padding-bottom: 0.5rem;
}

.markdown-editor .btn-group .btn {
  padding: 0.25rem 0.5rem;
}

.markdown-preview {
  min-height: 200px;
  max-height: 400px;
  overflow-y: auto;
}

.markdown-preview pre {
  background-color: #f8f9fa;
  padding: 1rem;
  border-radius: 0.375rem;
  border: 1px solid #dee2e6;
}

.markdown-preview code {
  background-color: #f8f9fa;
  padding: 0.2rem 0.4rem;
  border-radius: 0.25rem;
  font-size: 0.875em;
}

.markdown-preview pre code {
  background-color: transparent;
  padding: 0;
}

.markdown-preview blockquote {
  border-left: 4px solid #dee2e6;
  padding-left: 1rem;
  margin-left: 0;
  color: #6c757d;
}

.markdown-preview img {
  max-width: 100%;
  height: auto;
}

.markdown-preview table {
  width: 100%;
  margin-bottom: 1rem;
  border-collapse: collapse;
}

.markdown-preview table th,
.markdown-preview table td {
  padding: 0.5rem;
  border: 1px solid #dee2e6;
}

.markdown-preview table th {
  background-color: #f8f9fa;
  font-weight: 600;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .card {
    margin-bottom: 1rem;
  }

  .table-responsive {
    font-size: 0.875rem;
  }

  .navbar-brand {
    font-size: 1rem;
  }

  .markdown-editor .btn-toolbar {
    flex-wrap: wrap;
  }

  .markdown-editor .btn-group {
    margin-bottom: 0.25rem;
  }
}

/* Dark mode specific styles */
[data-theme="dark"] {
  color-scheme: dark;
}

[data-theme="dark"] body {
  background-color: var(--bg-primary);
  color: var(--text-primary);
}

[data-theme="dark"] .card {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .card:hover {
  box-shadow: 0 0.5rem 1rem var(--card-shadow-hover);
}

[data-theme="dark"] .card-header {
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .card-body {
  background-color: var(--bg-secondary);
  color: var(--text-primary);
}

[data-theme="dark"] .card-footer {
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
  color: var(--text-secondary);
}

[data-theme="dark"] .table {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > * {
  --bs-table-bg-type: var(--bg-secondary);
  color: var(--text-primary);
}

[data-theme="dark"] .table-hover > tbody > tr:hover > * {
  --bs-table-hover-bg: var(--bg-tertiary);
  color: var(--text-primary);
}

[data-theme="dark"] .breadcrumb {
  background-color: transparent;
}

[data-theme="dark"] .breadcrumb-item,
[data-theme="dark"] .breadcrumb-item a {
  color: var(--text-secondary);
}

[data-theme="dark"] .breadcrumb-item.active {
  color: var(--text-primary);
}

[data-theme="dark"] .navbar {
  background-color: var(--bg-secondary) !important;
  border-bottom: 1px solid var(--border-color);
}

[data-theme="dark"] .nav-link {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .nav-link.active,
[data-theme="dark"] .nav-link:hover {
  color: var(--text-primary) !important;
}

[data-theme="dark"] footer {
  background-color: var(--bg-secondary);
  border-top: 1px solid var(--border-color);
  color: var(--text-secondary);
}

[data-theme="dark"] footer a {
  color: var(--text-secondary);
}

[data-theme="dark"] footer a:hover {
  color: var(--bs-link-color);
}

[data-theme="dark"] .markdown-editor .nav-link {
  color: var(--text-secondary);
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
}

[data-theme="dark"] .markdown-editor .nav-link.active {
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
}

[data-theme="dark"] .markdown-editor .tab-content {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
}

[data-theme="dark"] .markdown-editor textarea {
  background-color: var(--bg-secondary);
  color: var(--text-primary);
}

[data-theme="dark"] .markdown-preview pre {
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .markdown-preview code {
  background-color: var(--bg-tertiary);
  color: var(--text-primary);
}

[data-theme="dark"] .markdown-preview pre code {
  background-color: transparent;
}

[data-theme="dark"] .markdown-preview blockquote {
  border-left-color: var(--border-color);
  color: var(--text-secondary);
}

[data-theme="dark"] .markdown-preview table th,
[data-theme="dark"] .markdown-preview table td {
  border-color: var(--border-color);
}

[data-theme="dark"] .markdown-preview table th {
  background-color: var(--bg-tertiary);
}

[data-theme="dark"] .modal-content {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
  border-color: var(--border-color);
}

[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  background-color: var(--bg-tertiary);
  border-color: #5ea3f7;
  color: var(--text-primary);
}

[data-theme="dark"] .form-control::placeholder {
  color: var(--text-secondary);
  opacity: 0.6;
}

[data-theme="dark"] .btn-close {
  filter: invert(1) grayscale(100%) brightness(200%);
}

[data-theme="dark"] .form-label,
[data-theme="dark"] label {
  color: var(--text-primary);
}

[data-theme="dark"] .text-muted {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] small,
[data-theme="dark"] .small {
  color: var(--text-secondary);
}

[data-theme="dark"] .table thead {
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table thead th {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table tbody td {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .bg-light {
  background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] .border-top {
  border-top-color: var(--border-color) !important;
}

[data-theme="dark"] .alert {
  background-color: var(--bg-tertiary);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .alert-danger {
  background-color: rgba(220, 53, 69, 0.2);
  border-color: rgba(220, 53, 69, 0.4);
  color: #f8d7da;
}

[data-theme="dark"] .alert-success {
  background-color: rgba(25, 135, 84, 0.2);
  border-color: rgba(25, 135, 84, 0.4);
  color: #d1e7dd;
}

[data-theme="dark"] .alert-info {
  background-color: rgba(13, 202, 240, 0.2);
  border-color: rgba(13, 202, 240, 0.4);
  color: #cff4fc;
}

[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
  color: var(--text-primary);
}

[data-theme="dark"] dt {
  color: var(--text-secondary);
}

[data-theme="dark"] dd {
  color: var(--text-primary);
}

/* Theme toggle button */
#theme-toggle {
  cursor: pointer;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  font-size: 1.25rem;
  padding: 0.5rem;
  transition: color 0.2s;
}

#theme-toggle:hover {
  color: var(--text-primary);
}
