/* Optimo Partner Portal - Consistent Form Styling */
/* Brand Colors: #141A8C (Deep Blue), #FFFFFF (White), #80F291 (Accent Green) */

/* Default Form Input Fields - Light Theme (White backgrounds) */
.form-input {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  background-color: #FFFFFF;
  border: 2px solid #141A8C !important;
  color: #141A8C;
  font-family: 'Inter', sans-serif;
  transition: all 0.3s ease;
}

.form-input:focus {
  outline: none;
  border-color: #80F291 !important;
  background-color: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(128, 242, 145, 0.1);
}

.form-input::placeholder {
  color: rgba(20, 26, 140, 0.5);
}

/* Form Labels */
.form-label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: #141A8C;
  margin-bottom: 0.5rem;
}

/* Form Select/Dropdown */
.form-select {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  background-color: #FFFFFF;
  border: 2px solid #141A8C !important;
  color: #141A8C;
  font-family: 'Inter', sans-serif;
  transition: all 0.3s ease;
}

.form-select:focus {
  outline: none;
  border-color: #80F291 !important;
  background-color: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(128, 242, 145, 0.1);
}

/* Textarea */
.form-textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  background-color: #FFFFFF;
  border: 2px solid #141A8C !important;
  color: #141A8C;
  font-family: 'Inter', sans-serif;
  transition: all 0.3s ease;
  min-height: 100px;
  resize: vertical;
}

.form-textarea:focus {
  outline: none;
  border-color: #80F291 !important;
  background-color: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(128, 242, 145, 0.1);
}

/* Checkbox & Radio Styles - Light Theme Default */
.form-checkbox,
.form-radio {
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid #141A8C !important;
  background-color: #FFFFFF;
  cursor: pointer;
  transition: all 0.2s ease;
}

.form-checkbox:hover,
.form-radio:hover {
  border-color: #80F291 !important;
}

.form-checkbox:checked,
.form-radio:checked {
  background-color: #80F291;
  border-color: #80F291 !important;
}

/* Context: Checkboxes inside blue boxes */
.blue-box .form-checkbox,
.blue-box .form-radio {
  border: 2px solid rgba(255, 255, 255, 0.3) !important;
  background-color: rgba(255, 255, 255, 0.1);
}

.blue-box .form-checkbox:checked,
.blue-box .form-radio:checked {
  background-color: #80F291;
  border-color: #80F291 !important;
}

/* Context: Forms inside blue boxes - Semi-transparent background + White Text */
.blue-box .form-input,
.blue-box .form-select,
.blue-box .form-textarea {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.3) !important;
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
}

.blue-box .form-input:focus,
.blue-box .form-select:focus,
.blue-box .form-textarea:focus {
  background-color: rgba(255, 255, 255, 0.15);
}

.blue-box .form-input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.blue-box .form-label {
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
}

/* Fix browser autocomplete styling - Light backgrounds */
.form-input:-webkit-autofill,
.form-input:-webkit-autofill:hover,
.form-input:-webkit-autofill:focus,
.form-input:-webkit-autofill:active,
.form-select:-webkit-autofill,
.form-select:-webkit-autofill:hover,
.form-select:-webkit-autofill:focus,
.form-select:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px #FFFFFF inset !important;
  -webkit-text-fill-color: #141A8C !important;
  border: 2px solid #141A8C !important;
  transition: background-color 5000s ease-in-out 0s;
}

/* Fix browser autocomplete styling - Blue box contexts */
.blue-box .form-input:-webkit-autofill,
.blue-box .form-input:-webkit-autofill:hover,
.blue-box .form-input:-webkit-autofill:focus,
.blue-box .form-input:-webkit-autofill:active,
.blue-box .form-select:-webkit-autofill,
.blue-box .form-select:-webkit-autofill:hover,
.blue-box .form-select:-webkit-autofill:focus,
.blue-box .form-select:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0.1) inset !important;
  -webkit-text-fill-color: #FFFFFF !important;
  border: 2px solid rgba(255, 255, 255, 0.3) !important;
  transition: background-color 5000s ease-in-out 0s;
}
