
/* ---------- GENERIC FORM STYLES ---------- */

.form { /* wrapper */
  display: grid;
  gap: 16px;
  margin-top: 18px;
  text-align: left;
  justify-items: stretch;
}

.form-row { display: grid; gap: 8px; }

.form-row > :is(.form-input, .form-select, .form-button) {
  width: 100%;
}

.form-label {
  font-weight: 700;
  color: var(--muted-dark);
}
body.light-mode .form-label { color: var(--muted-light); }

.form-input,
.form-select {
  appearance: none;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border-dark);
  background: #2b2b2b;
  color: var(--text-dark);
  box-shadow:
    inset 0 2px 6px rgba(0, 0, 0, 0.6),
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 1px 2px rgba(0, 0, 0, 0.3);
  transition: box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.form-input::placeholder { color: #8a8a8a; }

.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow:
    inset 0 2px 6px rgba(0, 0, 0, 0.7),
    0 0 0 3px rgba(77, 182, 255, 0.22),
    0 4px 14px rgba(0, 0, 0, 0.35);
}

/* Light mode fields */
body.light-mode .form-input,
body.light-mode .form-select {
  background: #ffffff;
  color: var(--text-light);
  border-color: var(--border-light);
  box-shadow:
    inset 0 1px 2px rgba(0, 0, 0, 0.06),
    0 1px 2px rgba(0, 0, 0, 0.06);
}

body.light-mode .form-input:focus,
body.light-mode .form-select:focus {
  border-color: var(--accent-light);
  box-shadow:
    inset 0 1px 2px rgba(0, 0, 0, 0.08),
    0 0 0 3px rgba(0, 122, 204, 0.18);
}

/* File input tweak */
.form-input[type="file"] { padding: 10px 12px; }
.form-input[type="file"]::file-selector-button {
  margin-right: 10px;
  padding: 8px 12px;
  border: 1px solid #555;
  border-radius: 6px;
  background: #383838;
  color: var(--text-dark);
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}
.form-input[type="file"]::file-selector-button:hover { background: #424242; }

body.light-mode .form-input[type="file"]::file-selector-button {
  background: #f5f5f5;
  border-color: var(--border-light);
  color: var(--text-light);
}
body.light-mode .form-input[type="file"]::file-selector-button:hover { background: #efefef; }

.form-help {
  font-size: 12px;
  color: #9a9a9a;
}
body.light-mode .form-help { color: #666; }

.form-button {
  display: inline-block;
  margin-top: 4px;
  padding: 10px 16px;
  border: none;
  border-radius: 10px;
  background-color: #30444f;
  color: #fff;
  cursor: pointer;
  font-size: 14px;
  transition: background-color 0.2s ease, transform 0.02s ease-in-out;
}
.form-button:hover { background-color: #344c57; }
.form-button:active { transform: translateY(1px); }

body.light-mode .form-button { background-color: #387da8; }
body.light-mode .form-button:hover { background-color: #558fb4; }
