/*
  File: WEB/css/notifications-center.css
  Description: Notification center layout and channel-driven notice treatments.
  TOC: page header; dashboard; channel filters; notice cards; destinations; responsive rules.
  Summary: Keeps notifications readable and functional while staying in the Streets visual language.
*/
.notification-center-shell { padding-top: 118px; }
.notification-center { width: min(1240px, calc(100% - 36px)); margin: 0 auto; padding-bottom: 42px; }
.notification-center-heading { align-items: end; margin-bottom: 22px; }
.notification-center-heading h1 { color: #fff1d7; font-family: var(--font-display); font-size: clamp(38px, 6vw, 62px); letter-spacing: 0; line-height: .96; margin: 13px 0 10px; }
.notification-kicker { color: #d99832; font: 800 12px var(--font-ui); letter-spacing: 0; margin: 18px 0 0; text-transform: uppercase; }
.notification-intro { color: rgba(255, 235, 206, .72); font-size: 15px; line-height: 1.55; margin: 0; max-width: 680px; }
.notification-dashboard { display: grid; grid-template-columns: minmax(245px, 310px) minmax(0, 1fr); gap: 18px; }
.notification-controls { align-self: start; display: grid; gap: 18px; }
.notification-controls .streets-panel-head strong { font-size: 25px; }
.notification-stat-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.notification-stat-grid div { border: 1px solid rgba(225, 157, 47, .18); border-radius: 7px; background: rgba(0, 0, 0, .3); padding: 13px; }
.notification-stat-grid strong { color: #ffe0a8; display: block; font: 700 25px var(--font-display); }
.notification-stat-grid span { color: rgba(255, 233, 200, .6); font-size: 12px; }
.notification-toggle { align-items: center; color: rgba(255, 235, 206, .76); display: flex; font: 700 13px var(--font-ui); gap: 10px; }
.notification-toggle input { accent-color: #da982d; height: 16px; width: 16px; }
.notification-filters { display: grid; gap: 7px; }
.notification-filter { align-items: center; background: rgba(0, 0, 0, .26); border: 1px solid rgba(225, 157, 47, .16); border-radius: 6px; color: rgba(255, 235, 206, .76); cursor: pointer; display: flex; font: 700 13px var(--font-ui); justify-content: space-between; min-height: 42px; padding: 8px 11px; text-align: left; }
.notification-filter.is-active { background: rgba(123, 69, 12, .34); border-color: #d99832; color: #ffe5b1; }
.notification-filter span:last-child { border-radius: 999px; background: rgba(223, 149, 42, .14); color: #eab154; padding: 3px 8px; }
.notification-actions { display: grid; gap: 8px; }
.notification-actions button, .notification-item-action, .notification-messages-link { align-items: center; border: 1px solid rgba(255, 185, 78, .34); border-radius: 7px; background: rgba(36, 13, 3, .78); color: #f6d08b; cursor: pointer; display: inline-flex; font: 900 13px var(--font-ui); justify-content: center; padding: 10px 12px; text-decoration: none; text-transform: uppercase; }
.notification-stream-panel { min-height: 540px; }
.notification-list--center { margin-top: 18px; }
.notification-center-item { display: grid; gap: 11px; grid-template-columns: 54px minmax(0, 1fr) auto; padding: 15px; }
.notification-center-item.is-unread { background: linear-gradient(95deg, rgba(108, 57, 8, .38), rgba(0, 0, 0, .28)); }
.notification-channel-icon { align-items: center; border: 1px solid rgba(235, 176, 67, .34); border-radius: 7px; color: #eaa53b; display: flex; font: 800 11px var(--font-ui); height: 52px; justify-content: center; text-transform: uppercase; width: 52px; }
.notification-copy strong { font-size: 15px; }
.notification-copy p { margin-bottom: 9px; }
.notification-meta { display: flex; flex-wrap: wrap; gap: 11px; }
.notification-meta span { color: rgba(231, 168, 64, .76); }
.notification-item-controls { align-items: flex-end; display: flex; flex-direction: column; gap: 8px; }
.notification-item-action { font-size: 12px; min-width: 94px; padding: 8px 10px; }
.notification-item-action.is-subtle { background: transparent; border-color: rgba(255, 185, 78, .18); }
.notification-destinations { display: grid; gap: 10px; grid-template-columns: repeat(4, minmax(0, 1fr)); margin-top: 18px; }
.notification-destination { border: 1px solid rgba(207, 132, 31, .32); border-radius: 8px; background: rgba(16, 6, 2, .76); color: #ffe3af; padding: 16px; text-decoration: none; }
.notification-destination strong { display: block; font: 700 18px var(--font-ui); text-transform: uppercase; }
.notification-destination span { color: rgba(255, 235, 206, .68); display: block; font-size: 13px; line-height: 1.4; margin-top: 6px; }
@media (max-width: 900px) {
  .notification-dashboard, .notification-destinations { grid-template-columns: 1fr; }
  .notification-center-item { grid-template-columns: 48px minmax(0, 1fr); }
  .notification-item-controls { align-items: stretch; flex-direction: row; grid-column: 2; }
}
@media (max-width: 560px) {
  .notification-center { width: min(100% - 24px, 1240px); }
  .notification-center-heading { align-items: start; flex-direction: column; }
}

/* Clickable cards */
.notification-center-item.is-clickable { cursor: pointer; }
.notification-center-item.is-clickable:hover { background: linear-gradient(95deg, rgba(108, 57, 8, .28), rgba(0, 0, 0, .22)); border-color: rgba(225, 157, 47, .28); }
.notification-center-item.is-clickable.is-unread:hover { background: linear-gradient(95deg, rgba(108, 57, 8, .48), rgba(0, 0, 0, .32)); }

/* Title link inside notification */
.notif-title-link { color: inherit; text-decoration: none; }
.notif-title-link:hover { color: #f5d087; text-decoration: underline; }

/* Unread indicator */
.notif-unread-dot {
  color: #da982d;
  font-weight: 700;
  position: relative;
  padding-left: 12px;
}
.notif-unread-dot::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #da982d;
}
