/**
 * Admin campaign update compose page: form layout and field styling.
 * Ensures stacked fields, full-width inputs/textarea, and clear hierarchy.
 */

.admin-updates-page {
  max-width: 42em;
}

.admin-updates-header {
  margin-bottom: 1rem;
}

.admin-updates-header h1 {
  margin-bottom: 0.25rem;
}

.admin-updates-header p {
  margin-bottom: 0;
}

.admin-updates-flash {
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  border-radius: 4px;
  font-size: var(--font-size-body);
}

.admin-updates-flash--success {
  background: var(--color-success);
  color: #fff;
  border: 1px solid #047857;
}

.admin-updates-flash--error {
  background: var(--color-error-bg);
  color: var(--color-error);
  border: 1px solid var(--color-error-border);
}

.admin-updates-compose {
  margin-bottom: 2rem;
}

.admin-updates-compose h2 {
  margin-top: 0;
  margin-bottom: 1rem;
}

.admin-updates-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.admin-updates-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.admin-updates-field label {
  display: block;
  font-size: var(--font-size-label);
  font-weight: 600;
  color: var(--color-text, #222);
}

.admin-updates-hint {
  font-size: var(--font-size-sm, 0.875rem);
  color: #5f6368;
}

.admin-updates-field input[type="text"],
.admin-updates-field textarea {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: 0.5rem 0.6rem;
  font: inherit;
  font-size: var(--font-size-body);
  border: 1px solid var(--color-border, #ccc);
  border-radius: 4px;
  background: #fff;
}

.admin-updates-field input[type="text"]:focus,
.admin-updates-field textarea:focus {
  outline: 2px solid var(--color-border-focus, #333);
  outline-offset: 2px;
}

.admin-updates-field textarea {
  resize: vertical;
  min-height: 12em;
}

.admin-updates-fieldset {
  margin: 0;
  padding: 0;
  border: none;
}

.admin-updates-legend {
  font-size: var(--font-size-label);
  font-weight: 600;
  color: var(--color-text, #222);
  margin-bottom: 0.5rem;
}

.admin-updates-radio-wrap {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

.admin-updates-radio-wrap:last-of-type {
  margin-bottom: 0;
}

.admin-updates-radio {
  margin: 0;
  flex-shrink: 0;
}

.admin-updates-radio:focus {
  outline: 2px solid var(--color-border-focus, #333);
  outline-offset: 2px;
}

.admin-updates-radio-wrap label {
  margin: 0;
  cursor: pointer;
  font-size: var(--font-size-body);
}

.admin-updates-list-type {
  font-weight: 600;
  color: var(--color-text-muted, #555);
}

.admin-updates-form .btn {
  align-self: flex-start;
  margin-top: 0.25rem;
}

.admin-updates-list h2 {
  margin-top: 0;
  margin-bottom: 0.75rem;
}

.admin-updates-list-ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.admin-updates-list-item {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-border-light, #eee);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1rem;
}

.admin-updates-list-item:last-child {
  border-bottom: none;
}

.admin-updates-list-title {
  font-weight: 600;
}

.admin-updates-list-meta {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted, #555);
}

.admin-updates-list-item a {
  font-size: var(--font-size-sm);
}

.admin-updates-list-item .btn {
  font-size: var(--font-size-sm);
}

/* Send status page */
.admin-send-status-subtitle {
  margin: 0;
  font-size: var(--font-size-body);
  color: var(--color-text-muted, #555);
}

.admin-send-status-progress {
  margin: 1.5rem 0;
}

.admin-send-status-progress p {
  margin: 0 0 0.5rem 0;
}

.admin-send-status-bar-wrap {
  max-width: 20em;
  height: 8px;
  background: var(--color-border-light, #eee);
  border-radius: 4px;
  overflow: hidden;
}

.admin-send-status-bar {
  height: 100%;
  width: 0%;
  background: var(--color-success);
  transition: width 0.2s ease;
}

.admin-send-status-back {
  margin-top: 1.5rem;
}

.admin-send-status-redirect {
  margin-top: 0.75rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted, #555);
}

/* Recipients page */
.admin-recipients-subtitle {
  margin: 0.25rem 0 0.5rem 0;
  font-size: var(--font-size-body);
  color: var(--color-text-muted, #555);
}

.admin-recipients-section {
  margin-top: 1rem;
}

.admin-recipients-actions {
  margin-bottom: 0.75rem;
  display: flex;
  gap: 0.5rem;
}

.admin-recipients-hint {
  margin: 0 0 0.5rem 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted, #555);
}

.admin-recipients-list {
  list-style: none;
  padding-left: 0;
  margin: 0 0 1rem 0;
  border: 1px solid var(--color-border, #ccc);
  border-radius: 4px;
  max-height: 20em;
  overflow-y: auto;
}

.admin-recipients-item {
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--color-border-light, #eee);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.admin-recipients-item:last-child {
  border-bottom: none;
}

.admin-recipients-checkbox {
  margin: 0;
  flex-shrink: 0;
}

.admin-recipients-checkbox:focus {
  outline: 2px solid var(--color-border-focus, #333);
  outline-offset: 2px;
}

.admin-recipients-item label {
  margin: 0;
  cursor: pointer;
  font-size: var(--font-size-body);
}

.admin-recipients-submit {
  margin: 0;
}
