.form {
    padding: 2rem;
    padding-top: 27vh;
    padding-bottom: 20vh;
    min-height: 30vh;
    max-width: min(80vw, 800px);
    margin: 0 auto;
}

.formio-logo,
.formio-footer {
    display: none !important;
}

/* Form container */
.formio-form {
  background: var(--background-100);
  padding: 2rem;
  border-radius: 1rem;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
  color: var(--text);
  font-family: 'Segoe UI', sans-serif;
}

/* Labels */
.formio-component label {
  font-weight: 600;
  font-size: 1rem;
  margin-bottom: 0.5rem;
  display: block;
  color: var(--text-900);
}

/* Input fields (text, number, email, password) */
.form-control {
  width: 90%;
  margin: auto;
  padding: 0.75rem;
  font-size: 1rem;
  border: 1px solid var(--background-400);
  border-radius: 0.5rem;
  background: var(--background-200);
  color: var(--text);
  transition: border-color 0.2s ease;
}

.form-control:focus {
  border-color: var(--primary);
  outline: none;
  background: var(--background-300);
}

.form-control::placeholder {
  color: var(--text-600);
}

/* Required Asterisk */
.formio-component-required label::after {
  content: ' *';
  color: var(--primary-500);
}

/* Error messages */
.formio-error-wrapper {
  color: #ff4c4c;
  font-size: 0.9rem;
  margin-top: 0.3rem;
}

.alert {
    padding: 1rem;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
}

.alert-success {
  background-color: var(--primary-100);
  color: var(--primary-900);
}

.alert-danger {
  background-color: color-mix(in srgb, var(--accent-300) 100%, red);
  color: var(--accent-900);
}

.alert li {
    list-style: none;
    text-decoration: none;
}

/* Buttons */
.formio-component-button .btn {
  background-color: var(--primary);
  color: var(--text);
  font-weight: bold;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.formio-component-button .btn:hover {
  background-color: var(--primary-400);
}

/* Checkbox & Radio */
.form-check input[type="checkbox"],
.form-check input[type="radio"] {
  accent-color: var(--primary);
  margin-right: 0.5rem;
}

.form-check label {
  color: var(--text);
  display: flex;
  align-items: center;
  font-weight: normal;
}

/* Select dropdown */
.formio-component-select select {
  background: var(--background-200);
  color: var(--text);
  border: 1px solid var(--background-400);
  border-radius: 0.5rem;
  padding: 0.75rem;
  appearance: none;
}

.formio-component-select select:focus {
  border-color: var(--primary);
  background: var(--background-300);
}

/* File Upload / Drag & Drop */
.formio-component-file .fileSelector {
  background: var(--background-200);
  border: 2px dashed var(--accent-400);
  color: var(--text-800);
  padding: 1rem;
  text-align: center;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.formio-component-file .fileSelector:hover {
  border-color: var(--accent-600);
  background-color: var(--background-300);
}

.formio-component-file .form-control {
  background: var(--background-300);
}

/* Description / Help text */
.formio-component-description {
  font-size: 0.85rem;
  color: var(--text-700);
  margin-bottom: 0.5rem;
}

/* Drag & Drop (e.g. layout builder) */
.formio-drop-zone {
  border: 2px dashed var(--accent-400);
  border-radius: 0.5rem;
  padding: 1rem;
  background: var(--background-200);
  color: var(--text-600);
  text-align: center;
}

.formio-drop-zone-active {
  border-color: var(--primary-500);
  background: var(--background-300);
}

/* Panel / Container / Fieldset Titles */
legend,
.panel-title,
.card-header {
  color: var(--text-900);
  font-size: 1.1rem;
  font-weight: 600;
  padding-bottom: 0.5rem;
}

/* Form group spacing */
.form-group {
  margin-bottom: 1.5rem;
}

/* Table elements in forms */
.table {
  background: var(--background-200);
  color: var(--text);
}

.table th,
.table td {
  border-color: var(--background-400);
}

/* Tags / chips / multiple values */
.tagify {
  background: var(--background-200);
  border: 1px solid var(--background-400);
  border-radius: 0.5rem;
  color: var(--text);
}

.tagify__tag {
  background: var(--accent-500);
  color: var(--text);
}

/* Custom checkbox/radio group appearance */
.formio-radio input[type="radio"],
.formio-checkbox input[type="checkbox"] {
  accent-color: var(--primary);
}


.autocomplete {
    background-color: var(--background-200) !important;
    color: var(--text) !important;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
}

.autocomplete>div.selected, .autocomplete>div:hover:not(.group) {
    background-color: var(--primary-300) !important;
    color: var(--text) !important;
}

.choices__list--dropdown  {
    background-color: var(--background-200) !important;
    color: var(--text) !important;
}

.choices.form-group.formio-choices::after {
    content: '';
    display: none;
}

.choices__input {
    background-color: var(--background-200) !important;
    color: var(--text) !important;
}

.choices__item--selectable.is-highlighted {
    background-color: var(--primary-300) !important;
    color: var(--text) !important;
}

.form-check-input[type="checkbox"] {
  accent-color: var(--primary);
  width: 1.2em;
  height: 1.2em;
  background-color: var(--background-100);
  border: 1px solid var(--primary-400);
  border-radius: 4px;
}
.form-check-label {
  color: var(--text-900);
}


.form-check-input[type="radio"] {
  accent-color: var(--accent);
  width: 1.2em;
  height: 1.2em;
  background-color: var(--background-100);
  border: 1px solid var(--accent-400);
}



.nav-tabs {
  border-bottom: 1px solid var(--primary-400);
  display: flex;
  list-style: none;
}
.nav-tabs .nav-item {
  background-color: var(--background-100);
  color: var(--text-700);
  border: 1px solid transparent;
  margin-right: 4px;
}
.nav-tabs .nav-item.active {
  background-color: var(--background-200);
  border-color: var(--primary-500);
  color: var(--text-900);
}

.nav-item a {
  text-decoration: none;
  padding: 0.5rem 1rem;
  display: block;
  color: inherit;
}

.formio-component-survey .table {
  background-color: var(--background-100);
  color: var(--text-900);
}
.formio-component-survey th,
.formio-component-survey td {
  border: 1px solid var(--background-300);
  padding: 0.5em;
}
.formio-component-survey input[type="radio"] {
  accent-color: var(--accent);
}

.signature-pad-body {
  border: 1px solid var(--primary-400);
  background-color: var(--background-100);
  border-radius: 6px;
}

.formio-signature-pad-buttons .btn {
  background-color: var(--primary-500);
  color: var(--text);
  border: none;
  padding: 0.4em 0.8em;
  border-radius: 6px;
}
.formio-signature-pad-buttons .btn:hover {
  background-color: var(--primary-600);
}



.formio-form nav {
  background-color: var(--background-100);
  border-bottom: 1px solid var(--primary-400);
}

.formio-form nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 1rem;
}

.formio-form nav button {
  color: var(--text) !important;
  padding: 0.5rem 1rem;
  text-decoration: none;
background: var(--background-300);
border-bottom-left-radius: 0px;
border-bottom-right-radius: 0px;
}

.formio-form nav button:hover {
    background: var(--primary-300);
    color: var(--text);
    scale: 1;
}
.formio-form nav a.active {
  color: var(--text-900);
  border-bottom: 2px solid var(--primary-500);
}

.formio-form div > ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
} 

.formio-form div > ul li button {
    background: var(--background-300);
    color: var(--text);
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    border: none;
    cursor: pointer;
}

.formio-form div > ul li button:hover {
    background: var(--primary-300);
    color: var(--text);
    scale: 1.02;
}

.formio-form div > ul li button.btn-wizard-nav-submit {
    background: var(--primary-500);
    color: var(--text);
    border-radius: 0.5rem;

}

.formio-form div > ul li button.btn-wizard-nav-submit:hover {
    background: var(--primary-600);
    color: var(--text);
}

.formio-form button:after {
    content: '';
    display: none;
}

.formio-component-htmlelement {
  text-align: left;
}

.left {
  text-align: left !important;
}