/* ============================================
   FORMS.CSS - Inputs, Selects, Form Layouts
   ============================================
   Contains:
   - Form container
   - Form labels
   - Form controls
   - Form selects
   - Buttons
   - Empty state
   - Sync cards
   - Dark mode form overrides
   ============================================ */

/* Forms - Soft styling */
.form-container {
    background-color: var(--surface);
    padding: var(--space-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-soft);
}

.form-label {
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.form-control {
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
    padding: 10px 14px;
    font-size: 0.9375rem;
    transition: all var(--transition-fast);
}

.form-control:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-soft);
}

.form-select {
    border-radius: var(--radius-full);
    border: 1.5px solid var(--border);
    padding: 8px 32px 8px 14px;
    font-size: 0.9375rem;
    font-family: inherit;
    background-color: var(--surface);
    color: var(--text-primary);
    cursor: pointer;
    transition: all var(--transition-base);
}

.form-select:hover {
    border-color: var(--border-focus);
}

.form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-soft), var(--shadow-sm);
    outline: none;
}

/* Buttons - Soft, friendly */
.btn {
    border-radius: var(--radius-md);
    font-weight: 600;
    transition: all var(--transition-base);
}

.btn:active {
    transform: scale(0.98);
}

.btn-primary {
    background-color: var(--primary);
    border-color: var(--primary);
}

.btn-primary:hover {
    background-color: var(--primary-hover);
    border-color: var(--primary-hover);
    box-shadow: var(--shadow-sm);
}

.btn-submit {
    background-color: var(--primary);
    color: white;
    border: none;
    padding: 12px 24px;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-weight: 600;
    transition: all var(--transition-base);
}

.btn-submit:hover {
    background-color: var(--primary-hover);
    box-shadow: var(--shadow-md);
}

/* Empty State - Friendly */
.empty-state {
    text-align: center;
    padding: var(--space-2xl) var(--space-lg);
    color: var(--text-secondary);
}

.empty-state i {
    font-size: 3rem;
    margin-bottom: var(--space-md);
    color: var(--text-muted);
}

/* Sync Cards - Soft styling */
.sync-card {
    background-color: var(--surface);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-soft);
    transition: all var(--transition-base);
    margin-bottom: var(--space-lg);
}

.sync-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.sync-card h5 {
    color: var(--primary);
    font-weight: 700;
    margin-bottom: var(--space-sm);
}

.sync-card .sync-status {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

/* Sync Health Cards - Soft styling */
.sync-health-card {
    background-color: var(--surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-soft);
    padding: var(--space-lg);
    margin-bottom: var(--space-lg);
    transition: all var(--transition-base);
}

.sync-health-card:hover {
    box-shadow: var(--shadow-md);
}

/* ============================================
   DARK MODE FORM OVERRIDES
   ============================================ */

/* Dark mode form inputs */
[data-theme="dark"] .filter-select,
[data-theme="dark"] input.form-control,
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select,
[data-theme="dark"] .form-select-sm,
[data-theme="dark"] select.form-select,
[data-theme="dark"] select.form-select-sm {
  background-color: var(--surface) !important;
  color: var(--text-primary) !important;
  border-color: var(--border) !important;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus,
[data-theme="dark"] .form-select-sm:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px var(--primary-soft) !important;
}

[data-theme="dark"] .form-select:hover,
[data-theme="dark"] .form-select-sm:hover {
  border-color: var(--border-focus) !important;
}

/* Dark mode select dropdown arrow - lighter color for visibility */
[data-theme="dark"] .form-select,
[data-theme="dark"] .form-select-sm,
[data-theme="dark"] select.form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
}

[data-theme="dark"] .search-control-shell:focus-within .search-control-shell__icon {
  color: var(--primary);
}

.search-input {
  width: 100%;
  max-width: 280px;
  padding: 10px 16px 10px 40px;
  background: var(--surface);
  color: var(--text-primary);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-full);
  font-size: 0.9375rem;
  font-family: inherit;
  transition: all var(--transition-base);
  outline: none;
}

.search-input::placeholder {
  color: var(--text-muted);
  opacity: 0.8;
  transition: opacity var(--transition-fast);
}

.search-input:hover {
  border-color: var(--border-focus);
  background: var(--surface);
}

.search-input:hover::placeholder {
  opacity: 1;
}

.search-input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-soft), var(--shadow-sm);
  background: var(--surface);
  color: var(--text-primary);
}

.search-input:focus::placeholder {
  opacity: 0.6;
}

/* Dark mode search inputs */
[data-theme="dark"] input[type="search"],
[data-theme="dark"] .search-input {
  background-color: var(--surface) !important;
  color: var(--text-primary) !important;
  border: 1.5px solid var(--border) !important;
}

[data-theme="dark"] .search-input:hover {
  border-color: var(--border-focus) !important;
}

[data-theme="dark"] .search-input:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px var(--primary-soft), var(--shadow-sm) !important;
}

[data-theme="dark"] .search-input::placeholder {
  color: var(--text-muted) !important;
}

/* Dark mode select options */
[data-theme="dark"] .filter-select option,
[data-theme="dark"] select.form-control option,
[data-theme="dark"] .form-select option {
  background-color: var(--surface) !important;
  color: var(--text-primary) !important;
}

/* Dark mode buttons */
[data-theme="dark"] .btn-light {
  background-color: var(--surface-hover) !important;
  color: var(--text-primary) !important;
  border-color: var(--border) !important;
}

[data-theme="dark"] .btn-light:hover {
  background-color: var(--primary-soft) !important;
  color: var(--primary) !important;
  border-color: var(--primary) !important;
}

[data-theme="dark"] .btn-outline-secondary {
  color: var(--text-primary);
  border-color: var(--border);
}

[data-theme="dark"] .btn-outline-secondary:hover {
  background-color: var(--surface-hover);
  border-color: var(--primary);
  color: var(--primary);
}

/* Dark mode reset buttons */
[data-theme="dark"] #resetWIFiltersBtn,
[data-theme="dark"] #resetPRFiltersBtn,
[data-theme="dark"] .filter-reset-cell .btn {
  background-color: var(--surface-hover) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border) !important;
}

[data-theme="dark"] #resetWIFiltersBtn:hover,
[data-theme="dark"] #resetPRFiltersBtn:hover,
[data-theme="dark"] .filter-reset-cell .btn:hover {
  background-color: var(--primary-soft) !important;
  border-color: var(--primary) !important;
  color: var(--primary) !important;
}

/* Dark mode auth status */
[data-theme="dark"] .auth-status .text-muted {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .auth-status a {
  color: var(--primary) !important;
}
