@import url('./design-tokens.css');

.modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: flex-end;
  justify-content: center;
  background: rgba(102, 125, 255, 0.12);
  backdrop-filter: blur(16px);
  z-index: 80;
  padding: 0 var(--space-4) calc(var(--space-8) + env(safe-area-inset-bottom)) var(--space-4);
}

.modal.is-visible {
  display: flex;
}

.modal-content {
  width: 100%;
  max-width: 420px;
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: 0 26px 48px rgba(102, 125, 255, 0.18);
  display: grid;
  gap: var(--space-5);
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

.modal-title {
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.close-button {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: rgba(82, 113, 189, 0.16);
  color: var(--color-text-primary);
  display: grid;
  place-items: center;
  font-size: var(--font-size-lg);
}

.app-form {
  display: grid;
  gap: var(--space-4);
}

.form-group {
  display: grid;
  gap: var(--space-2);
}

.form-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.form-input {
  border: 1px solid rgba(82, 113, 189, 0.24);
  border-radius: var(--radius-md);
  padding: 14px;
  background: var(--color-surface);
  color: var(--color-text-primary);
  box-shadow: inset 0 0 0 1px rgba(248, 250, 255, 0.4);
}

.form-actions {
  display: grid;
  gap: var(--space-3);
}

.error-message {
  font-size: var(--font-size-xs);
  color: var(--color-danger);
  background: rgba(251, 113, 133, 0.1);
  padding: var(--space-3);
  border-radius: var(--radius-md);
}

.modal[style*="block"],
.modal[style*="flex"] {
  display: flex !important;
}

.modal[style*="none"] {
  display: none !important;
}

.app-form .app-button {
  width: 100%;
}
