/* ============================================================
   XFIRMA UI ENHANCEMENTS
   Dark Mode · Skeleton Loading · Animations · Accessibility
   ============================================================ */

/* --------------------------------------------------------
   1. CSS CUSTOM PROPERTIES (Light & Dark Themes)
   -------------------------------------------------------- */
:root {
  /* Light theme (default) */
  --bg-primary: #ffffff;
  --bg-secondary: #f8fafc;
  --bg-tertiary: #f1f5f9;
  --bg-card: #ffffff;
  --bg-nav: rgba(255, 255, 255, 0.98);
  --text-primary: #0f172a;
  --text-secondary: #475569;
  --text-muted: #94a3b8;
  --border-color: #e2e8f0;
  --border-light: #f1f5f9;
  --accent: #d9232d;
  --accent-hover: #e24d55;
  --accent-soft: #fef2f2;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.04);
  --overlay: rgba(15, 23, 42, 0.5);
  --skeleton-base: #e2e8f0;
  --skeleton-shine: #f1f5f9;
  --scrollbar-track: #f1f5f9;
  --scrollbar-thumb: #cbd5e1;
  --focus-ring: rgba(217, 35, 45, 0.4);
  --success: #10b981;
  --warning: #f59e0b;
  --error: #ef4444;
  --info: #3b82f6;
  --gradient-hero: linear-gradient(135deg, #0b1020 0%, #0f172a 45%, #2563eb 100%);
  --nav-blur: blur(12px);
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Dark theme */
[data-theme="dark"] {
  --bg-primary: #0f172a;
  --bg-secondary: #1e293b;
  --bg-tertiary: #334155;
  --bg-card: #1e293b;
  --bg-nav: rgba(15, 23, 42, 0.98);
  --text-primary: #f1f5f9;
  --text-secondary: #cbd5e1;
  --text-muted: #64748b;
  --border-color: #334155;
  --border-light: #1e293b;
  --accent: #ef4444;
  --accent-hover: #f87171;
  --accent-soft: #1e293b;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5);
  --overlay: rgba(0, 0, 0, 0.6);
  --skeleton-base: #334155;
  --skeleton-shine: #475569;
  --scrollbar-track: #1e293b;
  --scrollbar-thumb: #475569;
  --focus-ring: rgba(239, 68, 68, 0.5);
  --gradient-hero: linear-gradient(135deg, #020617 0%, #0f172a 45%, #1e3a5f 100%);
  --nav-blur: blur(16px);

  /* Firma detay sayfası (view.php) değişkenlerini geçersiz kıl */
  --ink-900: #f1f5f9;
  --ink-700: #cbd5e1;
  --muted-600: #94a3b8;
  --muted-400: #64748b;
  --muted-200: #334155;
  --accent-500: #ef4444;
  --accent-600: #dc2626;
  --accent-glow: rgba(239, 68, 68, 0.25);
  --green-500: #10b981;
  --green-600: #059669;
  --amber-500: #f59e0b;
  --rose-500: #f43f5e;
  --card: #1e293b;
  --card-muted: #334155;
  --card-hover: #475569;
  --line: #334155;
  --line-light: #1e293b;
}

/* Apply theme variables */
body {
  background-color: var(--bg-secondary);
  color: var(--text-primary);
  transition: background-color var(--transition-base), color var(--transition-base);
}

/* --------------------------------------------------------
   2. DARK MODE TOGGLE
   -------------------------------------------------------- */
.theme-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--border-color);
  background: var(--bg-card);
  color: var(--text-primary);
  cursor: pointer;
  font-size: 18px;
  transition: all var(--transition-fast);
  outline: none;
  margin-left: 12px;
}

.theme-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
  transform: rotate(15deg);
  box-shadow: 0 0 20px var(--focus-ring);
}

.theme-toggle:focus-visible {
  box-shadow: 0 0 0 3px var(--focus-ring);
}

.theme-toggle .icon-sun,
.theme-toggle .icon-moon {
  transition: transform var(--transition-base), opacity var(--transition-base);
}

[data-theme="dark"] .theme-toggle .icon-sun { display: inline; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }
[data-theme="light"] .theme-toggle .icon-sun { display: none; }
[data-theme="light"] .theme-toggle .icon-moon { display: inline; }

/* --------------------------------------------------------
   3. SKELETON LOADING
   -------------------------------------------------------- */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--skeleton-base) 25%,
    var(--skeleton-shine) 50%,
    var(--skeleton-base) 75%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s ease-in-out infinite;
  border-radius: 6px;
  color: transparent !important;
  user-select: none;
  pointer-events: none;
}

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

.skeleton-text {
  height: 1em;
  margin-bottom: 0.5em;
  width: 100%;
}

.skeleton-text-sm { height: 0.75em; width: 60%; }
.skeleton-text-lg { height: 1.5em; width: 80%; }
.skeleton-avatar { width: 48px; height: 48px; border-radius: 50%; }
.skeleton-thumbnail { width: 100%; height: 180px; border-radius: 8px; }
.skeleton-card {
  width: 100%;
  height: 200px;
  border-radius: 12px;
  margin-bottom: 1rem;
}

/* Skeleton grid for firm listings */
.skeleton-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
  padding: 1rem 0;
}

.skeleton-grid .skeleton-card-item {
  background: var(--bg-card);
  border-radius: 12px;
  padding: 1.5rem;
  border: 1px solid var(--border-color);
}

/* --------------------------------------------------------
   4. SCROLL-TRIGGERED ANIMATIONS (AOS-like)
   -------------------------------------------------------- */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-on-scroll.animated {
  opacity: 1;
  transform: translateY(0);
}

.animate-on-scroll.animate-left {
  transform: translateX(-30px);
}
.animate-on-scroll.animate-left.animated {
  transform: translateX(0);
}

.animate-on-scroll.animate-right {
  transform: translateX(30px);
}
.animate-on-scroll.animate-right.animated {
  transform: translateX(0);
}

.animate-on-scroll.animate-scale {
  transform: scale(0.9);
}
.animate-on-scroll.animate-scale.animated {
  transform: scale(1);
}

/* Stagger children */
.animate-stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.animate-stagger.animated > *:nth-child(1) { transition-delay: 0.05s; }
.animate-stagger.animated > *:nth-child(2) { transition-delay: 0.1s; }
.animate-stagger.animated > *:nth-child(3) { transition-delay: 0.15s; }
.animate-stagger.animated > *:nth-child(4) { transition-delay: 0.2s; }
.animate-stagger.animated > *:nth-child(5) { transition-delay: 0.25s; }
.animate-stagger.animated > *:nth-child(6) { transition-delay: 0.3s; }
.animate-stagger.animated > *:nth-child(7) { transition-delay: 0.35s; }
.animate-stagger.animated > *:nth-child(8) { transition-delay: 0.4s; }

.animate-stagger.animated > * {
  opacity: 1;
  transform: translateY(0);
}

/* --------------------------------------------------------
   5. MICRO-INTERACTIONS & HOVER EFFECTS
   -------------------------------------------------------- */

/* Card hover lift */
.card-hover {
  transition: transform var(--transition-base),
              box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.card-hover:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--accent);
}

/* Button ripple effect */
.btn-ripple {
  position: relative;
  overflow: hidden;
}

.btn-ripple::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--ripple-x, 50%) var(--ripple-y, 50%), 
              rgba(255, 255, 255, 0.3) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}

.btn-ripple:active::after {
  opacity: 1;
  transition: 0s;
}

/* Link underline animation */
.link-underline {
  position: relative;
  text-decoration: none;
}

.link-underline::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--accent);
  transition: width var(--transition-base);
}

.link-underline:hover::after {
  width: 100%;
}

/* Image zoom on hover */
.img-zoom {
  overflow: hidden;
}

.img-zoom img {
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.img-zoom:hover img {
  transform: scale(1.08);
}

/* Smooth fade-in for page transitions */
.page-enter {
  animation: page-enter 0.4s ease-out;
}

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

/* Pulse glow for accent elements */
.pulse-glow {
  animation: pulse-glow 2s ease-in-out infinite;
}

@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(217, 35, 45, 0.3); }
  50% { box-shadow: 0 0 0 8px rgba(217, 35, 45, 0); }
}

/* Counter number animation */
.count-up {
  display: inline-block;
}

/* --------------------------------------------------------
   6. ACCESSIBILITY (WCAG) IMPROVEMENTS
   -------------------------------------------------------- */

/* Skip to main content */
.skip-to-content {
  position: absolute;
  top: -100%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent);
  color: #fff;
  padding: 12px 24px;
  border-radius: 0 0 8px 8px;
  z-index: 10000;
  font-weight: 600;
  text-decoration: none;
  transition: top var(--transition-fast);
}

.skip-to-content:focus {
  top: 0;
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

/* Focus styles */
:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Remove focus outline for mouse users */
:focus:not(:focus-visible) {
  outline: none;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .animate-on-scroll {
    opacity: 1 !important;
    transform: none !important;
  }

  .skeleton {
    animation: none !important;
    background: var(--skeleton-base) !important;
  }
}

/* High contrast mode */
@media (prefers-contrast: high) {
  :root {
    --text-primary: #000000;
    --text-secondary: #1a1a1a;
    --border-color: #000000;
    --accent: #cc0000;
  }

  [data-theme="dark"] {
    --text-primary: #ffffff;
    --text-secondary: #e0e0e0;
    --border-color: #ffffff;
    --accent: #ff4444;
  }

  .card-hover:hover {
    border-width: 2px;
  }
}

/* Screen reader only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Better touch targets for mobile */
@media (hover: none) and (pointer: coarse) {
  a, button, .nav-menu a, .dropdown-item {
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  .nav-menu > ul > li {
    padding: 8px 0 8px 20px;
  }
}

/* --------------------------------------------------------
   7. SCROLLBAR STYLING
   -------------------------------------------------------- */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

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

::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted);
}

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

/* --------------------------------------------------------
   8. INFINITE SCROLL LOADING INDICATOR
   -------------------------------------------------------- */
.infinite-scroll-loader {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2rem 0;
  gap: 0.5rem;
}

.infinite-scroll-loader .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  animation: dot-bounce 1.4s ease-in-out infinite both;
}

.infinite-scroll-loader .dot:nth-child(1) { animation-delay: -0.32s; }
.infinite-scroll-loader .dot:nth-child(2) { animation-delay: -0.16s; }
.infinite-scroll-loader .dot:nth-child(3) { animation-delay: 0s; }

@keyframes dot-bounce {
  0%, 80%, 100% {
    transform: scale(0.6);
    opacity: 0.4;
  }
  40% {
    transform: scale(1);
    opacity: 1;
  }
}

.infinite-scroll-end {
  text-align: center;
  padding: 1.5rem;
  color: var(--text-muted);
  font-size: 0.9rem;
}

/* --------------------------------------------------------
   9. DARK MODE OVERRIDES FOR EXISTING ELEMENTS
   -------------------------------------------------------- */
[data-theme="dark"] #header {
  background: var(--bg-nav);
  backdrop-filter: var(--nav-blur);
  -webkit-backdrop-filter: var(--nav-blur);
  border-bottom: 1px solid var(--border-color);
}

[data-theme="dark"] #header .logo a {
  color: var(--text-primary);
}

[data-theme="dark"] .nav-menu a {
  color: var(--text-secondary);
}

[data-theme="dark"] .nav-menu a:hover,
[data-theme="dark"] .nav-menu .active > a,
[data-theme="dark"] .nav-menu li:hover > a {
  color: var(--accent);
}

[data-theme="dark"] .nav-menu .drop-down ul {
  background: var(--bg-card);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-color);
}

[data-theme="dark"] .nav-menu .drop-down ul a {
  color: var(--text-secondary);
}

[data-theme="dark"] .nav-menu .drop-down ul a:hover {
  color: var(--accent);
  background: var(--bg-tertiary);
}

[data-theme="dark"] .mobile-nav {
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
}

[data-theme="dark"] .mobile-nav a {
  color: var(--text-secondary);
}

[data-theme="dark"] .mobile-nav-overly {
  background: var(--overlay);
}

[data-theme="dark"] #footer {
  background: #020617;
}

[data-theme="dark"] #footer .footer-top {
  background: #0f172a;
}

[data-theme="dark"] .breadcrumbs {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .section-bg,
[data-theme="dark"] .services .icon-box {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .card,
[data-theme="dark"] .panel,
[data-theme="dark"] .well {
  background: var(--bg-card);
  border-color: var(--border-color);
}

[data-theme="dark"] .form-control {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .form-control:focus {
  border-color: var(--accent);
}

[data-theme="dark"] .table {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .modal-content {
  background: var(--bg-card);
  border-color: var(--border-color);
}

[data-theme="dark"] .close {
  color: var(--text-primary);
}

[data-theme="dark"] .list-group-item {
  background: var(--bg-card);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .page-link {
  background: var(--bg-card);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .page-item.active .page-link {
  background: var(--accent);
  border-color: var(--accent);
}

[data-theme="dark"] .dropdown-menu {
  background: var(--bg-card);
  border-color: var(--border-color);
}

[data-theme="dark"] .dropdown-item {
  color: var(--text-secondary);
}

[data-theme="dark"] .dropdown-item:hover {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

[data-theme="dark"] .alert {
  border-color: var(--border-color);
}

[data-theme="dark"] .bg-white {
  background: var(--bg-card) !important;
}

[data-theme="dark"] .text-dark {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .text-muted {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .border {
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .border-bottom {
  border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .border-top {
  border-top-color: var(--border-color) !important;
}

[data-theme="dark"] .search-hover {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .search-hover:focus {
  border-color: var(--accent);
}

[data-theme="dark"] .input-group-text {
  background: transparent;
  color: var(--text-muted);
  border: none;
}

[data-theme="dark"] .hero-xl {
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .back-to-top i {
  background: var(--accent);
}

[data-theme="dark"] .back-to-top i:hover {
  background: var(--accent-hover);
}

/* --------------------------------------------------------
   10. SMOOTH TRANSITIONS FOR THEME SWITCH
   -------------------------------------------------------- */
.theme-transitioning,
.theme-transitioning *,
.theme-transitioning *::before,
.theme-transitioning *::after {
  transition: background-color 0.3s ease,
              color 0.3s ease,
              border-color 0.3s ease,
              box-shadow 0.3s ease !important;
}

/* --------------------------------------------------------
   11. TOAST NOTIFICATION STYLES
   -------------------------------------------------------- */
.toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 380px;
}

.toast {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-radius: 10px;
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-lg);
  color: var(--text-primary);
  font-size: 14px;
  animation: toast-in 0.3s ease-out;
  cursor: pointer;
}

.toast.toast-success { border-left: 4px solid var(--success); }
.toast.toast-error { border-left: 4px solid var(--error); }
.toast.toast-warning { border-left: 4px solid var(--warning); }
.toast.toast-info { border-left: 4px solid var(--info); }

.toast .toast-icon { font-size: 20px; }
.toast.toast-success .toast-icon { color: var(--success); }
.toast.toast-error .toast-icon { color: var(--error); }
.toast.toast-warning .toast-icon { color: var(--warning); }
.toast.toast-info .toast-icon { color: var(--info); }

.toast.toast-exit {
  animation: toast-out 0.3s ease-in forwards;
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateX(100%) scale(0.9);
  }
  to {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

@keyframes toast-out {
  from {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateX(100%) scale(0.9);
  }
}

/* --------------------------------------------------------
   12. PROGRESS BAR (Page load)
   -------------------------------------------------------- */
#nprogress {
  pointer-events: none;
  display: none;
}

#nprogress .bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--accent);
  z-index: 99999;
  animation: nprogress-indeterminate 2s ease-in-out infinite;
  transform-origin: left;
}

@keyframes nprogress-indeterminate {
  0% { transform: scaleX(0); }
  50% { transform: scaleX(0.5); }
  100% { transform: scaleX(1); }
}

/* --------------------------------------------------------
   13. RESPONSIVE IMPROVEMENTS
   -------------------------------------------------------- */
@media (max-width: 768px) {
  .theme-toggle {
    width: 36px;
    height: 36px;
    font-size: 16px;
    margin-left: 8px;
  }

  .toast-container {
    left: 16px;
    right: 16px;
    bottom: 16px;
    max-width: none;
  }

  .skeleton-grid {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------
   14. PRINT STYLES
   -------------------------------------------------------- */
@media print {
  .theme-toggle,
  .back-to-top,
  .infinite-scroll-loader,
  .toast-container,
  #nprogress {
    display: none !important;
  }

  body {
    background: white !important;
    color: black !important;
  }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
    color: #666;
  }
}

/* ============================================================
   15. COMPREHENSIVE DARK MODE OVERRIDES
   ============================================================ */

/* --- Firma Detay Sayfası (view.php) --- */
[data-theme="dark"] body {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .hero-card,
[data-theme="dark"] .card,
[data-theme="dark"] .card-body,
[data-theme="dark"] .card-header,
[data-theme="dark"] .card-footer {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary);
}

[data-theme="dark"] .hero-title,
[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3,
[data-theme="dark"] h4, [data-theme="dark"] h5, [data-theme="dark"] h6 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .hero-sub,
[data-theme="dark"] p, [data-theme="dark"] .text-muted,
[data-theme="dark"] .text-secondary,
[data-theme="dark"] .muted-text {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .pill {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .pill.soft {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .pill.outline {
  border-color: var(--border-color) !important;
  color: var(--text-muted) !important;
}

[data-theme="dark"] .btn-soft {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .btn-soft:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

[data-theme="dark"] .btn-danger-soft {
  background: rgba(239, 68, 68, 0.15) !important;
  border-color: rgba(239, 68, 68, 0.3) !important;
  color: #fca5a5 !important;
}

[data-theme="dark"] .btn-outline-sm {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .btn-ghost-sm {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .btn-ghost-sm:hover {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .stat-grid,
[data-theme="dark"] .stat-item {
  color: var(--text-primary);
}

[data-theme="dark"] .stat-label {
  color: var(--text-muted);
}

[data-theme="dark"] .info-row {
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .info-label {
  color: var(--text-muted);
}

[data-theme="dark"] .info-value {
  color: var(--text-primary);
}

[data-theme="dark"] .section-title h2 {
  color: var(--text-muted);
}

[data-theme="dark"] .section-title p {
  color: var(--text-primary);
}

[data-theme="dark"] .tab-pane,
[data-theme="dark"] .nav-tabs .nav-link {
  color: var(--text-secondary);
}

[data-theme="dark"] .nav-tabs .nav-link.active {
  color: var(--accent);
  background: var(--bg-card);
  border-color: var(--border-color);
}

[data-theme="dark"] .table {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table th,
[data-theme="dark"] .table td {
  border-color: var(--border-color);
}

[data-theme="dark"] .table-striped tbody tr:nth-of-type(odd) {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .table-hover tbody tr:hover {
  background: var(--bg-tertiary);
}

/* --- İletişim Sayfası (contact.php) --- */
[data-theme="dark"] .member .pic i {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .member-info h4 a {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .member-info p {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .member-info .social a {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .member-info .social a.text-white {
  color: var(--text-primary) !important;
}

/* --- Login Sayfası --- */
[data-theme="dark"] .site-login {
  color: var(--text-primary);
}

[data-theme="dark"] .site-login div[style*="color:#999"] {
  color: var(--text-muted) !important;
}

/* --- Error Sayfası --- */
[data-theme="dark"] .site-error h1 {
  color: var(--text-primary);
}

[data-theme="dark"] .site-error p {
  color: var(--text-secondary);
}

/* --- About Sayfası --- */
[data-theme="dark"] .site-about h1 {
  color: var(--text-primary);
}

[data-theme="dark"] .site-about p {
  color: var(--text-secondary);
}

[data-theme="dark"] .site-about code {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

/* --- Firma Ekleme Sayfası (company/) --- */
[data-theme="dark"] .company-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .company-card .card-header {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .company-card .card-body {
  color: var(--text-secondary);
}

[data-theme="dark"] .company-card .card-body ul.text-muted {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .company-progress {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .form-control,
[data-theme="dark"] input.form-control,
[data-theme="dark"] textarea.form-control,
[data-theme="dark"] select.form-control {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--focus-ring) !important;
}

[data-theme="dark"] .form-group.floating > label {
  background: var(--bg-card) !important;
  color: var(--text-muted) !important;
}

[data-theme="dark"] .form-control.floating:focus ~ label {
  color: var(--accent) !important;
}

[data-theme="dark"] .help-block,
[data-theme="dark"] .hint-block {
  color: var(--text-muted) !important;
}

/* --- Confirmation Sayfası --- */
[data-theme="dark"] .card.shadow-sm.border-0 {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .card.shadow-sm.border-0 .card-body h4 {
  color: var(--text-primary);
}

[data-theme="dark"] .card.shadow-sm.border-0 .card-body p.text-muted {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .alert-info {
  background: rgba(59, 130, 246, 0.15) !important;
  border-color: rgba(59, 130, 246, 0.3) !important;
  color: #93c5fd !important;
}

[data-theme="dark"] .alert-success {
  background: rgba(16, 185, 129, 0.15) !important;
  border-color: rgba(16, 185, 129, 0.3) !important;
  color: #6ee7b7 !important;
}

[data-theme="dark"] .alert-warning {
  background: rgba(245, 158, 11, 0.15) !important;
  border-color: rgba(245, 158, 11, 0.3) !important;
  color: #fcd34d !important;
}

[data-theme="dark"] .alert-danger {
  background: rgba(239, 68, 68, 0.15) !important;
  border-color: rgba(239, 68, 68, 0.3) !important;
  color: #fca5a5 !important;
}

/* --- Düzenleme Sayfası (edit.php) --- */
[data-theme="dark"] .nav-tabs {
  border-color: var(--border-color);
}

[data-theme="dark"] .nav-tabs .nav-link {
  background: transparent;
  border-color: transparent;
  color: var(--text-secondary);
}

[data-theme="dark"] .nav-tabs .nav-link:hover {
  border-color: var(--border-color);
  background: var(--bg-tertiary);
}

[data-theme="dark"] .nav-tabs .nav-link.active {
  background: var(--bg-card);
  border-color: var(--border-color) var(--border-color) var(--bg-card);
  color: var(--accent);
}

[data-theme="dark"] .tab-content {
  background: var(--bg-card);
  color: var(--text-primary);
}

/* --- Yakındaki Firmalar (nearby.php) --- */
[data-theme="dark"] .alert-warning u {
  color: var(--text-primary);
}

/* --- Genel Bootstrap Override'ları --- */
[data-theme="dark"] .breadcrumb {
  background: transparent !important;
}

[data-theme="dark"] .breadcrumb-item {
  color: var(--text-muted);
}

[data-theme="dark"] .breadcrumb-item a {
  color: var(--text-secondary);
}

[data-theme="dark"] .breadcrumb-item.active {
  color: var(--text-primary);
}

[data-theme="dark"] .breadcrumb-item + .breadcrumb-item::before {
  color: var(--text-muted);
}

[data-theme="dark"] .label,
[data-theme="dark"] label,
[data-theme="dark"] .control-label {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .btn-primary {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
}

[data-theme="dark"] .btn-primary:hover {
  background: var(--accent-hover) !important;
  border-color: var(--accent-hover) !important;
}

[data-theme="dark"] .btn-outline-secondary {
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .btn-outline-secondary:hover {
  background: var(--bg-tertiary) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

[data-theme="dark"] .btn-link {
  color: var(--accent) !important;
}

[data-theme="dark"] .list-group-item {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .list-group-item:hover {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .well,
[data-theme="dark"] .jumbotron {
  background: var(--bg-card) !important;
  color: var(--text-primary);
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-body,
[data-theme="dark"] .modal-footer {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary);
}

[data-theme="dark"] .modal-title {
  color: var(--text-primary);
}

[data-theme="dark"] .close {
  color: var(--text-primary) !important;
  text-shadow: none !important;
}

[data-theme="dark"] .dropdown-menu {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .dropdown-item {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .dropdown-item:hover {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .popover,
[data-theme="dark"] .popover-header,
[data-theme="dark"] .popover-body {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary);
}

[data-theme="dark"] .tooltip-inner {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .bs-tooltip-auto[x-placement^=top] .arrow::before,
[data-theme="dark"] .bs-tooltip-top .arrow::before {
  border-top-color: var(--bg-tertiary) !important;
}

/* --- Captcha --- */
[data-theme="dark"] .captcha-image {
  border-color: var(--border-color);
}

/* --- PJAX Loader --- */
[data-theme="dark"] #pjax-loader .spinner {
  border-color: var(--bg-tertiary) !important;
  border-top-color: var(--accent) !important;
}

/* --- Kartik Widgets --- */
[data-theme="dark"] .kv-editable,
[data-theme="dark"] .kv-editable-value {
  color: var(--text-primary) !important;
  background: transparent !important;
}

[data-theme="dark"] .kv-editable-link {
  color: var(--accent) !important;
}

[data-theme="dark"] .file-input-wrapper,
[data-theme="dark"] .file-preview-frame {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .file-caption-name {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .rating-container .rating-stars {
  color: var(--accent) !important;
}

[data-theme="dark"] .slider-handle {
  background: var(--accent) !important;
}

[data-theme="dark"] .slider-track {
  background: var(--bg-tertiary) !important;
}

/* --- Yorumlar --- */
[data-theme="dark"] .comment,
[data-theme="dark"] .comment-item {
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .comment-author {
  color: var(--text-primary);
}

[data-theme="dark"] .comment-text {
  color: var(--text-secondary);
}

[data-theme="dark"] .comment-date {
  color: var(--text-muted);
}

/* --- Star Rating --- */
[data-theme="dark"] .star-rating,
[data-theme="dark"] .rating-disabled {
  color: var(--accent) !important;
}

/* --- Harita (Yandex/Leaflet) --- */
[data-theme="dark"] .ymaps-2-1-79-map {
  filter: invert(0.9) hue-rotate(180deg);
}

[data-theme="dark"] .leaflet-container {
  background: var(--bg-tertiary) !important;
}

/* --- Sosyal Paylaşım --- */
[data-theme="dark"] .social-share a {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .social-share a:hover {
  color: var(--accent) !important;
}

/* --- Çalışma Saatleri --- */
[data-theme="dark"] .working-hours-table,
[data-theme="dark"] .hours-row {
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .day-name {
  color: var(--text-primary);
}

[data-theme="dark"] .day-hours {
  color: var(--text-secondary);
}

/* --- Firma Ekleme Progress --- */
[data-theme="dark"] .company-hero {
  background: linear-gradient(135deg, #1e3a5f 0%, #1e40af 50%, #3b82f6 100%) !important;
}

/* --- Support Tickets --- */
[data-theme="dark"] .ticket-card,
[data-theme="dark"] .ticket-item {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .ticket-subject {
  color: var(--text-primary);
}

[data-theme="dark"] .ticket-status {
  color: var(--text-secondary);
}

/* --- Kullanıcı Paneli (Dektrium) --- */
[data-theme="dark"] .panel,
[data-theme="dark"] .panel-default {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .panel-heading {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .panel-body {
  color: var(--text-secondary);
}

[data-theme="dark"] .panel-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .nav-pills > li > a {
  color: var(--text-secondary);
}

[data-theme="dark"] .nav-pills > li.active > a,
[data-theme="dark"] .nav-pills > li > a:hover {
  background: var(--bg-tertiary);
  color: var(--accent);
}

[data-theme="dark"] .auth-clients .auth-link {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .auth-clients .auth-link:hover {
  border-color: var(--accent) !important;
}

/* --- GridView --- */
[data-theme="dark"] .grid-view {
  color: var(--text-primary);
}

[data-theme="dark"] .grid-view th {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .grid-view td {
  border-color: var(--border-color);
}

[data-theme="dark"] .grid-view .filters input,
[data-theme="dark"] .grid-view .filters select {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border-color: var(--border-color);
}

/* --- Detail View --- */
[data-theme="dark"] .detail-view th {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

[data-theme="dark"] .detail-view td {
  color: var(--text-secondary);
}

/* --- Progress Bar --- */
[data-theme="dark"] .progress {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .progress-bar {
  color: #fff !important;
}

/* --- Badge --- */
[data-theme="dark"] .badge {
  color: #fff !important;
}

[data-theme="dark"] .badge-light {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
}

/* --- Card img --- */
[data-theme="dark"] .card-img-top {
  filter: brightness(0.9);
}

/* --- Blockquote --- */
[data-theme="dark"] blockquote {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

/* --- Code --- */
[data-theme="dark"] code,
[data-theme="dark"] pre {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

/* --- Horizontal Rule --- */
[data-theme="dark"] hr {
  border-color: var(--border-color) !important;
}

/* --- Text colors --- */
[data-theme="dark"] .text-primary {
  color: var(--accent) !important;
}

[data-theme="dark"] .text-success {
  color: var(--success) !important;
}

[data-theme="dark"] .text-warning {
  color: var(--warning) !important;
}

[data-theme="dark"] .text-danger {
  color: var(--error) !important;
}

[data-theme="dark"] .text-info {
  color: var(--info) !important;
}

[data-theme="dark"] .bg-primary {
  background: var(--accent) !important;
}

[data-theme="dark"] .bg-light {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .bg-dark {
  background: var(--bg-primary) !important;
}

/* --- Link colors --- */
[data-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item):not(.page-link) {
  color: var(--accent);
}

[data-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item):not(.page-link):hover {
  color: var(--accent-hover);
}

/* --- Cookie Monster (GDPR) --- */
[data-theme="dark"] .cookiemonster {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .cookiemonster .btn {
  background: var(--accent) !important;
  color: #fff !important;
}

/* --- Mobile nav dark mode fix --- */
[data-theme="dark"] .mobile-nav-toggle i {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .mobile-nav-active .mobile-nav-toggle i {
  color: #fff !important;
}

/* --- Back to top --- */
[data-theme="dark"] .back-to-top i {
  background: var(--accent) !important;
}

/* --- Owl Carousel --- */
[data-theme="dark"] .owl-dot {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .owl-dot.active {
  background: var(--accent) !important;
}

/* --- Venobox --- */
[data-theme="dark"] .vbox-overlay {
  background: rgba(0, 0, 0, 0.9) !important;
}

/* --- Isotope --- */
[data-theme="dark"] .isotope-item {
  transition: none !important;
}

/* ============================================================
   16. FIX: Inline style hardcoded colors in views
   ============================================================ */
[data-theme="dark"] [style*="color:#556270"] {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] [style*="color: #556270"] {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] [style*="color:#999"] {
  color: var(--text-muted) !important;
}

[data-theme="dark"] [style*="color: #999"] {
  color: var(--text-muted) !important;
}

[data-theme="dark"] [style*="color:#fff"] {
  color: var(--text-primary) !important;
}

[data-theme="dark"] [style*="background:#fff"] {
  background: var(--bg-card) !important;
}

[data-theme="dark"] [style*="background: #fff"] {
  background: var(--bg-card) !important;
}

[data-theme="dark"] [style*="background:white"] {
  background: var(--bg-card) !important;
}

[data-theme="dark"] [style*="background: white"] {
  background: var(--bg-card) !important;
}

[data-theme="dark"] [style*="background-color:white"] {
  background: var(--bg-card) !important;
}

[data-theme="dark"] [style*="background-color: white"] {
  background: var(--bg-card) !important;
}

/* --- Firma detay sayfası inline CSS değişkenleri --- */
[data-theme="dark"] .firma-hero {
  --card: var(--bg-card);
  --card-muted: var(--bg-tertiary);
  --card-hover: var(--bg-tertiary);
  --line: var(--border-color);
  --line-light: var(--border-light);
  --ink-900: var(--text-primary);
  --ink-700: var(--text-secondary);
  --muted-600: var(--text-secondary);
  --muted-400: var(--text-muted);
  --muted-200: var(--border-color);
}

[data-theme="dark"] .firma-hero body {
  background: var(--bg-secondary);
}

[data-theme="dark"] .hero-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .hero-card::after {
  opacity: 0.3;
}

[data-theme="dark"] .stat-value {
  color: var(--text-primary);
}

[data-theme="dark"] .stat-label {
  color: var(--text-muted);
}

[data-theme="dark"] .info-row {
  border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .info-label {
  color: var(--text-muted);
}

[data-theme="dark"] .info-value {
  color: var(--text-primary);
}

[data-theme="dark"] .info-value a {
  color: var(--accent);
}

/* --- Yandex harita dark mode --- */
[data-theme="dark"] ymaps {
  filter: invert(0.9) hue-rotate(180deg);
}

/* --- Sosyal medya linkleri footer --- */
[data-theme="dark"] #footer .social-links a {
  background: rgba(255, 255, 255, 0.1) !important;
}

[data-theme="dark"] #footer .social-links a:hover {
  background: var(--accent) !important;
}

/* ============================================================
   17. USER PANEL (Dektrium) DARK MODE
   ============================================================ */
[data-theme="dark"] .settings-hero {
  background: linear-gradient(135deg, #1e3a5f, #1e40af) !important;
}

[data-theme="dark"] .auth-hero {
  background: linear-gradient(135deg, #1e3a5f, #1e40af) !important;
}

[data-theme="dark"] .hero-card {
  background: rgba(255, 255, 255, 0.06) !important;
}

[data-theme="dark"] .hero-card .eyebrow {
  color: rgba(255, 255, 255, 0.7) !important;
}

[data-theme="dark"] .hero-card h1 {
  color: #fff !important;
}

[data-theme="dark"] .hero-card .subtitle {
  color: rgba(255, 255, 255, 0.8) !important;
}

[data-theme="dark"] .hero-card .btn-light {
  background: rgba(255, 255, 255, 0.15) !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
  color: #fff !important;
}

[data-theme="dark"] .hero-card .btn-light:hover {
  background: rgba(255, 255, 255, 0.25) !important;
}

[data-theme="dark"] .hero-card .btn-outline-light {
  border-color: rgba(255, 255, 255, 0.3) !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

[data-theme="dark"] .hero-card .btn-outline-light:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

[data-theme="dark"] .hero-meta .meta-block {
  background: rgba(255, 255, 255, 0.08) !important;
}

[data-theme="dark"] .hero-meta .meta-label {
  color: rgba(255, 255, 255, 0.7) !important;
}

[data-theme="dark"] .hero-meta strong {
  color: #fff !important;
}

[data-theme="dark"] .auth-card,
[data-theme="dark"] .settings-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .auth-card .card-body h3,
[data-theme="dark"] .settings-card .card-body h3 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .auth-card .card-body p,
[data-theme="dark"] .settings-card .card-body p {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .auth-body {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .settings-section {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .settings-section h2,
[data-theme="dark"] .settings-section h3 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .settings-section p {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .settings-section .text-muted {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .company-item,
[data-theme="dark"] .claim-item {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .company-item:hover,
[data-theme="dark"] .claim-item:hover {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .company-name,
[data-theme="dark"] .claim-name {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .company-meta,
[data-theme="dark"] .claim-meta {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .empty-state {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .empty-state p {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .profile-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .profile-name {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .profile-bio {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .profile-stats {
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .profile-stat-value {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .profile-stat-label {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .recovery-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .recovery-card h3 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .recovery-card p {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .network-block {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .network-block .network-name {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .network-block .network-status {
  color: var(--text-muted) !important;
}

/* --- Dektrium default overrides --- */
[data-theme="dark"] .dektrium-user-box {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .dektrium-user-box h3 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .dektrium-user-box p {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .dektrium-user-box .help-block {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .alert {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .alert-success {
  background: rgba(16, 185, 129, 0.15) !important;
  border-color: rgba(16, 185, 129, 0.3) !important;
  color: #6ee7b7 !important;
}

[data-theme="dark"] .alert-info {
  background: rgba(59, 130, 246, 0.15) !important;
  border-color: rgba(59, 130, 246, 0.3) !important;
  color: #93c5fd !important;
}

[data-theme="dark"] .alert-warning {
  background: rgba(245, 158, 11, 0.15) !important;
  border-color: rgba(245, 158, 11, 0.3) !important;
  color: #fcd34d !important;
}

[data-theme="dark"] .alert-danger {
  background: rgba(239, 68, 68, 0.15) !important;
  border-color: rgba(239, 68, 68, 0.3) !important;
  color: #fca5a5 !important;
}

/* --- Support tickets --- */
[data-theme="dark"] .support-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .support-card .card-header {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .ticket-reply {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .ticket-reply .reply-author {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .ticket-reply .reply-date {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .ticket-reply .reply-body {
  color: var(--text-secondary) !important;
}

/* --- Comnews --- */
[data-theme="dark"] .news-card {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .news-card .news-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .news-card .news-text {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .news-card .news-date {
  color: var(--text-muted) !important;
}

/* --- Apps page --- */
[data-theme="dark"] .apps-page {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .apps-page h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .apps-page p {
  color: var(--text-secondary) !important;
}

/* --- Co (CRUD) pages --- */
[data-theme="dark"] .co-index h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .co-index .summary {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .co-form {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .co-form h1 {
  color: var(--text-primary) !important;
}

/* --- Sitemap pages --- */
[data-theme="dark"] .sitemap-page {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .sitemap-page h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .sitemap-page a {
  color: var(--accent) !important;
}

/* --- Provinces page --- */
[data-theme="dark"] .provinces-page h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .provinces-page .province-link {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .provinces-page .province-link:hover {
  color: var(--accent) !important;
}

/* --- Godirections page --- */
[data-theme="dark"] .directions-page h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .directions-page p {
  color: var(--text-secondary) !important;
}

/* --- Compmap page --- */
[data-theme="dark"] .compmap-page h1 {
  color: var(--text-primary) !important;
}

/* --- Messagesent page --- */
[data-theme="dark"] .messagesent-page {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .messagesent-page h1 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .messagesent-page p {
  color: var(--text-secondary) !important;
}

/* ============================================================
   18. FORCE OVERRIDE FOR INLINE STYLES
   ============================================================ */
[data-theme="dark"] [style*="background: #f8fbff"] {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] [style*="background:#f8fbff"] {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] [style*="border-bottom: 1px solid #edf2f7"] {
  border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] [style*="border: 1px solid #e5ecf6"] {
  border-color: var(--border-color) !important;
}

[data-theme="dark"] [style*="background: #e8f0fb"] {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] [style*="background:#e8f0fb"] {
  background: var(--bg-tertiary) !important;
}

[data-theme="dark"] [style*="box-shadow: inset 0 0 0 1px #e5ecf6"] {
  box-shadow: inset 0 0 0 1px var(--border-color) !important;
}
