/* Festival Form Styles */
.edit-person-form.festival-form {
  padding: var(--spacing-base);
  max-width: var(--content-narrow-width);
}

.festival-form .form-section {
  margin-bottom: var(--spacing-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.festival-form .form-section p {
  margin: 0;
}

/* Bonus Program Styles */
.edit-person-form.bonus-form {
  padding: var(--spacing-md);
}

.bonus-form .form-section {
  margin-bottom: var(--spacing-sm);
}

.bonus-form .form-section p {
  margin: 0;
}

/* Shared Program Table Styles */
table.program {
  width: auto;
  margin: var(--spacing-sm) auto;
  border-collapse: separate;
  border-spacing: 0 var(--spacing-xs);
}

table.program td {
  padding: var(--spacing-xs) var(--spacing-sm);
  vertical-align: middle;
}

/* Form Field Sizes - program specific */
#id_privateLessons,
#id_groupClasses,
#id_parties {
  width: var(--input-width-xs);
}

/* Compact tabs for bonus program */
.bonus-form .tabs {
  margin: var(--spacing-sm) 0;
}

.bonus-form .tabs h3 {
  padding: var(--spacing-sm) var(--spacing-base);
  font-size: var(--text-sm);
}

.bonus-form .tabs > div > div {
  padding: var(--spacing-sm) var(--spacing-base);
}

/* Compact notes area */
.bonus-form #id_notes {
  min-height: 60px;
  margin: 0;
}

/* Adjust button spacing */
.bonus-form .form-buttons {
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-md);
}

/* Custom details text size */
.bonus-form .details {
  font-size: var(--text-xs);
  margin: var(--spacing-xs) 0;
  line-height: var(--leading-snug);
}

/* Program specific form fields */
.edit-person-form.program-template-form {
  padding: var(--spacing-base);
  max-width: var(--content-max-width);
}

.program-template-form .form-section {
  margin-bottom: var(--spacing-xs);
}

.program-template-form .form-section p {
  margin: 0;
  line-height: var(--leading-relaxed);
}

/* Program pricing table */
.program-template-form table.program {
  width: auto;
  margin: var(--spacing-base) auto;
  border-collapse: collapse;
  border-spacing: 0;
}

.program-template-form table.program td {
  padding: var(--spacing-sm);
  vertical-align: middle;
}

.program-template-form table.program td.total {
  border-top: var(--border-thin) solid var(--color-border);
  padding-top: var(--spacing-md);
}

.program-template-form .text-right {
  text-align: right;
}

/* Program template specific input sizing */
.program-template-form #id_privateLessons,
.program-template-form #id_groupClasses,
.program-template-form #id_parties {
  width: 7ex;
  padding: var(--spacing-md);
  border: var(--border-thin) solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}

.program-template-form #id_privateLessonPrice,
.program-template-form #id_groupClassPrice,
.program-template-form #id_partyPrice,
.program-template-form #id_amount,
.program-template-form #id_discount {
  width: 10ex;
  padding: var(--spacing-md);
  border: var(--border-thin) solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}

.program-template-form #id_name {
  width: var(--input-width-lg);
  padding: var(--spacing-md);
  border: var(--border-thin) solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}

.program-template-form #id_notes {
  width: 96%;
  margin: 0 auto;
  min-height: 100px;
  resize: vertical;
  padding: var(--spacing-md);
  border: var(--border-thin) solid var(--color-border);
  border-radius: var(--radius-sm);
}

/* Update button specific styling */
.program-template-form .update-button {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--text-sm);
  background-color: var(--color-table-header);
  color: var(--color-text);
  border: var(--border-thin) solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.program-template-form .update-button:hover {
  background-color: var(--color-secondary);
  color: var(--color-background);
}

/* Responsive Design */
@media (max-width: 768px) /* --breakpoint-md */ {
  .edit-person-form.festival-form,
  .edit-person-form.bonus-form,
  .edit-person-form.program-template-form {
    margin: var(--spacing-sm);
    padding: var(--spacing-sm);
  }

  table.program {
    width: 100%;
  }

  .program-template-form #id_name,
  .program-template-form #id_notes {
    width: 100%;
  }
}

@media (max-width: 480px) /* --breakpoint-sm */ {
  .bonus-form .tabs h3 {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--text-xs);
  }

  .program-template-form table.program td {
    padding: var(--spacing-xs);
  }
}
