/* Mystical Bootstrap Theme - Occult Mystic */
/* This file overrides Bootstrap's default colors with mystical theme colors */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600&family=Crimson+Text:ital@0;1&display=swap');

:root {
  /* Mystical color palette */
  --mystic-dark: #0a0a0f;
  --mystic-purple-dark: #1a0033;
  --mystic-purple: #330066;
  --mystic-purple-medium: #220044;
  --mystic-purple-light: #b794f6;
  --mystic-lavender: #e9d8fd;
  --mystic-pink: #f687b3;
  --mystic-text: #e0d5ff;
  
  /* Bootstrap color overrides */
  --bs-primary: #b794f6;
  --bs-secondary: #330066;
  --bs-success: #9ae6b4;
  --bs-info: #90cdf4;
  --bs-warning: #fbd38d;
  --bs-danger: #f687b3;
  --bs-light: #e9d8fd;
  --bs-dark: #1a0033;
  
  /* RGB values for Bootstrap */
  --bs-primary-rgb: 183, 148, 246;
  --bs-secondary-rgb: 51, 0, 102;
  --bs-success-rgb: 154, 230, 180;
  --bs-info-rgb: 144, 205, 244;
  --bs-warning-rgb: 251, 211, 141;
  --bs-danger-rgb: 246, 135, 179;
  --bs-light-rgb: 233, 216, 253;
  --bs-dark-rgb: 26, 0, 51;
  
  /* Component colors */
  --bs-body-bg: #0a0a0f;
  --bs-body-color: #e0d5ff;
  --bs-border-color: rgba(183, 148, 246, 0.3);
  --bs-border-color-translucent: rgba(183, 148, 246, 0.175);
}

/* Body and base styles */
body {
  background-color: var(--mystic-dark);
  color: var(--mystic-text);
  font-family: 'Crimson Text', serif;
  background-image: 
    radial-gradient(circle at 20% 80%, rgba(26, 0, 51, 0.3) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(51, 0, 102, 0.3) 0%, transparent 50%),
    radial-gradient(circle at 40% 40%, rgba(34, 0, 68, 0.3) 0%, transparent 50%);
  background-attachment: fixed;
}

/* Typography */
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Cinzel', serif;
  color: var(--mystic-lavender);
  font-weight: 600;
}

a {
  color: var(--mystic-purple-light);
  text-decoration: none;
}

a:hover {
  color: var(--mystic-pink);
  text-decoration: none;
}

/* Cards */
.card {
  background-color: rgba(26, 0, 51, 0.6);
  border: 1px solid var(--bs-border-color);
  backdrop-filter: blur(10px);
  box-shadow: 0 0 20px rgba(183, 148, 246, 0.1);
}

.card-header {
  background-color: rgba(51, 0, 102, 0.5);
  border-bottom: 1px solid var(--bs-border-color);
  font-family: 'Cinzel', serif;
}

.card-body {
  background-color: rgba(10, 10, 15, 0.3);
}

/* Buttons */
.btn {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  border-radius: 10px;
  transition: all 0.3s ease;
}

.btn-primary {
  background: linear-gradient(45deg, #b794f6, #e9d8fd);
  border-color: #b794f6;
  color: #0a0a0f;
}

.btn-primary:hover, .btn-primary:focus {
  background: linear-gradient(45deg, #e9d8fd, #b794f6);
  border-color: #e9d8fd;
  box-shadow: 0 0 20px rgba(183, 148, 246, 0.5);
  transform: translateY(-2px);
}

.btn-secondary {
  background-color: #330066;
  border-color: #330066;
  color: #e9d8fd;
}

.btn-secondary:hover, .btn-secondary:focus {
  background-color: #220044;
  border-color: #220044;
  box-shadow: 0 0 15px rgba(51, 0, 102, 0.5);
}

.btn-danger {
  background: linear-gradient(45deg, #f687b3, #fc8181);
  border-color: #f687b3;
  color: #0a0a0f;
}

.btn-danger:hover, .btn-danger:focus {
  background: linear-gradient(45deg, #fc8181, #f687b3);
  border-color: #fc8181;
  box-shadow: 0 0 20px rgba(246, 135, 179, 0.5);
}

.btn-success {
  background-color: #48bb78;
  border-color: #48bb78;
  color: #0a0a0f;
}

.btn-info {
  background-color: #4299e1;
  border-color: #4299e1;
  color: #0a0a0f;
}

.btn-warning {
  background-color: #ed8936;
  border-color: #ed8936;
  color: #0a0a0f;
}

.btn-light {
  background-color: var(--mystic-lavender);
  border-color: var(--mystic-lavender);
  color: var(--mystic-dark);
}

.btn-dark {
  background-color: var(--mystic-purple-dark);
  border-color: var(--mystic-purple-dark);
  color: var(--mystic-lavender);
}

/* Forms */
.form-control, .form-select {
  background-color: rgba(10, 10, 15, 0.7);
  border: 1px solid var(--bs-border-color);
  color: var(--mystic-text);
  border-radius: 10px;
}

.form-control:focus, .form-select:focus {
  background-color: rgba(10, 10, 15, 0.9);
  border-color: var(--mystic-pink);
  color: var(--mystic-text);
  box-shadow: 0 0 15px rgba(246, 135, 179, 0.3);
}

.form-control::placeholder {
  color: rgba(224, 213, 255, 0.5);
}

.form-label {
  color: var(--mystic-lavender);
  font-weight: 600;
}

/* Tables */
.table {
  color: var(--mystic-text);
  border-color: var(--bs-border-color);
}

.table > :not(caption) > * > * {
  background-color: transparent;
  border-bottom-color: var(--bs-border-color);
  color: var(--mystic-text);
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: rgba(183, 148, 246, 0.05);
}

.table-hover > tbody > tr:hover > * {
  background-color: rgba(183, 148, 246, 0.1);
  color: var(--mystic-text);
}

.table-dark {
  background-color: rgba(26, 0, 51, 0.9);
  color: var(--mystic-text);
}

thead.thead-dark {
  background-color: rgba(51, 0, 102, 0.9);
}

/* Badges */
.badge {
  font-family: 'Crimson Text', serif;
  font-weight: 600;
  padding: 0.35em 0.65em;
}

.bg-primary { background: linear-gradient(45deg, #b794f6, #e9d8fd) !important; }
.bg-secondary { background-color: #330066 !important; }
.bg-success { background-color: #48bb78 !important; }
.bg-danger { background: linear-gradient(45deg, #f687b3, #fc8181) !important; }
.bg-warning { background-color: #ed8936 !important; }
.bg-info { background-color: #4299e1 !important; }
.bg-light { background-color: var(--mystic-lavender) !important; color: var(--mystic-dark) !important; }
.bg-dark { background-color: var(--mystic-purple-dark) !important; }

/* Alerts */
.alert {
  border-radius: 10px;
  border: 1px solid;
}

.alert-primary {
  background-color: rgba(183, 148, 246, 0.2);
  border-color: var(--mystic-purple-light);
  color: var(--mystic-lavender);
}

.alert-danger {
  background-color: rgba(246, 135, 179, 0.2);
  border-color: var(--mystic-pink);
  color: #fbb6ce;
}

.alert-info {
  background-color: rgba(144, 205, 244, 0.2);
  border-color: #90cdf4;
  color: #bee3f8;
}

.alert-success {
  background-color: rgba(154, 230, 180, 0.2);
  border-color: #9ae6b4;
  color: #c6f6d5;
}

/* Modal */
.modal-content {
  background-color: rgba(26, 0, 51, 0.95);
  border: 1px solid var(--bs-border-color);
  backdrop-filter: blur(10px);
}

.modal-header {
  border-bottom-color: var(--bs-border-color);
}

.modal-footer {
  border-top-color: var(--bs-border-color);
}

.modal-backdrop {
  background-color: rgba(10, 10, 15, 0.8);
}

/* Navigation */
.navbar {
  background-color: rgba(26, 0, 51, 0.9) !important;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--bs-border-color);
}

.navbar-brand {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  color: var(--mystic-lavender) !important;
}

.navbar-dark .navbar-nav .nav-link {
  color: var(--mystic-text);
}

.navbar-dark .navbar-nav .nav-link:hover {
  color: var(--mystic-pink);
}

.nav-tabs {
  border-bottom-color: var(--bs-border-color);
}

.nav-tabs .nav-link {
  color: var(--mystic-text);
  border-color: transparent;
}

.nav-tabs .nav-link:hover {
  border-color: var(--bs-border-color);
  color: var(--mystic-pink);
}

.nav-tabs .nav-link.active {
  background-color: rgba(183, 148, 246, 0.1);
  border-color: var(--bs-border-color) var(--bs-border-color) transparent;
  color: var(--mystic-lavender);
}

/* Dropdowns */
.dropdown-menu {
  background-color: rgba(26, 0, 51, 0.95);
  border: 1px solid var(--bs-border-color);
  backdrop-filter: blur(10px);
}

.dropdown-item {
  color: var(--mystic-text);
}

.dropdown-item:hover, .dropdown-item:focus {
  background-color: rgba(183, 148, 246, 0.2);
  color: var(--mystic-lavender);
}

/* Progress bars */
.progress {
  background-color: rgba(10, 10, 15, 0.5);
}

.progress-bar {
  background: linear-gradient(45deg, #b794f6, #e9d8fd);
}

/* Pagination */
.pagination {
  --bs-pagination-bg: rgba(10, 10, 15, 0.5);
  --bs-pagination-border-color: var(--bs-border-color);
  --bs-pagination-color: var(--mystic-text);
  --bs-pagination-hover-bg: rgba(183, 148, 246, 0.2);
  --bs-pagination-hover-color: var(--mystic-lavender);
  --bs-pagination-hover-border-color: var(--mystic-purple-light);
  --bs-pagination-active-bg: var(--mystic-purple-light);
  --bs-pagination-active-border-color: var(--mystic-purple-light);
}

/* List groups */
.list-group-item {
  background-color: rgba(10, 10, 15, 0.5);
  border-color: var(--bs-border-color);
  color: var(--mystic-text);
}

.list-group-item:hover {
  background-color: rgba(183, 148, 246, 0.1);
}

/* Tooltips and popovers */
.tooltip-inner {
  background-color: var(--mystic-purple-dark);
  color: var(--mystic-lavender);
}

.popover {
  background-color: rgba(26, 0, 51, 0.95);
  border-color: var(--bs-border-color);
}

.popover-header {
  background-color: rgba(51, 0, 102, 0.5);
  border-bottom-color: var(--bs-border-color);
  color: var(--mystic-lavender);
}

.popover-body {
  color: var(--mystic-text);
}

/* Breadcrumbs */
.breadcrumb {
  background-color: rgba(10, 10, 15, 0.3);
}

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--mystic-purple-light);
}

/* Custom scrollbar */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: rgba(10, 10, 15, 0.5);
}

::-webkit-scrollbar-thumb {
  background: var(--mystic-purple-light);
  border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--mystic-pink);
}

/* Mystical glow effects */
.mystical-glow {
  animation: glow 2s ease-in-out infinite alternate;
}

@keyframes glow {
  from { filter: brightness(1) drop-shadow(0 0 20px rgba(183, 148, 246, 0.5)); }
  to { filter: brightness(1.2) drop-shadow(0 0 30px rgba(183, 148, 246, 0.8)); }
}

/* Custom utilities */
.text-mystic-purple { color: var(--mystic-purple-light) !important; }
.text-mystic-pink { color: var(--mystic-pink) !important; }
.text-mystic-lavender { color: var(--mystic-lavender) !important; }

.bg-mystic-dark { background-color: var(--mystic-dark) !important; }
.bg-mystic-purple { background-color: var(--mystic-purple) !important; }
.bg-mystic-purple-light { background-color: var(--mystic-purple-light) !important; }

/* Input group */
.input-group-text {
  background-color: rgba(51, 0, 102, 0.5);
  border-color: var(--bs-border-color);
  color: var(--mystic-lavender);
}

/* Close button */
.btn-close {
  filter: invert(1) grayscale(100%) brightness(200%);
}

/* Select2 overrides */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  background-color: rgba(10, 10, 15, 0.7);
  border-color: var(--bs-border-color);
  color: var(--mystic-text);
}

.select2-dropdown {
  background-color: rgba(26, 0, 51, 0.95);
  border-color: var(--bs-border-color);
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--mystic-purple-light);
}

/* Toast notifications */
.toast {
  background-color: rgba(26, 0, 51, 0.95);
  border: 1px solid var(--bs-border-color);
  color: var(--mystic-text);
}

.toast-header {
  background-color: rgba(51, 0, 102, 0.5);
  border-bottom-color: var(--bs-border-color);
  color: var(--mystic-lavender);
}