/* Enhanced Checklist Sidebar Styles */

/* Sidebar Layout */
#selected-items-sidebar {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  background: var(--sidebar-bg, #f8f9fa);
  border-left: 1px solid var(--border-color, #dee2e6);
  padding: 20px;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  flex-basis: 45% !important;
  flex-grow: 1 !important;
  flex-shrink: 1 !important;
  box-sizing: border-box !important;
}

/* Header */
#selected-items-header {
  margin: 0 0 20px 0;
  padding: 8px 12px;
  background: var(--header-bg, #fff);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text-color, #333);
  cursor: text;
  transition: all 0.2s;
}

#selected-items-header:focus {
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 2px;
}

/* Toggle Controls */
.sidebar-toggle-group {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 4px !important;
  margin-bottom: 20px;
  justify-content: space-between;
  align-items: stretch;
}

/* Override forms.css to ensure buttons stay side-by-side */
#selected-items-sidebar .sidebar-toggle-group .feature-toggle-button {
  flex: 1 1 25% !important;
  width: auto !important;
  max-width: calc(25% - 3px) !important;
  display: flex !important;
  padding: 4px 6px;
  font-size: 0.75rem;
  gap: 4px;
}

/* Adjust Save as Prechecklist button specifically */
#selected-items-sidebar .save-prechecklist-btn span {
  white-space: normal;
  line-height: 1.2;
}

.feature-toggle-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 10px;
  background: var(--button-bg, #fff);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  color: var(--text-color, #495057);
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.85rem;
  flex: 1 1 33%;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.feature-toggle-button i {
  font-size: 1rem;
  width: 1.2em;
  text-align: center;
}

.feature-toggle-button:hover {
  background: var(--button-hover-bg, #f8f9fa);
  border-color: var(--primary-color, #007bff);
}

.feature-toggle-button.active {
  background: var(--primary-color, #007bff);
  border-color: var(--primary-color, #007bff);
  color: white;
}

/* Save Prechecklist Button - Make it stand out */
.save-prechecklist-btn {
  background: var(--success-color, #28a745) !important;
  border-color: var(--success-color, #28a745) !important;
  color: white !important;
  font-weight: 500;
}

.save-prechecklist-btn:hover {
  background: var(--success-hover, #218838) !important;
  border-color: var(--success-hover, #218838) !important;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(40, 167, 69, 0.3);
}

/* Adjust button text for medium screens */
@media (max-width: 1400px) {
  .feature-toggle-button {
    font-size: 0.75rem;
    padding: 6px 6px;
  }
  .feature-toggle-button span {
    font-size: 0.7rem;
  }
}

/* Hide button text on small screens to save space */
@media (max-width: 1200px) {
  .feature-toggle-button span {
    display: none;
  }
  .feature-toggle-button {
    padding: 8px 8px;
    flex: 1 1 auto;
    position: relative;
  }
  .feature-toggle-button:hover::after {
    content: attr(title);
    position: absolute;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.8);
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    white-space: nowrap;
    z-index: 1000;
  }
}

/* Selected Items Container */
#selected-items-container {
  flex-grow: 1;
  overflow-y: auto;
  padding-bottom: 0;
  width: 100%;
  box-sizing: border-box;
}

.checklist-disabled-message,
.empty-selection-message {
  text-align: center;
  padding: 40px 20px;
  color: var(--muted-text, #6c757d);
}

.checklist-disabled-message i,
.empty-selection-message i {
  font-size: 2rem;
  margin-bottom: 10px;
  display: block;
  color: var(--muted-text, #6c757d);
}

.empty-text {
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
}

.empty-description {
  font-size: 0.9rem;
  margin: 0;
  line-height: 1.4;
}

/* Selected Items List */
.selected-items-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Individual Checklist Item */
.selected-item {
  background: var(--item-bg, #fff);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 8px;
  padding: 12px;
  transition: all 0.2s;
}

.selected-item:hover {
  border-color: var(--primary-color, #007bff);
  box-shadow: 0 2px 8px rgba(0, 123, 255, 0.1);
}

.selected-item.show-details {
  border-color: var(--primary-color, #007bff);
  background: var(--expanded-item-bg, #f8f9ff);
}

.selected-item.has-note .item-name-row::after {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--futuristic-accent-warning, #f59e0b);
  border-radius: 50%;
  margin-left: 6px;
  box-shadow: 0 0 4px rgba(245, 158, 11, 0.6);
}

/* Hide the duplicate status-dot element in checklist sidebar */
#selected-items-sidebar .status-dot.has-note {
  display: none !important;
}

/* Inline note tabs styling for rich text editor toolbar */
.note-tabs-inline {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-right: 8px;
}

.note-tab-inline {
  padding: 4px 8px;
  background: transparent;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 4px;
  cursor: pointer;
  color: var(--text-color, #495057);
  font-size: 0.75rem;
  transition: all 0.2s;
  min-width: 40px;
}

.note-tab-inline:hover {
  background: var(--button-hover-bg, #f8f9fa);
  color: var(--primary-color, #007bff);
  border-color: var(--primary-color, #007bff);
}

.note-tab-inline.active {
  color: white;
  background: var(--primary-color, #007bff);
  border-color: var(--primary-color, #007bff);
}

.toolbar-separator {
  width: 1px;
  height: 20px;
  background: var(--border-color, #dee2e6);
  margin: 0 4px;
}

/* Adjust rich text editor for inline tabs */
.rich-text-editor {
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  overflow: hidden;
}

.rich-text-editor .editor-toolbar {
  display: flex;
  align-items: center;
  padding: 8px;
  background: var(--header-bg, #f8f9fa);
  border-bottom: 1px solid var(--border-color, #dee2e6);
}

/* Main Item Row */
.checklist-item-main-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.item-checkbox-column {
  flex-shrink: 0;
}

.item-checkbox {
  width: 18px;
  height: 18px;
  cursor: pointer;
}

.item-info-column {
  flex: 1;
  min-width: 0;
  overflow: hidden; /* Prevent content from breaking layout */
}

.item-name-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
}

.item-name {
  font-weight: 500;
  color: var(--text-color, #333);
  cursor: pointer;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: all 0.2s;
}

.item-name.completed {
  text-decoration: line-through;
  color: var(--muted-text, #6c757d);
}

.expand-details-btn {
  background: none;
  border: none;
  color: var(--muted-text, #6c757d);
  cursor: pointer;
  padding: 2px;
  border-radius: 3px;
  transition: all 0.2s;
  flex-shrink: 0;
}

.expand-details-btn:hover {
  background: var(--button-hover-bg, #f8f9fa);
  color: var(--primary-color, #007bff);
}

.expand-details-btn.expanded {
  transform: rotate(180deg);
  color: var(--primary-color, #007bff);
}

.item-quick-info {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: var(--muted-text, #6c757d);
  width: 100%;
  overflow: hidden; /* Prevent overflow */
}

.item-price-display {
  font-weight: 600;
  color: var(--success-color, #28a745);
  flex-shrink: 1; /* Allow shrinking if needed */
  min-width: 0; /* Allow shrinking below content */
}

/* Inline Editing Enhancements */
.item-price-display.editable-price {
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
  transition: all 0.2s ease;
}

.item-price-display.editable-price:hover {
  background: rgba(40, 167, 69, 0.1);
  transform: scale(1.05);
}

.item-quantity-display {
  font-size: 0.85rem;
}

.item-quantity-display.editable-quantity {
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
  transition: all 0.2s ease;
}

.item-quantity-display.editable-quantity:hover {
  background: rgba(0, 123, 255, 0.1);
  transform: scale(1.05);
}

/* Always-Editable Inputs */
.price-always-editable {
  width: 70px;
  padding: 2px 4px;
  border: 1px solid transparent;
  background: rgba(40, 167, 69, 0.05);
  color: var(--success-color, #28a745);
  font-size: inherit;
  text-align: center;
  font-weight: 600;
  cursor: pointer;
  border-radius: 3px;
  transition: all 0.2s ease;
}

.price-always-editable:hover {
  background: rgba(40, 167, 69, 0.1);
  border: 1px solid var(--success-color, #28a745);
}

.price-always-editable:focus {
  background: var(--input-bg, #fff);
  border: 1px solid var(--success-color, #28a745);
  color: var(--text-color, #333);
  outline: 2px solid var(--success-color, #28a745);
  outline-offset: 1px;
}

.quantity-wrapper {
  display: inline-flex;
  align-items: center;
  font-size: 0.85rem;
  color: var(--muted-text, #6c757d);
}

.quantity-prefix,
.quantity-suffix {
  color: var(--muted-text, #6c757d);
}

.quantity-always-editable {
  width: 30px;
  padding: 2px 2px;
  border: none;
  background: transparent;
  color: var(--muted-text, #6c757d);
  font-size: inherit;
  text-align: center;
  cursor: pointer;
  border-radius: 3px;
  transition: all 0.2s ease;
}

.quantity-always-editable:hover {
  background: rgba(108, 117, 125, 0.1);
  border: 1px solid var(--muted-text, #6c757d);
}

.quantity-always-editable:focus {
  background: var(--input-bg, #fff);
  border: 1px solid var(--primary-color, #007bff);
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 1px;
}

/* Legacy Inline Edit Inputs */
.price-edit-input,
.quantity-edit-input {
  width: 80px;
  padding: 2px 6px;
  border: 1px solid var(--primary-color, #007bff);
  border-radius: 3px;
  background: var(--input-bg, #fff);
  color: var(--text-color, #333);
  font-size: inherit;
  text-align: center;
  font-weight: 600;
}

.price-edit-input:focus,
.quantity-edit-input:focus {
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 1px;
}

/* Price Difference Indicator */
.price-difference {
  font-size: 0.8rem;
  font-weight: 500;
  padding: 2px 6px;
  border-radius: 12px;
  margin-left: 6px;
  display: inline-flex;
  align-items: center;
}

.price-difference.price-increase {
  background: rgba(220, 53, 69, 0.1);
  color: var(--danger-color, #dc3545);
}

.price-difference.price-decrease {
  background: rgba(40, 167, 69, 0.1);
  color: var(--success-color, #28a745);
}

/* Checklist specific pricing layout */
.checklist-pricing {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap; /* Prevent wrapping */
  justify-content: space-between;
  width: 100%;
}

/* Item Total Price - right aligned */
.item-total-price {
  margin-left: auto;
  flex-shrink: 0;
  padding-left: 8px;
  text-align: right;
  min-width: fit-content; /* Ensure it doesn't shrink below content */
  white-space: nowrap; /* Prevent text wrapping */
}

.item-total-price .total-amount {
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-color, #333);
  display: inline-block;
  white-space: nowrap;
}

.item-total-price .total-amount.has-discount {
  color: var(--success-color, #28a745);
}

/* Ensure total price stays right-aligned with long numbers */
.selected-item .item-quick-info {
  position: relative;
}

/* Force total to stay on the same line */
.item-quick-info > * {
  flex-shrink: 0; /* Prevent individual elements from shrinking */
}

/* Allow price and quantity area to shrink if needed */
.item-quick-info > *:not(.item-total-price) {
  flex-shrink: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Ensure discounts don't push total down */
.item-discount-display,
.discount-edit-group {
  max-width: 30%;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Discount Editing */
.item-discount-display.editable-discount {
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
  transition: all 0.2s ease;
  color: var(--danger-color, #dc3545);
  font-weight: 500;
}

.item-discount-display.editable-discount:hover {
  background: rgba(220, 53, 69, 0.1);
  transform: scale(1.05);
}

.item-discount-placeholder.editable-discount {
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
  transition: all 0.2s ease;
  color: var(--muted-text, #6c757d);
  font-size: 0.8rem;
  opacity: 0.7;
}

.item-discount-placeholder.editable-discount:hover {
  background: rgba(108, 117, 125, 0.1);
  opacity: 1;
  transform: scale(1.05);
}

.discount-edit-group {
  display: flex;
  align-items: center;
  gap: 2px;
}

.discount-prefix,
.discount-suffix {
  color: var(--danger-color, #dc3545);
}

.discount-type-toggle {
  color: var(--danger-color, #dc3545);
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
  transition: all 0.2s ease;
  font-weight: 500;
  user-select: none;
  min-width: 16px;
  text-align: center;
  display: inline-block;
}

.discount-type-toggle:hover {
  background: rgba(220, 53, 69, 0.1);
  transform: scale(1.1);
}

/* Legacy Discount Styles */
.discount-edit-input {
  width: 60px;
  padding: 2px 6px;
  border: 1px solid var(--danger-color, #dc3545);
  border-radius: 3px;
  background: var(--input-bg, #fff);
  color: var(--text-color, #333);
  font-size: inherit;
  text-align: center;
  font-weight: 500;
}

.discount-edit-input:focus {
  outline: 2px solid var(--danger-color, #dc3545);
  outline-offset: 1px;
}

.discount-type-select {
  padding: 2px 4px;
  border: 1px solid var(--danger-color, #dc3545);
  border-radius: 3px;
  background: var(--input-bg, #fff);
  color: var(--text-color, #333);
  font-size: inherit;
  cursor: pointer;
}

/* Quick Actions */
.item-quick-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.icon-button {
  background: none;
  border: none;
  color: var(--muted-text, #6c757d);
  cursor: pointer;
  padding: 6px;
  border-radius: 4px;
  transition: all 0.2s;
  font-size: 0.9rem;
}

.icon-button:hover {
  background: var(--button-hover-bg, #f8f9fa);
  color: var(--primary-color, #007bff);
}

.icon-button.active {
  background: var(--primary-color, #007bff);
  color: white;
}

.icon-button.danger:hover {
  background: var(--danger-color, #dc3545);
  color: white;
}

/* Note Area */
.checklist-note-area {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-color, #dee2e6);
}

.checklist-note-input {
  width: 100%;
  min-height: 60px;
  padding: 8px 12px;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  resize: vertical;
  font-family: inherit;
  font-size: 0.9rem;
}

.checklist-note-input:focus {
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 2px;
}

/* Cost Options */
.cost-options {
  position: static;
  margin-top: 15px;
  width: 100%;
  left: auto;
  right: auto;
  bottom: auto;
  border-top: 1px solid var(--futuristic-border-primary);
  padding-top: 15px;
  flex-shrink: 0;
}

#discount-area {
  border: none;
  border-radius: 0;
  overflow: visible;
}

.total-cost-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 20px;
  background: var(--primary-color, #007bff);
  color: white;
  cursor: pointer;
  font-weight: 600;
  font-size: 1.1rem;
  border-radius: 8px;
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 10px;
  transition: all 0.2s;
}

.total-cost-container:hover {
  background: var(--primary-hover-color, #0056b3);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 123, 255, 0.2);
}

.total-cost-value {
  font-size: 1.3rem;
  font-weight: 700;
}

.cost-breakdown {
  padding: 15px 20px;
  background: var(--item-bg, #fff);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 8px;
  margin-bottom: 10px;
}

.cost-line {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  padding: 4px 0;
}

.cost-line:last-child {
  margin-bottom: 0;
}

.total-line {
  border-top: 1px solid var(--border-color, #dee2e6);
  padding-top: 12px;
  margin-top: 12px;
  font-size: 1.1rem;
}

.cost-inputs {
  padding: 15px 20px;
  background: var(--highlight-bg, #f8f9fa);
  border-top: 1px solid var(--border-color, #dee2e6);
  display: flex;
  gap: 15px;
}

.cost-input-group {
  flex: 1;
}

.cost-input-group label {
  display: block;
  margin-bottom: 8px;
  font-weight: 500;
  color: var(--text-color, #333);
  font-size: 0.875rem;
}

.input-row {
  display: flex;
  gap: 4px;
  align-items: center;
}

.input-row input {
  flex: 1;
  padding: 8px 12px;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  font-size: 0.95rem;
}

.input-row select {
  width: 55px;
  padding: 8px;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  font-size: 0.9rem;
}

.input-suffix {
  font-weight: 500;
  color: var(--text-color, #666);
  font-size: 0.95rem;
  padding: 0 8px;
}

/* Responsive adjustments for cost inputs */
@media (max-width: 360px) {
  .cost-inputs {
    flex-direction: column;
    gap: 10px;
  }
}

/* Export Options */
#export-options {
  margin-top: 10px;
  border-top: none;
  padding-top: 0;
}
.export-dropdown {
  position: relative;
}

.export-button {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  background: var(--success-color, #28a745);
  color: white;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
  transition: all 0.2s;
}

.export-button:hover:not(:disabled) {
  background: var(--success-hover-color, #218838);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(40, 167, 69, 0.3);
}

.export-button:disabled {
  background: var(--muted-text, #6c757d);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.export-count {
  background: rgba(255, 255, 255, 0.2);
  padding: 2px 6px;
  border-radius: 12px;
  font-size: 0.85rem;
}

.dropdown-content {
  position: absolute;
  bottom: 100%;
  left: 0;
  right: 0;
  background: var(--item-bg, #fff);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 1000;
  margin-bottom: 8px;
  overflow: hidden;
}

.export-section {
  padding: 8px;
}

.export-section button {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: none;
  border: none;
  color: var(--text-color, #333);
  cursor: pointer;
  border-radius: 6px;
  transition: all 0.2s;
  text-align: left;
}

.export-section button:hover {
  background: var(--button-hover-bg, #f8f9fa);
  color: var(--primary-color, #007bff);
}

/* Responsive Design */
@media (max-width: 768px) {
  #selected-items-sidebar {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: 15px;
  }

  .checklist-item-main-row {
    flex-wrap: wrap;
  }

  .item-quick-actions {
    flex-wrap: wrap;
  }
}

/* Dark mode support */
.dark-mode {
  --sidebar-bg: #1a1a1a;
  --item-bg: #2d2d2d;
  --header-bg: #2d2d2d;
  --button-bg: #3d3d3d;
  --button-hover-bg: #4d4d4d;
  --text-color: #ffffff;
  --muted-text: #a0a0a0;
  --border-color: #404040;
  --expanded-item-bg: #2a2a3a;
  --highlight-bg: #3a3a3a;
  --input-bg: #2d3748;
  --dark-border-color: #4a5568;
  --dark-text-color: #ffffff;
}

.dark-mode .price-edit-input,
.dark-mode .quantity-edit-input {
  background: var(--input-bg, #2d3748);
  border-color: var(--dark-border-color, #4a5568);
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .item-price-display.editable-price:hover {
  background: rgba(77, 144, 254, 0.2);
}

.dark-mode .item-quantity-display.editable-quantity:hover {
  background: rgba(77, 144, 254, 0.2);
}

.dark-mode .discount-edit-input,
.dark-mode .discount-type-select {
  background: var(--input-bg, #2d3748);
  border-color: var(--danger-color, #e53e3e);
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .item-discount-display.editable-discount:hover {
  background: rgba(229, 62, 62, 0.2);
}

.dark-mode .item-discount-placeholder.editable-discount:hover {
  background: rgba(160, 160, 160, 0.2);
}

/* Dark mode support for always-editable inputs */
.dark-mode .price-always-editable {
  background: rgba(77, 144, 254, 0.1);
  color: var(--success-color, #4db8ff);
}

.dark-mode .price-always-editable:hover {
  background: rgba(77, 144, 254, 0.2);
  border-color: var(--success-color, #4db8ff);
}

.dark-mode .price-always-editable:focus {
  background: var(--input-bg, #2d3748);
  color: var(--dark-text-color, #ffffff);
  border-color: var(--success-color, #4db8ff);
}

.dark-mode .quantity-always-editable {
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .quantity-always-editable:focus {
  background: var(--input-bg, #2d3748);
}

.dark-mode .discount-prefix,
.dark-mode .discount-suffix {
  color: var(--danger-color, #e53e3e);
}

.dark-mode .discount-type-toggle {
  color: var(--danger-color, #e53e3e);
}

.dark-mode .discount-type-toggle:hover {
  background: rgba(229, 62, 62, 0.2);
}

/* Subcategory Header Styles */
.checklist-subcategory-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--subcategory-bg, #f0f0f0);
  border-radius: 6px;
  margin: 8px 0;
  font-weight: 500;
}

.subcategory-checkbox-wrapper {
  flex-shrink: 0;
}

.subcategory-checkbox {
  cursor: pointer;
}

.subcategory-title {
  color: var(--text-color, #333);
  font-size: 0.9rem;
}

.dark-mode .checklist-subcategory-header {
  background: var(--dark-subcategory-bg, #2d2d2d);
}

.dark-mode .subcategory-title {
  color: var(--dark-text-color, #ffffff);
}

/* Ensure all sidebar elements use full width */
#selected-items-sidebar h3,
#selected-items-sidebar .sidebar-toggle-group,
#selected-items-sidebar .cost-options,
#selected-items-sidebar #export-options,
#selected-items-sidebar .selected-items-list,
#selected-items-sidebar #checklist-progress-section,
#selected-items-sidebar #selected-items-header,
#selected-items-sidebar .item-list-entry,
#selected-items-sidebar .selected-item {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* Subcategory group styling */
.checklist-subcategory-group {
  margin-left: 20px;
  margin-top: 12px;
  padding-left: 12px;
  border-left: 2px solid var(--border-color, #dee2e6);
}

.subcategory-items-list {
  list-style: none;
  padding: 0;
  margin: 8px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.subcategory-item {
  margin-left: 20px;
}

/* Category header in checklist */
.checklist-category-header {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--primary-color, #007bff);
  padding: 8px 0;
  margin: 12px 0 8px 0;
  border-bottom: 1px solid var(--border-color, #dee2e6);
}

.checklist-category-group:first-child .checklist-category-header {
  margin-top: 0;
}

/* Dark mode support for subcategory groups */
.dark-mode .checklist-subcategory-group {
  border-left-color: var(--dark-border-color, #4a5568);
}

.dark-mode .checklist-category-header {
  color: var(--primary-color, #4facfe);
  border-bottom-color: var(--dark-border-color, #4a5568);
}

/* Date Label Configuration */
.date-labels-config {
  margin-bottom: 15px;
  padding: 10px;
  background: var(--item-bg, #f8f9fa);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
}

/* Bulk Date Update Section */
.bulk-date-update {
  margin-top: 10px;
  margin-bottom: 15px;
  padding: 12px;
  background: var(--highlight-bg, #f0f4f8);
  border: 1px solid var(--primary-color, #007bff);
  border-radius: 6px;
}

.bulk-update-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-color, #333);
  margin: 0 0 10px 0;
}

.bulk-date-fields {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.bulk-date-field {
  flex: 1;
  min-width: 140px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.bulk-date-input {
  width: 100%;
  padding: 6px 8px;
  border: 1px solid var(--primary-color, #007bff);
  border-radius: 4px;
  font-size: 0.85rem;
  background: var(--input-bg, #fff);
  color: var(--text-color, #333);
  cursor: pointer;
}

.bulk-date-input:hover {
  border-color: var(--primary-hover-color, #0056b3);
  box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.1);
}

.bulk-date-input:focus {
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 1px;
}

.bulk-date-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.clear-all-dates-btn {
  padding: 6px 12px;
  background: var(--danger-color, #dc3545);
  color: white;
  border: none;
  border-radius: 4px;
  font-size: 0.85rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s;
}

.clear-all-dates-btn:hover {
  background: var(--danger-hover-color, #c82333);
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(220, 53, 69, 0.3);
}

.clear-all-dates-btn i {
  font-size: 0.9rem;
}

.date-label-field {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.date-label-field:last-child {
  margin-bottom: 0;
}

.date-label-field label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-color, #333);
  min-width: 90px;
}

.date-label-input {
  flex: 1;
  padding: 4px 8px;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 4px;
  font-size: 0.85rem;
  background: var(--input-bg, #fff);
  color: var(--text-color, #333);
}

.date-label-input:focus {
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 1px;
}

/* Date Fields on Checklist Items */
.checklist-date-fields {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-color, #dee2e6);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.date-field-wrapper {
  flex: 1;
  min-width: 140px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.date-field-label {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--text-color, #333);
}

.date-field-input {
  padding: 6px 8px;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 4px;
  font-size: 0.85rem;
  background: var(--input-bg, #fff);
  color: var(--text-color, #333);
  cursor: pointer;
}

.date-field-input:hover {
  border-color: var(--primary-color, #007bff);
}

.date-field-input:focus {
  outline: 2px solid var(--primary-color, #007bff);
  outline-offset: 1px;
}

/* Dark mode support for date fields */
.dark-mode .date-labels-config {
  background: var(--item-bg, #2d2d2d);
  border-color: var(--dark-border-color, #4a5568);
}

.dark-mode .date-label-field label,
.dark-mode .date-field-label {
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .date-label-input,
.dark-mode .date-field-input {
  background: var(--input-bg, #2d3748);
  border-color: var(--dark-border-color, #4a5568);
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .date-label-input:focus,
.dark-mode .date-field-input:focus {
  border-color: var(--primary-color, #4facfe);
}

.dark-mode .checklist-date-fields {
  border-top-color: var(--dark-border-color, #4a5568);
}

/* Dark mode support for bulk date update */
.dark-mode .bulk-date-update {
  background: var(--dark-highlight-bg, #2a3a4a);
  border-color: var(--primary-color, #4facfe);
}

.dark-mode .bulk-update-title {
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .bulk-date-input {
  background: var(--input-bg-dark, #2d3748);
  border-color: var(--primary-color, #4facfe);
  color: var(--dark-text-color, #ffffff);
}

.dark-mode .bulk-date-input:hover {
  border-color: var(--primary-hover-color, #3498db);
  box-shadow: 0 0 0 2px rgba(79, 172, 254, 0.2);
}

.dark-mode .bulk-date-input:focus {
  border-color: var(--primary-color, #4facfe);
  outline-color: var(--primary-color, #4facfe);
}

.dark-mode .clear-all-dates-btn {
  background: var(--danger-color, #e53e3e);
}

.dark-mode .clear-all-dates-btn:hover {
  background: var(--danger-hover-color, #c53030);
  box-shadow: 0 2px 4px rgba(229, 62, 62, 0.3);
}

/* Export menu positioning fixes */
#export-menu {
  /* Position the menu above the button */
  top: auto; /* Remove top positioning */
  bottom: 100%; /* Position bottom of menu at top of button */
  margin-bottom: 6px; /* Add spacing between button and menu */

  position: absolute;
  left: 0;
  right: auto; /* Allow left alignment */
  width: 260px; /* Specific width */
  z-index: 1010; /* Ensure above other elements */

  /* Add animation */
  animation: slideUpFadeIn 0.2s ease-out;
}

/* Show the menu when dropdown is active */
.export-dropdown.active #export-menu {
  display: block;
}

@keyframes slideUpFadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
