/* PromptManager Styles */

.loading-container,
.error-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  text-align: center;
}

.search-container {
  background: var(--ion-background-color, #ffffff);
  border-bottom: 1px solid var(--ion-color-light, #f4f5f8);
}

.filters-container {
  background: var(--ion-color-light, #f8f9fa);
  border-radius: 8px;
  margin: 8px;
  border: 1px solid var(--ion-color-step-200, #e0e0e0);
}

/* Filter Header Styles */
.filter-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  padding: 16px 16px 0 16px;
}

.filter-header h3 {
  margin: 0;
  color: var(--ion-color-dark, #222428);
  font-size: 18px;
  font-weight: 600;
}

.filter-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.filter-header-actions ion-button {
  --color: var(--ion-color-medium, #92949c);
  --padding-start: 8px;
  --padding-end: 8px;
  height: 32px;
}

.filter-header-actions ion-button:hover {
  --color: var(--ion-color-primary, #3880ff);
}

.reset-button {
  --color: var(--ion-color-danger, #eb445a) !important;
}

.reset-button:hover {
  --color: var(--ion-color-danger-shade, #d33d4c) !important;
}

/* Filter Count Badge */
.filter-count-badge {
  background: var(--ion-color-primary, #3880ff);
  color: white;
  border-radius: 12px;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 600;
  margin-left: 4px;
  min-width: 20px;
  text-align: center;
}

/* Filter Items */
.filter-item {
  --background: transparent;
  --color: var(--ion-color-dark, #222428);
  --detail-icon-color: var(--ion-color-medium, #92949c);
  margin: 0 8px 8px 8px;
  border-radius: 8px;
}

.filter-item ion-label {
  color: var(--ion-color-dark, #222428);
  font-weight: 500;
}

.filter-item ion-select {
  --color: var(--ion-color-dark, #222428);
  --placeholder-color: var(--ion-color-medium, #92949c);
}

/* Favorites Filter Item */
.favorites-filter-item {
  --background: transparent;
  --color: var(--ion-color-dark, #222428);
  margin: 0 8px 8px 8px;
  border-radius: 8px;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.favorites-filter-item:hover {
  --background: var(--ion-color-step-50, #f7f7f7);
}

.favorites-filter-item.active {
  --background: var(--ion-color-danger-tint, #f25454);
  --color: white;
}

.favorites-filter-item.active ion-label {
  color: white;
}

/* Active Filter Summary */
.active-filter-summary {
  margin-top: 16px;
  margin-bottom: 8px;
  padding: 14px 16px;
  background: var(--ion-color-light, #f8f9fa);
  border-radius: 10px;
  border-left: 4px solid var(--ion-color-primary, #3880ff);
  animation: slideIn 0.3s ease-out;
}

.active-filter-summary p {
  margin: 0;
  font-size: 14px;
  color: var(--ion-color-dark, #222428);
  line-height: 1.5;
}

.active-filter-summary .filter-count {
  font-weight: 600;
  color: var(--ion-color-primary, #3880ff);
}

.active-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.active-filter-chips ion-chip {
  --background: var(--ion-color-primary, #3880ff);
  --color: white;
  font-size: 12px;
  height: 26px;
  font-weight: 500;
  border-radius: 13px;
}

.active-filter-chips ion-chip[color="danger"] {
  --background: var(--ion-color-danger, #eb445a);
}

/* Clear Filters Button in Empty State */
.clear-filters-button {
  margin-top: 12px;
  --border-width: 2px;
  --border-color: var(--ion-color-primary, #3880ff);
  --color: var(--ion-color-primary, #3880ff);
}

.clear-filters-button:hover {
  --background: var(--ion-color-primary-tint, #4c8dff);
  --color: white;
}

.empty-state {
  text-align: center;
  margin: 40px 0;
}

.empty-state h3 {
  color: var(--ion-color-medium, #92949c);
  margin-bottom: 8px;
}

.empty-state p {
  color: var(--ion-color-medium, #92949c);
  font-size: 14px;
  line-height: 1.4;
}

/* Prompt Card Styles */
.prompt-card {
  margin: 12px 16px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  transition: all 0.2s ease;
}

.prompt-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 8px;
}

.prompt-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--ion-color-dark, #222428);
  line-height: 1.3;
  margin-bottom: 8px;
  flex: 1;
  margin-right: 8px;
}

.prompt-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.prompt-content {
  color: var(--ion-color-dark, #222428);
  line-height: 1.5;
  margin-bottom: 12px;
  font-size: 14px;
}

.prompt-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
  align-items: center;
}

.prompt-tags ion-chip {
  font-size: 12px;
  font-weight: 500;
  height: 28px;
  min-width: auto;
  --border-radius: 14px;
  --background: transparent;
  --color: var(--ion-color-primary, #3880ff);
  border: 1px solid var(--ion-color-primary, #3880ff);
  box-shadow: none;
  transition: all 0.2s ease;
  margin: 3px;
  padding: 0 10px;
}

.prompt-tags ion-chip:hover {
  --background: var(--ion-color-primary-tint, rgba(56, 128, 255, 0.1));
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(56, 128, 255, 0.2);
  border-color: var(--ion-color-primary-shade, #3171e0);
}

/* Dark mode tag styling */
@media (prefers-color-scheme: dark) {
  .prompt-tags ion-chip {
    --color: var(--ion-color-primary, #428cff);
    border-color: var(--ion-color-primary, #428cff);
  }
  
  .prompt-tags ion-chip:hover {
    --background: rgba(66, 140, 255, 0.15);
    box-shadow: 0 2px 4px rgba(66, 140, 255, 0.3);
    border-color: var(--ion-color-primary-shade, #3a7be0);
  }
}

.prompt-actions {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
  border-top: 1px solid var(--ion-color-light, #f4f5f8);
  padding-top: 8px;
}

.prompt-stats {
  color: var(--ion-color-medium, #92949c);
  font-size: 12px;
}

.rating {
  display: flex;
  align-items: center;
  gap: 2px;
}

.rating ion-icon {
  font-size: 16px;
}

/* Form Styles */
.form-section {
  margin: 16px 0;
  padding: 0 16px;
}

.form-section h3 {
  margin: 0 0 8px 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--ion-color-dark, #222428);
}

.star-rating {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 8px 0;
}

.color-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 8px 0;
}

.color-option {
  transition: transform 0.2s ease;
}

.color-option:hover {
  transform: scale(1.1);
}

.color-option.selected {
  transform: scale(1.2);
}

.prompt-preview {
  background: var(--ion-color-light, #f8f9fa);
  transition: all 0.3s ease;
}

.form-actions {
  margin-top: 24px;
  padding: 0 16px 16px;
}

/* Responsive Design */
@media (max-width: 768px) {
  .prompt-card {
    margin: 8px 12px;
  }
  
  .prompt-title {
    font-size: 16px;
  }
  
  .prompt-meta {
    gap: 6px;
  }
  
  .prompt-actions {
    justify-content: space-around;
  }
  
  .color-picker {
    justify-content: center;
  }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
  .prompt-card {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    background: var(--ion-color-step-50, #1e1e1e);
  }
  
  .prompt-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6);
  }
  
  .filters-container {
    background: var(--ion-color-step-100, #1a1a1a);
    border-color: var(--ion-color-step-200, #2a2a2a);
  }
  
  .prompt-preview {
    background: var(--ion-color-step-100, #1a1a1a);
  }
  
  .filter-header h3 {
    color: var(--ion-color-light, #f4f5f8);
  }
  
  .filter-item {
    --color: var(--ion-color-light, #f4f5f8);
    --background: var(--ion-color-step-50, #1e1e1e);
  }
  
  .filter-item ion-label {
    color: var(--ion-color-light, #f4f5f8);
  }
  
  .filter-item ion-select {
    --color: var(--ion-color-light, #f4f5f8);
    --placeholder-color: var(--ion-color-medium, #92949c);
  }
  
  .favorites-filter-item {
    --color: var(--ion-color-light, #f4f5f8);
    --background: var(--ion-color-step-50, #1e1e1e);
  }
  
  .favorites-filter-item:hover {
    --background: var(--ion-color-step-150, #262626);
  }
  
  .active-filter-summary {
    background: var(--ion-color-step-100, #1a1a1a);
    border-left-color: var(--ion-color-primary, #428cff);
  }
  
  .active-filter-summary p {
    color: var(--ion-color-light, #f4f5f8);
  }
  
  .active-filter-summary .filter-count {
    color: var(--ion-color-primary, #428cff);
  }
  
  .filter-count-badge {
    background: var(--ion-color-primary, #428cff);
  }
  
  .clear-filters-button {
    --border-color: var(--ion-color-primary, #428cff);
    --color: var(--ion-color-primary, #428cff);
  }
  
  .clear-filters-button:hover {
    --background: var(--ion-color-primary, #428cff);
    --color: white;
  }
}

/* Animation Classes */
.fade-in {
  animation: fadeIn 0.3s ease-in;
}

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

.slide-in {
  animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0);
  }
}

/* Accessibility Improvements */
.prompt-card:focus-within {
  outline: 2px solid var(--ion-color-primary, #3880ff);
  outline-offset: 2px;
}

.color-option:focus {
  outline: 2px solid var(--ion-color-primary, #3880ff);
  outline-offset: 2px;
}

/* Loading States */
.prompt-card.loading {
  opacity: 0.6;
  pointer-events: none;
}

.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, transparent 37%, #f0f0f0 63%);
  background-size: 400% 100%;
  animation: skeleton 1.4s ease infinite;
}

@keyframes skeleton {
  0% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0 50%;
  }
}

/* Floating Action Button Adjustments */
ion-fab {
  position: fixed !important;
  bottom: 20px !important;
  right: 20px !important;
  z-index: 999 !important;
}

ion-fab-button {
  --background: var(--ion-color-primary, #3880ff);
  --color: white;
  --box-shadow: 0 4px 16px rgba(56, 128, 255, 0.3);
  width: 56px;
  height: 56px;
  transition: all 0.2s ease;
}

ion-fab-button:hover {
  --box-shadow: 0 6px 20px rgba(56, 128, 255, 0.4);
  transform: scale(1.05);
}

ion-fab-button:active {
  transform: scale(0.95);
}

/* FAB responsive positioning */
@media (max-width: 768px) {
  ion-fab {
    bottom: calc(70px + env(safe-area-inset-bottom)) !important;
    right: 16px !important;
  }
  
  ion-fab-button {
    width: 52px;
    height: 52px;
  }
}

/* Ensure content doesn't overlap with FAB */
.prompt-manager-content {
  padding-bottom: 90px;
}

@media (max-width: 768px) {
  .prompt-manager-content {
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}

/* Fix for when list is short */
ion-list {
  min-height: calc(100vh - 200px);
  padding-bottom: 90px;
}

/* Fix for small devices - remove min-height to prevent long sections */
@media (max-width: 768px) {
  ion-list {
    min-height: auto !important;
    padding-bottom: 90px;
  }
}

@media (max-width: 768px) {
  ion-list {
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}

/* Toast Customization */
.toast-success {
  --background: var(--ion-color-success, #2dd36f);
}

.toast-error {
  --background: var(--ion-color-danger, #eb445a);
}

.toast-warning {
  --background: var(--ion-color-warning, #ffc409);
}

/* Action Sheet Customization */
.action-sheet-destructive {
  color: var(--ion-color-danger, #eb445a);
}

/* Search Bar Enhancements */
ion-searchbar {
  --background: var(--ion-background-color, #ffffff);
  --border-radius: 12px;
  --box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Category Chips */
ion-chip {
  --background: var(--ion-color-primary, #3880ff);
  --color: white;
  font-weight: 500;
  border-radius: 16px;
}

ion-chip[outline] {
  --border-color: var(--ion-color-medium, #92949c);
  --color: var(--ion-color-medium, #92949c);
}

/* Button Enhancements */
ion-button[fill="clear"] {
  --color: var(--ion-color-medium, #92949c);
}

ion-button[fill="clear"]:hover {
  --color: var(--ion-color-primary, #3880ff);
}

/* Progress Indicators */
.progress-bar {
  width: 100%;
  height: 4px;
  background: var(--ion-color-light, #f4f5f8);
  border-radius: 2px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  background: var(--ion-color-primary, #3880ff);
  transition: width 0.3s ease;
}

/* Custom Scrollbar */
.custom-scroll::-webkit-scrollbar {
  width: 6px;
}

.custom-scroll::-webkit-scrollbar-track {
  background: var(--ion-color-light, #f4f5f8);
}

.custom-scroll::-webkit-scrollbar-thumb {
  background: var(--ion-color-medium, #92949c);
  border-radius: 3px;
}

.custom-scroll::-webkit-scrollbar-thumb:hover {
  background: var(--ion-color-dark, #222428);
}
/* CategoryManager Styles */

/* Prevent FAB from overlapping last category */
.category-manager-content {
  --padding-bottom: 100px;
}

.category-card {
  margin: 12px 16px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  transition: all 0.2s ease;
}

.category-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

.category-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
}

.category-info {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
}

.category-icon-title {
  display: flex;
  align-items: center;
  flex: 1;
}

.category-title {
  margin: 0;
  cursor: pointer;
  transition: color 0.2s ease;
  font-size: 1.2rem;
  font-weight: 600;
}

.category-title:hover {
  opacity: 0.8;
}

.category-title.selected {
  color: var(--ion-color-primary);
}

.category-stats {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.category-stats ion-chip {
  cursor: pointer;
  transition: transform 0.2s ease;
}

.category-stats ion-chip:hover {
  transform: scale(1.05);
}

.category-meta {
  margin-top: 8px;
}

.selected-category {
  --background: var(--ion-color-primary-tint);
  --color: var(--ion-color-primary-contrast);
}

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 200px;
  padding: 32px 16px;
}

.loading-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 200px;
  gap: 16px;
}

.error-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 200px;
  gap: 16px;
  padding: 32px 16px;
}

/* CategoryForm Styles */

.category-preview-card {
  margin-bottom: 24px;
  border-radius: 12px;
  background: var(--ion-color-light);
}

.color-grid {
  padding: 16px 0;
}

.color-option {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  margin: 0 auto 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.color-option:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.color-option.selected {
  transform: scale(1.15);
  box-shadow: 0 0 0 3px var(--ion-color-primary-tint);
}

.color-name {
  text-align: center;
  margin: 0;
  font-size: 0.8rem;
  color: var(--ion-color-medium);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .category-manager-content {
    --padding-bottom: 140px;
  }
  
  .category-card {
    margin: 6px 12px;
  }
  
  .category-icon-title {
    gap: 8px;
  }
  
  .category-title {
    font-size: 1.1rem;
  }
  
  .color-option {
    width: 40px;
    height: 40px;
  }
}

/* Dark mode adjustments */
@media (prefers-color-scheme: dark) {
  .category-card {
    background: var(--ion-color-step-50, #1e1e1e);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  }
  
  .category-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6);
  }
  
  .category-preview-card {
    background: var(--ion-color-step-100, #1a1a1a);
  }
  
  .color-option {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  }
  
  .color-option:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5);
  }
}

/* Animation for category actions */
.category-card {
  animation: slideInUp 0.3s ease-out;
}

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

/* Fab button positioning */
ion-fab {
  position: fixed !important;
  bottom: 20px !important;
  right: 20px !important;
  z-index: 999 !important;
}

ion-fab-button {
  --background: var(--ion-color-primary, #3880ff);
  --color: white;
  --box-shadow: 0 4px 16px rgba(56, 128, 255, 0.3);
  width: 56px;
  height: 56px;
  transition: all 0.2s ease;
}

ion-fab-button:hover {
  --box-shadow: 0 6px 20px rgba(56, 128, 255, 0.4);
  transform: scale(1.05);
}

ion-fab-button:active {
  transform: scale(0.95);
}

/* FAB responsive positioning */
@media (max-width: 768px) {
  ion-fab {
    bottom: calc(70px + env(safe-area-inset-bottom)) !important;
    right: 16px !important;
  }
  
  ion-fab-button {
    width: 52px;
    height: 52px;
  }
}
/* SearchComponent.css */

/* Search Container */
.search-container {
  padding: 8px 16px;
  background: var(--ion-color-light);
  border-bottom: 1px solid var(--ion-color-light-shade);
  position: relative;
}

/* Suggestions Card */
.suggestions-card {
  position: absolute;
  top: 100%;
  left: 16px;
  right: 16px;
  z-index: 1000;
  margin: 0;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  animation: slideDown 0.25s ease-out;
  background: var(--ion-background-color, white);
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.suggestions-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.suggestion-chip {
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 13px;
  font-weight: 500;
  user-select: none;
}

.suggestion-chip:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

.suggestion-chip:active {
  transform: scale(0.98);
}

/* View Segments */
.view-segments {
  margin: 0 16px 16px 16px;
  border-radius: 8px;
  background: var(--ion-color-light);
}

/* Loading Container */
.loading-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  text-align: center;
}

.loading-container ion-spinner {
  margin-bottom: 16px;
}

/* Results Container */
.results-container {
  padding: 0 16px 16px 16px;
}

/* Empty State */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  text-align: center;
  min-height: 300px;
}

.empty-state h3 {
  margin: 16px 0 8px 0;
  font-size: 1.25rem;
  font-weight: 600;
}

.empty-state p {
  margin: 0 0 24px 0;
  line-height: 1.4;
}

/* Prompt Cards */
.prompt-card {
  margin-bottom: 16px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  transition: all 0.2s ease;
  overflow: hidden;
  background: var(--ion-background-color, white);
}

.prompt-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

/* Prompt Header */
.prompt-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.prompt-title {
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.3;
  cursor: pointer;
  flex: 1;
  color: var(--ion-color-primary);
  transition: color 0.2s ease;
}

.prompt-title:hover {
  color: var(--ion-color-primary-shade);
}

.prompt-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.prompt-actions ion-button {
  --padding-start: 8px;
  --padding-end: 8px;
  --padding-top: 8px;
  --padding-bottom: 8px;
  --min-width: 32px;
  --min-height: 32px;
}

/* Prompt Content */
.prompt-content {
  padding-top: 8px;
}

.content-preview {
  margin: 0 0 12px 0;
  line-height: 1.5;
  color: var(--ion-color-medium);
  font-size: 0.9rem;
}

/* Prompt Meta */
.prompt-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}

.prompt-meta ion-chip {
  --background: var(--ion-color-light);
  --border-color: var(--ion-color-medium);
  --border-width: 1px;
  --color: var(--ion-color-medium);
  font-size: 0.75rem;
  height: 26px;
}

.prompt-meta ion-chip ion-icon {
  font-size: 0.75rem;
  margin-right: 4px;
}

/* Prompt Stats */
.prompt-stats {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--ion-color-light-shade);
}

.prompt-stats small {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.75rem;
}

.prompt-stats ion-icon {
  font-size: 0.75rem;
}

/* History Container */
.history-container {
  padding: 16px;
}

.history-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  padding: 0 8px;
}

.history-header h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
}

.history-container ion-list {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.history-container ion-item {
  --border-color: var(--ion-color-light-shade);
  --padding-start: 16px;
  --padding-end: 16px;
  --inner-padding-end: 0;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.history-container ion-item:hover {
  --background: var(--ion-color-light);
}

.history-container ion-item h3 {
  margin: 0 0 4px 0;
  font-size: 0.95rem;
  font-weight: 500;
}

.history-container ion-item p {
  margin: 0;
  font-size: 0.8rem;
  color: var(--ion-color-medium);
}

/* Filter Modal */
.filter-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--ion-color-light-shade);
}

.filter-actions ion-button {
  --border-radius: 8px;
  font-weight: 500;
}

/* Responsive Design */
@media (max-width: 768px) {
  .prompt-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  
  .prompt-actions {
    align-self: flex-end;
    margin-top: -8px;
  }
  
  .suggestions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
}

@media (max-width: 480px) {
  .search-container {
    padding: 8px 12px;
  }
  
  .results-container {
    padding: 0 12px 16px 12px;
  }
  
  .history-container {
    padding: 12px;
  }
  
  .empty-state {
    padding: 32px 16px;
    min-height: 250px;
  }
  
  .prompt-meta {
    gap: 4px;
  }
  
  .prompt-meta ion-chip {
    font-size: 0.7rem;
    height: 24px;
  }
}

/* Dark Mode Adjustments */
@media (prefers-color-scheme: dark) {
  .search-container {
    background: var(--ion-color-step-100, #1a1a1a);
    border-bottom-color: var(--ion-color-step-200, #2a2a2a);
  }
  
  .prompt-card {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    background: var(--ion-color-step-50, #1e1e1e);
  }
  
  .prompt-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6);
  }
  
  .suggestions-card {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
    background: var(--ion-color-step-50, #1e1e1e);
  }
  
  .history-container ion-list {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    background: var(--ion-color-step-50, #1e1e1e);
  }
  
  .view-segments {
    background: var(--ion-color-step-100, #1a1a1a);
  }
}

/* Badge Styles */
ion-badge {
  --background: var(--ion-color-primary);
  --color: var(--ion-color-primary-contrast);
  font-size: 0.7rem;
  font-weight: 600;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  margin-left: 4px;
}

/* Segment Button Adjustments */
ion-segment-button {
  --color: var(--ion-color-medium);
  --color-checked: var(--ion-color-primary);
  --indicator-color: var(--ion-color-primary);
  font-size: 0.9rem;
  font-weight: 500;
}

/* Range Slider Customization */
ion-range {
  --bar-background: var(--ion-color-light-shade);
  --bar-background-active: var(--ion-color-primary);
  --knob-background: var(--ion-color-primary);
  --pin-background: var(--ion-color-primary);
  --pin-color: var(--ion-color-primary-contrast);
}

/* Checkbox Customization */
ion-checkbox {
  --background-checked: var(--ion-color-primary);
  --border-color-checked: var(--ion-color-primary);
  --checkmark-color: var(--ion-color-primary-contrast);
}

/* Select Customization */
ion-select {
  --placeholder-color: var(--ion-color-medium);
}

/* DateTime Customization */
ion-datetime {
  --background: var(--ion-color-light);
}

/* Animation for filter badge */
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}

ion-badge {
  animation: pulse 0.3s ease-in-out;
}

/* Improved accessibility */
.prompt-title:focus,
.suggestion-chip:focus,
ion-item:focus {
  outline: 2px solid var(--ion-color-primary);
  outline-offset: 2px;
}

/* Loading animation */
.loading-container ion-spinner {
  --color: var(--ion-color-primary);
}

/* Smooth transitions */
* {
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

/* Custom scrollbar for webkit browsers */
::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: var(--ion-color-light);
}

::-webkit-scrollbar-thumb {
  background: var(--ion-color-medium);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--ion-color-dark);
}
/* ExportComponent.css */

/* Export Container */
.export-container {
  padding: 16px;
  max-width: 800px;
  margin: 0 auto;
}

/* Export Header */
.export-container ion-card-title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1.3rem;
  font-weight: 600;
}

.export-container ion-card-title ion-icon {
  font-size: 1.5rem;
  color: var(--ion-color-primary);
}

/* Export Options */
.export-container ion-card {
  margin-bottom: 16px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.export-container ion-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

/* Export Format Section */
.export-container ion-select {
  --padding-start: 0;
  --padding-end: 0;
}

.export-container ion-input {
  --padding-start: 0;
  --padding-end: 0;
}

/* Toggle Sections */
.export-container ion-toggle {
  margin-right: 16px;
}

.export-container ion-item {
  --padding-start: 16px;
  --padding-end: 16px;
  --inner-padding-end: 0;
  --border-color: transparent;
}

.export-container ion-item h3 {
  margin: 0 0 4px 0;
  font-size: 1rem;
  font-weight: 500;
  color: var(--ion-color-dark);
}

.export-container ion-item p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--ion-color-medium);
  line-height: 1.3;
}

/* Template Section */
.export-container .template-preview {
  background: var(--ion-color-light);
  border-radius: 8px;
  padding: 12px;
  margin-top: 12px;
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  color: var(--ion-color-dark);
  white-space: pre-wrap;
  overflow-x: auto;
}

/* Export Actions */
.export-container ion-grid {
  --ion-grid-padding: 0;
}

.export-container ion-col {
  --ion-grid-column-padding: 8px;
}

.export-container ion-button {
  --border-radius: 8px;
  font-weight: 500;
}

.export-container ion-button ion-icon {
  font-size: 1.1rem;
}

/* Filter Badge */
.export-container ion-badge {
  --background: var(--ion-color-primary);
  --color: var(--ion-color-primary-contrast);
  font-size: 0.7rem;
  font-weight: 600;
  min-width: 20px;
  height: 20px;
  border-radius: 10px;
}

/* Template Modal */
.template-modal ion-list {
  margin: 0;
}

.template-modal ion-item {
  --border-color: var(--ion-color-light-shade);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.template-modal ion-item:hover {
  --background: var(--ion-color-light);
}

.template-modal ion-item h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 6px 0;
}

.template-modal ion-item p {
  font-size: 0.9rem;
  color: var(--ion-color-medium);
  margin: 0 0 8px 0;
}

.template-modal ion-chip {
  --background: var(--ion-color-light);
  --color: var(--ion-color-dark);
  font-size: 0.7rem;
  font-weight: 600;
  height: 24px;
}

/* Filter Modal */
.filter-modal ion-button {
  margin-top: 24px;
}

/* Loading State */
.export-loading ion-spinner {
  --color: var(--ion-color-primary);
}

/* Success/Error States */
ion-toast.export-success {
  --background: var(--ion-color-success);
  --color: var(--ion-color-success-contrast);
}

ion-toast.export-error {
  --background: var(--ion-color-danger);
  --color: var(--ion-color-danger-contrast);
}

/* Progress Indicator */
.export-progress {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--ion-color-light);
  border-radius: 8px;
  margin: 16px 0;
}

.export-progress ion-spinner {
  margin-right: 12px;
}

.export-progress span {
  font-weight: 500;
  color: var(--ion-color-dark);
}

/* Export Statistics */
.export-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: var(--ion-color-light);
  border-radius: 8px;
  margin-top: 12px;
}

.export-stats .stat-item {
  text-align: center;
}

.export-stats .stat-number {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--ion-color-primary);
  margin: 0;
}

.export-stats .stat-label {
  font-size: 0.8rem;
  color: var(--ion-color-medium);
  margin: 0;
}

/* Responsive Design */
@media (max-width: 768px) {
  .export-container {
    padding: 12px;
  }
  
  .export-container ion-card {
    margin-bottom: 12px;
  }
  
  .export-container ion-grid ion-col {
    --ion-grid-column-padding: 4px;
  }
  
  .export-stats {
    flex-direction: column;
    gap: 8px;
  }
  
  .export-stats .stat-item {
    display: flex;
    justify-content: space-between;
    width: 100%;
  }
}

@media (max-width: 480px) {
  .export-container {
    padding: 8px;
  }
  
  .export-container ion-card-title {
    font-size: 1.1rem;
  }
  
  .template-preview {
    font-size: 0.75rem;
  }
  
  .export-container ion-button {
    font-size: 0.9rem;
  }
}

/* Dark Mode Adjustments */
@media (prefers-color-scheme: dark) {
  .export-container ion-card {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  }
  
  .export-container ion-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  }
  
  .template-preview {
    background: var(--ion-color-dark);
    color: var(--ion-color-light);
    border: 1px solid var(--ion-color-medium);
  }
}

/* Animation for export progress */
@keyframes exportProgress {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}

.export-progress-bar {
  position: relative;
  height: 4px;
  background: var(--ion-color-light);
  border-radius: 2px;
  overflow: hidden;
  margin: 16px 0;
}

.export-progress-bar::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--ion-color-primary);
  animation: exportProgress 2s ease-in-out infinite;
}

/* Format-specific styling */
.format-txt {
  --background: #e3f2fd;
  --color: #1565c0;
}

.format-json {
  --background: #f3e5f5;
  --color: #7b1fa2;
}

.format-pdf {
  --background: #fff3e0;
  --color: #ef6c00;
}

/* Export button states */
.export-container ion-button.exporting {
  --opacity: 0.7;
  pointer-events: none;
}

.export-container ion-button.export-success {
  --background: var(--ion-color-success);
  --color: var(--ion-color-success-contrast);
}

.export-container ion-button.export-error {
  --background: var(--ion-color-danger);
  --color: var(--ion-color-danger-contrast);
}

/* Template chip colors */
ion-chip.format-txt {
  --background: #e3f2fd;
  --color: #1565c0;
}

ion-chip.format-json {
  --background: #f3e5f5;
  --color: #7b1fa2;
}

ion-chip.format-pdf {
  --background: #fff3e0;
  --color: #ef6c00;
}

/* Accessibility improvements */
.export-container ion-button:focus,
.export-container ion-item:focus,
.template-modal ion-item:focus {
  outline: 2px solid var(--ion-color-primary);
  outline-offset: 2px;
}

/* Smooth transitions */
.export-container * {
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
/* SettingsComponent.css */

/* Settings Container */
.settings-container {
  padding: 16px;
  max-width: 800px;
  margin: 0 auto;
}

/* Card Styling */
.settings-container ion-card {
  margin-bottom: 16px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.settings-container ion-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

/* Card Titles */
.settings-container ion-card-title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1.2rem;
  font-weight: 600;
}

.settings-container ion-card-title ion-icon {
  font-size: 1.4rem;
  color: var(--ion-color-primary);
}

/* Statistics Display */
.stat-item {
  text-align: center;
  padding: 8px;
}

.stat-number {
  font-size: 2rem;
  font-weight: 700;
  color: var(--ion-color-primary);
  margin: 0;
  line-height: 1;
}

.stat-label {
  font-size: 0.8rem;
  color: var(--ion-color-medium);
  margin: 4px 0 0 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* App Info Chip */
.settings-container ion-chip {
  margin-left: 12px;
  font-weight: 600;
  font-size: 0.7rem;
}

/* List Items */
.settings-container ion-list {
  margin: 0;
}

.settings-container ion-item {
  --padding-start: 16px;
  --padding-end: 16px;
  --inner-padding-end: 0;
  --border-color: var(--ion-color-light-shade);
  margin-bottom: 1px;
}

.settings-container ion-item h3 {
  margin: 0 0 4px 0;
  font-size: 1rem;
  font-weight: 500;
  color: var(--ion-color-dark);
}

.settings-container ion-item p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--ion-color-medium);
  line-height: 1.3;
}

/* Toggle Switches */
.settings-container ion-toggle {
  margin-right: 16px;
}

/* Range Sliders */
.settings-container ion-range {
  --bar-background: var(--ion-color-light);
  --bar-background-active: var(--ion-color-primary);
  --knob-background: var(--ion-color-primary);
  --knob-border-radius: 50%;
  --knob-size: 24px;
  --pin-background: var(--ion-color-primary);
  --pin-color: var(--ion-color-primary-contrast);
}

/* Select Components */
.settings-container ion-select {
  --padding-start: 0;
  --padding-end: 0;
}

/* Buttons */
.settings-container ion-button {
  --border-radius: 8px;
  font-weight: 500;
}

.settings-container ion-button ion-icon {
  font-size: 1.1rem;
}

/* Grid Layout */
.settings-container ion-grid {
  --ion-grid-padding: 0;
}

.settings-container ion-col {
  --ion-grid-column-padding: 8px;
}

/* Version Information */
.settings-container .version-info {
  margin-top: 16px;
  padding: 16px;
  background: var(--ion-color-light);
  border-radius: 8px;
}

.settings-container .version-info p {
  margin: 4px 0;
  font-size: 0.9rem;
  color: var(--ion-color-medium);
}

/* Backup Section */
.backup-actions {
  margin-top: 16px;
}

.backup-actions ion-button {
  margin: 4px 0;
}

/* Danger Actions */
.settings-container ion-button[color="danger"] {
  margin-top: 16px;
}

/* Toast Styling */
ion-toast.settings-toast {
  --border-radius: 8px;
}

/* Modal Content */
.settings-modal ion-content {
  --padding-top: 0;
  --padding-bottom: 0;
  --padding-start: 16px;
  --padding-end: 16px;
}

.settings-modal h2 {
  color: var(--ion-color-primary);
  margin: 24px 0 16px 0;
  font-size: 1.5rem;
  font-weight: 600;
}

.settings-modal h3 {
  color: var(--ion-color-dark);
  margin: 16px 0 8px 0;
  font-size: 1.2rem;
  font-weight: 500;
}

.settings-modal ul {
  margin: 0 0 16px 20px;
  padding: 0;
}

.settings-modal li {
  margin: 4px 0;
  color: var(--ion-color-dark);
  line-height: 1.4;
}

/* Loading States */
.settings-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.settings-loading ion-spinner {
  margin-right: 12px;
  --color: var(--ion-color-primary);
}

/* Badge Styling */
.settings-container ion-badge {
  --background: var(--ion-color-success);
  --color: var(--ion-color-success-contrast);
  font-size: 0.7rem;
  font-weight: 600;
  min-width: 50px;
  height: 24px;
  border-radius: 12px;
}

/* Responsive Design */
@media (max-width: 768px) {
  .settings-container {
    padding: 12px;
  }
  
  .settings-container ion-card {
    margin-bottom: 12px;
  }
  
  .stat-number {
    font-size: 1.8rem;
  }
  
  .stat-label {
    font-size: 0.75rem;
  }
  
  .settings-container ion-card-title {
    font-size: 1.1rem;
  }
  
  .settings-container ion-col {
    --ion-grid-column-padding: 4px;
  }
}

@media (max-width: 480px) {
  .settings-container {
    padding: 8px;
  }
  
  .stat-item {
    padding: 4px;
  }
  
  .stat-number {
    font-size: 1.5rem;
  }
  
  .stat-label {
    font-size: 0.7rem;
  }
  
  .settings-container ion-item h3 {
    font-size: 0.95rem;
  }
  
  .settings-container ion-item p {
    font-size: 0.85rem;
  }
}

/* Fix for small devices - remove min-height to prevent long sections */
@media (max-width: 768px) {
  .settings-container ion-list {
    min-height: auto !important;
  }
}

/* Dark Mode Adjustments */
@media (prefers-color-scheme: dark) {
  .settings-container ion-card {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  }
  
  .settings-container ion-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  }
  
  .settings-container .version-info {
    background: var(--ion-color-dark);
    border: 1px solid var(--ion-color-medium);
  }
}

/* Theme-specific styling */
.theme-light .settings-container {
  background: var(--ion-color-light-tint);
}

.theme-dark .settings-container {
  background: var(--ion-color-dark-shade);
}

.theme-dark .settings-container ion-card {
  background: var(--ion-color-dark-tint);
}

/* Animation for settings changes */
.settings-container ion-item {
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.settings-container ion-item.setting-changed {
  background-color: var(--ion-color-success-tint);
  transform: scale(1.02);
}

.settings-container ion-item.setting-changed::after {
  content: '✓';
  position: absolute;
  right: 16px;
  color: var(--ion-color-success);
  font-weight: bold;
  animation: fadeOut 2s ease-out forwards;
}

@keyframes fadeOut {
  0% { opacity: 1; }
  70% { opacity: 1; }
  100% { opacity: 0; }
}

/* Focus states for accessibility */
.settings-container ion-button:focus,
.settings-container ion-item:focus,
.settings-container ion-toggle:focus,
.settings-container ion-select:focus,
.settings-container ion-range:focus {
  outline: 2px solid var(--ion-color-primary);
  outline-offset: 2px;
}

/* Smooth transitions */
.settings-container * {
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

/* Special styling for Pro badge */
.settings-container ion-chip[color="success"] {
  --background: linear-gradient(45deg, var(--ion-color-success), var(--ion-color-success-shade));
  --color: var(--ion-color-success-contrast);
  animation: subtle-glow 3s ease-in-out infinite alternate;
}

@keyframes subtle-glow {
  from {
    box-shadow: 0 0 5px rgba(72, 187, 120, 0.3);
  }
  to {
    box-shadow: 0 0 15px rgba(72, 187, 120, 0.6);
  }
}

/* Settings section dividers */
.settings-container ion-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--ion-color-primary), var(--ion-color-primary-shade));
  border-radius: 12px 12px 0 0;
}

/* Enhanced button styling */
.settings-container .backup-actions ion-button {
  position: relative;
  overflow: hidden;
}

.settings-container .backup-actions ion-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transition: left 0.5s ease;
}

.settings-container .backup-actions ion-button:hover::before {
  left: 100%;
}

/* Error states */
.settings-error {
  color: var(--ion-color-danger);
  font-size: 0.9rem;
  margin-top: 8px;
  padding: 8px;
  background: var(--ion-color-danger-tint);
  border-radius: 4px;
}

/* Success states */
.settings-success {
  color: var(--ion-color-success);
  font-size: 0.9rem;
  margin-top: 8px;
  padding: 8px;
  background: var(--ion-color-success-tint);
  border-radius: 4px;
}
:root{--ion-color-primary: #0054e9;--ion-color-primary-rgb: 0, 84, 233;--ion-color-primary-contrast: #fff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #004acd;--ion-color-primary-tint: #1a65eb;--ion-color-secondary: #0163aa;--ion-color-secondary-rgb: 1, 99, 170;--ion-color-secondary-contrast: #fff;--ion-color-secondary-contrast-rgb: 255, 255, 255;--ion-color-secondary-shade: #015796;--ion-color-secondary-tint: #1a73b3;--ion-color-tertiary: #6030ff;--ion-color-tertiary-rgb: 96, 48, 255;--ion-color-tertiary-contrast: #fff;--ion-color-tertiary-contrast-rgb: 255, 255, 255;--ion-color-tertiary-shade: #542ae0;--ion-color-tertiary-tint: #7045ff;--ion-color-success: #2dd55b;--ion-color-success-rgb: 45, 213, 91;--ion-color-success-contrast: #000;--ion-color-success-contrast-rgb: 0, 0, 0;--ion-color-success-shade: #28bb50;--ion-color-success-tint: #42d96b;--ion-color-warning: #ffc409;--ion-color-warning-rgb: 255, 196, 9;--ion-color-warning-contrast: #000;--ion-color-warning-contrast-rgb: 0, 0, 0;--ion-color-warning-shade: #e0ac08;--ion-color-warning-tint: #ffca22;--ion-color-danger: #c5000f;--ion-color-danger-rgb: 197, 0, 15;--ion-color-danger-contrast: #fff;--ion-color-danger-contrast-rgb: 255, 255, 255;--ion-color-danger-shade: #ad000d;--ion-color-danger-tint: #cb1a27;--ion-color-light: #f4f5f8;--ion-color-light-rgb: 244, 245, 248;--ion-color-light-contrast: #000;--ion-color-light-contrast-rgb: 0, 0, 0;--ion-color-light-shade: #d7d8da;--ion-color-light-tint: #f5f6f9;--ion-color-medium: #636469;--ion-color-medium-rgb: 99, 100, 105;--ion-color-medium-contrast: #fff;--ion-color-medium-contrast-rgb: 255, 255, 255;--ion-color-medium-shade: #57585c;--ion-color-medium-tint: #737478;--ion-color-dark: #222428;--ion-color-dark-rgb: 34, 36, 40;--ion-color-dark-contrast: #fff;--ion-color-dark-contrast-rgb: 255, 255, 255;--ion-color-dark-shade: #1e2023;--ion-color-dark-tint: #383a3e}html.ios{--ion-default-font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Roboto", sans-serif}html.md{--ion-default-font: "Roboto", "Helvetica Neue", sans-serif}html{--ion-dynamic-font: -apple-system-body;--ion-font-family: var(--ion-default-font)}body{background:var(--ion-background-color);color:var(--ion-text-color)}body.backdrop-no-scroll{overflow:hidden}html.ios ion-modal.modal-card ion-header ion-toolbar:first-of-type,html.ios ion-modal.modal-sheet ion-header ion-toolbar:first-of-type,html.ios ion-modal ion-footer ion-toolbar:first-of-type,html.ios ion-footer.modal-footer-moving ion-toolbar:first-of-type{padding-top:6px}html.ios ion-modal.modal-card ion-header ion-toolbar:last-of-type,html.ios ion-modal.modal-sheet ion-header ion-toolbar:last-of-type{padding-bottom:6px}html.ios ion-modal ion-toolbar,html.ios .modal-footer-moving ion-toolbar{padding-right:calc(var(--ion-safe-area-right) + 8px);padding-left:calc(var(--ion-safe-area-left) + 8px)}@media screen and (min-width: 768px){html.ios ion-modal.modal-card:first-of-type{--backdrop-opacity: 0.18}}ion-modal.modal-default.show-modal~ion-modal.modal-default{--backdrop-opacity: 0;--box-shadow: none}html.ios ion-modal.modal-card .ion-page{border-top-left-radius:var(--border-radius)}.ion-color-primary{--ion-color-base: var(--ion-color-primary, #0054e9) !important;--ion-color-base-rgb: var(--ion-color-primary-rgb, 0, 84, 233) !important;--ion-color-contrast: var(--ion-color-primary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-primary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-primary-shade, #004acd) !important;--ion-color-tint: var(--ion-color-primary-tint, #1a65eb) !important}.ion-color-secondary{--ion-color-base: var(--ion-color-secondary, #0163aa) !important;--ion-color-base-rgb: var(--ion-color-secondary-rgb, 1, 99, 170) !important;--ion-color-contrast: var(--ion-color-secondary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-secondary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-secondary-shade, #015796) !important;--ion-color-tint: var(--ion-color-secondary-tint, #1a73b3) !important}.ion-color-tertiary{--ion-color-base: var(--ion-color-tertiary, #6030ff) !important;--ion-color-base-rgb: var(--ion-color-tertiary-rgb, 96, 48, 255) !important;--ion-color-contrast: var(--ion-color-tertiary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-tertiary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-tertiary-shade, #542ae0) !important;--ion-color-tint: var(--ion-color-tertiary-tint, #7045ff) !important}.ion-color-success{--ion-color-base: var(--ion-color-success, #2dd55b) !important;--ion-color-base-rgb: var(--ion-color-success-rgb, 45, 213, 91) !important;--ion-color-contrast: var(--ion-color-success-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-success-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-success-shade, #28bb50) !important;--ion-color-tint: var(--ion-color-success-tint, #42d96b) !important}.ion-color-warning{--ion-color-base: var(--ion-color-warning, #ffc409) !important;--ion-color-base-rgb: var(--ion-color-warning-rgb, 255, 196, 9) !important;--ion-color-contrast: var(--ion-color-warning-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-warning-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-warning-shade, #e0ac08) !important;--ion-color-tint: var(--ion-color-warning-tint, #ffca22) !important}.ion-color-danger{--ion-color-base: var(--ion-color-danger, #c5000f) !important;--ion-color-base-rgb: var(--ion-color-danger-rgb, 197, 0, 15) !important;--ion-color-contrast: var(--ion-color-danger-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-danger-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-danger-shade, #ad000d) !important;--ion-color-tint: var(--ion-color-danger-tint, #cb1a27) !important}.ion-color-light{--ion-color-base: var(--ion-color-light, #f4f5f8) !important;--ion-color-base-rgb: var(--ion-color-light-rgb, 244, 245, 248) !important;--ion-color-contrast: var(--ion-color-light-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-light-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-light-shade, #d7d8da) !important;--ion-color-tint: var(--ion-color-light-tint, #f5f6f9) !important}.ion-color-medium{--ion-color-base: var(--ion-color-medium, #636469) !important;--ion-color-base-rgb: var(--ion-color-medium-rgb, 99, 100, 105) !important;--ion-color-contrast: var(--ion-color-medium-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-medium-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-medium-shade, #57585c) !important;--ion-color-tint: var(--ion-color-medium-tint, #737478) !important}.ion-color-dark{--ion-color-base: var(--ion-color-dark, #222428) !important;--ion-color-base-rgb: var(--ion-color-dark-rgb, 34, 36, 40) !important;--ion-color-contrast: var(--ion-color-dark-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-dark-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-dark-shade, #1e2023) !important;--ion-color-tint: var(--ion-color-dark-tint, #383a3e) !important}.ion-page{left:0;right:0;top:0;bottom:0;display:flex;position:absolute;flex-direction:column;justify-content:space-between;contain:layout size style;z-index:0}ion-modal>.ion-page{position:relative;contain:layout style;height:100%}.split-pane-visible>.ion-page.split-pane-main{position:relative}ion-route,ion-route-redirect,ion-router,ion-select-option,ion-nav-controller,ion-menu-controller,ion-action-sheet-controller,ion-alert-controller,ion-loading-controller,ion-modal-controller,ion-picker-controller,ion-popover-controller,ion-toast-controller,.ion-page-hidden{display:none !important}.ion-page-invisible{opacity:0}.can-go-back>ion-header ion-back-button{display:block}html.plt-ios.plt-hybrid,html.plt-ios.plt-pwa{--ion-statusbar-padding: 20px}@supports(padding-top: 20px){html{--ion-safe-area-top: var(--ion-statusbar-padding)}}@supports(padding-top: env(safe-area-inset-top)){html{--ion-safe-area-top: env(safe-area-inset-top);--ion-safe-area-bottom: env(safe-area-inset-bottom);--ion-safe-area-left: env(safe-area-inset-left);--ion-safe-area-right: env(safe-area-inset-right)}}ion-card.ion-color .ion-inherit-color,ion-card-header.ion-color .ion-inherit-color{color:inherit}.menu-content{transform:translate3d(0,  0,  0)}.menu-content-open{cursor:pointer;touch-action:manipulation;pointer-events:none;overflow-y:hidden}.menu-content-open ion-content{--overflow: hidden}.menu-content-open .ion-content-scroll-host{overflow:hidden}.ios .menu-content-reveal{box-shadow:-8px 0 42px rgba(0,0,0,.08)}[dir=rtl].ios .menu-content-reveal{box-shadow:8px 0 42px rgba(0,0,0,.08)}.md .menu-content-reveal{box-shadow:4px 0px 16px rgba(0,0,0,.18)}.md .menu-content-push{box-shadow:4px 0px 16px rgba(0,0,0,.18)}ion-accordion-group.accordion-group-expand-inset>ion-accordion:first-of-type{border-top-left-radius:8px;border-top-right-radius:8px}ion-accordion-group.accordion-group-expand-inset>ion-accordion:last-of-type{border-bottom-left-radius:8px;border-bottom-right-radius:8px}ion-accordion-group>ion-accordion:last-of-type ion-item[slot=header]{--border-width: 0px}ion-accordion.accordion-animated>[slot=header] .ion-accordion-toggle-icon{transition:300ms transform cubic-bezier(0.25, 0.8, 0.5, 1)}@media(prefers-reduced-motion: reduce){ion-accordion .ion-accordion-toggle-icon{transition:none !important}}ion-accordion.accordion-expanding>[slot=header] .ion-accordion-toggle-icon,ion-accordion.accordion-expanded>[slot=header] .ion-accordion-toggle-icon{transform:rotate(180deg)}ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-previous ion-item[slot=header]{--border-width: 0px;--inner-border-width: 0px}ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-expanding:first-of-type,ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-expanded:first-of-type{margin-top:0}ion-input input::-webkit-date-and-time-value{text-align:start}.ion-datetime-button-overlay{--width: fit-content;--height: fit-content}.ion-datetime-button-overlay ion-datetime.datetime-grid{width:320px;min-height:320px}[ion-last-focus],header[tabindex="-1"]:focus,[role=banner][tabindex="-1"]:focus,main[tabindex="-1"]:focus,[role=main][tabindex="-1"]:focus,h1[tabindex="-1"]:focus,[role=heading][aria-level="1"][tabindex="-1"]:focus{outline:none}.popover-viewport:has(>ion-content){overflow:hidden}@supports not selector(:has(> ion-content)){.popover-viewport{overflow:hidden}}/*# sourceMappingURL=core.css.map */
audio,canvas,progress,video{vertical-align:baseline}audio:not([controls]){display:none;height:0}b,strong{font-weight:bold}img{max-width:100%}hr{height:1px;border-width:0;box-sizing:content-box}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}label,input,select,textarea{font-family:inherit;line-height:normal}textarea{overflow:auto;height:auto;font:inherit;color:inherit}textarea::placeholder{padding-left:2px}form,input,optgroup,select{margin:0;font:inherit;color:inherit}html input[type=button],input[type=reset],input[type=submit]{cursor:pointer;-webkit-appearance:button}a,a div,a span,a ion-icon,a ion-label,button,button div,button span,button ion-icon,button ion-label,.ion-tappable,[tappable],[tappable] div,[tappable] span,[tappable] ion-icon,[tappable] ion-label,input,textarea{touch-action:manipulation}a ion-label,button ion-label{pointer-events:none}button{padding:0;border:0;border-radius:0;font-family:inherit;font-style:inherit;font-variant:inherit;line-height:1;text-transform:none;cursor:pointer;-webkit-appearance:button}[tappable]{cursor:pointer}a[disabled],button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}/*# sourceMappingURL=normalize.css.map */
*{box-sizing:border-box;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{width:100%;height:100%;-webkit-text-size-adjust:100%;text-size-adjust:100%}html.ion-ce body{display:block}html.plt-pwa{height:100vh}body{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;position:fixed;width:100%;max-width:100%;height:100%;max-height:100%;transform:translateZ(0);text-rendering:optimizeLegibility;overflow:hidden;touch-action:manipulation;-webkit-user-drag:none;-ms-content-zooming:none;word-wrap:break-word;overscroll-behavior-y:none;-webkit-text-size-adjust:none;text-size-adjust:none}/*# sourceMappingURL=structure.css.map */
html{font-family:var(--ion-font-family)}@supports(-webkit-touch-callout: none){html{font:var(--ion-dynamic-font, 16px var(--ion-font-family))}}a{background-color:transparent;color:var(--ion-color-primary, #0054e9)}h1,h2,h3,h4,h5,h6{margin-top:16px;margin-bottom:10px;font-weight:500;line-height:1.2}h1{margin-top:20px;font-size:1.625rem}h2{margin-top:18px;font-size:1.5rem}h3{font-size:1.375rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}small{font-size:75%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}/*# sourceMappingURL=typography.css.map */
.ion-no-padding{--padding-start: 0;--padding-end: 0;--padding-top: 0;--padding-bottom: 0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}.ion-padding{--padding-start: var(--ion-padding, 16px);--padding-end: var(--ion-padding, 16px);--padding-top: var(--ion-padding, 16px);--padding-bottom: var(--ion-padding, 16px);-webkit-padding-start:var(--ion-padding, 16px);padding-inline-start:var(--ion-padding, 16px);-webkit-padding-end:var(--ion-padding, 16px);padding-inline-end:var(--ion-padding, 16px);padding-top:var(--ion-padding, 16px);padding-bottom:var(--ion-padding, 16px)}.ion-padding-top{--padding-top: var(--ion-padding, 16px);padding-top:var(--ion-padding, 16px)}.ion-padding-start{--padding-start: var(--ion-padding, 16px);-webkit-padding-start:var(--ion-padding, 16px);padding-inline-start:var(--ion-padding, 16px)}.ion-padding-end{--padding-end: var(--ion-padding, 16px);-webkit-padding-end:var(--ion-padding, 16px);padding-inline-end:var(--ion-padding, 16px)}.ion-padding-bottom{--padding-bottom: var(--ion-padding, 16px);padding-bottom:var(--ion-padding, 16px)}.ion-padding-vertical{--padding-top: var(--ion-padding, 16px);--padding-bottom: var(--ion-padding, 16px);padding-top:var(--ion-padding, 16px);padding-bottom:var(--ion-padding, 16px)}.ion-padding-horizontal{--padding-start: var(--ion-padding, 16px);--padding-end: var(--ion-padding, 16px);-webkit-padding-start:var(--ion-padding, 16px);padding-inline-start:var(--ion-padding, 16px);-webkit-padding-end:var(--ion-padding, 16px);padding-inline-end:var(--ion-padding, 16px)}.ion-no-margin{--margin-start: 0;--margin-end: 0;--margin-top: 0;--margin-bottom: 0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.ion-margin{--margin-start: var(--ion-margin, 16px);--margin-end: var(--ion-margin, 16px);--margin-top: var(--ion-margin, 16px);--margin-bottom: var(--ion-margin, 16px);-webkit-margin-start:var(--ion-margin, 16px);margin-inline-start:var(--ion-margin, 16px);-webkit-margin-end:var(--ion-margin, 16px);margin-inline-end:var(--ion-margin, 16px);margin-top:var(--ion-margin, 16px);margin-bottom:var(--ion-margin, 16px)}.ion-margin-top{--margin-top: var(--ion-margin, 16px);margin-top:var(--ion-margin, 16px)}.ion-margin-start{--margin-start: var(--ion-margin, 16px);-webkit-margin-start:var(--ion-margin, 16px);margin-inline-start:var(--ion-margin, 16px)}.ion-margin-end{--margin-end: var(--ion-margin, 16px);-webkit-margin-end:var(--ion-margin, 16px);margin-inline-end:var(--ion-margin, 16px)}.ion-margin-bottom{--margin-bottom: var(--ion-margin, 16px);margin-bottom:var(--ion-margin, 16px)}.ion-margin-vertical{--margin-top: var(--ion-margin, 16px);--margin-bottom: var(--ion-margin, 16px);margin-top:var(--ion-margin, 16px);margin-bottom:var(--ion-margin, 16px)}.ion-margin-horizontal{--margin-start: var(--ion-margin, 16px);--margin-end: var(--ion-margin, 16px);-webkit-margin-start:var(--ion-margin, 16px);margin-inline-start:var(--ion-margin, 16px);-webkit-margin-end:var(--ion-margin, 16px);margin-inline-end:var(--ion-margin, 16px)}/*# sourceMappingURL=padding.css.map */
.ion-float-left{float:left !important}.ion-float-right{float:right !important}.ion-float-start{float:left !important}:host-context([dir=rtl]) .ion-float-start{float:right !important}[dir=rtl] .ion-float-start{float:right !important}@supports selector(:dir(rtl)){.ion-float-start:dir(rtl){float:right !important}}.ion-float-end{float:right !important}:host-context([dir=rtl]) .ion-float-end{float:left !important}[dir=rtl] .ion-float-end{float:left !important}@supports selector(:dir(rtl)){.ion-float-end:dir(rtl){float:left !important}}@media(min-width: 576px){.ion-float-sm-left{float:left !important}.ion-float-sm-right{float:right !important}.ion-float-sm-start{float:left !important}:host-context([dir=rtl]) .ion-float-sm-start{float:right !important}[dir=rtl] .ion-float-sm-start{float:right !important}@supports selector(:dir(rtl)){.ion-float-sm-start:dir(rtl){float:right !important}}.ion-float-sm-end{float:right !important}:host-context([dir=rtl]) .ion-float-sm-end{float:left !important}[dir=rtl] .ion-float-sm-end{float:left !important}@supports selector(:dir(rtl)){.ion-float-sm-end:dir(rtl){float:left !important}}}@media(min-width: 768px){.ion-float-md-left{float:left !important}.ion-float-md-right{float:right !important}.ion-float-md-start{float:left !important}:host-context([dir=rtl]) .ion-float-md-start{float:right !important}[dir=rtl] .ion-float-md-start{float:right !important}@supports selector(:dir(rtl)){.ion-float-md-start:dir(rtl){float:right !important}}.ion-float-md-end{float:right !important}:host-context([dir=rtl]) .ion-float-md-end{float:left !important}[dir=rtl] .ion-float-md-end{float:left !important}@supports selector(:dir(rtl)){.ion-float-md-end:dir(rtl){float:left !important}}}@media(min-width: 992px){.ion-float-lg-left{float:left !important}.ion-float-lg-right{float:right !important}.ion-float-lg-start{float:left !important}:host-context([dir=rtl]) .ion-float-lg-start{float:right !important}[dir=rtl] .ion-float-lg-start{float:right !important}@supports selector(:dir(rtl)){.ion-float-lg-start:dir(rtl){float:right !important}}.ion-float-lg-end{float:right !important}:host-context([dir=rtl]) .ion-float-lg-end{float:left !important}[dir=rtl] .ion-float-lg-end{float:left !important}@supports selector(:dir(rtl)){.ion-float-lg-end:dir(rtl){float:left !important}}}@media(min-width: 1200px){.ion-float-xl-left{float:left !important}.ion-float-xl-right{float:right !important}.ion-float-xl-start{float:left !important}:host-context([dir=rtl]) .ion-float-xl-start{float:right !important}[dir=rtl] .ion-float-xl-start{float:right !important}@supports selector(:dir(rtl)){.ion-float-xl-start:dir(rtl){float:right !important}}.ion-float-xl-end{float:right !important}:host-context([dir=rtl]) .ion-float-xl-end{float:left !important}[dir=rtl] .ion-float-xl-end{float:left !important}@supports selector(:dir(rtl)){.ion-float-xl-end:dir(rtl){float:left !important}}}/*# sourceMappingURL=float-elements.css.map */
.ion-text-center{text-align:center !important}.ion-text-justify{text-align:justify !important}.ion-text-start{text-align:start !important}.ion-text-end{text-align:end !important}.ion-text-left{text-align:left !important}.ion-text-right{text-align:right !important}.ion-text-nowrap{white-space:nowrap !important}.ion-text-wrap{white-space:normal !important}@media(min-width: 576px){.ion-text-sm-center{text-align:center !important}.ion-text-sm-justify{text-align:justify !important}.ion-text-sm-start{text-align:start !important}.ion-text-sm-end{text-align:end !important}.ion-text-sm-left{text-align:left !important}.ion-text-sm-right{text-align:right !important}.ion-text-sm-nowrap{white-space:nowrap !important}.ion-text-sm-wrap{white-space:normal !important}}@media(min-width: 768px){.ion-text-md-center{text-align:center !important}.ion-text-md-justify{text-align:justify !important}.ion-text-md-start{text-align:start !important}.ion-text-md-end{text-align:end !important}.ion-text-md-left{text-align:left !important}.ion-text-md-right{text-align:right !important}.ion-text-md-nowrap{white-space:nowrap !important}.ion-text-md-wrap{white-space:normal !important}}@media(min-width: 992px){.ion-text-lg-center{text-align:center !important}.ion-text-lg-justify{text-align:justify !important}.ion-text-lg-start{text-align:start !important}.ion-text-lg-end{text-align:end !important}.ion-text-lg-left{text-align:left !important}.ion-text-lg-right{text-align:right !important}.ion-text-lg-nowrap{white-space:nowrap !important}.ion-text-lg-wrap{white-space:normal !important}}@media(min-width: 1200px){.ion-text-xl-center{text-align:center !important}.ion-text-xl-justify{text-align:justify !important}.ion-text-xl-start{text-align:start !important}.ion-text-xl-end{text-align:end !important}.ion-text-xl-left{text-align:left !important}.ion-text-xl-right{text-align:right !important}.ion-text-xl-nowrap{white-space:nowrap !important}.ion-text-xl-wrap{white-space:normal !important}}/*# sourceMappingURL=text-alignment.css.map */
.ion-text-uppercase{text-transform:uppercase !important}.ion-text-lowercase{text-transform:lowercase !important}.ion-text-capitalize{text-transform:capitalize !important}@media(min-width: 576px){.ion-text-sm-uppercase{text-transform:uppercase !important}.ion-text-sm-lowercase{text-transform:lowercase !important}.ion-text-sm-capitalize{text-transform:capitalize !important}}@media(min-width: 768px){.ion-text-md-uppercase{text-transform:uppercase !important}.ion-text-md-lowercase{text-transform:lowercase !important}.ion-text-md-capitalize{text-transform:capitalize !important}}@media(min-width: 992px){.ion-text-lg-uppercase{text-transform:uppercase !important}.ion-text-lg-lowercase{text-transform:lowercase !important}.ion-text-lg-capitalize{text-transform:capitalize !important}}@media(min-width: 1200px){.ion-text-xl-uppercase{text-transform:uppercase !important}.ion-text-xl-lowercase{text-transform:lowercase !important}.ion-text-xl-capitalize{text-transform:capitalize !important}}/*# sourceMappingURL=text-transformation.css.map */
.ion-align-content-start{align-content:flex-start !important}.ion-align-content-end{align-content:flex-end !important}.ion-align-content-center{align-content:center !important}.ion-align-content-between{align-content:space-between !important}.ion-align-content-around{align-content:space-around !important}.ion-align-content-stretch{align-content:stretch !important}@media(min-width: 576px){.ion-align-content-sm-start{align-content:flex-start !important}.ion-align-content-sm-end{align-content:flex-end !important}.ion-align-content-sm-center{align-content:center !important}.ion-align-content-sm-between{align-content:space-between !important}.ion-align-content-sm-around{align-content:space-around !important}.ion-align-content-sm-stretch{align-content:stretch !important}}@media(min-width: 768px){.ion-align-content-md-start{align-content:flex-start !important}.ion-align-content-md-end{align-content:flex-end !important}.ion-align-content-md-center{align-content:center !important}.ion-align-content-md-between{align-content:space-between !important}.ion-align-content-md-around{align-content:space-around !important}.ion-align-content-md-stretch{align-content:stretch !important}}@media(min-width: 992px){.ion-align-content-lg-start{align-content:flex-start !important}.ion-align-content-lg-end{align-content:flex-end !important}.ion-align-content-lg-center{align-content:center !important}.ion-align-content-lg-between{align-content:space-between !important}.ion-align-content-lg-around{align-content:space-around !important}.ion-align-content-lg-stretch{align-content:stretch !important}}@media(min-width: 1200px){.ion-align-content-xl-start{align-content:flex-start !important}.ion-align-content-xl-end{align-content:flex-end !important}.ion-align-content-xl-center{align-content:center !important}.ion-align-content-xl-between{align-content:space-between !important}.ion-align-content-xl-around{align-content:space-around !important}.ion-align-content-xl-stretch{align-content:stretch !important}}.ion-align-items-start{align-items:start !important}.ion-align-items-end{align-items:end !important}.ion-align-items-center{align-items:center !important}.ion-align-items-stretch{align-items:stretch !important}.ion-align-items-baseline{align-items:baseline !important}@media(min-width: 576px){.ion-align-items-sm-start{align-items:start !important}.ion-align-items-sm-end{align-items:end !important}.ion-align-items-sm-center{align-items:center !important}.ion-align-items-sm-stretch{align-items:stretch !important}.ion-align-items-sm-baseline{align-items:baseline !important}}@media(min-width: 768px){.ion-align-items-md-start{align-items:start !important}.ion-align-items-md-end{align-items:end !important}.ion-align-items-md-center{align-items:center !important}.ion-align-items-md-stretch{align-items:stretch !important}.ion-align-items-md-baseline{align-items:baseline !important}}@media(min-width: 992px){.ion-align-items-lg-start{align-items:start !important}.ion-align-items-lg-end{align-items:end !important}.ion-align-items-lg-center{align-items:center !important}.ion-align-items-lg-stretch{align-items:stretch !important}.ion-align-items-lg-baseline{align-items:baseline !important}}@media(min-width: 1200px){.ion-align-items-xl-start{align-items:start !important}.ion-align-items-xl-end{align-items:end !important}.ion-align-items-xl-center{align-items:center !important}.ion-align-items-xl-stretch{align-items:stretch !important}.ion-align-items-xl-baseline{align-items:baseline !important}}.ion-align-self-start{align-self:start !important}.ion-align-self-end{align-self:end !important}.ion-align-self-center{align-self:center !important}.ion-align-self-stretch{align-self:stretch !important}.ion-align-self-baseline{align-self:baseline !important}.ion-align-self-auto{align-self:auto !important}@media(min-width: 576px){.ion-align-self-sm-start{align-self:start !important}.ion-align-self-sm-end{align-self:end !important}.ion-align-self-sm-center{align-self:center !important}.ion-align-self-sm-stretch{align-self:stretch !important}.ion-align-self-sm-baseline{align-self:baseline !important}.ion-align-self-sm-auto{align-self:auto !important}}@media(min-width: 768px){.ion-align-self-md-start{align-self:start !important}.ion-align-self-md-end{align-self:end !important}.ion-align-self-md-center{align-self:center !important}.ion-align-self-md-stretch{align-self:stretch !important}.ion-align-self-md-baseline{align-self:baseline !important}.ion-align-self-md-auto{align-self:auto !important}}@media(min-width: 992px){.ion-align-self-lg-start{align-self:start !important}.ion-align-self-lg-end{align-self:end !important}.ion-align-self-lg-center{align-self:center !important}.ion-align-self-lg-stretch{align-self:stretch !important}.ion-align-self-lg-baseline{align-self:baseline !important}.ion-align-self-lg-auto{align-self:auto !important}}@media(min-width: 1200px){.ion-align-self-xl-start{align-self:start !important}.ion-align-self-xl-end{align-self:end !important}.ion-align-self-xl-center{align-self:center !important}.ion-align-self-xl-stretch{align-self:stretch !important}.ion-align-self-xl-baseline{align-self:baseline !important}.ion-align-self-xl-auto{align-self:auto !important}}.ion-justify-content-start{justify-content:flex-start !important}.ion-justify-content-end{justify-content:flex-end !important}.ion-justify-content-center{justify-content:center !important}.ion-justify-content-between{justify-content:space-between !important}.ion-justify-content-around{justify-content:space-around !important}.ion-justify-content-evenly{justify-content:space-evenly !important}@media(min-width: 576px){.ion-justify-content-sm-start{justify-content:flex-start !important}.ion-justify-content-sm-end{justify-content:flex-end !important}.ion-justify-content-sm-center{justify-content:center !important}.ion-justify-content-sm-between{justify-content:space-between !important}.ion-justify-content-sm-around{justify-content:space-around !important}.ion-justify-content-sm-evenly{justify-content:space-evenly !important}}@media(min-width: 768px){.ion-justify-content-md-start{justify-content:flex-start !important}.ion-justify-content-md-end{justify-content:flex-end !important}.ion-justify-content-md-center{justify-content:center !important}.ion-justify-content-md-between{justify-content:space-between !important}.ion-justify-content-md-around{justify-content:space-around !important}.ion-justify-content-md-evenly{justify-content:space-evenly !important}}@media(min-width: 992px){.ion-justify-content-lg-start{justify-content:flex-start !important}.ion-justify-content-lg-end{justify-content:flex-end !important}.ion-justify-content-lg-center{justify-content:center !important}.ion-justify-content-lg-between{justify-content:space-between !important}.ion-justify-content-lg-around{justify-content:space-around !important}.ion-justify-content-lg-evenly{justify-content:space-evenly !important}}@media(min-width: 1200px){.ion-justify-content-xl-start{justify-content:flex-start !important}.ion-justify-content-xl-end{justify-content:flex-end !important}.ion-justify-content-xl-center{justify-content:center !important}.ion-justify-content-xl-between{justify-content:space-between !important}.ion-justify-content-xl-around{justify-content:space-around !important}.ion-justify-content-xl-evenly{justify-content:space-evenly !important}}.ion-flex-row{flex-direction:row !important}.ion-flex-row-reverse{flex-direction:row-reverse !important}.ion-flex-column{flex-direction:column !important}.ion-flex-column-reverse{flex-direction:column-reverse !important}@media(min-width: 576px){.ion-flex-sm-row{flex-direction:row !important}.ion-flex-sm-row-reverse{flex-direction:row-reverse !important}.ion-flex-sm-column{flex-direction:column !important}.ion-flex-sm-column-reverse{flex-direction:column-reverse !important}}@media(min-width: 768px){.ion-flex-md-row{flex-direction:row !important}.ion-flex-md-row-reverse{flex-direction:row-reverse !important}.ion-flex-md-column{flex-direction:column !important}.ion-flex-md-column-reverse{flex-direction:column-reverse !important}}@media(min-width: 992px){.ion-flex-lg-row{flex-direction:row !important}.ion-flex-lg-row-reverse{flex-direction:row-reverse !important}.ion-flex-lg-column{flex-direction:column !important}.ion-flex-lg-column-reverse{flex-direction:column-reverse !important}}@media(min-width: 1200px){.ion-flex-xl-row{flex-direction:row !important}.ion-flex-xl-row-reverse{flex-direction:row-reverse !important}.ion-flex-xl-column{flex-direction:column !important}.ion-flex-xl-column-reverse{flex-direction:column-reverse !important}}.ion-wrap{flex-wrap:wrap !important}.ion-nowrap{flex-wrap:nowrap !important}.ion-wrap-reverse{flex-wrap:wrap-reverse !important}.ion-flex-wrap{flex-wrap:wrap !important}.ion-flex-nowrap{flex-wrap:nowrap !important}.ion-flex-wrap-reverse{flex-wrap:wrap-reverse !important}@media(min-width: 576px){.ion-flex-sm-wrap{flex-wrap:wrap !important}.ion-flex-sm-nowrap{flex-wrap:nowrap !important}.ion-flex-sm-wrap-reverse{flex-wrap:wrap-reverse !important}}@media(min-width: 768px){.ion-flex-md-wrap{flex-wrap:wrap !important}.ion-flex-md-nowrap{flex-wrap:nowrap !important}.ion-flex-md-wrap-reverse{flex-wrap:wrap-reverse !important}}@media(min-width: 992px){.ion-flex-lg-wrap{flex-wrap:wrap !important}.ion-flex-lg-nowrap{flex-wrap:nowrap !important}.ion-flex-lg-wrap-reverse{flex-wrap:wrap-reverse !important}}@media(min-width: 1200px){.ion-flex-xl-wrap{flex-wrap:wrap !important}.ion-flex-xl-nowrap{flex-wrap:nowrap !important}.ion-flex-xl-wrap-reverse{flex-wrap:wrap-reverse !important}}.ion-flex-1{flex:1 !important}.ion-flex-auto{flex:auto !important}.ion-flex-initial{flex:initial !important}.ion-flex-none{flex:none !important}@media(min-width: 576px){.ion-flex-sm-1{flex:1 !important}.ion-flex-sm-auto{flex:auto !important}.ion-flex-sm-initial{flex:initial !important}.ion-flex-sm-none{flex:none !important}}@media(min-width: 768px){.ion-flex-md-1{flex:1 !important}.ion-flex-md-auto{flex:auto !important}.ion-flex-md-initial{flex:initial !important}.ion-flex-md-none{flex:none !important}}@media(min-width: 992px){.ion-flex-lg-1{flex:1 !important}.ion-flex-lg-auto{flex:auto !important}.ion-flex-lg-initial{flex:initial !important}.ion-flex-lg-none{flex:none !important}}@media(min-width: 1200px){.ion-flex-xl-1{flex:1 !important}.ion-flex-xl-auto{flex:auto !important}.ion-flex-xl-initial{flex:initial !important}.ion-flex-xl-none{flex:none !important}}.ion-flex-grow-0{flex-grow:0 !important}.ion-flex-grow-1{flex-grow:1 !important}.ion-flex-shrink-0{flex-shrink:0 !important}.ion-flex-shrink-1{flex-shrink:1 !important}@media(min-width: 576px){.ion-flex-sm-grow-0{flex-grow:0 !important}.ion-flex-sm-grow-1{flex-grow:1 !important}.ion-flex-sm-shrink-0{flex-shrink:0 !important}.ion-flex-sm-shrink-1{flex-shrink:1 !important}}@media(min-width: 768px){.ion-flex-md-grow-0{flex-grow:0 !important}.ion-flex-md-grow-1{flex-grow:1 !important}.ion-flex-md-shrink-0{flex-shrink:0 !important}.ion-flex-md-shrink-1{flex-shrink:1 !important}}@media(min-width: 992px){.ion-flex-lg-grow-0{flex-grow:0 !important}.ion-flex-lg-grow-1{flex-grow:1 !important}.ion-flex-lg-shrink-0{flex-shrink:0 !important}.ion-flex-lg-shrink-1{flex-shrink:1 !important}}@media(min-width: 1200px){.ion-flex-xl-grow-0{flex-grow:0 !important}.ion-flex-xl-grow-1{flex-grow:1 !important}.ion-flex-xl-shrink-0{flex-shrink:0 !important}.ion-flex-xl-shrink-1{flex-shrink:1 !important}}.ion-order-first{order:-1 !important}.ion-order-0{order:0 !important}.ion-order-1{order:1 !important}.ion-order-2{order:2 !important}.ion-order-3{order:3 !important}.ion-order-4{order:4 !important}.ion-order-5{order:5 !important}.ion-order-6{order:6 !important}.ion-order-7{order:7 !important}.ion-order-8{order:8 !important}.ion-order-9{order:9 !important}.ion-order-10{order:10 !important}.ion-order-11{order:11 !important}.ion-order-12{order:12 !important}.ion-order-last{order:13 !important}@media(min-width: 576px){.ion-order-sm-first{order:-1 !important}.ion-order-sm-0{order:0 !important}.ion-order-sm-1{order:1 !important}.ion-order-sm-2{order:2 !important}.ion-order-sm-3{order:3 !important}.ion-order-sm-4{order:4 !important}.ion-order-sm-5{order:5 !important}.ion-order-sm-6{order:6 !important}.ion-order-sm-7{order:7 !important}.ion-order-sm-8{order:8 !important}.ion-order-sm-9{order:9 !important}.ion-order-sm-10{order:10 !important}.ion-order-sm-11{order:11 !important}.ion-order-sm-12{order:12 !important}.ion-order-sm-last{order:13 !important}}@media(min-width: 768px){.ion-order-md-first{order:-1 !important}.ion-order-md-0{order:0 !important}.ion-order-md-1{order:1 !important}.ion-order-md-2{order:2 !important}.ion-order-md-3{order:3 !important}.ion-order-md-4{order:4 !important}.ion-order-md-5{order:5 !important}.ion-order-md-6{order:6 !important}.ion-order-md-7{order:7 !important}.ion-order-md-8{order:8 !important}.ion-order-md-9{order:9 !important}.ion-order-md-10{order:10 !important}.ion-order-md-11{order:11 !important}.ion-order-md-12{order:12 !important}.ion-order-md-last{order:13 !important}}@media(min-width: 992px){.ion-order-lg-first{order:-1 !important}.ion-order-lg-0{order:0 !important}.ion-order-lg-1{order:1 !important}.ion-order-lg-2{order:2 !important}.ion-order-lg-3{order:3 !important}.ion-order-lg-4{order:4 !important}.ion-order-lg-5{order:5 !important}.ion-order-lg-6{order:6 !important}.ion-order-lg-7{order:7 !important}.ion-order-lg-8{order:8 !important}.ion-order-lg-9{order:9 !important}.ion-order-lg-10{order:10 !important}.ion-order-lg-11{order:11 !important}.ion-order-lg-12{order:12 !important}.ion-order-lg-last{order:13 !important}}@media(min-width: 1200px){.ion-order-xl-first{order:-1 !important}.ion-order-xl-0{order:0 !important}.ion-order-xl-1{order:1 !important}.ion-order-xl-2{order:2 !important}.ion-order-xl-3{order:3 !important}.ion-order-xl-4{order:4 !important}.ion-order-xl-5{order:5 !important}.ion-order-xl-6{order:6 !important}.ion-order-xl-7{order:7 !important}.ion-order-xl-8{order:8 !important}.ion-order-xl-9{order:9 !important}.ion-order-xl-10{order:10 !important}.ion-order-xl-11{order:11 !important}.ion-order-xl-12{order:12 !important}.ion-order-xl-last{order:13 !important}}/*# sourceMappingURL=flex-utils.css.map */
.ion-hide{display:none !important}.ion-hide-up{display:none !important}.ion-hide-down{display:none !important}@media(min-width: 576px){.ion-hide-sm-up{display:none !important}}@media(max-width: 575.98px){.ion-hide-sm-down{display:none !important}}@media(min-width: 768px){.ion-hide-md-up{display:none !important}}@media(max-width: 767.98px){.ion-hide-md-down{display:none !important}}@media(min-width: 992px){.ion-hide-lg-up{display:none !important}}@media(max-width: 991.98px){.ion-hide-lg-down{display:none !important}}@media(min-width: 1200px){.ion-hide-xl-up{display:none !important}}@media(max-width: 1199.98px){.ion-hide-xl-down{display:none !important}}.ion-display-none{display:none !important}@media(min-width: 576px){.ion-display-sm-none{display:none !important}}@media(min-width: 768px){.ion-display-md-none{display:none !important}}@media(min-width: 992px){.ion-display-lg-none{display:none !important}}@media(min-width: 1200px){.ion-display-xl-none{display:none !important}}.ion-display-inline{display:inline !important}@media(min-width: 576px){.ion-display-sm-inline{display:inline !important}}@media(min-width: 768px){.ion-display-md-inline{display:inline !important}}@media(min-width: 992px){.ion-display-lg-inline{display:inline !important}}@media(min-width: 1200px){.ion-display-xl-inline{display:inline !important}}.ion-display-inline-block{display:inline-block !important}@media(min-width: 576px){.ion-display-sm-inline-block{display:inline-block !important}}@media(min-width: 768px){.ion-display-md-inline-block{display:inline-block !important}}@media(min-width: 992px){.ion-display-lg-inline-block{display:inline-block !important}}@media(min-width: 1200px){.ion-display-xl-inline-block{display:inline-block !important}}.ion-display-block{display:block !important}@media(min-width: 576px){.ion-display-sm-block{display:block !important}}@media(min-width: 768px){.ion-display-md-block{display:block !important}}@media(min-width: 992px){.ion-display-lg-block{display:block !important}}@media(min-width: 1200px){.ion-display-xl-block{display:block !important}}.ion-display-flex{display:flex !important}@media(min-width: 576px){.ion-display-sm-flex{display:flex !important}}@media(min-width: 768px){.ion-display-md-flex{display:flex !important}}@media(min-width: 992px){.ion-display-lg-flex{display:flex !important}}@media(min-width: 1200px){.ion-display-xl-flex{display:flex !important}}.ion-display-inline-flex{display:inline-flex !important}@media(min-width: 576px){.ion-display-sm-inline-flex{display:inline-flex !important}}@media(min-width: 768px){.ion-display-md-inline-flex{display:inline-flex !important}}@media(min-width: 992px){.ion-display-lg-inline-flex{display:inline-flex !important}}@media(min-width: 1200px){.ion-display-xl-inline-flex{display:inline-flex !important}}.ion-display-grid{display:grid !important}@media(min-width: 576px){.ion-display-sm-grid{display:grid !important}}@media(min-width: 768px){.ion-display-md-grid{display:grid !important}}@media(min-width: 992px){.ion-display-lg-grid{display:grid !important}}@media(min-width: 1200px){.ion-display-xl-grid{display:grid !important}}.ion-display-inline-grid{display:inline-grid !important}@media(min-width: 576px){.ion-display-sm-inline-grid{display:inline-grid !important}}@media(min-width: 768px){.ion-display-md-inline-grid{display:inline-grid !important}}@media(min-width: 992px){.ion-display-lg-inline-grid{display:inline-grid !important}}@media(min-width: 1200px){.ion-display-xl-inline-grid{display:inline-grid !important}}.ion-display-table{display:table !important}@media(min-width: 576px){.ion-display-sm-table{display:table !important}}@media(min-width: 768px){.ion-display-md-table{display:table !important}}@media(min-width: 992px){.ion-display-lg-table{display:table !important}}@media(min-width: 1200px){.ion-display-xl-table{display:table !important}}.ion-display-table-cell{display:table-cell !important}@media(min-width: 576px){.ion-display-sm-table-cell{display:table-cell !important}}@media(min-width: 768px){.ion-display-md-table-cell{display:table-cell !important}}@media(min-width: 992px){.ion-display-lg-table-cell{display:table-cell !important}}@media(min-width: 1200px){.ion-display-xl-table-cell{display:table-cell !important}}.ion-display-table-row{display:table-row !important}@media(min-width: 576px){.ion-display-sm-table-row{display:table-row !important}}@media(min-width: 768px){.ion-display-md-table-row{display:table-row !important}}@media(min-width: 992px){.ion-display-lg-table-row{display:table-row !important}}@media(min-width: 1200px){.ion-display-xl-table-row{display:table-row !important}}/*# sourceMappingURL=display.css.map */
@media(prefers-color-scheme: dark){:root{--ion-color-primary: #4d8dff;--ion-color-primary-rgb: 77, 141, 255;--ion-color-primary-contrast: #000;--ion-color-primary-contrast-rgb: 0, 0, 0;--ion-color-primary-shade: #447ce0;--ion-color-primary-tint: #5f98ff;--ion-color-secondary: #46b1ff;--ion-color-secondary-rgb: 70, 177, 255;--ion-color-secondary-contrast: #000;--ion-color-secondary-contrast-rgb: 0, 0, 0;--ion-color-secondary-shade: #3e9ce0;--ion-color-secondary-tint: #59b9ff;--ion-color-tertiary: #8482fb;--ion-color-tertiary-rgb: 132, 130, 251;--ion-color-tertiary-contrast: #000;--ion-color-tertiary-contrast-rgb: 0, 0, 0;--ion-color-tertiary-shade: #7472dd;--ion-color-tertiary-tint: #908ffb;--ion-color-success: #2dd55b;--ion-color-success-rgb: 45, 213, 91;--ion-color-success-contrast: #000;--ion-color-success-contrast-rgb: 0, 0, 0;--ion-color-success-shade: #28bb50;--ion-color-success-tint: #42d96b;--ion-color-warning: #ffce31;--ion-color-warning-rgb: 255, 206, 49;--ion-color-warning-contrast: #000;--ion-color-warning-contrast-rgb: 0, 0, 0;--ion-color-warning-shade: #e0b52b;--ion-color-warning-tint: #ffd346;--ion-color-danger: #f24c58;--ion-color-danger-rgb: 242, 76, 88;--ion-color-danger-contrast: #000;--ion-color-danger-contrast-rgb: 0, 0, 0;--ion-color-danger-shade: #d5434d;--ion-color-danger-tint: #f35e69;--ion-color-light: #222428;--ion-color-light-rgb: 34, 36, 40;--ion-color-light-contrast: #fff;--ion-color-light-contrast-rgb: 255, 255, 255;--ion-color-light-shade: #1e2023;--ion-color-light-tint: #383a3e;--ion-color-medium: #989aa2;--ion-color-medium-rgb: 152, 154, 162;--ion-color-medium-contrast: #000;--ion-color-medium-contrast-rgb: 0, 0, 0;--ion-color-medium-shade: #86888f;--ion-color-medium-tint: #a2a4ab;--ion-color-dark: #f4f5f8;--ion-color-dark-rgb: 244, 245, 248;--ion-color-dark-contrast: #000;--ion-color-dark-contrast-rgb: 0, 0, 0;--ion-color-dark-shade: #d7d8da;--ion-color-dark-tint: #f5f6f9}:root.ios{--ion-background-color: #000000;--ion-background-color-rgb: 0, 0, 0;--ion-text-color: #ffffff;--ion-text-color-rgb: 255, 255, 255;--ion-background-color-step-50: #0d0d0d;--ion-background-color-step-100: #1a1a1a;--ion-background-color-step-150: #262626;--ion-background-color-step-200: #333333;--ion-background-color-step-250: #404040;--ion-background-color-step-300: #4d4d4d;--ion-background-color-step-350: #595959;--ion-background-color-step-400: #666666;--ion-background-color-step-450: #737373;--ion-background-color-step-500: #808080;--ion-background-color-step-550: #8c8c8c;--ion-background-color-step-600: #999999;--ion-background-color-step-650: #a6a6a6;--ion-background-color-step-700: #b3b3b3;--ion-background-color-step-750: #bfbfbf;--ion-background-color-step-800: #cccccc;--ion-background-color-step-850: #d9d9d9;--ion-background-color-step-900: #e6e6e6;--ion-background-color-step-950: #f2f2f2;--ion-text-color-step-50: #f2f2f2;--ion-text-color-step-100: #e6e6e6;--ion-text-color-step-150: #d9d9d9;--ion-text-color-step-200: #cccccc;--ion-text-color-step-250: #bfbfbf;--ion-text-color-step-300: #b3b3b3;--ion-text-color-step-350: #a6a6a6;--ion-text-color-step-400: #999999;--ion-text-color-step-450: #8c8c8c;--ion-text-color-step-500: #808080;--ion-text-color-step-550: #737373;--ion-text-color-step-600: #666666;--ion-text-color-step-650: #595959;--ion-text-color-step-700: #4d4d4d;--ion-text-color-step-750: #404040;--ion-text-color-step-800: #333333;--ion-text-color-step-850: #262626;--ion-text-color-step-900: #1a1a1a;--ion-text-color-step-950: #0d0d0d;--ion-item-background: #000000;--ion-card-background: #1c1c1d}:root.ios ion-modal{--ion-background-color: var(--ion-color-step-100, var(--ion-background-color-step-100));--ion-toolbar-background: var(--ion-color-step-150, var(--ion-background-color-step-150));--ion-toolbar-border-color: var(--ion-color-step-250, var(--ion-background-color-step-250))}:root.md{--ion-background-color: #121212;--ion-background-color-rgb: 18, 18, 18;--ion-text-color: #ffffff;--ion-text-color-rgb: 255, 255, 255;--ion-background-color-step-50: #1e1e1e;--ion-background-color-step-100: #2a2a2a;--ion-background-color-step-150: #363636;--ion-background-color-step-200: #414141;--ion-background-color-step-250: #4d4d4d;--ion-background-color-step-300: #595959;--ion-background-color-step-350: #656565;--ion-background-color-step-400: #717171;--ion-background-color-step-450: #7d7d7d;--ion-background-color-step-500: #898989;--ion-background-color-step-550: #949494;--ion-background-color-step-600: #a0a0a0;--ion-background-color-step-650: #acacac;--ion-background-color-step-700: #b8b8b8;--ion-background-color-step-750: #c4c4c4;--ion-background-color-step-800: #d0d0d0;--ion-background-color-step-850: #dbdbdb;--ion-background-color-step-900: #e7e7e7;--ion-background-color-step-950: #f3f3f3;--ion-text-color-step-50: #f3f3f3;--ion-text-color-step-100: #e7e7e7;--ion-text-color-step-150: #dbdbdb;--ion-text-color-step-200: #d0d0d0;--ion-text-color-step-250: #c4c4c4;--ion-text-color-step-300: #b8b8b8;--ion-text-color-step-350: #acacac;--ion-text-color-step-400: #a0a0a0;--ion-text-color-step-450: #949494;--ion-text-color-step-500: #898989;--ion-text-color-step-550: #7d7d7d;--ion-text-color-step-600: #717171;--ion-text-color-step-650: #656565;--ion-text-color-step-700: #595959;--ion-text-color-step-750: #4d4d4d;--ion-text-color-step-800: #414141;--ion-text-color-step-850: #363636;--ion-text-color-step-900: #2a2a2a;--ion-text-color-step-950: #1e1e1e;--ion-item-background: #1e1e1e;--ion-toolbar-background: #1f1f1f;--ion-tab-bar-background: #1f1f1f;--ion-card-background: #1e1e1e}}/*# sourceMappingURL=dark.system.css.map */
/* Ionic Variables and Theming. For more info, please see:
http://ionicframework.com/docs/theming/ */

/* Import responsive styles */

/* Responsive Design System for AI Prompt Vault */

/* Mobile First Approach */

/* Base styles for mobile devices (320px - 767px) */

.mobile-only {
  display: block;
}

.tablet-only,
.desktop-only {
  display: none;
}

/* Touch-friendly tap targets */

button,
.ion-activatable,
.ion-selectable {
  min-height: 44px;
  min-width: 44px;
}

/* Mobile navigation improvements */

.mobile-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--app-z-fixed);
  background: var(--ion-background-color);
  border-top: 1px solid var(--ion-border-color);
  padding: env(safe-area-inset-bottom) 0 0 0;
}

/* Mobile-optimized cards */

.prompt-card,
.category-card {
  margin: var(--app-spacing-sm);
  border-radius: var(--app-radius-lg);
}

/* Mobile typography */

.mobile-title {
  font-size: var(--app-font-size-lg);
  font-weight: var(--app-font-weight-semibold);
  line-height: var(--app-line-height-tight);
}

.mobile-body {
  font-size: var(--app-font-size-sm);
  line-height: var(--app-line-height-normal);
}

/* Mobile spacing */

.mobile-padding {
  padding: var(--app-spacing-sm);
}

.mobile-margin {
  margin: var(--app-spacing-sm);
}

/* Mobile grid system */

.mobile-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--app-spacing-sm);
}

/* Tablet styles (768px - 1023px) */

@media (min-width: 768px) {
  .mobile-only {
    display: none;
  }
  
  .tablet-only {
    display: block;
  }
  
  .desktop-only {
    display: none;
  }

  /* Tablet layout improvements */
  .tablet-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--app-spacing-md);
  }

  /* Tablet cards */
  .prompt-card,
  .category-card {
    margin: var(--app-spacing-md);
    border-radius: var(--app-radius-xl);
  }

  /* Tablet typography */
  .tablet-title {
    font-size: var(--app-font-size-xl);
    font-weight: var(--app-font-weight-semibold);
  }

  /* Tablet sidebar */
  .tablet-sidebar {
    width: 280px;
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    background: var(--app-surface);
    border-right: 1px solid var(--app-outline);
    overflow-y: auto;
    z-index: var(--app-z-sticky);
  }

  .tablet-main {
    margin-left: 280px;
    min-height: 100vh;
  }

  /* Tablet floating elements */
  .tablet-fab {
    bottom: var(--app-spacing-lg);
    right: var(--app-spacing-lg);
  }
}

/* Desktop styles (1024px and up) */

@media (min-width: 1024px) {
  .tablet-only {
    display: none;
  }
  
  .desktop-only {
    display: block;
  }

  /* Desktop grid system */
  .desktop-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--app-spacing-lg);
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--app-spacing-lg);
  }

  .desktop-grid-4 {
    grid-template-columns: repeat(4, 1fr);
  }

  .desktop-grid-2 {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Desktop cards */
  .prompt-card,
  .category-card {
    margin: var(--app-spacing-lg);
    border-radius: var(--app-radius-2xl);
    transition: transform var(--app-duration-fast) ease,
                box-shadow var(--app-duration-fast) ease;
  }

  .prompt-card:hover,
  .category-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--app-shadow-lg);
  }

  /* Desktop typography */
  .desktop-title {
    font-size: var(--app-font-size-2xl);
    font-weight: var(--app-font-weight-bold);
  }

  /* Desktop sidebar */
  .desktop-sidebar {
    width: 320px;
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    background: var(--app-surface);
    border-right: 1px solid var(--app-outline);
    overflow-y: auto;
    z-index: var(--app-z-sticky);
  }

  .desktop-main {
    margin-left: 320px;
    min-height: 100vh;
  }

  /* Desktop content area */
  .desktop-content {
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--app-spacing-xl);
  }

  /* Desktop floating elements */
  .desktop-fab {
    bottom: var(--app-spacing-xl);
    right: var(--app-spacing-xl);
  }

  /* Desktop modal improvements */
  ion-modal.desktop-modal {
    --width: 800px;
    --height: 600px;
    --border-radius: var(--app-radius-2xl);
  }
}

/* Large desktop styles (1200px and up) */

@media (min-width: 1200px) {
  .desktop-grid {
    grid-template-columns: repeat(4, 1fr);
    max-width: 1400px;
  }

  .desktop-content {
    padding: var(--app-spacing-2xl);
  }

  /* Large desktop typography */
  .large-title {
    font-size: var(--app-font-size-3xl);
    font-weight: var(--app-font-weight-bold);
  }
}

/* Ultra-wide desktop styles (1400px and up) */

@media (min-width: 1400px) {
  .desktop-grid {
    grid-template-columns: repeat(5, 1fr);
    max-width: 1600px;
  }
}

/* Component-specific responsive styles */

/* Search bar responsive */

.search-container {
  position: sticky;
  top: 0;
  z-index: var(--app-z-sticky);
  background: var(--ion-background-color);
  border-bottom: 1px solid var(--app-outline);
  padding: var(--app-spacing-sm);
}

@media (min-width: 768px) {
  .search-container {
    padding: var(--app-spacing-md);
  }
}

@media (min-width: 1024px) {
  .search-container {
    padding: var(--app-spacing-lg);
  }
}

/* Settings page responsive */

.settings-container {
  max-width: 100%;
  margin: 0 auto;
  padding: var(--app-spacing-sm);
}

@media (min-width: 768px) {
  .settings-container {
    max-width: 800px;
    padding: var(--app-spacing-md);
  }
}

@media (min-width: 1024px) {
  .settings-container {
    max-width: 1000px;
    padding: var(--app-spacing-lg);
  }
}

/* Form responsive */

.form-container {
  width: 100%;
  max-width: 100%;
}

@media (min-width: 768px) {
  .form-container {
    max-width: 600px;
    margin: 0 auto;
  }
}

@media (min-width: 1024px) {
  .form-container {
    max-width: 800px;
  }
}

/* Stats grid responsive */

.stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--app-spacing-sm);
}

@media (min-width: 768px) {
  .stats-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--app-spacing-md);
  }
}

/* Action buttons responsive */

.action-buttons {
  display: flex;
  flex-direction: column;
  gap: var(--app-spacing-sm);
}

@media (min-width: 768px) {
  .action-buttons {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
}

/* Loading states responsive */

.loading-container,
.error-container,
.empty-state {
  padding: var(--app-spacing-xl);
  text-align: center;
  min-height: 200px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/* Responsive images */

.responsive-image {
  max-width: 100%;
  height: auto;
  border-radius: var(--app-radius-md);
}

/* Responsive text truncation */

.text-truncate-mobile {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .text-truncate-mobile {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
  }
}

/* Responsive visibility helpers */

.hide-on-mobile {
  display: none;
}

@media (min-width: 768px) {
  .hide-on-mobile {
    display: block;
  }
}

.hide-on-tablet {
  display: block;
}

@media (min-width: 768px) and (max-width: 1023px) {
  .hide-on-tablet {
    display: none;
  }
}

.hide-on-desktop {
  display: block;
}

@media (min-width: 1024px) {
  .hide-on-desktop {
    display: none;
  }
}

/* Responsive spacing utilities */

.responsive-margin {
  margin: var(--app-spacing-sm);
}

@media (min-width: 768px) {
  .responsive-margin {
    margin: var(--app-spacing-md);
  }
}

@media (min-width: 1024px) {
  .responsive-margin {
    margin: var(--app-spacing-lg);
  }
}

.responsive-padding {
  padding: var(--app-spacing-sm);
}

@media (min-width: 768px) {
  .responsive-padding {
    padding: var(--app-spacing-md);
  }
}

@media (min-width: 1024px) {
  .responsive-padding {
    padding: var(--app-spacing-lg);
  }
}

/* Safe area handling */

.safe-area-top {
  padding-top: env(safe-area-inset-top);
}

.safe-area-bottom {
  padding-bottom: env(safe-area-inset-bottom);
}

.safe-area-left {
  padding-left: env(safe-area-inset-left);
}

.safe-area-right {
  padding-right: env(safe-area-inset-right);
}

/* Landscape orientation adjustments */

@media (orientation: landscape) and (max-height: 500px) {
  .landscape-compact {
    padding: var(--app-spacing-xs);
  }
  
  .landscape-compact .prompt-card,
  .landscape-compact .category-card {
    margin: var(--app-spacing-xs);
    padding: var(--app-spacing-sm);
  }
}

/* Print styles */

@media print {
  .no-print,
  .hide-print {
    display: none !important;
  }
  
  .prompt-card,
  .category-card {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ccc;
    margin-bottom: var(--app-spacing-md);
  }
  
  body {
    font-size: 12pt;
    line-height: 1.4;
  }
}

/* High DPI displays */

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .high-dpi-icon {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
}

/* Reduce motion for accessibility */

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  
  .prompt-card,
  .category-card {
    transform: none !important;
  }
}

/* High contrast mode */

@media (prefers-contrast: high) {
  .prompt-card,
  .category-card {
    border: 2px solid var(--ion-text-color);
  }
  
  button,
  .ion-activatable {
    border: 2px solid var(--ion-text-color);
  }
}

/* Focus management for keyboard navigation */

.keyboard-focus:focus-visible {
  outline: 3px solid var(--ion-color-primary);
  outline-offset: 2px;
}

/* Scrollbar styling */

.custom-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: var(--ion-color-medium) var(--ion-background-color);
}

.custom-scrollbar::-webkit-scrollbar {
  width: 8px;
}

.custom-scrollbar::-webkit-scrollbar-track {
  background: var(--ion-background-color);
}

.custom-scrollbar::-webkit-scrollbar-thumb {
  background-color: var(--ion-color-medium);
  border-radius: 4px;
  border: 2px solid var(--ion-background-color);
}

/* Animation utilities */

.fade-in {
  animation: fadeIn var(--app-duration-normal) ease-in;
}

.slide-up {
  animation: slideUp var(--app-duration-normal) ease-out;
}

.bounce-in {
  animation: bounceIn var(--app-duration-slow) ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideUp {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

@keyframes bounceIn {
  0% { transform: scale(0.3); opacity: 0; }
  50% { transform: scale(1.05); }
  70% { transform: scale(0.9); }
  100% { transform: scale(1); opacity: 1; }
}

/* Skeleton loading states */

.skeleton {
  background: linear-gradient(90deg,
    var(--ion-color-light) 25%,
    var(--ion-color-light-shade) 50%,
    var(--ion-color-light) 75%
  );
  background-size: 200% 100%;
  animation: skeleton-loading 1.5s infinite;
}

@keyframes skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.skeleton-text {
  height: 1em;
  margin-bottom: 0.5em;
  border-radius: 4px;
}

.skeleton-title {
  height: 1.5em;
  width: 60%;
  margin-bottom: 1em;
  border-radius: 4px;
}

.skeleton-paragraph {
  height: 0.8em;
  margin-bottom: 0.5em;
  border-radius: 4px;
}

.skeleton-paragraph:last-child {
  width: 80%;
}

/** Ionic CSS Variables **/

:root {
  /** Primary Colors **/
  --ion-color-primary: #3880ff;
  --ion-color-primary-rgb: 56, 128, 255;
  --ion-color-primary-contrast: #ffffff;
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #3171e0;
  --ion-color-primary-tint: #4c8dff;

  /** Secondary Colors **/
  --ion-color-secondary: #3dc2ff;
  --ion-color-secondary-rgb: 61, 194, 255;
  --ion-color-secondary-contrast: #ffffff;
  --ion-color-secondary-contrast-rgb: 255, 255, 255;
  --ion-color-secondary-shade: #36abe0;
  --ion-color-secondary-tint: #50c8ff;

  /** Tertiary Colors **/
  --ion-color-tertiary: #5260ff;
  --ion-color-tertiary-rgb: 82, 96, 255;
  --ion-color-tertiary-contrast: #ffffff;
  --ion-color-tertiary-contrast-rgb: 255, 255, 255;
  --ion-color-tertiary-shade: #4854e0;
  --ion-color-tertiary-tint: #6370ff;

  /** Success Colors **/
  --ion-color-success: #2dd36f;
  --ion-color-success-rgb: 45, 211, 111;
  --ion-color-success-contrast: #ffffff;
  --ion-color-success-contrast-rgb: 255, 255, 255;
  --ion-color-success-shade: #28ba62;
  --ion-color-success-tint: #42d77d;

  /** Warning Colors **/
  --ion-color-warning: #ffc409;
  --ion-color-warning-rgb: 255, 196, 9;
  --ion-color-warning-contrast: #000000;
  --ion-color-warning-contrast-rgb: 0, 0, 0;
  --ion-color-warning-shade: #e0ac08;
  --ion-color-warning-tint: #ffca22;

  /** Danger Colors **/
  --ion-color-danger: #eb445a;
  --ion-color-danger-rgb: 235, 68, 90;
  --ion-color-danger-contrast: #ffffff;
  --ion-color-danger-contrast-rgb: 255, 255, 255;
  --ion-color-danger-shade: #cf3c4f;
  --ion-color-danger-tint: #ed576b;

  /** Dark Colors **/
  --ion-color-dark: #222428;
  --ion-color-dark-rgb: 34, 36, 40;
  --ion-color-dark-contrast: #ffffff;
  --ion-color-dark-contrast-rgb: 255, 255, 255;
  --ion-color-dark-shade: #1e2023;
  --ion-color-dark-tint: #383a3e;

  /** Medium Colors **/
  --ion-color-medium: #92949c;
  --ion-color-medium-rgb: 146, 148, 156;
  --ion-color-medium-contrast: #ffffff;
  --ion-color-medium-contrast-rgb: 255, 255, 255;
  --ion-color-medium-shade: #808289;
  --ion-color-medium-tint: #9d9fa6;

  /** Light Colors **/
  --ion-color-light: #f4f5f8;
  --ion-color-light-rgb: 244, 245, 248;
  --ion-color-light-contrast: #000000;
  --ion-color-light-contrast-rgb: 0, 0, 0;
  --ion-color-light-shade: #d7d8da;
  --ion-color-light-tint: #f5f6f9;

  /* Custom App Colors */
  --app-color-gradient-start: #667eea;
  --app-color-gradient-end: #764ba2;
  --app-color-accent: #ff6b6b;
  --app-color-accent-light: #ff8e8e;
  --app-color-text-heading: #2d3748;
  --app-color-text-body: #4a5568;
  --app-color-text-muted: #718096;
  --app-color-border: #e2e8f0;
  --app-color-surface: #ffffff;
  --app-color-surface-variant: #f7fafc;
  
  /* Spacing */
  --app-spacing-xs: 4px;
  --app-spacing-sm: 8px;
  --app-spacing-md: 16px;
  --app-spacing-lg: 24px;
  --app-spacing-xl: 32px;
  --app-spacing-2xl: 48px;
  
  /* Border Radius */
  --app-radius-sm: 4px;
  --app-radius-md: 8px;
  --app-radius-lg: 12px;
  --app-radius-xl: 16px;
  --app-radius-2xl: 24px;
  --app-radius-full: 9999px;
  
  /* Typography */
  --app-font-size-xs: 0.75rem;
  --app-font-size-sm: 0.875rem;
  --app-font-size-md: 1rem;
  --app-font-size-lg: 1.125rem;
  --app-font-size-xl: 1.25rem;
  --app-font-size-2xl: 1.5rem;
  --app-font-size-3xl: 1.875rem;
  --app-font-size-4xl: 2.25rem;
  
  --app-font-weight-normal: 400;
  --app-font-weight-medium: 500;
  --app-font-weight-semibold: 600;
  --app-font-weight-bold: 700;
  
  --app-line-height-tight: 1.25;
  --app-line-height-normal: 1.5;
  --app-line-height-relaxed: 1.75;
  
  /* Shadows */
  --app-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --app-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --app-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --app-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  
  /* Z-Index Scale */
  --app-z-dropdown: 1000;
  --app-z-sticky: 1020;
  --app-z-fixed: 1030;
  --app-z-modal-backdrop: 1040;
  --app-z-modal: 1050;
  --app-z-popover: 1060;
  --app-z-tooltip: 1070;
  --app-z-toast: 1080;
  
  /* Animation Durations */
  --app-duration-fast: 150ms;
  --app-duration-normal: 300ms;
  --app-duration-slow: 500ms;
  
  /* Breakpoints (for reference, used in media queries) */
  --app-breakpoint-sm: 576px;
  --app-breakpoint-md: 768px;
  --app-breakpoint-lg: 992px;
  --app-breakpoint-xl: 1200px;
  --app-breakpoint-2xl: 1400px;
}

/* Light Theme Variables */

:root {
  --ion-background-color: #ffffff;
  --ion-background-color-rgb: 255, 255, 255;
  --ion-text-color: #000000;
  --ion-text-color-rgb: 0, 0, 0;
  --ion-backdrop-color: #000000;
  --ion-backdrop-opacity: 0.32;
  --ion-overlay-background-color: #ffffff;
  --ion-border-color: #e2e8f0;
  --ion-box-shadow-color: rgba(0, 0, 0, 0.1);
  
  /* Custom Light Theme */
  --app-background: #ffffff;
  --app-surface: #f8f9fa;
  --app-surface-variant: #f1f3f4;
  --app-on-surface: #202124;
  --app-on-surface-variant: #5f6368;
  --app-outline: #dadce0;
  --app-outline-variant: #e8eaed;
}

/* Dark Theme Variables */

@media (prefers-color-scheme: dark) {
  :root {
    --ion-color-primary: #428cff;
    --ion-color-primary-rgb: 66, 140, 255;
    --ion-color-primary-contrast: #ffffff;
    --ion-color-primary-contrast-rgb: 255, 255, 255;
    --ion-color-primary-shade: #3a7be0;
    --ion-color-primary-tint: #5598ff;

    --ion-color-secondary: #50c8ff;
    --ion-color-secondary-rgb: 80, 200, 255;
    --ion-color-secondary-contrast: #ffffff;
    --ion-color-secondary-contrast-rgb: 255, 255, 255;
    --ion-color-secondary-shade: #46b0e0;
    --ion-color-secondary-tint: #62ceff;

    --ion-color-tertiary: #6a64ff;
    --ion-color-tertiary-rgb: 106, 100, 255;
    --ion-color-tertiary-contrast: #ffffff;
    --ion-color-tertiary-contrast-rgb: 255, 255, 255;
    --ion-color-tertiary-shade: #5d58e0;
    --ion-color-tertiary-tint: #7974ff;

    --ion-color-success: #2fdf75;
    --ion-color-success-rgb: 47, 223, 117;
    --ion-color-success-contrast: #000000;
    --ion-color-success-contrast-rgb: 0, 0, 0;
    --ion-color-success-shade: #29c467;
    --ion-color-success-tint: #44e283;

    --ion-color-warning: #ffd534;
    --ion-color-warning-rgb: 255, 213, 52;
    --ion-color-warning-contrast: #000000;
    --ion-color-warning-contrast-rgb: 0, 0, 0;
    --ion-color-warning-shade: #e0bb2e;
    --ion-color-warning-tint: #ffd948;

    --ion-color-danger: #ff4961;
    --ion-color-danger-rgb: 255, 73, 97;
    --ion-color-danger-contrast: #ffffff;
    --ion-color-danger-contrast-rgb: 255, 255, 255;
    --ion-color-danger-shade: #e04055;
    --ion-color-danger-tint: #ff5b71;

    --ion-color-dark: #f4f5f8;
    --ion-color-dark-rgb: 244, 245, 248;
    --ion-color-dark-contrast: #000000;
    --ion-color-dark-contrast-rgb: 0, 0, 0;
    --ion-color-dark-shade: #d7d8da;
    --ion-color-dark-tint: #f5f6f9;

    --ion-color-medium: #989aa2;
    --ion-color-medium-rgb: 152, 154, 162;
    --ion-color-medium-contrast: #000000;
    --ion-color-medium-contrast-rgb: 0, 0, 0;
    --ion-color-medium-shade: #86888f;
    --ion-color-medium-tint: #a2a4ab;

    --ion-color-light: #222428;
    --ion-color-light-rgb: 34, 36, 40;
    --ion-color-light-contrast: #ffffff;
    --ion-color-light-contrast-rgb: 255, 255, 255;
    --ion-color-light-shade: #1e2023;
    --ion-color-light-tint: #383a3e;
  }

  /* Dark Theme Background */
  :root {
    --ion-background-color: #0d1117;
    --ion-background-color-rgb: 13, 17, 23;
    --ion-text-color: #ffffff;
    --ion-text-color-rgb: 255, 255, 255;
    --ion-backdrop-color: #000000;
    --ion-backdrop-opacity: 0.6;
    --ion-overlay-background-color: #161b22;
    --ion-border-color: #30363d;
    --ion-box-shadow-color: rgba(0, 0, 0, 0.5);
    
    /* Custom Dark Theme */
    --app-background: #0d1117;
    --app-surface: #161b22;
    --app-surface-variant: #21262d;
    --app-on-surface: #f0f6fc;
    --app-on-surface-variant: #8b949e;
    --app-outline: #30363d;
    --app-outline-variant: #21262d;
    --app-color-text-heading: #f0f6fc;
    --app-color-text-body: #c9d1d9;
    --app-color-text-muted: #8b949e;
  }

  /* Dark theme specific component adjustments */
  .ios body {
    --ion-background-color: #000000;
    --ion-background-color-rgb: 0, 0, 0;
    --ion-text-color: #ffffff;
    --ion-text-color-rgb: 255, 255, 255;
  }

  .md body {
    --ion-background-color: #121212;
    --ion-background-color-rgb: 18, 18, 18;
    --ion-text-color: #ffffff;
    --ion-text-color-rgb: 255, 255, 255;
  }
}

/* Force Dark Theme (when manually enabled) */

.dark-theme {
  --ion-color-primary: #428cff;
  --ion-color-primary-rgb: 66, 140, 255;
  --ion-color-primary-contrast: #ffffff;
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #3a7be0;
  --ion-color-primary-tint: #5598ff;

  --ion-background-color: #0d1117;
  --ion-background-color-rgb: 13, 17, 23;
  --ion-text-color: #ffffff;
  --ion-text-color-rgb: 255, 255, 255;
  --ion-backdrop-color: #000000;
  --ion-backdrop-opacity: 0.6;
  --ion-overlay-background-color: #161b22;
  --ion-border-color: #30363d;
  --ion-box-shadow-color: rgba(0, 0, 0, 0.5);
  
  /* Custom Dark Theme */
  --app-background: #0d1117;
  --app-surface: #161b22;
  --app-surface-variant: #21262d;
  --app-on-surface: #f0f6fc;
  --app-on-surface-variant: #8b949e;
  --app-outline: #30363d;
  --app-outline-variant: #21262d;
  --app-color-text-heading: #f0f6fc;
  --app-color-text-body: #c9d1d9;
  --app-color-text-muted: #8b949e;
}

/* Force Light Theme (when manually enabled) */

.light-theme {
  --ion-background-color: #ffffff;
  --ion-background-color-rgb: 255, 255, 255;
  --ion-text-color: #000000;
  --ion-text-color-rgb: 0, 0, 0;
  --ion-backdrop-color: #000000;
  --ion-backdrop-opacity: 0.32;
  --ion-overlay-background-color: #ffffff;
  --ion-border-color: #e2e8f0;
  --ion-box-shadow-color: rgba(0, 0, 0, 0.1);
  
  /* Custom Light Theme */
  --app-background: #ffffff;
  --app-surface: #f8f9fa;
  --app-surface-variant: #f1f3f4;
  --app-on-surface: #202124;
  --app-on-surface-variant: #5f6368;
  --app-outline: #dadce0;
  --app-outline-variant: #e8eaed;
  --app-color-text-heading: #2d3748;
  --app-color-text-body: #4a5568;
  --app-color-text-muted: #718096;
}

/* Responsive Design Utilities */

@media (max-width: 575.98px) {
  :root {
    --app-container-padding: var(--app-spacing-sm);
    --app-font-size-responsive-lg: var(--app-font-size-md);
    --app-font-size-responsive-xl: var(--app-font-size-lg);
  }
}

@media (min-width: 576px) and (max-width: 767.98px) {
  :root {
    --app-container-padding: var(--app-spacing-md);
    --app-font-size-responsive-lg: var(--app-font-size-lg);
    --app-font-size-responsive-xl: var(--app-font-size-xl);
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {
  :root {
    --app-container-padding: var(--app-spacing-lg);
  }
}

@media (min-width: 992px) {
  :root {
    --app-container-padding: var(--app-spacing-xl);
  }
}

/* High contrast mode support */

@media (prefers-contrast: high) {
  :root {
    --ion-color-primary: #0066cc;
    --ion-color-danger: #cc0000;
    --ion-color-success: #006600;
    --ion-color-warning: #cc6600;
    --app-outline: #000000;
    --ion-border-color: #000000;
  }
  
  .dark-theme {
    --app-outline: #ffffff;
    --ion-border-color: #ffffff;
  }
}

/* Reduced motion support */

@media (prefers-reduced-motion: reduce) {
  :root {
    --app-duration-fast: 0ms;
    --app-duration-normal: 0ms;
    --app-duration-slow: 0ms;
  }
  
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Focus visible improvements */

:focus-visible {
  outline: 2px solid var(--ion-color-primary);
  outline-offset: 2px;
}

/* Print styles */

@media print {
  :root {
    --ion-background-color: white;
    --ion-text-color: black;
    --app-background: white;
    --app-on-surface: black;
  }
  
  .no-print {
    display: none !important;
  }
}

/* Component-specific responsive styles */

.app-container {
  max-width: 100%;
  margin: 0 auto;
  padding: 0 var(--app-container-padding, var(--app-spacing-md));
}

@media (min-width: 576px) {
  .app-container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  .app-container {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  .app-container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .app-container {
    max-width: 1140px;
  }
}

@media (min-width: 1400px) {
  .app-container {
    max-width: 1320px;
  }
}
