html, body { height:100%; margin:0; }

.topbar {
  min-height: 48px;
  display:flex; align-items:center; justify-content:space-between;
  padding: 4px 16px;
  border-bottom: 1px solid #e5e7eb;
  font: 14px/1.2 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background:#fff;
}
.topbar .brand {
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:700;
}
.brand-logo {
  height: 65px;
  width:auto;
  border-radius:4px;
}
.brand-text { display:flex; flex-direction:column; gap:4px; }
.brand-title { font-weight:700; font-size:15px; color:#111827; }
.brand-subtitle { font-size:13px; color:#475569; font-weight:500; }
.topbar .actions { display:flex; align-items:center; gap:8px; }

.dnd-toggle { display:flex; align-items:center; gap:8px; user-select:none; }
.dnd-toggle input { transform: translateY(1px); }

#Schedule { height: calc(100% - 56px); }

.topbar .btn.ghost {
  background:#f8fafc;
  border-color:#cbd5f5;
  color:#1d4ed8;
}

.contact-callout {
  border-top:1px solid #e2e8f0;
  background:#f8fafc;
  padding:24px 16px 32px;
  display:flex;
  justify-content:center;
}

.contact-callout__container {
  width:100%;
  max-width:960px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font: 14px/1.4 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:#0f172a;
}

.contact-callout__info {
  display:grid;
  gap:4px;
}

.contact-callout__name {
  font-size:15px;
  font-weight:600;
}

.contact-callout__address {
  font-size:14px;
  color:#475569;
}

.contact-callout__button {
  border-color:#cbd5f5;
  color:#1d4ed8;
  background:#fff;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.contact-callout__button:hover,
.contact-callout__button:focus {
  background:#e0ecff;
  border-color:#93c5fd;
  color:#1e3a8a;
}

@media (max-width: 640px) {
  .contact-callout__container {
    flex-direction:column;
    align-items:flex-start;
  }

  .contact-callout__button {
    align-self:stretch;
    text-align:center;
  }
}


.contact-modal[hidden] { display:none; }
.contact-modal {
  position:fixed;
  inset:0;
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}

.contact-modal__backdrop {
  position:absolute;
  inset:0;
  background:rgba(15, 23, 42, 0.45);
}

.contact-modal__dialog {
  position:relative;
  max-width:520px;
  width:100%;
  background:#fff;
  border-radius:12px;
  box-shadow:0 18px 48px rgba(15, 23, 42, 0.25);
  padding:24px 28px 28px;
  font: 15px/1.5 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:#0f172a;
}

.contact-modal__close {
  position:absolute;
  top:12px;
  right:16px;
  border:0;
  background:transparent;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  color:#64748b;
}

.contact-modal__header h2 {
  margin:0;
  font-size:20px;
  font-weight:700;
  color:#0f172a;
}

.contact-modal__body {
  margin-top:18px;
  display:grid;
  gap:20px;
}

.contact-info__lead {
  margin:0 0 8px;
  font-weight:600;
  color:#1e293b;
}

.contact-info__details {
  display:grid;
  gap:6px;
}

.contact-info__name {
  font-size:16px;
  font-weight:600;
  color:#111827;
}

.contact-info__address {
  font-size:14px;
  color:#475569;
}

.contact-info__link {
  color:#1d4ed8;
  text-decoration:none;
  font-weight:500;
}

.contact-info__link:hover,
.contact-info__link:focus {
  text-decoration:underline;
}

.contact-info__divider {
  height:1px;
  background:#e2e8f0;
}

.contact-info__section-title {
  margin:0 0 6px;
  font-size:16px;
  font-weight:600;
  color:#0f172a;
}

.contact-info__use-case { display:grid; gap:8px; }
.contact-info__use-case p {
  margin:0;
  color:#334155;
}
.contact-info__use-case p + p { margin-top:4px; }

.search-modal[hidden] { display:none; }
.search-modal {
  position:fixed;
  inset:0;
  z-index:1100;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}

.search-modal__backdrop {
  position:absolute;
  inset:0;
  background:rgba(15, 23, 42, 0.45);
}

.search-modal__dialog {
  position:relative;
  max-width:720px;
  width:100%;
  background:#fff;
  border-radius:12px;
  box-shadow:0 18px 48px rgba(15, 23, 42, 0.25);
  padding:28px;
  display:grid;
  gap:18px;
  font: 15px/1.45 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:#0f172a;
}

.search-modal__close {
  position:absolute;
  top:12px;
  right:16px;
  border:0;
  background:transparent;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  color:#64748b;
}

.search-modal__header { display:grid; gap:6px; }
.search-modal__header h2 {
  margin:0;
  font-size:22px;
  font-weight:700;
  color:#0f172a;
}
.search-modal__header p {
  margin:0;
  color:#475569;
}

.search-modal__form {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:flex-end;
}

.search-modal__field {
  display:flex;
  flex-direction:column;
  gap:6px;
  flex:1;
  min-width:220px;
}

.search-modal__label {
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.04em;
  color:#64748b;
}

.search-modal__input {
  width:100%;
  border:1px solid #cbd5f5;
  border-radius:10px;
  padding:10px 14px;
  font: inherit;
  background:#fff;
  box-sizing:border-box;
}

.search-modal__input:focus {
  outline:3px solid rgba(59, 130, 246, 0.25);
  border-color:#3b82f6;
}

.search-modal__status {
  font-size:13px;
  color:#475569;
}

.search-modal__results {
  max-height:380px;
  overflow-y:auto;
  display:grid;
  gap:10px;
  padding-right:4px;
}

.search-result {
  text-align:left;
  width:100%;
  border:1px solid #e2e8f0;
  background:#fff;
  border-radius:10px;
  padding:14px 16px;
  display:grid;
  gap:8px;
  cursor:pointer;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.search-result:hover,
.search-result:focus {
  background:#f8fafc;
  border-color:#bfdbfe;
  box-shadow:0 4px 12px rgba(15, 23, 42, 0.12);
}

.search-result:focus {
  outline:3px solid rgba(59, 130, 246, 0.3);
  outline-offset:2px;
}

.search-result__headline {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:baseline;
}

.search-result__title {
  font-size:16px;
  font-weight:600;
  color:#0f172a;
}

.search-result__job-number {
  font-size:13px;
  font-weight:500;
  color:#1d4ed8;
}

.search-result__meta {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  font-size:13px;
  color:#475569;
}

.search-result__chip {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 8px;
  border-radius:999px;
  background:#eff6ff;
  color:#1d4ed8;
  font-weight:500;
}

.search-result__label {
  font-weight:600;
  color:#334155;
}

.search-result__value {
  color:#0f172a;
}

@media (max-width: 640px) {
  .search-modal__dialog {
    padding:22px 20px;
  }

  .search-modal__form {
    flex-direction:column;
    align-items:stretch;
  }

  .search-modal__field {
    min-width:0;
  }

  .search-modal__results {
    max-height:320px;
  }
}

.modal-open {
  overflow:hidden;
}

/* Appointment template */
.appt { display:flex; align-items:center; justify-content:space-between; padding:6px 8px; line-height:1.2; width:100%; }
.appt-left { display:flex; flex-direction:column; flex:1; min-width:0; }
.appt-right { flex-shrink:0; margin-left:10px; display:flex; align-items:center; gap:6px; }
.appt-top { font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.appt-bot { font-size:12px; opacity:.9; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
/* Let our template control boldness */
.e-schedule .e-appointment .e-subject { font-weight:inherit; }

.file-clip{font-size:24px;color:#fff;cursor:pointer;font-size:medium;}
.media-icon{font-size:20px;color:#fff;cursor:pointer;}

.file-popup{position:absolute;z-index:1000;background:#fff;border:1px solid #d4d4d8;border-radius:4px;box-shadow:0 2px 6px rgba(0,0,0,0.2);padding:6px 8px;}
.file-popup ul{list-style:none;margin:0;padding:0;}
.file-popup li{margin:0;}
.file-popup li.extra-heading{margin-top:6px;}
.file-popup a{text-decoration:none;color:#2563eb;}

/* Dialog niceties */
.qi-dialog.e-dialog .e-dlg-header-content { border-bottom:1px solid #eee; }
.qi-dialog .qi { padding: 14px 16px; }

.qa-dialog .e-dlg-content { padding: 0; }
.qa { padding: 18px; font: inherit; }
.qa-grid { display:grid; grid-template-columns:1fr 1fr; column-gap:18px; row-gap:14px; }
.qa-row { display:grid; gap:8px; }
.qa-row label { font-size:12px; color:#64748b; }
.qa input, .qa select, .qa textarea {
  width:100%; background:#fff; border:1px solid #e5e7eb; border-radius:10px;
  padding:10px 12px; font:inherit; box-sizing:border-box;
}
.qa textarea { min-height:70px; resize:vertical; }
.qa-tabs { display:flex; gap:8px; margin-bottom:14px; }
.qa-tabs button { flex:1; padding:8px 12px; border:1px solid #e5e7eb; background:#fff; border-radius:8px; cursor:pointer; }
.qa-tabs button.active { background:#e5e7eb; }
.qa-tab-content[hidden] { display:none; }
.status-row { grid-column:1 / -1; }
.days-wrap { display:grid; gap:16px; grid-column:1 / -1; }
.day-card { border:1px solid #e5e7eb; border-radius:14px; background:#fff; padding:14px; }
.day-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.day-head .left { display:flex; align-items:center; gap:8px; }
.day-head .tag { font-weight:700; }
.day-head .actions { display:flex; gap:8px; }
.btn { border-radius:8px; padding:8px 12px; border:1px solid #e5e7eb; background:#fff; cursor:pointer }
.btn.sm { padding:6px 10px; font-size:13px; border-radius:6px; }
.btn.xs { padding:4px 8px; font-size:12px; border-radius:999px; }
.btn.ghost { background:transparent; }
.btn.primary {
  background:#1d4ed8;
  border-color:#1d4ed8;
  color:#fff;
}
.btn.primary:hover,
.btn.primary:focus {
  background:#1e3a8a;
  border-color:#1e3a8a;
  color:#fff;
}
.btn.danger { border-color:#ef4444; color:#ef4444; }
.caret-btn { width:30px; text-align:center; }
.day-body { display:block; }
.day-card.collapsed .day-body { display:none; }
.day-grid { display:grid; grid-template-columns:2fr 2fr; column-gap:16px; row-gap:10px; }
.time-col { display:grid; gap:12px; }
.time-triple { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; align-items:center; }
.time-triple input[type="number"] { text-align:center; }
.counts { display:grid; gap:12px; grid-template-columns:repeat(9, minmax(0, 1fr)); margin-top:10px; }
.day-notes { margin-top:12px; }
.files-row { margin-top:12px; display:grid; gap:10px; grid-template-columns:1fr 1fr; }
.file-hint { font-size:12px; color:#6b7280; }

@media (max-width:1080px){
  .qa-grid { grid-template-columns:1fr; }
  .day-grid { grid-template-columns:1fr; }
  .counts  { grid-template-columns:repeat(3, minmax(0, 1fr)); }
  .files-row { grid-template-columns:1fr; }
}

/* put in app.css */
#Schedule.dnd-off .e-appointment { cursor: not-allowed; }

/* Status colors */
.e-appointment[class*="status-"] { border:1px solid transparent; }
.e-appointment.status-placeholder,
.e-appointment.status-placeholder .appt { background:#b0b0b0 !important; color:#fff !important; }
.e-appointment.status-requested,
.e-appointment.status-requested .appt { background:#f472b6 !important; color:#fff !important; }
.e-appointment.status-needs_paperwork,
.e-appointment.status-needs_paperwork .appt { background:#4b9dd3 !important; color:#fff !important; }
.e-appointment.status-scheduled,
.e-appointment.status-scheduled .appt { background:#003366 !important; color:#fff !important; }
.e-appointment.status-dispatched,
.e-appointment.status-dispatched .appt { background:#e68a00 !important; color:#fff !important; }
.e-appointment.status-canceled,
.e-appointment.status-canceled .appt { background:#800020 !important; color:#fff !important; }
.e-appointment.status-completed,
.e-appointment.status-completed .appt { background:#10b981 !important; color:#fff !important; }
.e-appointment.status-paid,
.e-appointment.status-paid .appt { background:#e68a00 !important; color:#fff !important; }
.e-appointment.status-paid { border:2px solid #c87000 !important; }

.qi-warning {
  background:#fef3c7;
  color:#b91c1c;
  padding:8px 12px;
  border-radius:4px;
  margin:0 12px 12px;
  text-align:center;
  font-weight:600;
}

/* ---------- Quick Info (old look, centered, with shadow) ---------- */
.qi-dialog .e-dlg-content { padding: 0; }

.qi-card {
  min-width: 460px;
  max-width: 680px;
  background: #fff;
  border-radius: 12px;
  padding: 16px 16px 10px 16px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.12);
  border: 1px solid #e5e7eb;
  font: 14px/1.4 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

.qi-title {
  font-size: 18px;
  font-weight: 700;
  margin: 6px 6px 12px 6px;
  color: #111827;
}

.qi-sheet { display: grid; gap: 0; }

.qi-row {
  display: grid;
  grid-template-columns: 150px 1fr;
  align-items: start;
  padding: 8px 12px;
  border-top: 1px solid #eef0f3;
}
.qi-row:first-child { border-top: 0; }

.qi-label {
  color: #64748b;
  font-weight: 600;
}
.qi-value { white-space: pre-line; }

.qi-footer {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding: 12px;
  background: #f9fafb;
  border-top: 1px solid #eef0f3;
}

.qi-btn {
  border-radius: 6px;
  padding: 8px 12px;
  border: 1px solid #e5e7eb;
  background: #fff;
  cursor: pointer;
}
.qi-btn.primary { background: #0ea5e9; border-color: #0ea5e9; color: #fff; }
.qi-btn.danger  { border-color: #ef4444; color: #ef4444; }

.qi-download-list {
  padding: 16px;
  display: grid;
  gap: 12px;
}

.qi-download-actions {
  display: grid;
  gap: 10px;
}

.qi-download-actions .qi-btn {
  width: 100%;
  text-align: center;
}

.qi-download-actions .qi-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.sms-toast-container {
  position:fixed;
  right:20px;
  bottom:20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:1200;
  max-width:320px;
}

.sms-toast {
  background:#0f172a;
  color:#f8fafc;
  border-radius:12px;
  padding:16px 18px;
  box-shadow:0 18px 36px rgba(15,23,42,0.3);
  display:grid;
  gap:12px;
  font:14px/1.45 system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

.sms-toast__title {
  font-size:15px;
  font-weight:700;
  margin:0;
}

.sms-toast__preview {
  font-size:13px;
  color:#e2e8f0;
  margin:0;
}

.sms-toast__badge {
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:600;
  color:#facc15;
}

.sms-toast__actions {
  display:flex;
  gap:10px;
}

.sms-toast__btn {
  flex:1;
  padding:8px 12px;
  border-radius:10px;
  border:0;
  font-weight:600;
  cursor:pointer;
  font-size:13px;
  transition:transform 0.15s ease, opacity 0.15s ease;
}

.sms-toast__btn--primary {
  background:#38bdf8;
  color:#082f49;
}

.sms-toast__btn--ghost {
  background:rgba(15,23,42,0.35);
  color:#e2e8f0;
}

.sms-toast__btn:hover,
.sms-toast__btn:focus {
  transform:translateY(-1px);
}

@media (max-width: 640px) {
  .sms-toast-container {
    left:20px;
    right:20px;
    bottom:20px;
    max-width:none;
  }
}
.role-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem 0.65rem;
  border-radius: 999px;
  background: #e2e8f0;
  color: #0f172a;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.role-todo-toast {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 340px;
  max-width: calc(100vw - 2rem);
  background: linear-gradient(145deg, rgba(15, 23, 42, 0.95), rgba(30, 64, 175, 0.95));
  color: #f8fafc;
  border-radius: 20px;
  box-shadow: 0 25px 70px rgba(15, 23, 42, 0.55);
  padding: 1.1rem 1.2rem 1.25rem;
  border: 1px solid rgba(148, 163, 184, 0.25);
  z-index: 2000;
  backdrop-filter: blur(14px);
  transform: translateY(15px);
  opacity: 0;
  animation: roleTodoToastIn 0.4s ease forwards;
}
.role-todo-toast__header { display: flex; justify-content: space-between; gap: 0.75rem; align-items: flex-start; }
.role-todo-toast__title { display: flex; gap: 0.85rem; align-items: center; }
.role-todo-toast__badge {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: rgba(15, 23, 42, 0.4);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
  transition: transform 0.3s ease, background 0.3s ease;
}
.role-todo-toast__badge.is-empty { opacity: 0.7; }
.role-todo-toast__icon { font-size: 1.2rem; line-height: 1; }
.role-todo-toast__count { font-size: 0.85rem; font-weight: 700; }
.role-todo-toast__subtitle { margin: 0; font-size: 0.8rem; color: #cbd5f5; }
.role-todo-toast__header-actions { display: flex; flex-wrap: wrap; gap: 0.4rem; justify-content: flex-end; }
.role-todo-toast__snooze {
  background: #f97316;
  border-color: #ea580c;
  color: #fff;
}
.role-todo-toast__snooze:hover,
.role-todo-toast__snooze:focus {
  background: #ea580c;
  border-color: #c2410c;
  color: #fff;
}
.role-todo-toast__calendar {
  background: #0ea5e9;
  border-color: #0284c7;
  color: #fff;
}
.role-todo-toast__calendar:hover,
.role-todo-toast__calendar:focus {
  background: #0284c7;
  border-color: #0369a1;
  color: #fff;
}
.role-todo-toast__body { max-height: 60vh; overflow-y: auto; }
.role-todo-toast__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.6rem; }
.role-todo-toast__item { background: rgba(15, 23, 42, 0.35); border-radius: 14px; border: 1px solid rgba(148, 163, 184, 0.25); padding: 0.75rem; display: flex; flex-direction: column; gap: 0.45rem; box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02); }
.role-todo-toast__item-header { display: flex; justify-content: space-between; gap: 0.5rem; }
.role-todo-toast__item-title { font-weight: 600; font-size: 0.95rem; }
.role-todo-toast__item-meta { font-size: 0.8rem; color: rgba(203, 213, 225, 0.85); }
.role-todo-toast__item-more { border: none; background: transparent; color: #93c5fd; cursor: pointer; font-size: 0.8rem; text-decoration: underline; }
.role-todo-toast__item-more:hover { color: #bfdbfe; }
.role-todo-toast__details { font-size: 0.85rem; color: #e2e8f0; background: rgba(15, 23, 42, 0.5); border-radius: 12px; padding: 0.45rem 0.6rem; white-space: pre-wrap; }
.role-todo-toast__details--empty { color: #94a3b8; font-style: italic; }
.role-todo-toast__actions { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.role-todo-toast__action--dismiss {
  background: rgba(148, 163, 184, 0.25);
  border-color: rgba(148, 163, 184, 0.45);
  color: #e2e8f0;
}
.role-todo-toast__action--dismiss:hover,
.role-todo-toast__action--dismiss:focus {
  background: rgba(148, 163, 184, 0.4);
  border-color: rgba(148, 163, 184, 0.6);
  color: #fff;
}
.role-todo-toast__empty { margin: 0; font-size: 0.85rem; color: #94a3b8; }
.role-todo-toast__error { margin-top: 0.4rem; font-size: 0.8rem; color: #fecaca; }

@keyframes roleTodoToastIn {
  from {
    opacity: 0;
    transform: translateY(15px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 640px) {
  .role-todo-toast { left: 1rem; right: 1rem; bottom: 1rem; width: auto; }
  .role-todo-toast__header { flex-direction: column; align-items: flex-start; }
  .role-todo-toast__header-actions { justify-content: flex-start; }
}

.role-todo-calendar-fab {
  position: fixed;
  top: 77px;
  right: 5.5rem;
  z-index: 1200;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 1rem;
  border-radius: 999px;
  background: #0ea5e9;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid #0284c7;
  box-shadow: 0 15px 35px rgba(14, 165, 233, 0.35);
}
.role-todo-calendar-fab:hover,
.role-todo-calendar-fab:focus {
  background: #0284c7;
  border-color: #0369a1;
  color: #fff;
  box-shadow: 0 18px 40px rgba(14, 165, 233, 0.45);
}
.role-todo-calendar-fab__icon {
  font-size: 1.1rem;
  line-height: 1;
}
@media (max-width: 1024px) {
  .role-todo-calendar-fab {
    top: auto;
    bottom: 7.5rem;
    right: 1rem;
  }
}
@media (max-width: 640px) {
  .role-todo-calendar-fab {
    position: static;
    display: inline-flex;
    margin: 0.75rem 1rem 0;
  }
}
.activity-toast-container {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  z-index: 5000;
  max-width: 320px;
}

.activity-toast {
  background: rgba(15, 23, 42, 0.95);
  color: #f8fafc;
  border-radius: 12px;
  padding: 0.9rem 1rem;
  box-shadow: 0 20px 45px rgba(15, 23, 42, 0.35);
  border: 1px solid rgba(148, 163, 184, 0.2);
  animation: toast-in 180ms ease-out;
}

.activity-toast__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.75rem;
}

.activity-toast__title {
  font-weight: 600;
  font-size: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.activity-toast__status {
  background: rgba(59, 130, 246, 0.15);
  color: #bfdbfe;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.activity-toast__event {
  display: inline-flex;
  margin-top: 0.2rem;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #94a3b8;
}

.activity-toast__message {
  margin: 0.5rem 0 0.25rem;
  line-height: 1.4;
}

.activity-toast__details {
  margin: 0 0 0.4rem;
  padding-left: 1.1rem;
  color: #cbd5f5;
  font-size: 0.8rem;
  line-height: 1.4;
}

.activity-toast__details li + li {
  margin-top: 0.2rem;
}

.activity-toast__footer {
  font-size: 0.8rem;
  color: #cbd5f5;
}

.activity-toast__close {
  background: transparent;
  border: none;
  color: #94a3b8;
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}

.activity-toast__close:hover,
.activity-toast__close:focus {
  color: #e2e8f0;
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}