:root {
  --primary: #6366f1;
  --primary-dark: #4f46e5;
  --secondary: #8b5cf6;
  --accent: #3db2ff;
  --dark: #121212;
  --dark-secondary: #1e1e1e;
  --dark-tertiary: #2d2d2d;
  --text-light: #f8f9fa;
  --text-muted: #cccccc;
  --danger: #dc3545;
  --success: #198754;
  --warning: #ffc107;
  --info: #0dcaf0;
  --transition-speed: 0.3s;
  --card-bg: #2a2a2a;
  --border-color: rgba(255, 255, 255, 0.08);
}

html {
  font-size: 14px;
  position: relative;
  min-height: 100%;
  scroll-behavior: smooth;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

body {
  margin-bottom: 60px;
  background-color: var(--dark);
  color: var(--text-light);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  transition: background-color var(--transition-speed), color var(--transition-speed);
}

/* Focus states with dark theme adjustment */
.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.15rem rgba(99, 102, 241, 0.5);
}

/* Form control styling */
.form-control, .form-select {
  background-color: var(--dark-tertiary);
  border-color: var(--border-color);
  color: var(--text-light);
  transition: all var(--transition-speed) ease;
}

.form-control:focus, .form-select:focus {
  background-color: var(--dark-tertiary);
  border-color: var(--primary);
  color: var(--text-light);
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--text-muted);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

.form-floating > label {
  color: var(--text-muted);
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label {
  color: var(--primary);
  opacity: 0.9;
}

/* Card styling */
.card {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden;
  color: var(--text-light);
}

.card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
}

.card-header {
  background-color: rgba(0, 0, 0, 0.2) !important;
  border-bottom: 1px solid var(--border-color);
}

.card-body {
  color: var(--text-light);
}

.card-footer {
  background-color: rgba(0, 0, 0, 0.1) !important;
  border-top: 1px solid var(--border-color);
}

.card-title {
  color: var(--primary);
  font-weight: 600;
}

.card-text {
  color: var(--text-light);
  font-weight: 400;
}

/* Button styling */
.btn {
  border-radius: 0.375rem;
  transition: all var(--transition-speed);
  font-weight: 500;
}

.btn-primary {
  background-color: var(--primary);
  border-color: var(--primary);
}

.btn-primary:hover, .btn-primary:focus {
  background-color: var(--primary-dark);
  border-color: var(--primary-dark);
}

.btn-outline-danger {
  color: var(--danger);
  border-color: var(--danger);
}

.btn-outline-danger:hover {
  background-color: var(--danger);
  color: white;
}

/* Alerts */
.alert {
  border-radius: 0.375rem;
  border: none;
}

.alert-success {
  background-color: rgba(25, 135, 84, 0.2);
  color: #75b798;
}

.alert-warning {
  background-color: rgba(255, 193, 7, 0.2);
  color: #ffda6a;
}

.alert-info {
  background-color: rgba(13, 202, 240, 0.2);
  color: #6edff6;
}

.alert-danger {
  background-color: rgba(220, 53, 69, 0.2);
  color: #ea868f;
}

/* Validation error messages */
.validation-summary-errors {
  padding: 1rem;
  margin-bottom: 1rem;
  background-color: rgba(220, 53, 69, 0.1);
  border-radius: 0.375rem;
  border-left: 4px solid var(--danger);
}

.validation-summary-errors ul {
  margin-bottom: 0;
  list-style-type: none;
  padding-left: 0;
}

.text-danger {
  color: #ea868f !important;
  font-weight: 500;
}

/* Add this section for form controls */
.form-control:focus, .form-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 0.25rem rgba(99, 102, 241, 0.25);
}

/* Form error state */
.input-validation-error {
  border-color: var(--danger) !important;
  background-color: rgba(220, 53, 69, 0.05) !important;
}

.input-validation-error:focus {
  box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25) !important;
}

/* Animations */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.fade-in {
  animation: fadeIn 0.5s ease forwards;
}

/* Container padding adjustment */
.container {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

/* List group */
.list-group-item {
  background-color: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-light);
}

/* Text and icon colors */
.text-primary {
  color: var(--primary) !important;
}

.text-accent {
  color: var(--accent) !important;
}

.text-muted {
  color: var(--text-muted) !important;
}

/* Icon styling in cards */
.card .bi {
  color: var(--primary);
}

/* Glass container text adjustments */
.glass-container {
  color: var(--text-light);
}

/* Table styling */
.table {
  color: var(--text-light);
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: rgba(255, 255, 255, 0.02);
}

.table-hover > tbody > tr:hover > * {
  background-color: rgba(255, 255, 255, 0.05);
}

/* Navbar text color fixes */
.navbar-dark .navbar-nav .nav-link {
  color: var(--text-light) !important;
}

.navbar-dark .navbar-nav .nav-link:hover {
  color: var(--primary) !important;
}

.navbar-dark .navbar-nav .nav-link.active {
  color: var(--primary) !important;
}

.navbar-dark .navbar-brand {
  color: var(--primary) !important;
}

.navbar-dark .navbar-text {
  color: var(--text-muted) !important;
}

/* Dropdown menu styling */
.dropdown-menu {
  background-color: var(--card-bg) !important;
  border: 1px solid var(--border-color) !important;
}

.dropdown-item {
  color: var(--text-light) !important;
}

.dropdown-item:hover, .dropdown-item:focus {
  background-color: var(--dark-tertiary) !important;
  color: var(--primary) !important;
}

.dropdown-divider {
  border-color: var(--border-color) !important;
}

/* Tailwind replacement utility classes */
.glass-container {
  background: rgba(42, 42, 42, 0.6);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border-color);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.37);
}

/* Layout utilities */
.relative { position: relative; }
.absolute { position: absolute; }
.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }
.z-10 { z-index: 10; }
.overflow-hidden { overflow: hidden; }
.pointer-events-none { pointer-events: none; }

/* Flexbox utilities */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-row { flex-direction: row; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }

/* Grid utilities */
.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }

@media (min-width: 768px) {
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .sm\:flex-row { flex-direction: row; }
}

/* Spacing utilities */
.mb-3 { margin-bottom: 0.75rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-5 { margin-bottom: 1.25rem; }
.mb-6 { margin-bottom: 1.5rem; }
.mb-8 { margin-bottom: 2rem; }
.mt-3 { margin-top: 0.75rem; }
.mt-6 { margin-top: 1.5rem; }
.mt-8 { margin-top: 2rem; }
.mx-auto { margin-left: auto; margin-right: auto; }
.me-2 { margin-right: 0.5rem; }
.p-6 { padding: 1.5rem; }
.p-8 { padding: 2rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
.py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }

/* Sizing utilities */
.w-16 { width: 4rem; }
.h-16 { height: 4rem; }
.h-100 { height: 100%; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }

/* Border radius utilities */
.rounded-full { border-radius: 9999px; }
.rounded-xl { border-radius: 0.75rem; }
.rounded-2xl { border-radius: 1rem; }

/* Text utilities */
.text-center { text-align: center; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-2xl { font-size: 1.5rem; line-height: 2rem; }
.text-sm { font-size: 0.875rem; line-height: 1.25rem; }
.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.font-medium { font-weight: 500; }
.leading-relaxed { line-height: 1.625; }
.text-white { color: white; }
.text-gray-300 { color: #d1d5db; }
.text-transparent { color: transparent; }

/* Background utilities */
.bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); }
.bg-gradient-to-r { background-image: linear-gradient(to right, var(--tw-gradient-stops)); }
.from-primary { --tw-gradient-from: var(--primary); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(99, 102, 241, 0)); }
.to-accent { --tw-gradient-to: var(--accent); }
.to-primary-dark { --tw-gradient-to: var(--primary-dark); }
.from-secondary { --tw-gradient-from: var(--secondary); }
.to-purple-600 { --tw-gradient-to: #9333ea; }
.from-accent { --tw-gradient-from: var(--accent); }
.to-blue-500 { --tw-gradient-to: #3b82f6; }
.from-green-500 { --tw-gradient-from: #22c55e; }
.to-emerald-600 { --tw-gradient-to: #059669; }
.from-orange-500 { --tw-gradient-from: #f97316; }
.to-red-500 { --tw-gradient-to: #ef4444; }
.from-gray-800\/50 { --tw-gradient-from: rgba(31, 41, 55, 0.5); }
.to-gray-900\/50 { --tw-gradient-to: rgba(17, 24, 39, 0.5); }
.from-primary\/10 { --tw-gradient-from: rgba(99, 102, 241, 0.1); }
.via-transparent { --tw-gradient-stops: var(--tw-gradient-from), transparent, var(--tw-gradient-to, rgba(0, 0, 0, 0)); }
.to-accent\/10 { --tw-gradient-to: rgba(61, 178, 255, 0.1); }
.from-primary\/5 { --tw-gradient-from: rgba(99, 102, 241, 0.05); }
.from-secondary\/5 { --tw-gradient-from: rgba(139, 92, 246, 0.05); }
.to-accent\/5 { --tw-gradient-to: rgba(61, 178, 255, 0.05); }
.bg-clip-text { -webkit-background-clip: text; background-clip: text; }
.backdrop-blur-sm { backdrop-filter: blur(4px); }

/* Display utilities */
.inline-flex { display: inline-flex; }

/* Shadow utilities */
.shadow-lg { box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); }
.shadow-xl { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }

/* Transform utilities */
.transform { transform: translateZ(0); }
.hover\:scale-105:hover { transform: scale(1.05); }
.hover\:-translate-y-1:hover { transform: translateY(-0.25rem); }
.group:hover .group-hover\:scale-105 { transform: scale(1.05); }

/* Transition utilities */
.transition-all { transition-property: all; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms; }
.duration-300 { transition-duration: 300ms; }

/* Border utilities */
.border-0 { border-width: 0; }
.border-2 { border-width: 2px; }

/* Hover utilities */
.hover\:bg-white\/10:hover { background-color: rgba(255, 255, 255, 0.1); }
.hover\:shadow-xl:hover { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }

/* Pipeline test - PowerShell syntax fixes applied - comprehensive resolution */
