/* Safe Haven Facebook-style notifications */
.shn-wrap{position:relative;display:inline-flex;align-items:center;margin-left:10px;z-index:9999}
.shn-bell{position:relative;border:1px solid rgba(212,175,55,.38);background:#111;color:#fff;border-radius:999px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px}
.shn-bell:hover{border-color:#d4af37;background:#171717}
.shn-badge{position:absolute;top:-7px;right:-8px;background:#d93016;color:#fff;border-radius:999px;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;border:2px solid #050505}
.shn-panel{display:none;position:absolute;right:0;top:52px;width:390px;max-width:calc(100vw - 24px);background:#101010;border:1px solid rgba(212,175,55,.32);border-radius:20px;box-shadow:0 24px 60px rgba(0,0,0,.65);overflow:hidden}
.shn-panel.open{display:block}
.shn-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.shn-head strong{font-size:18px}
.shn-link{background:transparent;border:0;color:#d4af37;cursor:pointer;font-weight:800;font-size:13px}
.shn-list{max-height:430px;overflow:auto}
.shn-item{display:flex;gap:12px;padding:14px 18px;text-decoration:none;color:#fff;border-bottom:1px solid rgba(255,255,255,.06);background:#101010}
.shn-item:hover{background:#171717}
.shn-item.unread{background:linear-gradient(90deg,rgba(212,175,55,.13),rgba(16,16,16,.95))}
.shn-dot{width:9px;height:9px;border-radius:99px;background:transparent;margin-top:7px;flex:0 0 auto}
.shn-item.unread .shn-dot{background:#d4af37}
.shn-item strong{display:block;font-size:14px;margin-bottom:4px}
.shn-item em{display:block;font-style:normal;color:#cfcfcf;font-size:13px;line-height:1.35}
.shn-item small{display:block;color:#d4af37;margin-top:6px;font-size:11px}
.shn-empty{padding:25px 18px;color:#aaa}
.shn-view-all{display:block;text-align:center;padding:14px 18px;color:#fff;text-decoration:none;font-weight:900;border-top:1px solid rgba(255,255,255,.08);background:#151515}
.shn-view-all:hover{background:#1d1d1d}
@media(max-width:700px){.shn-wrap{position:static}.shn-panel{right:12px;left:12px;top:70px;width:auto;position:fixed}}
