/* ============================================================
   notifications.css — Notifications Centre (Send Announcement +
   Sent Announcements). Broadcast-only model: announcements/{docId}
   { title, body, createdAt, createdBy } — no audience targeting,
   no per-user read tracking.
   ============================================================ */

.page-content {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

/* ── Generic card (not yet in components.css) ──────────────── */

.card {
  background: var(--bg-card);
  border: 1px solid var(--gold-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
}

/* ── Send Announcement form ─────────────────────────────────── */

.notif-card .section-title {
  margin-bottom: var(--sp-5);
}

#announcement-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.form-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  font-weight: 500;
}

.form-input,
.form-textarea {
  width: 100%;
  background: var(--bg-input);
  border: 1px solid var(--border-neutral);
  border-radius: var(--radius-md);
  padding: var(--sp-3) var(--sp-4);
  color: var(--text-primary);
  font-size: var(--text-base);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color var(--transition-fast);
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--text-muted);
}

.form-input:focus,
.form-textarea:focus {
  border-color: var(--gold);
}

.form-input.input-error,
.form-textarea.input-error {
  border-color: var(--danger);
}

.form-textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.5;
}

.char-counter {
  align-self: flex-end;
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.char-counter.near-limit {
  color: var(--warning);
}

/* ── Schedule radios ────────────────────────────────────────── */

.radio-row {
  display: flex;
  gap: var(--sp-5);
}

.radio-option {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-base);
  color: var(--text-primary);
  cursor: pointer;
}

.radio-option input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--gold);
  cursor: pointer;
}

.form-row.schedule-inputs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
  background: var(--bg-card-alt);
  border: 1px solid var(--border-neutral);
  border-radius: var(--radius-md);
  padding: var(--sp-4);
}

@media (max-width: 600px) {
  .form-row.schedule-inputs {
    grid-template-columns: 1fr;
  }
}

/* date/time inputs render the native calendar-picker icon in gold-ish theme */
.form-input[type="date"],
.form-input[type="time"] {
  color-scheme: dark;
}

/* ── Send button ────────────────────────────────────────────── */

.btn-full {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-base);
}

.btn-full:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* ── Sent Announcements list ────────────────────────────────── */

.notif-list-section .section-title {
  margin-bottom: var(--sp-4);
}

.announcements-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.announcement-card {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  background: var(--bg-card);
  border: 1px solid var(--border-neutral);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
}

.announcement-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--gold-glow);
  border: 1px solid var(--gold-border);
  color: var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
}

.announcement-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.announcement-top-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
}

.announcement-title {
  font-weight: 700;
  color: var(--text-primary);
  font-size: var(--text-base);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.announcement-time {
  flex-shrink: 0;
  font-size: var(--text-xs);
  color: var(--text-secondary);
  white-space: nowrap;
}

.announcement-preview {
  color: var(--text-secondary);
  font-size: var(--text-sm);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.announcement-meta {
  margin-top: var(--sp-1);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.tag-pill {
  display: inline-flex;
  align-items: center;
  color: var(--gold);
  border: 1px solid var(--gold-border);
  background: var(--gold-glow);
  border-radius: var(--radius-pill);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 2px var(--sp-3);
}

/* ── Scheduled (pending manual post) ────────────────────────── */

.scheduled-hint {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--sp-4);
  line-height: 1.5;
}

.tag-pill.tag-pill-warning {
  color: var(--warning);
  border-color: color-mix(in srgb, var(--warning) 35%, transparent);
  background: color-mix(in srgb, var(--warning) 12%, transparent);
}

.announcement-card.scheduled-card .announcement-icon {
  color: var(--warning);
  border-color: color-mix(in srgb, var(--warning) 35%, transparent);
  background: color-mix(in srgb, var(--warning) 12%, transparent);
}

.announcement-actions {
  display: flex;
  gap: var(--sp-2);
  margin-top: var(--sp-2);
}

.announcement-actions button {
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--text-xs);
}

/* ── Empty state ─────────────────────────────────────────────── */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  color: var(--text-muted);
  padding: var(--sp-8) 0;
  text-align: center;
}

.empty-state svg {
  color: var(--text-muted);
  margin-bottom: var(--sp-1);
}

.empty-state p {
  font-size: var(--text-sm);
}
