/* ============================================================
   AI Watermark Remover - Redesigned Styles (FIXED)
   Preserves all original selectors while improving UX
   ============================================================ */

/* Root variables - Enhanced color system */
.aiwr-root {
  --aiwr-radius-lg: 16px;
  --aiwr-radius-md: 12px;
  --aiwr-radius-sm: 8px;
  --aiwr-radius-xs: 4px;

  --aiwr-primary: #667eea;
  --aiwr-primary-dark: #5a67d8;
  --aiwr-primary-light: #7c8ff0;
  --aiwr-primary-2: #764ba2;
  
  --aiwr-success: #10b981;
  --aiwr-warning: #f59e0b;
  --aiwr-danger: #ef4444;
  --aiwr-info: #3b82f6;
  
  --aiwr-border: #e5e7eb;
  --aiwr-border-2: #d1d5db;
  --aiwr-bg: #ffffff;
  --aiwr-bg-soft: #f9fafb;
  --aiwr-bg-muted: #f3f4f6;
  --aiwr-text: #111827;
  --aiwr-text-2: #374151;
  --aiwr-text-muted: #6b7280;
  --aiwr-text-light: #9ca3af;
  
  /* Enhanced text colors for better visibility */
  --aiwr-text-ins: #14532d;
  --aiwr-text-del: #7f1d1d;
  --aiwr-bg-ins: linear-gradient(135deg, #dcfce7, #bbf7d0);
  --aiwr-bg-del: linear-gradient(135deg, #fee2e2, #fecaca);

  --aiwr-shadow-lg: 0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);
  --aiwr-shadow-md: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);
  --aiwr-shadow-sm: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);
  
  --aiwr-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Container - Clean card design with proper overflow for dropdowns */
.aiwr-root .aiwr-container {
  background: var(--aiwr-bg);
  border-radius: var(--aiwr-radius-lg);
  box-shadow: var(--aiwr-shadow-lg);
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0;
  overflow: visible; /* Allow dropdown to overflow */
  position: relative;
  isolation: isolate; /* Create new stacking context */
}

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

/* ============================================================
   HEADER SECTION - Hero stats with improved prominence
   ============================================================ */

.aiwr-root .aiwr-header {
  background: linear-gradient(135deg, var(--aiwr-primary) 0%, var(--aiwr-primary-2) 100%);
  padding: 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  border-radius: var(--aiwr-radius-lg) var(--aiwr-radius-lg) 0 0;
}

.aiwr-root .aiwr-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at top right, rgba(255,255,255,0.1), transparent);
  pointer-events: none;
}

.aiwr-root .aiwr-title {
  color: white;
  font-size: 2rem; /* Increased from 1.75rem */
  font-weight: 700;
  margin: 0 0 1.5rem;
  position: relative;
}

/* Stats wrapper with client-only badge */
.aiwr-root .aiwr-stats-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  position: relative;
}

/* Stats - Prominent card-based display */
.aiwr-root .aiwr-stats {
  display: flex;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.aiwr-root .aiwr-stat {
  background: rgba(255, 255, 255, 0.95);
  border-radius: var(--aiwr-radius-md);
  padding: 1.25rem 2rem;
  min-width: 140px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  transition: var(--aiwr-transition);
  transform: translateY(0);
}

.aiwr-root .aiwr-stat:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
}

.aiwr-root .aiwr-stat > span {
  display: block;
  color: var(--aiwr-text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}

.aiwr-root .aiwr-char-count,
.aiwr-root .aiwr-wm-count,
.aiwr-root .aiwr-score {
  font-size: 2rem;
  font-weight: 800;
  color: var(--aiwr-primary);
  line-height: 1;
}

/* Client-only badge positioned to the right */
.aiwr-root .aiwr-badge--info {
  position: absolute;
  right: 0;
  background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
  border: 1px solid #bfdbfe;
  color: #1e40af;
  font-weight: 500;
  padding: 0.5rem 0.75rem;
  border-radius: var(--aiwr-radius-sm);
  font-size: 0.875rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

/* ============================================================
   INPUT SECTION - Unified controls and tabbed interface
   ============================================================ */

.aiwr-root .aiwr-input-section {
  padding: 2rem;
  border-bottom: 1px solid var(--aiwr-border);
}

.aiwr-root .aiwr-input-controls {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.aiwr-root .aiwr-input-tabs {
  display: flex;
  gap: 0.25rem;
  border-bottom: 2px solid var(--aiwr-border);
  flex: 1;
  min-width: 300px;
}

.aiwr-root .aiwr-toolbar-actions {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}

.aiwr-root .aiwr-input-tab {
  padding: 0.75rem 1.5rem;
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--aiwr-text-muted);
  font-weight: 500;
  cursor: pointer;
  transition: var(--aiwr-transition);
  position: relative;
  margin-bottom: -2px;
}

.aiwr-root .aiwr-input-tab:hover {
  color: var(--aiwr-text);
  background: var(--aiwr-bg-soft);
}

.aiwr-root .aiwr-input-tab.active {
  color: var(--aiwr-primary);
  border-bottom-color: var(--aiwr-primary);
}

.aiwr-root .aiwr-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  background: var(--aiwr-bg);
  border: 1px solid var(--aiwr-border-2);
  border-radius: var(--aiwr-radius-sm);
  font-size: 0.875rem;
  color: var(--aiwr-text-2);
  transition: var(--aiwr-transition);
}

.aiwr-root .aiwr-badge:hover {
  border-color: var(--aiwr-primary);
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.aiwr-root .aiwr-badge input[type="checkbox"],
.aiwr-root .aiwr-badge input[type="radio"] {
  accent-color: var(--aiwr-primary);
  cursor: pointer;
}

.aiwr-root .aiwr-badge label {
  cursor: pointer;
  user-select: none;
}

.aiwr-root .btn-help {
  background: var(--aiwr-info);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
}

.aiwr-root .btn-help:hover {
  background: #2563eb;
  transform: translateY(-1px);
}

.aiwr-root .aiwr-input-content {
  display: none;
}

.aiwr-root .aiwr-input-content.active {
  display: block;
  animation: fadeIn 0.3s ease-in-out;
}

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

/* Input helpers */
.aiwr-root .aiwr-input-helper {
  font-size: 0.875rem;
  color: var(--aiwr-text-muted);
}

.aiwr-root .aiwr-url-wrap {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

.aiwr-root .aiwr-url {
  flex: 1;
  padding: 0.75rem 1rem;
  border: 2px solid var(--aiwr-border);
  border-radius: var(--aiwr-radius-sm);
  font-size: 1rem;
  transition: var(--aiwr-transition);
  background: var(--aiwr-bg);
}

.aiwr-root .aiwr-url:focus {
  outline: none;
  border-color: var(--aiwr-primary);
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* File upload area */
.aiwr-root .aiwr-file-area {
  border: 2px dashed var(--aiwr-border-2);
  border-radius: var(--aiwr-radius-md);
  padding: 3rem 2rem;
  text-align: center;
  transition: var(--aiwr-transition);
  background: var(--aiwr-bg-soft);
}

.aiwr-root .aiwr-file-area:hover {
  border-color: var(--aiwr-primary);
  background: var(--aiwr-bg);
}

.aiwr-root .aiwr-file-area.drag-over {
  border-color: var(--aiwr-primary);
  background: linear-gradient(135deg, #f0f4ff, #fff);
}

.aiwr-root .aiwr-file {
  display: none;
}

/* ============================================================
   MAIN WORK AREA - Editor and preview
   ============================================================ */

.aiwr-root .aiwr-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.aiwr-root .aiwr-grid > div {
  padding: 2rem;
  overflow: visible;
}

.aiwr-root .aiwr-grid > div:first-child {
  border-right: 1px solid var(--aiwr-border);
}

.aiwr-root .aiwr-grid > div > label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--aiwr-text-2);
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.025em;
  margin-bottom: 1rem;
}

/* Textarea styling */
.aiwr-root .aiwr-field {
  width: 100%;
  height: 400px;
  padding: 1rem;
  border: 2px solid var(--aiwr-border);
  border-radius: var(--aiwr-radius-sm);
  font-size: 0.9375rem;
  line-height: 1.6;
  resize: vertical;
  transition: var(--aiwr-transition);
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
  background: var(--aiwr-bg);
  box-sizing: border-box;
}

.aiwr-root .aiwr-field:focus {
  outline: none;
  border-color: var(--aiwr-primary);
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.aiwr-root .aiwr-field::placeholder {
  color: var(--aiwr-text-light);
}

/* Output panel */
.aiwr-root .aiwr-output {
  width: 100%;
  height: 400px;
  max-width: 100%;
  padding: 1rem;
  background: var(--aiwr-bg-soft);
  border: 2px solid var(--aiwr-border);
  border-radius: var(--aiwr-radius-sm);
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
  font-size: 0.9375rem;
  line-height: 1.6;
  white-space: pre-wrap;
  word-wrap: break-word;
  word-break: break-word;
  overflow-x: auto;
  overflow-y: auto;
  position: relative;
  box-sizing: border-box;
  resize: vertical;
}

.aiwr-root .aiwr-output:empty::before {
  content: 'Processed text will appear here...';
  color: var(--aiwr-text-light);
  font-style: italic;
}

.aiwr-root .aiwr-output ins {
  background: var(--aiwr-bg-ins);
  color: var(--aiwr-text-ins);
  text-decoration: none;
  padding: 0.125rem 0.25rem;
  border-radius: var(--aiwr-radius-xs);
  display: inline-block;
}

.aiwr-root .aiwr-output del {
  background: var(--aiwr-bg-del);
  color: var(--aiwr-text-del);
  text-decoration: line-through;
  padding: 0.125rem 0.25rem;
  border-radius: var(--aiwr-radius-xs);
  display: inline-block;
}

/* ============================================================
   ACTION BARS - Primary actions
   ============================================================ */

.aiwr-root .aiwr-actions {
  padding: 1.5rem 2rem;
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}

.aiwr-root .aiwr-actions--primary {
  background: var(--aiwr-bg-soft);
  border-bottom: 1px solid var(--aiwr-border);
  justify-content: space-between;
  overflow: visible;
  position: relative;
  z-index: 50;
}

.aiwr-root .aiwr-action-controls {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.aiwr-root .aiwr-export-actions {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  flex-wrap: wrap;
}

/* ============================================================
   BUTTONS - Consistent styling with clear hierarchy
   ============================================================ */

.aiwr-root .aiwr-btn,
.aiwr-root .btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--aiwr-radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: var(--aiwr-transition);
  user-select: none;
  position: relative;
  text-decoration: none;
  min-height: 44px;
}

/* Button variants */
.aiwr-root .aiwr-btn--primary,
.aiwr-root .btn-primary {
  background: linear-gradient(135deg, var(--aiwr-primary) 0%, var(--aiwr-primary-2) 100%);
  color: white;
  border: none;
  font-size: 1rem;
  padding: 0.75rem 2rem;
  box-shadow: 0 4px 6px rgba(102, 126, 234, 0.25);
}

.aiwr-root .aiwr-btn--primary:hover,
.aiwr-root .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(102, 126, 234, 0.35);
}

.aiwr-root .btn-secondary {
  background: var(--aiwr-bg);
  color: var(--aiwr-text-2);
  border: 1px solid var(--aiwr-border-2);
}

.aiwr-root .btn-secondary:hover {
  background: var(--aiwr-bg-soft);
  border-color: var(--aiwr-border);
}

.aiwr-root .btn-filter {
  background: var(--aiwr-success);
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}

.aiwr-root .btn-filter:hover {
  background: #059669;
  transform: translateY(-1px);
}

.aiwr-root .aiwr-filter-count {
  background: rgba(255, 255, 255, 0.2);
  padding: 0.125rem 0.5rem;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 700;
}

.aiwr-root .aiwr-btn:disabled,
.aiwr-root .btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

/* Filter dropdown panel */
.aiwr-root .aiwr-filter {
  position: relative;
  z-index: 1000;
}

.aiwr-root .aiwr-filter-panel {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  z-index: 100000;
  min-width: 320px;
  max-height: 400px;
  background: var(--aiwr-bg);
  border: 1px solid var(--aiwr-border);
  border-radius: var(--aiwr-radius-md);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
  display: none;
  overflow: hidden;
  transform-origin: top right;
}

.aiwr-root .aiwr-filter[aria-expanded="true"] .aiwr-filter-panel {
  display: block;
  animation: slideDown 0.2s ease-out;
}

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

.aiwr-root .aiwr-filter-panel-header {
  padding: 1rem;
  border-bottom: 1px solid var(--aiwr-border);
  background: var(--aiwr-bg-soft);
}

.aiwr-root .aiwr-filter-panel-header label {
  color: var(--aiwr-text);
}

.aiwr-root .aiwr-filter-items {
  max-height: 320px;
  overflow-y: auto;
  padding: 0.5rem;
}

.aiwr-root .aiwr-filter-item {
  padding: 0.5rem;
  border-radius: var(--aiwr-radius-sm);
  transition: var(--aiwr-transition);
}

.aiwr-root .aiwr-filter-item:hover {
  background: var(--aiwr-bg-soft);
}

.aiwr-root .aiwr-filter-item label {
  color: var(--aiwr-text);
}

/* ============================================================
   LEGEND & STATUS - Information display
   ============================================================ */

.aiwr-root .aiwr-legend {
  padding: 0 2rem;
  margin-bottom: 1rem;
}

.aiwr-root .aiwr-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  background: var(--aiwr-bg-soft);
  border: 1px solid var(--aiwr-border);
  border-radius: 999px;
  font-size: 0.8125rem;
  margin: 0.25rem;
}

.aiwr-root .aiwr-state {
  padding: 0 2rem 1.5rem;
  color: var(--aiwr-text-muted);
  font-size: 0.875rem;
  min-height: 1.5rem;
}

.aiwr-root .aiwr-wm-token {
  display: inline-block;
  padding: 0.125rem 0.375rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  font-family: monospace;
}

/* Watermark color classes (preserved from original) */
.aiwr-root .wm-0  { background:#ff6b6b; color:#fff; }
.aiwr-root .wm-1  { background:#4ecdc4; color:#fff; }
.aiwr-root .wm-2  { background:#45b7d1; color:#fff; }
.aiwr-root .wm-3  { background:#f7b731; color:#000; }
.aiwr-root .wm-4  { background:#5f27cd; color:#fff; }
.aiwr-root .wm-5  { background:#00d2d3; color:#fff; }
.aiwr-root .wm-6  { background:#ff9ff3; color:#000; }
.aiwr-root .wm-7  { background:#54a0ff; color:#fff; }
.aiwr-root .wm-8  { background:#48dbfb; color:#000; }
.aiwr-root .wm-9  { background:#ff6348; color:#fff; }
.aiwr-root .wm-10 { background:#a29bfe; color:#fff; }
.aiwr-root .wm-11 { background:#fd79a8; color:#fff; }
.aiwr-root .wm-12 { background:#fdcb6e; color:#000; }
.aiwr-root .wm-13 { background:#6c5ce7; color:#fff; }
.aiwr-root .wm-14 { background:#ffeaa7; color:#000; }
.aiwr-root .wm-15 { background:#00b894; color:#fff; }
.aiwr-root .wm-16 { background:#e17055; color:#fff; }
.aiwr-root .wm-17 { background:#74b9ff; color:#000; }
.aiwr-root .wm-18 { background:#a0e7e5; color:#000; }
.aiwr-root .wm-19 { background:#b4e7ce; color:#000; }
.aiwr-root .wm-20 { background:#ffbe76; color:#000; }
.aiwr-root .wm-21 { background:#ff7979; color:#fff; }
.aiwr-root .wm-22 { background:#badc58; color:#000; }
.aiwr-root .wm-23 { background:#dfe6e9; color:#000; }
.aiwr-root .wm-24 { background:#c7ecee; color:#000; }
.aiwr-root .wm-25 { background:#f8b500; color:#fff; }
.aiwr-root .wm-26 { background:#778beb; color:#fff; }
.aiwr-root .wm-27 { background:#ea8685; color:#fff; }
.aiwr-root .wm-28 { background:#596275; color:#fff; }
.aiwr-root .wm-29 { background:#cf6a87; color:#fff; }
.aiwr-root .wm-30 { background:#786fa6; color:#fff; }
.aiwr-root .wm-31 { background:#f19066; color:#fff; }
.aiwr-root .wm-32 { background:#f5cd79; color:#000; }
.aiwr-root .wm-33 { background:#546de5; color:#fff; }

/* ============================================================
   RESPONSIVE DESIGN
   ============================================================ */

@media (max-width: 968px) {
  .aiwr-root .aiwr-grid {
    grid-template-columns: 1fr;
  }
  
  .aiwr-root .aiwr-grid > div:first-child {
    border-right: none;
    border-bottom: 1px solid var(--aiwr-border);
  }
  
  .aiwr-root .aiwr-stats-wrapper {
    flex-direction: column;
    gap: 1rem;
  }
  
  .aiwr-root .aiwr-stats {
    flex-direction: column;
    gap: 1rem;
  }
  
  .aiwr-root .aiwr-stat {
    width: 100%;
    max-width: 300px;
  }
  
  .aiwr-root .aiwr-badge--info {
    position: static;
    margin-top: 1rem;
  }
  
  .aiwr-root .aiwr-input-controls {
    flex-direction: column;
    align-items: stretch;
  }
  
  .aiwr-root .aiwr-input-tabs {
    width: 100%;
  }
  
  .aiwr-root .aiwr-toolbar-actions {
    width: 100%;
    justify-content: center;
  }
  
  .aiwr-root .aiwr-actions--primary {
    flex-direction: column;
    gap: 1rem;
  }
  
  .aiwr-root .aiwr-action-controls,
  .aiwr-root .aiwr-export-actions {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 640px) {
  .aiwr-root .aiwr-header {
    padding: 1.5rem 1rem;
  }
  
  .aiwr-root .aiwr-title {
    font-size: 1.75rem;
  }
  
  .aiwr-root .aiwr-actions {
    padding: 1rem;
  }
  
  .aiwr-root .aiwr-field,
  .aiwr-root .aiwr-output {
    height: 300px;
  }
  
  .aiwr-root .aiwr-export-actions {
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }
  
  .aiwr-root .aiwr-input-tab {
    padding: 0.5rem 0.75rem;
    font-size: 0.8125rem;
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .aiwr-root * {
    animation: none !important;
    transition: none !important;
  }
}

/* Dark mode support - Enhanced text visibility */
@media (prefers-color-scheme: dark) {
  .aiwr-root {
    --aiwr-bg: #0f172a;
    --aiwr-bg-soft: #1e293b;
    --aiwr-bg-muted: #334155;
    --aiwr-text: #f1f5f9;
    --aiwr-text-2: #e2e8f0;
    --aiwr-text-muted: #cbd5e1;
    --aiwr-text-light: #94a3b8;
    --aiwr-border: #334155;
    --aiwr-border-2: #475569;
    
    /* Enhanced colors for better dark mode visibility */
    --aiwr-text-ins: #4ade80;
    --aiwr-text-del: #f87171;
    --aiwr-bg-ins: linear-gradient(135deg, rgba(34, 197, 94, 0.25), rgba(34, 197, 94, 0.15));
    --aiwr-bg-del: linear-gradient(135deg, rgba(239, 68, 68, 0.25), rgba(239, 68, 68, 0.15));
  }
  
  .aiwr-root .aiwr-container {
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.5);
  }
  
  /* Ensure title is white in dark mode */
  .aiwr-root .aiwr-title {
    color: #ffffff !important;
  }
  
  .aiwr-root .aiwr-stat {
    background: rgba(30, 41, 59, 0.95);
    color: var(--aiwr-text);
  }
  
  /* Client-only badge in dark mode */
  .aiwr-root .aiwr-badge--info {
    background: rgba(30, 58, 138, 0.2);
    border-color: rgba(59, 130, 246, 0.3);
    color: #93c5fd;
  }
  
  /* Better visibility for diff elements */
  .aiwr-root .aiwr-output ins {
    background: var(--aiwr-bg-ins);
    color: var(--aiwr-text-ins);
    font-weight: 500;
    border: 1px solid rgba(34, 197, 94, 0.3);
    text-shadow: 0 0 1px rgba(0, 0, 0, 0.5);
  }
  
  .aiwr-root .aiwr-output del {
    background: var(--aiwr-bg-del);
    color: var(--aiwr-text-del);
    font-weight: 500;
    border: 1px solid rgba(239, 68, 68, 0.3);
    text-shadow: 0 0 1px rgba(0, 0, 0, 0.5);
  }
  
  /* Ensure watermark tokens are visible in dark mode */
  .aiwr-root .aiwr-wm-token {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
    font-weight: 600;
  }
  
  /* Enhanced button text visibility */
  .aiwr-root .btn-secondary {
    background: var(--aiwr-bg-muted);
    color: var(--aiwr-text);
    border-color: var(--aiwr-border-2);
  }
  
  .aiwr-root .btn-secondary:hover {
    background: #475569;
    color: #f1f5f9;
    border-color: #64748b;
  }
  
  /* Better input/output visibility */
  .aiwr-root .aiwr-field,
  .aiwr-root .aiwr-output {
    background: var(--aiwr-bg-soft);
    color: var(--aiwr-text);
    border-color: var(--aiwr-border-2);
  }
  
  .aiwr-root .aiwr-field::placeholder,
  .aiwr-root .aiwr-output:empty::before {
    color: var(--aiwr-text-light);
    opacity: 0.7;
  }
  
  /* Filter panel in dark mode - WHITE TEXT FIX */
  .aiwr-root .aiwr-filter-panel {
    background: var(--aiwr-bg-soft);
    border-color: var(--aiwr-border-2);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.5);
  }
  
  .aiwr-root .aiwr-filter-panel-header {
    background: var(--aiwr-bg-muted);
  }
  
  .aiwr-root .aiwr-filter-panel-header label {
    color: #ffffff !important;
  }
  
  .aiwr-root .aiwr-filter-item:hover {
    background: var(--aiwr-bg-muted);
  }
  
  .aiwr-root .aiwr-filter-item label {
    color: #ffffff !important;
  }
  
  .aiwr-root .aiwr-badge {
    background: var(--aiwr-bg-muted);
    border-color: var(--aiwr-border);
    color: var(--aiwr-text);
  }
  
  .aiwr-root .aiwr-badge:hover {
    background: #475569;
    border-color: var(--aiwr-primary);
  }
  
  /* Ensure input tabs and helper text are white in dark mode */
  .aiwr-root .aiwr-input-tab {
    color: var(--aiwr-text-muted);
  }
  
  .aiwr-root .aiwr-input-tab:hover {
    color: var(--aiwr-text);
  }
  
  .aiwr-root .aiwr-input-tab.active {
    color: var(--aiwr-primary-light);
  }
  
  .aiwr-root .aiwr-input-helper {
    color: var(--aiwr-text);
  }
  
  /* Success state in dark mode - WHITE TEXT FIX */
  .aiwr-root .aiwr-state {
    color: #ffffff !important;
  }
  
  /* Ensure all text elements have proper contrast */
  .aiwr-root .aiwr-title,
  .aiwr-root .aiwr-char-count,
  .aiwr-root .aiwr-wm-count,
  .aiwr-root .aiwr-score,
  .aiwr-root label,
  .aiwr-root p {
    color: inherit;
  }
  
  .aiwr-root .aiwr-chip {
    background: var(--aiwr-bg-muted);
    border-color: var(--aiwr-border-2);
    color: var(--aiwr-text);
  }
  
  /* Help button in dark mode */
  .aiwr-root .btn-help {
    background: var(--aiwr-info);
    color: white;
  }
  
  .aiwr-root .btn-help:hover {
    background: #2563eb;
  }
}