/* UI Modals */
.tzq-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--tzq-z-modal);
  align-items: center;
  justify-content: center;
  padding: var(--tzq-spacing-4);
}
.tzq-modal__backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
}
.tzq-modal__content {
  position: relative;
  background: var(--tzq-bg-primary);
  border-radius: var(--tzq-radius-md);
  box-shadow: var(--tzq-shadow-2xl);
  max-width: 600px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  z-index: 1;
}
.tzq-modal__content--medium {
  max-width: 600px;
}
.tzq-modal__content--large {
  max-width: 800px;
}
.tzq-modal__content--small {
  max-width: 400px;
}
.tzq-modal__header {
  padding: var(--tzq-spacing-6);
  border-bottom: 2px solid var(--tzq-border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.tzq-modal__title {
  font-family: var(--tzq-font-heading);
  font-size: var(--tzq-text-2xl);
  font-weight: var(--tzq-font-bold);
  margin: 0;
  color: var(--tzq-text-primary);
}
.tzq-modal__close {
  background: none;
  border: 1px solid var(--tzq-primary-light);
  font-size: var(--tzq-text-3xl);
  line-height: 1;
  cursor: pointer;
  padding: 0;
  color: var(--tzq-text-tertiary);
  transition: color var(--tzq-transition-fast);
}
.tzq-modal__close:hover {
  color: var(--tzq-text-primary);
}
.tzq-modal__body {
  padding: var(--tzq-spacing-6);
}
.tzq-modal__footer {
  padding: var(--tzq-spacing-6);
  border-top: 2px solid var(--tzq-border-light);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--tzq-gap-sm);
}
.tzq-modal--active {
  display: flex;
}
.tzq-modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
}
.tzq-modal-content {
  position: relative;
  background: var(--tzq-bg-primary);
  border-radius: var(--tzq-radius-md);
  box-shadow: var(--tzq-shadow-2xl);
  max-width: 600px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  z-index: 1;
}
.tzq-modal-content--medium {
  max-width: 600px;
}
.tzq-modal-content--large {
  max-width: 800px;
}
.tzq-modal-content--small {
  max-width: 400px;
}
.tzq-modal-header {
  padding: var(--tzq-spacing-lg);
  border-bottom: 2px solid var(--tzq-border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.tzq-modal-title {
  font-family: var(--tzq-font-heading);
  font-size: var(--tzq-text-2xl);
  font-weight: var(--tzq-font-bold);
  margin: 0;
  color: var(--tzq-text-primary);
}
.tzq-modal-close {
  background: none;
  border: 1px solid var(--tzq-primary-light);
  font-size: var(--tzq-text-3xl);
  line-height: 1;
  cursor: pointer;
  padding: 0;
  color: var(--tzq-text-tertiary);
  transition: color var(--tzq-transition-fast);
}
.tzq-modal-close:hover {
  color: var(--tzq-text-primary);
}
.tzq-modal-body {
  padding: var(--tzq-spacing-6);
}
.tzq-modal-footer {
  padding: var(--tzq-spacing-6);
  border-top: 2px solid var(--tzq-border-light);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--tzq-gap-sm);
}
.tzq-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  z-index: var(--tzq-z-modal, 9999);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--tzq-spacing-4);
}
.tzq-modal-overlay[style*="display: none"] {
  display: none !important;
}
.tzq-modal-container {
  position: relative;
  background: var(--tzq-bg-primary);
  border-radius: var(--tzq-radius-md);
  box-shadow: var(--tzq-shadow-2xl);
  max-width: 600px;
  margin: 0 auto;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  z-index: 1;
}
.tzq-icon-modal-overlay .tzq-modal-content {
  max-width: 900px;
}
.tzq-icon-modal-overlay .tzq-modal-body {
  max-height: 70vh;
  overflow-y: auto;
}

/* Report Issue Modal Specifics */
.tzq-report-issue-section {
  text-align: center;
}
.tzq-action-buttons {
  display: flex;
  gap: var(--tzq-spacing-md);
  justify-content: center;
  flex-wrap: wrap;
}
.tzq-report-issue-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--tzq-spacing-sm);
  padding: var(--tzq-spacing-md) var(--tzq-spacing-lg);
  background: var(--tzq-gradient-primary);
  color: white;
  border: 1px solid var(--tzq-primary-light);
  border-radius: var(--tzq-radius-md);
  font-size: var(--tzq-text-base);
  font-weight: var(--tzq-font-semibold);
  cursor: pointer;
  transition: var(--tzq-transition-all);
  box-shadow: var(--tzq-shadow-md);
}
.tzq-report-issue-toggle:hover {
  transform: translateY(-2px);
  box-shadow: var(--tzq-shadow-lg);
}
.tzq-report-icon {
  font-size: var(--tzq-text-lg);
}
.tzq-report-description {
  color: var(--tzq-text-secondary);
  font-size: var(--tzq-text-sm);
  margin: 0 0 var(--tzq-spacing-lg) 0;
  line-height: var(--tzq-leading-relaxed);
}
.tzq-report-issue-form .tzq-form-group {
  margin-bottom: var(--tzq-spacing-lg);
}
.tzq-report-issue-form .tzq-form-label,
.tzq-report-issue-form .tzq-form-group__label {
  display: block;
  margin-bottom: var(--tzq-spacing-xs);
  font-weight: var(--tzq-font-semibold);
  color: var(--tzq-text-primary);
  font-size: var(--tzq-text-sm);
}
.tzq-required {
  color: var(--tzq-error);
  margin-left: var(--tzq-spacing-xs);
}
.tzq-report-message {
  margin-top: var(--tzq-spacing-lg);
  padding: var(--tzq-spacing-md);
  border-radius: var(--tzq-radius-md);
  font-size: var(--tzq-text-sm);
  display: none;
}
.tzq-report-message.tzq-report-loading,
.tzq-report-message.tzq-report-success,
.tzq-report-message.tzq-report-error {
  display: block;
}
.tzq-report-loading {
  background: var(--tzq-bg-blue-light);
  border: 1px solid var(--tzq-primary-light);
  color: var(--tzq-primary-dark);
}
.tzq-report-success {
  background: var(--tzq-success-light);
  border: 1px solid var(--tzq-primary-light);
  color: var(--tzq-success-dark);
}
.tzq-report-error {
  background: var(--tzq-error-light);
  border: 1px solid var(--tzq-primary-light);
  color: var(--tzq-error-dark);
}
