/* ═══════════════════════════════════════════════
   DASHBOARD CSS — Clouds Hosting
   Tokens from Setting::generateCssVariables()
   injected inline; these are fallbacks.
   ═══════════════════════════════════════════════ */

:root {
  --p: #6EE7B7; --p-dim: rgba(110,231,183,.12); --p-glow: rgba(110,231,183,.25);
  --bg: #0a0a0b; --bg-s: #111113; --bg-c: #18181c; --bg-e: #1f1f25;
  --bd: rgba(255,255,255,.07); --bd-a: rgba(110,231,183,.3);
  --t1: #f4f4f5; --t2: #a1a1aa; --t3: #52525b;
  --er: #f87171;
  --r1: 8px; --r2: 12px; --r3: 16px;
  --sw: 220px;
}
[data-theme=light] {
  --p: #059669; --p-dim: rgba(5,150,105,.1); --p-glow: rgba(5,150,105,.2);
  --bg: #e2e8f0; --bg-s: #f1f5f9; --bg-c: #f8fafc; --bg-e: #cbd5e1;
  --bd: rgba(0,0,0,.08); --bd-a: rgba(16,163,100,.4);
  --t1: #1e293b; --t2: #475569; --t3: #94a3b8;
  --er: #dc2626;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
svg { display: block; max-width: 100%; height: auto; }
button svg, .icobtn svg { width: 16px !important; height: 16px !important; flex-shrink: 0; }
.pines-acc-btn svg { width: 14px !important; height: 14px !important; flex-shrink: 0; display: inline-block !important; }

/* ── SLIDE-OVER (Ticket Thread) ── */
.so-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(3px); z-index: 150; }
.so-panel { position: fixed; top: 0; right: 0; bottom: 0; width: 520px; max-width: 100vw; background: var(--bg-s); border-left: 1px solid var(--bd); z-index: 151; display: flex; flex-direction: column; overflow: hidden; }
@media (max-width: 600px) { .so-panel { width: 100vw; border-left: none; } }
.so-head { padding: 18px 20px; border-bottom: 1px solid var(--bd); display: flex; align-items: flex-start; gap: 12px; flex-shrink: 0; }
.so-body { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.so-foot { padding: 14px 20px; border-top: 1px solid var(--bd); flex-shrink: 0; background: var(--bg-s); }
/* Message bubbles */
.msg { display: flex; gap: 10px; }
.msg.staff { flex-direction: row-reverse; }
.msg-av { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; flex-shrink: 0; }
.msg-av.customer { background: var(--p-dim); color: var(--p); }
.msg-av.staff    { background: rgba(99,102,241,.18); color: #818cf8; }
.msg-bubble { background: var(--bg-e); border: 1px solid var(--bd); border-radius: var(--r2); padding: 10px 14px; font-size: 13px; color: var(--t1); line-height: 1.6; max-width: 80%; }
.msg.staff .msg-bubble { background: rgba(99,102,241,.1); border-color: rgba(99,102,241,.2); }
.msg-meta { font-size: 11px; color: var(--t3); margin-top: 4px; }
/* Original message box */
.ticket-orig { background: var(--bg-e); border: 1px solid var(--bd); border-radius: var(--r2); padding: 14px; font-size: 13px; color: var(--t2); line-height: 1.7; margin-bottom: 4px; }
/* Reply textarea */
.reply-input { width: 100%; background: var(--bg-e); border: 1px solid var(--bd); border-radius: var(--r2); padding: 10px 14px; font-family: 'DM Sans', sans-serif; font-size: 13px; color: var(--t1); outline: none; resize: none; min-height: 72px; transition: border-color .2s, box-shadow .2s; }
.reply-input:focus { border-color: var(--bd-a); box-shadow: 0 0 0 3px var(--p-glow); }
.reply-input::placeholder { color: var(--t3); }
/* Clickable ticket row */
.titem.clickable { cursor: pointer; border-radius: var(--r1); transition: background .15s; }
.titem.clickable:hover { background: var(--bg-e); }
.sb-logo svg, .logo-mark svg { width: 16px !important; height: 16px !important; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg); color: var(--t1);
  min-height: 100vh; display: flex; font-size: 14px; line-height: 1.6;
  transition: background .3s, color .3s;
}

/* ── SIDEBAR ── */
.sidebar {
  width: var(--sw); min-height: 100vh; background: var(--bg-s);
  border-right: 1px solid var(--bd); display: flex; flex-direction: column;
  position: fixed; left: 0; top: 0; bottom: 0; z-index: 100;
  transition: transform .3s cubic-bezier(.4,0,.2,1), background .3s;
}
.sb-logo { padding: 20px 20px 16px; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--bd); }
.logo-mark { width: 30px; height: 30px; border-radius: 8px; background: var(--p); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.logo-text { font-size: 15px; font-weight: 600; letter-spacing: -.3px; color: var(--t1); }
.logo-text span { color: var(--p); }
.sb-nav { flex: 1; padding: 12px 10px; overflow-y: auto; }
.nav-lbl { font-size: 10px; font-weight: 500; letter-spacing: .8px; text-transform: uppercase; color: var(--t3); padding: 8px 10px 4px; margin-top: 8px; display: block; }
.nav-a { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: var(--r1); cursor: pointer; color: var(--t2); font-size: 13.5px; font-weight: 400; transition: all .15s; user-select: none; position: relative; text-decoration: none; }
.nav-a:hover { background: var(--bg-e); color: var(--t1); }
.nav-a.active { background: var(--p-dim); color: var(--p); font-weight: 500; }
.nav-a.active::before { content: ''; position: absolute; left: 0; top: 20%; bottom: 20%; width: 2px; background: var(--p); border-radius: 2px; }
.nav-a .nb { margin-left: auto; background: var(--p-dim); color: var(--p); font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 20px; font-family: 'DM Mono', monospace; }
.sb-foot { padding: 14px 10px; border-top: 1px solid var(--bd); }

/* ── MAIN ── */
.main { margin-left: var(--sw); flex: 1; min-height: 100vh; display: flex; flex-direction: column; }

/* ── TOPBAR ── */
.topbar { background: var(--bg-s); border-bottom: 1px solid var(--bd); padding: 0 24px; height: 56px; display: flex; align-items: center; gap: 12px; position: sticky; top: 0; z-index: 50; transition: background .3s; }
.mtoggle { display: none; background: none; border: none; color: var(--t2); cursor: pointer; padding: 6px; border-radius: 6px; transition: color .15s, background .15s; }
.mtoggle:hover { background: var(--bg-e); color: var(--t1); }

/* ── SEARCH ── */
.srch-wrap { flex: 1; max-width: 380px; position: relative; }
.srch { width: 100%; background: var(--bg-e); border: 1px solid var(--bd); border-radius: var(--r2); padding: 7px 14px 7px 36px; font-family: 'DM Sans', sans-serif; font-size: 13px; color: var(--t1); outline: none; transition: border-color .2s, box-shadow .2s, background .3s; }
.srch::placeholder { color: var(--t3); }
.srch:focus { border-color: var(--bd-a); box-shadow: 0 0 0 3px var(--p-glow); background: var(--bg-c); }
.srch-ico { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--t3); pointer-events: none; }
.tb-right { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.icobtn { width: 34px; height: 34px; border-radius: var(--r1); background: none; border: 1px solid var(--bd); display: flex; align-items: center; justify-content: center; color: var(--t2); cursor: pointer; transition: all .15s; position: relative; }
.icobtn:hover { background: var(--bg-e); color: var(--t1); border-color: var(--bd-a); }
.ndot { position: absolute; top: 6px; right: 6px; width: 6px; height: 6px; border-radius: 50%; background: var(--p); border: 1.5px solid var(--bg-s); }

/* ── CONTENT ── */
.content { padding: 24px; flex: 1; }
.ph { margin-bottom: 24px; }
.ptitle { font-size: 20px; font-weight: 600; color: var(--t1); letter-spacing: -.3px; }
.psub { font-size: 13px; color: var(--t3); margin-top: 2px; }

/* ── CARDS ── */
.card { background: var(--bg-c); border: 1px solid var(--bd); border-radius: var(--r3); padding: 20px; transition: border-color .2s, background .3s; }
.card:hover { border-color: rgba(255,255,255,.12); }
.ctitle { font-size: 13px; font-weight: 600; color: var(--t1); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.ctitle .cnt { font-size: 11px; font-family: 'DM Mono', monospace; color: var(--t3); background: var(--bg-e); padding: 1px 7px; border-radius: 20px; }
.cact { margin-left: auto; display: flex; gap: 6px; }

/* ── GRIDS ── */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 12px; margin-bottom: 24px; }
.stat-card { background: var(--bg-c); border: 1px solid var(--bd); border-radius: var(--r3); padding: 18px 20px; transition: all .2s; }
.stat-card:hover { border-color: var(--bd-a); transform: translateY(-1px); }
.slbl { font-size: 11px; font-weight: 500; color: var(--t3); letter-spacing: .5px; text-transform: uppercase; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.sval { font-size: 26px; font-weight: 600; color: var(--t1); font-family: 'DM Mono', monospace; letter-spacing: -1px; line-height: 1; }
.schg { font-size: 11px; margin-top: 6px; display: flex; align-items: center; gap: 3px; font-family: 'DM Mono', monospace; }
.schg.up { color: var(--p); } .schg.dn { color: #f87171; }
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
.g3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 20px; }

/* ── BADGES ── */
.bdg { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 20px; font-family: 'DM Mono', monospace; }
.bdg-g { background: var(--p-dim); color: var(--p); }
.bdg-r { background: rgba(248,113,113,.12); color: #f87171; }
.bdg-a { background: rgba(251,191,36,.12); color: #fbbf24; }
.bdg-n { background: var(--bg-e); color: var(--t2); }

/* ── TABLE ── */
.tw { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th { text-align: left; font-size: 10.5px; font-weight: 500; color: var(--t3); letter-spacing: .6px; text-transform: uppercase; padding: 0 14px 10px; border-bottom: 1px solid var(--bd); }
td { padding: 13px 14px; color: var(--t2); border-bottom: 1px solid var(--bd); transition: background .1s; }
tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: var(--bg-e); }
td.mono { font-family: 'DM Mono', monospace; color: var(--t1); }

/* ── PROGRESS ── */
.pbar { height: 4px; background: var(--bg-e); border-radius: 4px; overflow: hidden; margin-top: 6px; }
.pfill { height: 100%; background: var(--p); border-radius: 4px; transition: width .6s cubic-bezier(.4,0,.2,1); }
.pfill.warn { background: #fbbf24; } .pfill.danger { background: #f87171; }
.uitem { margin-bottom: 18px; }
.uhdr { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.uname { font-size: 13px; color: var(--t2); }
.uval { font-size: 12px; color: var(--t3); font-family: 'DM Mono', monospace; }

/* ── PINES ACCORDION ── */
.pines-acc { border: 1px solid var(--bd); border-radius: var(--r2); overflow: hidden; margin-bottom: 8px; }
.pines-acc-btn { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 14px 16px; background: none; border: none; color: var(--t1); font-family: 'DM Sans', sans-serif; font-size: 13.5px; font-weight: 500; cursor: pointer; text-align: left; gap: 12px; transition: background .15s; }
.pines-acc-btn:hover { background: var(--bg-e); }
.pines-acc-body { padding: 0 16px 16px; font-size: 13px; color: var(--t2); line-height: 1.7; }
.pines-acc-body .btn-row { display: flex; gap: 8px; margin-top: 10px; }

/* ── PINES DROPDOWN ── */
.pdr { position: relative; }
.pdmenu { position: absolute; right: 0; top: calc(100% + 8px); width: 210px; background: var(--bg-c); border: 1px solid var(--bd); border-radius: var(--r3); box-shadow: 0 8px 32px rgba(0,0,0,.4); overflow: hidden; z-index: 200; transform-origin: top right; }
.pdhead { padding: 12px 14px; border-bottom: 1px solid var(--bd); }
.pdname { font-size: 13px; font-weight: 500; color: var(--t1); }
.pdemail { font-size: 11px; color: var(--t3); margin-top: 1px; }
.pdi { display: flex; align-items: center; gap: 10px; padding: 9px 14px; font-size: 13px; color: var(--t2); cursor: pointer; transition: background .12s, color .12s; }
.pdi:hover { background: var(--bg-e); color: var(--t1); }
.pdi.danger { color: #f87171; }
.pdi.danger:hover { background: rgba(248,113,113,.1); color: #ef4444; }
.pddiv { height: 1px; background: var(--bd); margin: 4px 0; }

/* ── AVATAR ── */
.avbtn { width: 34px; height: 34px; border-radius: 50%; background: var(--p-dim); border: 1.5px solid var(--bd-a); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; color: var(--p); transition: box-shadow .2s; }
.avbtn:hover { box-shadow: 0 0 0 3px var(--p-glow); }

/* ── DOMAIN ROWS ── */
.drow { display: flex; align-items: center; gap: 12px; padding: 13px 0; border-bottom: 1px solid var(--bd); }
.drow:last-child { border-bottom: none; }
.dico { width: 34px; height: 34px; border-radius: 8px; background: var(--bg-e); display: flex; align-items: center; justify-content: center; color: var(--t2); flex-shrink: 0; }
.dico.on { background: var(--p-dim); color: var(--p); }
.dname { font-size: 13px; font-weight: 500; color: var(--t1); }
.dmeta { font-size: 11px; color: var(--t3); margin-top: 1px; font-family: 'DM Mono', monospace; }
.dact { margin-left: auto; display: flex; gap: 6px; }

/* ── BUTTONS ── */
.mbtn { height: 28px; padding: 0 10px; border-radius: 6px; border: 1px solid var(--bd); background: none; color: var(--t2); font-size: 11.5px; font-family: 'DM Sans', sans-serif; cursor: pointer; transition: all .15s; }
.mbtn:hover { background: var(--bg-e); color: var(--t1); border-color: var(--bd-a); }
.mbtn.primary { background: var(--p-dim); color: var(--p); border-color: var(--bd-a); }

/* ── BILLING ── */
.bplan { border: 1px solid var(--bd-a); border-radius: var(--r3); padding: 20px; background: var(--p-dim); margin-bottom: 16px; }
.plan-badge { font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--p); font-family: 'DM Mono', monospace; margin-bottom: 6px; }
.plan-name { font-size: 20px; font-weight: 600; color: var(--t1); }
.plan-price { font-size: 28px; font-weight: 600; color: var(--p); font-family: 'DM Mono', monospace; margin-top: 4px; }
.plan-price span { font-size: 14px; color: var(--t3); font-weight: 400; }

/* ── TICKETS ── */
.titem { display: flex; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--bd); }
.titem:last-child { border-bottom: none; }
.tnum { font-size: 11px; font-family: 'DM Mono', monospace; color: var(--t3); margin-top: 2px; min-width: 50px; }
.ttitle { font-size: 13.5px; color: var(--t1); font-weight: 500; }
.tmeta { font-size: 11px; color: var(--t3); margin-top: 3px; }

/* ── MISC ── */
.sep { height: 1px; background: var(--bd); margin: 20px 0; }
.act-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--p); margin-top: 6px; flex-shrink: 0; }
.act-dot.warn { background: #fbbf24; }
.svc-icon { width: 38px; height: 38px; border-radius: 10px; background: var(--p-dim); display: flex; align-items: center; justify-content: center; }
.svc-icon.warn-bg { background: rgba(251,191,36,.12); }
.overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 90; backdrop-filter: blur(2px); }
.overlay.show { display: block; }

/* ── AUTH LAYOUT ── */
.auth-wrap { width: 100%; max-width: 400px; }
.auth-logo { text-align: center; margin-bottom: 32px; }
.auth-card { background: var(--bg-c); border: 1px solid var(--bd); border-radius: var(--r3); padding: 32px; }
.auth-field { margin-bottom: 16px; }
.auth-field label { display: block; font-size: 11px; color: var(--t3); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
.auth-input { width: 100%; background: var(--bg-e); border: 1px solid var(--bd); border-radius: var(--r1); padding: 10px 14px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--t1); outline: none; transition: border-color .2s, box-shadow .2s; }
.auth-input:focus { border-color: var(--bd-a); box-shadow: 0 0 0 3px var(--p-glow); }
.auth-input::placeholder { color: var(--t3); }
.auth-btn { width: 100%; height: 42px; background: var(--p-dim); border: 1px solid var(--bd-a); border-radius: var(--r1); color: var(--p); font-size: 14px; font-weight: 600; font-family: 'DM Sans', sans-serif; cursor: pointer; transition: all .2s; margin-top: 8px; }
.auth-btn:hover { background: var(--p); color: #0a0a0b; }
.auth-error { background: rgba(248,113,113,.1); border: 1px solid rgba(248,113,113,.3); border-radius: var(--r1); padding: 10px 14px; font-size: 13px; color: #f87171; margin-bottom: 16px; }

/* ── SKELETON LOADER ── */
.skel { background: linear-gradient(90deg, var(--bg-e) 25%, var(--bg-c) 50%, var(--bg-e) 75%); background-size: 200% 100%; animation: skel-shine 1.5s infinite; border-radius: 4px; }
@keyframes skel-shine { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ── ANIMATIONS ── */
.fade-pg { animation: fadeInPage .4s ease-out both; }
@keyframes fadeInPage {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: none; }
}

.animate__animated.s1 { animation-delay: .05s; }
.animate__animated.s2 { animation-delay: .12s; }
.animate__animated.s3 { animation-delay: .18s; }
.animate__animated.s4 { animation-delay: .24s; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  :root { --sw: 0px; }
  .sidebar { transform: translateX(-220px); width: 220px; }
  .sidebar.open { transform: translateX(0); }
  .main { margin-left: 0; }
  .mtoggle { display: flex; }
  .content { padding: 16px; }
  .g2, .g3 { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .dact { display: none; }
}
@media (max-width: 440px) { .stats-grid { grid-template-columns: 1fr; } }

@media (min-width: 1280px) {
  body { font-size: 16px; }
  .content { padding: 40px 48px; }
  .ptitle { font-size: 26px; } .psub { font-size: 15px; } .ph { margin-bottom: 40px; }
  .stats-grid { gap: 24px; margin-bottom: 48px; grid-template-columns: repeat(4,1fr); }
  .stat-card { padding: 26px 28px; }
  .sval { font-size: 34px; } .slbl { font-size: 12px; } .schg { font-size: 12.5px; }
  .g2 { gap: 32px; margin-bottom: 40px; } .g3 { gap: 32px; margin-bottom: 40px; }
  .card { padding: 28px 32px; } .ctitle { font-size: 15px; margin-bottom: 22px; }
  th { font-size: 12px; padding-bottom: 14px; padding-left: 16px; padding-right: 16px; }
  td { font-size: 14.5px; padding: 16px; }
  .nav-a { font-size: 15px; padding: 10px 12px; gap: 12px; } .nav-lbl { font-size: 11px; } .logo-text { font-size: 17px; }
  .topbar { height: 64px; padding: 0 48px; }
  .srch { font-size: 14.5px; padding: 9px 16px 9px 40px; }
  .mbtn { height: 32px; padding: 0 14px; font-size: 13px; }
  .sep { margin: 28px 0; }
}

/* ── REDUCED MOTION ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* ── NOTIFICATION CENTER ── */
.notif-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 340px;
  max-height: 480px;
  display: flex;
  flex-direction: column;
  background: var(--bg-c);
  border: 1px solid var(--bd);
  border-radius: var(--r3);
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
  z-index: 300;
  transform-origin: top right;
  overflow: hidden;
}
@media (max-width: 480px) {
  .notif-panel {
    position: fixed;
    top: 56px;
    right: 0;
    left: 0;
    width: 100%;
    border-radius: 0 0 var(--r3) var(--r3);
  }
}
.notif-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border-bottom: 1px solid var(--bd);
  flex-shrink: 0;
}
.notif-cnt {
  font-size: 10px;
  font-weight: 700;
  background: var(--p-dim);
  color: var(--p);
  border: 1px solid var(--bd-a);
  border-radius: 10px;
  padding: 1px 6px;
  font-family: 'DM Mono', monospace;
}
.notif-act-btn {
  width: 26px;
  height: 26px;
  border: 1px solid var(--bd);
  border-radius: 6px;
  background: none;
  color: var(--t3);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}
.notif-act-btn:hover { background: var(--bg-e); color: var(--t1); border-color: var(--bd-a); }
.notif-list {
  flex: 1;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--bg-e) transparent;
}
.notif-list::-webkit-scrollbar { width: 4px; }
.notif-list::-webkit-scrollbar-thumb { background: var(--bg-e); border-radius: 4px; }
.notif-empty {
  text-align: center;
  padding: 40px 20px;
  font-size: 13px;
  color: var(--t3);
}
.notif-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  cursor: pointer;
  border-bottom: 1px solid var(--bd);
  transition: background .12s;
  position: relative;
}
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--bg-e); }
.notif-item.unread { background: color-mix(in srgb, var(--p) 4%, transparent); }
.notif-item.unread:hover { background: var(--bg-e); }
.notif-unread-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--p);
  flex-shrink: 0;
  margin-top: 4px;
}
.notif-body { flex: 1; min-width: 0; }
.notif-title {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--t1);
  line-height: 1.4;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notif-desc {
  font-size: 11.5px;
  color: var(--t2);
  line-height: 1.4;
  margin-bottom: 3px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.notif-time {
  font-size: 10.5px;
  color: var(--t3);
  font-family: 'DM Mono', monospace;
}
.notif-foot {
  padding: 10px 14px;
  border-top: 1px solid var(--bd);
  flex-shrink: 0;
}
.notif-see-all {
  width: 100%;
  height: 32px;
  background: none;
  border: 1px solid var(--bd);
  border-radius: var(--r1);
  color: var(--t2);
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer;
  transition: all .15s;
}
.notif-see-all:hover { background: var(--bg-e); color: var(--t1); border-color: var(--bd-a); }

/* Notification icon color variants */
.notif-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.notif-icon.ic-blue   { background: rgba(99,179,237,.12); color: #63b3ed; }
.notif-icon.ic-amber  { background: rgba(251,191,36,.12); color: #fbbf24; }
.notif-icon.ic-green  { background: var(--p-dim); color: var(--p); }
.notif-icon.ic-purple { background: rgba(167,139,250,.12); color: #a78bfa; }
.notif-icon.ic-default { background: var(--bg-e); color: var(--t2); }

