:root {
  --bacaext-font-size-base: 1em;
  --bacaext-font-size-2xl: 1.5em;
  --bacaext-space-xs: 0.35em;
  --bacaext-space-sm: 0.5em;
  --bacaext-space-md: 0.75em;
  --bacaext-space-lg: 1em;
  --bacaext-space-xl: 1.25em;
  --bacaext-space-2xl: 1.5em;
  --bacaext-size-wrapper-max: 26.25em;
  --bacaext-size-dialog-max: 35em;
  --bacaext-size-close: 1.5em;
  --bacaext-radius-sm: 0.25em;
  --bacaext-radius-md: 0.5em;
  --bacaext-border-width: 0.0625em;
  --bacaext-focus-ring-size: 0.1875em;
  --bacaext-color-text: #111;
  --bacaext-color-text-muted: #555;
  --bacaext-color-label: #333;
  --bacaext-color-surface: #fff;
  --bacaext-color-border: #ccc;
  --bacaext-color-border-soft: #e0e0e0;
  --bacaext-color-primary: #111;
  --bacaext-color-primary-hover: #333;
  --bacaext-color-primary-contrast: #fff;
  --bacaext-color-focus: #007bff;
  --bacaext-color-focus-ring: rgba(0, 123, 255, 0.1);
  --bacaext-color-invalid: #dc3545;
  --bacaext-color-invalid-ring: rgba(220, 53, 69, 0.1);
  --bacaext-color-overlay: rgba(0, 0, 0, 0.8);
  --bacaext-color-close: #6c757d;
  --bacaext-color-close-hover: #111;
  --bacaext-color-success: #28a745;
  --bacaext-color-success-hover: #218838;
  --bacaext-color-error: #dc3545;
  --bacaext-color-error-hover: #c82333;
  --bacaext-bg-color-default: #333;
  --bacaext-alert-success-bg: #d4edda;
  --bacaext-alert-success-border: #c3e6cb;
  --bacaext-alert-success-text: #155724;
  --bacaext-alert-error-bg: #f8d7da;
  --bacaext-alert-error-border: #f5c6cb;
  --bacaext-alert-error-text: #721c24;
  --bacaext-alert-info-bg: #d1ecf1;
  --bacaext-alert-info-border: #bee5eb;
  --bacaext-alert-info-text: #0c5460;
  --bacaext-shadow-sm: 0 0.125em 0.5em rgba(0, 0, 0, 0.1);
  --bacaext-shadow-lg: 0 1.125em 2.8125em rgba(0, 0, 0, 0.28);
  --bacaext-duration-fast: 0.2s;
  --bacaext-duration-base: 0.3s;
  --bacaext-ease-standard: ease-out;
}

/* Modal shell: center in viewport */
.bacaext-modal.is-open {
  position: fixed;
  inset: 0;
  z-index: 99999999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--bacaext-space-lg);
  overflow-y: auto;
  background: none;
  animation: bacaModalFadeIn var(--bacaext-duration-fast) var(--bacaext-ease-standard);
}

.bacaext-modal__logo {
    flex: 0 0 auto;
    width: 5rem;
    height: 5rem;
    z-index: 5;
    position: relative;
}

/* Backdrop covers viewport */
.bacaext-modal__backdrop {
  position: absolute;
  inset: 0;
  background: var(--bacaext-color-overlay);
  cursor: pointer;
}

/* Dialog: centered, max width, scrollable */
.bacaext-modal__dialog {
  position: relative;
  width: min(92vw, var(--bacaext-size-dialog-max));
  max-width: var(--bacaext-size-dialog-max);
  max-height: calc(100dvh - 2em);
  padding: var(--bacaext-space-xl) var(--bacaext-space-xl) var(--bacaext-space-xl);
  overflow-y: auto;
  border-radius: var(--bacaext-radius-md);
  background: var(--bacaext-bg-color-default);
  box-shadow: var(--bacaext-shadow-lg);
  color: var(--bacaext-color-primary-contrast);
  animation: bacaModalSlideUp var(--bacaext-duration-base) var(--bacaext-ease-standard);
}

/* Remove wrapper margin/padding/background when inside modal */
.bacaext-modal .bacaext-form-wrapper {
  max-width: none;
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

/* Responsive: top-aligned on mobile, full width */
@media (max-width: 600px) {
  .bacaext-modal.is-open {
    align-items: flex-start;
    padding: var(--bacaext-space-sm);
  }
  .bacaext-modal__dialog {
    width: 98vw;
    max-width: 98vw;
    max-height: calc(100dvh - 1em);
    padding: var(--bacaext-space-lg);
  }
}

/* Close button */
.bacaext-modal__close {
  position: absolute;
  top: 0;
  right: 0;
  padding: 0;
  margin: 0;
  display: block;
  width: var(--bacaext-size-close);
  height: var(--bacaext-size-close);
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: var(--bacaext-color-close);
  font-size: calc(var(--bacaext-font-size-base) * 2);
  cursor: pointer;
  transition: color var(--bacaext-duration-fast), transform var(--bacaext-duration-fast);
}
.bacaext-modal__close:hover { color: var(--bacaext-color-close-hover); transform: none; background-color: transparent; }
.bacaext-modal__close--success { color: var(--bacaext-color-success); }
.bacaext-modal__close--success:hover { color: var(--bacaext-color-success-hover); }
.bacaext-modal__close--error { color: var(--bacaext-color-error); }
.bacaext-modal__close--error:hover { color: var(--bacaext-color-error-hover); }
.bacaext-modal__close:disabled {
  opacity: 0;
  pointer-events: none;
}

/* Modal content */
.bacaext-modal__title {
  margin: 0 0 var(--bacaext-space-lg);
  font-size: 1.25em;
  font-weight: 600;
  color: currentColor;
}
.bacaext-modal__message {
  margin: 0;
  padding-right: calc(var(--bacaext-size-close) + var(--bacaext-space-sm));
  font-size: 1em;
  line-height: 1.5;
  color: var(--bacaext-color-primary-contrast);
}
.is-success .bacaext-modal__title { color: var(--bacaext-color-success); }
.is-error .bacaext-modal__title { color: var(--bacaext-color-error); }

/* Form wrapper */
.bacaext-form-wrapper {
  max-width: var(--bacaext-size-wrapper-max);
  padding: var(--bacaext-space-2xl);
  margin: var(--bacaext-space-2xl) auto;
  background: var(--bacaext-color-surface);
  border: var(--bacaext-border-width) solid var(--bacaext-color-border-soft);
  border-radius: var(--bacaext-radius-md);
  box-shadow: var(--bacaext-shadow-sm);
  color: inherit;
}
h2.bacaext-form-title,
h3.bacaext-form-title {
  margin: var(--bacaext-space-2xl) auto;
  font-size: var(--bacaext-font-size-2xl);
  font-weight: 600;
  color: currentColor;
}
p {
  margin: var(--bacaext-space-sm) 0;
}

/* Form fields */
.bacaext-form-field {
  margin-bottom: 1.25em;
}
.bacaext-form-field label {
  display: block;
  margin-bottom: var(--bacaext-space-sm);
  font-size: 0.95em;
  font-weight: 600;
  color: currentColor;
}
.bacaext-form-field input,
.bacaext-form-field select,
.bacaext-form-field textarea {
  width: 100%;
  box-sizing: border-box;
  padding: var(--bacaext-space-md);
  border: var(--bacaext-border-width) solid var(--bacaext-color-border);
  border-radius: var(--bacaext-radius-sm);
  font: inherit;
  background-color: var(--bacaext-color-surface);
  transition: border-color var(--bacaext-duration-fast), box-shadow var(--bacaext-duration-fast);
}
.bacaext-form-field input:focus,
.bacaext-form-field select:focus,
.bacaext-form-field textarea:focus {
  outline: none;
  border-color: var(--bacaext-color-focus);
  box-shadow: 0 0 0 var(--bacaext-focus-ring-size) var(--bacaext-color-focus-ring);
}
.bacaext-form-field input.is-invalid,
.bacaext-form-field select.is-invalid,
.bacaext-form-field textarea.is-invalid {
  border-color: var(--bacaext-color-invalid);
}
.bacaext-form-field input.is-invalid:focus,
.bacaext-form-field select.is-invalid:focus,
.bacaext-form-field textarea.is-invalid:focus {
  box-shadow: 0 0 0 var(--bacaext-focus-ring-size) var(--bacaext-color-invalid-ring);
}
.bacaext-form-field__date-parts {
  display: flex;
  gap: var(--bacaext-space-sm);
}
.bacaext-form-field__date-parts input {
  flex: 1;
  padding: var(--bacaext-space-md);
  border: var(--bacaext-border-width) solid var(--bacaext-color-border);
  border-radius: var(--bacaext-radius-sm);
  text-align: center;
  font-size: 1em;
}
.bacaext-form-field__radio-group,
.bacaext-form-field__checkbox-group {
  display: flex;
  flex-direction: column;
  gap: var(--bacaext-space-md);
}
.bacaext-form-field__option {
  display: flex;
  align-items: center;
  gap: var(--bacaext-space-sm);
}
.bacaext-form-field__option input[type="radio"],
.bacaext-form-field__option input[type="checkbox"] {
  width: auto;
  margin: 0;
  cursor: pointer;
}
.bacaext-form-field__option label {
  display: flex;
  align-items: center;
  gap: var(--bacaext-space-sm);
  margin: 0;
  font-weight: inherit;
  cursor: pointer;
}

/* Messages and alerts */
.bacaext-error-message {
  display: block;
  margin-top: var(--bacaext-space-xs);
  font-size: 0.85em;
  line-height: 1.2;
  color: var(--bacaext-color-invalid);
}
.bacaext-alert {
  padding: var(--bacaext-space-lg);
  margin-bottom: var(--bacaext-space-lg);
  border-radius: var(--bacaext-radius-sm);
  font-size: 0.95em;
  line-height: 1.4;
}
.bacaext-alert--success {
  background-color: var(--bacaext-alert-success-bg);
  border: var(--bacaext-border-width) solid var(--bacaext-alert-success-border);
  color: var(--bacaext-alert-success-text);
}
.bacaext-alert--error {
  background-color: var(--bacaext-alert-error-bg);
  border: var(--bacaext-border-width) solid var(--bacaext-alert-error-border);
  color: var(--bacaext-alert-error-text);
}
.bacaext-alert--info {
  background-color: var(--bacaext-alert-info-bg);
  border: var(--bacaext-border-width) solid var(--bacaext-alert-info-border);
  color: var(--bacaext-alert-info-text);
}

/* Buttons */
button,
input[type="submit"] {
  width: 100%;
  padding: var(--bacaext-space-md) var(--bacaext-space-2xl);
  border: none;
  border-radius: var(--bacaext-radius-sm);
  background-color: var(--bacaext-color-primary);
  color: var(--bacaext-color-primary-contrast);
  font-size: 1em;
  font-family: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--bacaext-duration-fast), transform 0.1s;
  margin: var(--bacaext-space-sm) auto;
}
button:hover,
input[type="submit"]:hover {
  background-color: var(--bacaext-color-primary-hover);
  transform: translateY(-0.0625em);
}
button:active,
input[type="submit"]:active {
  transform: translateY(0);
}
button:disabled,
input[type="submit"]:disabled {
  background-color: var(--bacaext-color-border);
  cursor: not-allowed;
  transform: none;
}

/* Utility */
.bacaext-spinner {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-block;
  width: 1.25em;
  height: 1.25em;
  border: 0.1875em solid #f3f3f3;
  border-top: 0.1875em solid currentColor;
  border-radius: 50%;
  color: var(--bacaext-color-text);
  animation: bacaSpin 1s linear infinite;
  z-index: 999999;
}

/* Animations */
@keyframes bacaModalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes bacaModalSlideUp {
  from { opacity: 0; transform: translateY(1.25em); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes bacaSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@keyframes bacaModalFadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}
@keyframes bacaModalSlideDown {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(1.25em); }
}

/* Responsive tweaks for form fields */
@media (max-width: 37.5em) {
  .bacaext-form-wrapper {
    margin: var(--bacaext-space-lg);
    padding: var(--bacaext-space-xl);
  }
  .bacaext-form-field__date-parts {
    gap: var(--bacaext-space-xs);
  }
  .bacaext-form-field__date-parts input {
    padding: 0.6em var(--bacaext-space-xs);
    font-size: 0.9em;
  }
}

.bacaext-modal.bacaext-modal--closing {
  animation: bacaModalFadeOut var(--bacaext-duration-fast) var(--bacaext-ease-standard) forwards;
}
.bacaext-modal__dialog.bacaext-modal--closing {
  animation: bacaModalSlideDown var(--bacaext-duration-base) var(--bacaext-ease-standard) forwards;
}

.bacaext-modal__logo.is-hidden {
  animation: bacaModalFadeOut var(--bacaext-duration-base) var(--bacaext-ease-standard) forwards;
}

.bacaext-modal__loading-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.6);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999;
  pointer-events: all;
}

.bacaext-modal__loading-overlay.is-active {
  display: flex;
}
