:root{
  --hras-text:#0B1220;
  --hras-bg:#f6f7fb;
  --hras-font-family:inherit;
  --hras-font-size:14px;
  --hras-shell-max:1120px;
  --hras-shell-pad-x:12px;
  --hras-shell-pad-y:0px;
  --hras-shell-margin-y:22px;

  --hras-card:#ffffff;
  --hras-border:#dbe6f3;
  --hras-muted:#6B7A90;
  --hras-primary:#122678;
  --hras-danger:#e11d48;
  --hras-soft:#f3f4f6;

  --hras-shadow:0 10px 25px rgba(17,24,39,.08);
  --hras-shadow-sm:0 1px 2px rgba(0,0,0,.06);
  --hras-ring:0 0 0 4px rgba(18,38,120,.18);

  /* Glassmorphism */
  --hras-glass-bg:rgba(255,255,255,0.78);
  --hras-glass-border:rgba(18,38,120,0.12);
  --hras-glass-blur:14px;
  --hras-glow-primary:rgba(18,38,120,0.10);
  --hras-glow-danger:rgba(26,182,220,0.10);

  --hras-radius:16px;
  --hras-card-padding:16px;

  --hras-btn-radius:12px;
  --hras-btn-padding-y:10px;
  --hras-btn-padding-x:14px;

  --hras-table-cell-padding:12px;
  --hras-table-font-size:13px;
  --hras-table-head-bg:#fafbff;

  --hras-h2-size:22px;
  --hras-h3-size:16px;
}
.hras-shell{max-width:var(--hras-shell-max);margin:var(--hras-shell-margin-y) auto;padding:var(--hras-shell-pad-y) var(--hras-shell-pad-x);font-family:var(--hras-font-family);font-size:var(--hras-font-size);color:var(--hras-text)}
.hras-shell *{box-sizing:border-box}
.hras-shell{background:var(--hras-bg);border-radius:24px}
.hras-header{display:flex;gap:16px;align-items:flex-end;justify-content:space-between;margin-bottom:14px}
.hras-header h2{margin:0;font-size:var(--hras-h2-size);letter-spacing:-.02em}
.hras-shell h3{margin:0 0 10px;font-size:var(--hras-h3-size);letter-spacing:-.01em}
.hras-muted{color:var(--hras-muted);margin:6px 0 0;font-size:13px}
.hras-metric{background:var(--hras-glass-bg);border:1px solid var(--hras-glass-border);border-radius:var(--hras-radius);padding:12px 14px;min-width:140px;text-align:right;backdrop-filter:blur(var(--hras-glass-blur));-webkit-backdrop-filter:blur(var(--hras-glass-blur))}
.hras-metric span{display:block;color:var(--hras-muted);font-size:12px}
.hras-metric strong{display:block;font-size:20px}
.hras-card{background:var(--hras-glass-bg);border:1px solid var(--hras-glass-border);border-radius:var(--hras-radius);padding:var(--hras-card-padding);box-shadow:var(--hras-shadow-sm);backdrop-filter:blur(var(--hras-glass-blur));-webkit-backdrop-filter:blur(var(--hras-glass-blur))}
.hras-card:hover{box-shadow:var(--hras-shadow);transition:box-shadow .18s ease}
.hras-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;margin-top:14px}
@media (max-width:860px){.hras-grid{grid-template-columns:1fr}.hras-header{flex-direction:column;align-items:flex-start}.hras-metric{text-align:left;width:100%}}
.hras-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.hras-grow{flex:1}
.hras-btn{border:0;border-radius:var(--hras-btn-radius);padding:var(--hras-btn-padding-y) var(--hras-btn-padding-x);font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;box-shadow:var(--hras-shadow-sm);transition:transform .12s ease,box-shadow .12s ease,filter .12s ease;color:var(--hras-text)}
.hras-btn:hover{transform:translateY(-1px);box-shadow:var(--hras-shadow)}
.hras-btn:active{transform:translateY(0);filter:saturate(1.05)}
.hras-btn:focus-visible{outline:none;box-shadow:var(--hras-shadow),var(--hras-ring)}
.hras-btn[disabled]{opacity:.6;cursor:not-allowed}
.hras-primary{background:var(--hras-primary);color:#fff !important}
.hras-secondary{background:#eef2ff;color:#111827}
.hras-danger{background:var(--hras-danger);color:#fff !important}
.hras-pill{background:var(--hras-soft);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:700}
.hras-warn{background:#fff7ed;color:#9a3412}
.hras-success{background:#ecfdf5;color:#065f46}
.hras-error{background:#fef2f2;color:#991b1b}
.hras-alert{border-radius:14px;padding:10px 12px;margin:10px 0;font-weight:700;box-shadow:var(--hras-shadow-sm);animation:hras-pop .18s ease}
@keyframes hras-pop{from{transform:translateY(2px);opacity:.0}to{transform:translateY(0);opacity:1}}
.hras-tablewrap{overflow:auto;-webkit-overflow-scrolling:touch;margin-top:12px;border:1px solid var(--hras-border);border-radius:14px}
.hras-table{width:100%;border-collapse:collapse;min-width:920px}
.hras-table th,.hras-table td{padding:var(--hras-table-cell-padding);border-bottom:1px solid var(--hras-border);text-align:left;font-size:var(--hras-table-font-size);white-space:nowrap}
.hras-table th{background:var(--hras-table-head-bg);font-weight:900}
.hras-table tr:last-child td{border-bottom:none}
.hras-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:900}
.hras-badge-warn{background:#fff7ed;color:#9a3412}
.hras-badge-success{background:#ecfdf5;color:#065f46}
.hras-badge-danger{background:#fef2f2;color:#991b1b}
.hras-form label{display:block;font-weight:900;font-size:12px;margin-top:12px}
.hras-form input,.hras-form select,.hras-form textarea{width:100%;padding:10px;border:1px solid var(--hras-border);border-radius:12px;margin-top:6px}
.hras-form label.hras-check{display:flex;align-items:center;gap:8px;font-weight:800}
.hras-form input[type="checkbox"]{width:auto;padding:0;border:0;border-radius:0;margin-top:0}
.hras-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hras-kv{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.hras-kv div{border:1px solid var(--hras-border);border-radius:14px;padding:12px;background:#fafbff}
.hras-kv span{display:block;color:var(--hras-muted);font-size:12px;font-weight:800}
.hras-kv strong{display:block;margin-top:6px;font-size:16px}

@media (max-width:640px){
  .hras-actions{flex-direction:column;align-items:stretch}
  .hras-btn{width:100%}
  .hras-two{grid-template-columns:1fr}
  .hras-kv{grid-template-columns:1fr}

  /* Modern mobile table: card rows */
  .hras-table{min-width:0}
  .hras-table thead{display:none}
  .hras-tablewrap{border:none}
  .hras-table tr{display:block;margin:10px 0;border:1px solid var(--hras-border);border-radius:16px;background:var(--hras-card);box-shadow:var(--hras-shadow-sm);overflow:hidden}
  .hras-table td{display:flex;justify-content:space-between;gap:12px;white-space:normal;padding:10px 12px;border-bottom:1px dashed var(--hras-border)}
  .hras-table td:last-child{border-bottom:none}
  .hras-table td::before{content:attr(data-label);color:var(--hras-muted);font-weight:800;flex:0 0 auto}
}

/* Dark mode (auto) */
@media (prefers-color-scheme: dark){
  :root{
    --hras-text:#e5e7eb;
    --hras-bg:#0b1020;
    --hras-card:#0f172a;
    --hras-border:#243044;
    --hras-muted:#94a3b8;
    --hras-soft:#111827;
    --hras-table-head-bg:#111827;
    --hras-shadow:0 10px 25px rgba(0,0,0,.35);
    --hras-shadow-sm:0 1px 2px rgba(0,0,0,.35);
    --hras-ring:0 0 0 4px rgba(59,130,246,.25);

    --hras-glass-bg:rgba(15,23,42,.64);
    --hras-glass-border:rgba(255,255,255,.08);
    --hras-glass-blur:16px;
  }
  .hras-secondary{background:rgba(17,24,39,.62);color:var(--hras-text);backdrop-filter:blur(var(--hras-glass-blur));-webkit-backdrop-filter:blur(var(--hras-glass-blur))}
}

/* Ensure theme styles can't make dark buttons unreadable */
.hras-shell .hras-btn.hras-primary,
.hras-shell .hras-btn.hras-danger{color:#fff !important}


/* Employee header user meta */
.hras-user{display:flex;gap:12px;align-items:center;margin-top:8px}
.hras-avatar{width:44px;height:44px;border-radius:999px;object-fit:cover;border:1px solid var(--hras-border);background:var(--hras-soft)}
.hras-user-name{font-weight:700;font-size:16px;line-height:1.2;color:var(--hras-text)}
.hras-user-sub{color:var(--hras-muted);font-size:13px;line-height:1.3;margin-top:2px;word-break:break-word}


/* Optional glass effect */
.hras-shell.hras-glass{background:var(--hras-glass-bg);border:1px solid var(--hras-glass-border);-webkit-backdrop-filter:blur(var(--hras-glass-blur));backdrop-filter:blur(var(--hras-glass-blur));}

/* Chat UI */
/*
  Important for scrolling:
  - The chat needs a constrained height so the messages area can scroll.
  - Flex children need min-height:0 to allow overflow:auto to work correctly.
  You can override height via custom CSS: .hras-chat{height:600px}
*/
.hras-chat{display:flex;gap:0;height:min(72vh,720px);min-height:540px;border:1px solid var(--hras-border);border-radius:var(--hras-radius);overflow:hidden;background:var(--hras-chat-main-bg, var(--hras-card));font-family:var(--hras-chat-font-family, var(--hras-font-family));font-size:var(--hras-chat-font-size, var(--hras-font-size));color:var(--hras-chat-text, var(--hras-text))}
.hras-chat[data-layout="window"]{display:flex}
.hras-chat[data-layout="sidebar"]{display:flex}
.hras-chat[data-layout="sidebar"] .hras-chat-sidebar{width:100%;max-width:none;border-right:0}
.hras-chat-sidebar{width:340px;max-width:40%;border-right:1px solid var(--hras-border);display:flex;flex-direction:column;background:var(--hras-chat-sidebar-bg, rgba(255,255,255,.75));backdrop-filter:saturate(180%) blur(10px);-webkit-backdrop-filter:saturate(180%) blur(10px)}
.hras-chat-search{padding:10px;border-bottom:1px solid var(--hras-border)}
.hras-chat-search input{width:100%;padding:10px 12px;border:1px solid var(--hras-border);border-radius:999px;background:#fff;color:var(--hras-chat-text, var(--hras-text));outline:none}
.hras-chat-search input:focus{box-shadow:0 0 0 3px rgba(26,182,220,.18);border-color:rgba(26,182,220,.55)}
.hras-chat-lists{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.hras-chat-threads{overflow:visible;flex:0}

.hras-chat-top-actions{display:flex;gap:8px;align-items:center}
.hras-chat-groups{overflow:auto;flex:0;min-height:0;max-height:240px;border-bottom:1px solid rgba(0,0,0,.04)}
.hras-chat-grouprow{display:flex;gap:10px;align-items:center;padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.04)}
.hras-chat-grouprow:hover{background:rgba(18,38,120,.04)}
.hras-chat-grouprow.active{background:rgba(26,182,220,.10)}
.hras-chat-grouprow .icon{width:40px;height:40px;border-radius:14px;background:rgba(18,38,120,.08);display:flex;align-items:center;justify-content:center;font-weight:900;color:rgba(18,38,120,.85)}
.hras-chat-grouprow .meta{min-width:0;flex:1}
.hras-chat-grouprow .name{font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-grouprow .sub{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.hras-chat-grouprow .side{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.hras-chat-grouprow .side .time{font-size:11px;color:var(--hras-chat-muted, var(--hras-muted))}
.hras-chat-grouprow .icon-mini{font-size:12px;opacity:.8}
.hras-chat-grouprow .rowmenu{border:0;background:transparent;cursor:pointer;opacity:.55;font-size:18px;line-height:1;padding:0 4px}
.hras-chat-grouprow:hover .rowmenu{opacity:.9}
.hras-chat-grouprow .badge{background:var(--hras-primary);color:#fff;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:700}
.hras-chat-thread-actions{display:flex;gap:6px;align-items:center}
.hras-chat-mini{padding:6px 8px;border-radius:999px;line-height:1}

.hras-chat-group-results{margin-top:10px;max-height:240px;overflow:auto;border:1px solid rgba(0,0,0,.08);border-radius:14px}
.hras-chat-group-results .row{display:flex;gap:10px;align-items:center;padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.06)}
.hras-chat-group-results .row:hover{background:rgba(18,38,120,.04)}
.hras-chat-group-results img{width:34px;height:34px;border-radius:999px}
.hras-chat-group-results .meta{min-width:0;flex:1}
.hras-chat-group-results .name{font-weight:800}
.hras-chat-group-results .sub{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-group-selected{display:flex;flex-wrap:wrap;gap:6px}
.hras-chat-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.10);background:rgba(255,255,255,.96);font-size:12px}
.hras-chat-chip .x{cursor:pointer;font-weight:900;opacity:.7}
.hras-chat-chip .x:hover{opacity:1}

.hras-chat-people{overflow:auto;flex:1;min-height:0}
.hras-chat-userrow{display:flex;gap:10px;align-items:center;padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.04)}
.hras-chat-userrow:hover{background:rgba(18,38,120,.04)}
.hras-chat-userrow.active{background:rgba(26,182,220,.10)}
.hras-chat-userrow img{width:40px;height:40px;border-radius:999px}
.hras-chat-userrow .meta{min-width:0;flex:1}
.hras-chat-userrow .name{font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-userrow .sub{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.hras-chat-userrow .side{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.hras-chat-userrow .side .time{font-size:11px;color:var(--hras-chat-muted, var(--hras-muted))}
.hras-chat-userrow .icon-mini{font-size:12px;opacity:.8}
.hras-chat-userrow .rowmenu{border:0;background:transparent;cursor:pointer;opacity:.55;font-size:18px;line-height:1;padding:0 4px}
.hras-chat-userrow:hover .rowmenu{opacity:.9}
.hras-chat-userrow .badge{background:var(--hras-primary);color:#fff;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:700}
.hras-chat-userrow .dot{width:10px;height:10px;border-radius:50%;background:#94a3b8;box-shadow:0 0 0 2px rgba(255,255,255,.9)}
.hras-chat-userrow .dot.online{background:#22c55e}

/* Row menu */
.hras-chat-menu{position:fixed;z-index:999999;background:var(--hras-card);border:1px solid rgba(0,0,0,.10);border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.18);padding:6px;min-width:180px}
.hras-chat-menu .item{width:100%;text-align:left;border:0;background:transparent;padding:10px 10px;border-radius:10px;cursor:pointer;font-weight:800;color:var(--hras-text)}
.hras-chat-menu .item:hover{background:rgba(18,38,120,.06)}

/* Load older */
.hras-loadolder,.hras-loadhint{display:flex;justify-content:center;padding:8px 12px;font-size:12px;color:var(--hras-chat-muted, var(--hras-muted))}

/* Jump to bottom */
.hras-chat-jump{position:absolute;right:14px;bottom:92px;width:38px;height:38px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:rgba(255,255,255,.95);box-shadow:0 10px 22px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px}
.hras-chat-jump:hover{transform:translateY(-1px)}

/* Info modal */
.hras-chat-infobox .head{display:flex;gap:12px;align-items:center}
.hras-chat-infobox .head .av{width:52px;height:52px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:rgba(18,38,120,.08);font-size:22px}
.hras-chat-infobox .head img.av{width:52px;height:52px;border-radius:999px}
.hras-chat-infobox .meta .name{font-weight:900;font-size:16px}
.hras-chat-infobox .meta .sub{color:var(--hras-chat-muted, var(--hras-muted));font-size:12px;margin-top:2px}
.hras-chat-infobox .actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.hras-chat-infosec{margin-top:14px}
.hras-chat-infosec .ttl{font-weight:900;margin-bottom:10px}
.hras-chat-infosec .u{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:12px}
.hras-chat-infosec .u:hover{background:rgba(18,38,120,.04)}
.hras-chat-infosec img{width:38px;height:38px;border-radius:999px}
.hras-chat-infosec .m{min-width:0;flex:1}
.hras-chat-infosec .n{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-infosec .s{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-infosec .role{display:inline-flex;margin-left:6px;padding:2px 6px;border-radius:999px;background:rgba(26,182,220,.16);font-size:11px;font-weight:800}
.hras-chat-infosec .mini{padding:6px 10px}

.hras-chat-thread{display:flex;gap:10px;align-items:center;padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.04)}
.hras-chat-thread:hover{background:rgba(18,38,120,.04)}
.hras-chat-thread.active{background:rgba(26,182,220,.10)}
.hras-chat-thread img{width:40px;height:40px;border-radius:999px}
.hras-chat-thread .meta{min-width:0;flex:1}
.hras-chat-thread .name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-thread .last{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.hras-chat-thread .badge{background:var(--hras-primary);color:#fff;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:700}
.hras-chat-main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--hras-chat-main-bg, #fff);position:relative}
.hras-chat-head{padding:12px 14px;border-bottom:1px solid var(--hras-border);display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.85)}
.hras-chat-peer{font-weight:800}
.hras-chat-typing{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted))}
.hras-chat-messages{flex:1;min-height:0;overflow:auto;padding:14px;background:var(--hras-chat-message-bg, rgba(243,246,251,.85))}
.hras-msg{display:flex;gap:10px;margin:10px 0;align-items:flex-end}
.hras-msg.me{flex-direction:row-reverse}
.hras-msg img{width:28px;height:28px;border-radius:999px}
.hras-bubble{max-width:72%;padding:10px 12px;border-radius:16px;border:1px solid rgba(0,0,0,.06);background:var(--hras-chat-bubble-other-bg, #f3f6fb);color:var(--hras-chat-bubble-other-text, var(--hras-text));box-shadow:0 8px 20px rgba(0,0,0,.04);font-size:14px;line-height:1.35}
.hras-msg.me .hras-bubble{background:var(--hras-chat-bubble-me-bg, var(--hras-primary));color:var(--hras-chat-bubble-me-text, #fff);border-color:rgba(0,0,0,0)}
.hras-bubble .time{display:block;margin-top:6px;font-size:11px;color:var(--hras-muted)}

/* Better Arabic/mixed RTL-LTR rendering inside messages */
.hras-msg-text{direction:auto;unicode-bidi:plaintext;text-align:start;word-break:break-word}
.hras-attachments{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.hras-attachment{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid rgba(0,0,0,.10);background:rgba(255,255,255,.86);text-decoration:none;color:var(--hras-text)}
.hras-attachment:hover{background:rgba(26,182,220,.08)}
.hras-attachment .meta{min-width:0}
.hras-attachment .name{font-weight:800;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}
.hras-attachment .sub{font-size:12px;color:var(--hras-muted)}
.hras-attachment img.preview{width:44px;height:44px;border-radius:10px;object-fit:cover;border:1px solid rgba(0,0,0,.08)}
.hras-reactions{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.hras-reaction{font-size:12px;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:2px 8px;background:#fff;cursor:pointer}
.hras-reaction:hover{background:rgba(26,182,220,.08)}
.hras-chat-compose{padding:10px;border-top:1px solid var(--hras-border);display:flex;gap:10px;align-items:flex-end;background:rgba(255,255,255,.92)}
.hras-chat-uploads{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px;align-self:flex-start}
.hras-upload-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid rgba(0,0,0,.10);border-radius:999px;background:rgba(255,255,255,.95);font-size:12px;color:var(--hras-text)}
.hras-upload-chip .x{cursor:pointer;font-weight:900;opacity:.7}
.hras-upload-chip .x:hover{opacity:1}
.hras-chat-compose textarea{flex:1;resize:none;max-height:140px;min-height:44px;padding:10px 12px;border:1px solid var(--hras-border);border-radius:14px;background:#fff;color:var(--hras-chat-text, var(--hras-text));outline:none}
.hras-chat-compose textarea:focus{box-shadow:0 0 0 3px rgba(26,182,220,.16);border-color:rgba(26,182,220,.55)}

/* Let the browser detect Arabic vs English typing direction */
.hras-chat-compose textarea{direction:auto;text-align:start}
.hras-chat-card .hras-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.hras-btn.hras-btn-ghost{background:transparent;border:1px solid var(--hras-border);color:var(--hras-text)}
/* Modal */
.hras-modal{position:relative}
.hras-modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.55);z-index:9998}
.hras-modal-card{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(520px,92vw);background:#fff;border-radius:18px;z-index:9999;box-shadow:0 18px 60px rgba(0,0,0,.25);border:1px solid rgba(0,0,0,.08);overflow:hidden}
.hras-modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(0,0,0,.06)}
.hras-modal-title{font-weight:900}
.hras-modal-body{padding:14px}
.hras-modal-body input{width:100%;padding:10px 12px;border:1px solid rgba(0,0,0,.12);border-radius:12px;outline:none}
.hras-chat-user-results{margin-top:10px;max-height:340px;overflow:auto;border:1px solid rgba(0,0,0,.08);border-radius:14px}
.hras-chat-user{display:flex;gap:10px;align-items:center;padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.06)}
.hras-chat-user:hover{background:rgba(18,38,120,.04)}
.hras-chat-user img{width:36px;height:36px;border-radius:999px}
.hras-chat-user .meta{min-width:0}
.hras-chat-user .name{font-weight:800}
.hras-chat-user .sub{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width: 820px){
  .hras-chat{flex-direction:column}
  .hras-chat-sidebar{width:100%;max-width:100%;border-right:0;border-bottom:1px solid var(--hras-border)}
}

/* Mobile: keep chat usable within the viewport */
@media (max-width: 820px){
  .hras-chat{height:calc(100svh - 120px);max-height:calc(100svh - 120px);min-height:520px}
  .hras-chat-messages{-webkit-overflow-scrolling:touch}
}


/* Chat reply/edit bars + actions + ticks */
.hras-chat-replybar,.hras-chat-editbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;margin-bottom:8px;border:1px solid var(--hras-border);border-radius:14px;background:rgba(255,255,255,.75)}
.hras-chat-replybar .meta,.hras-chat-editbar .meta{min-width:0;flex:1}
.hras-chat-replybar .top,.hras-chat-editbar .top{font-weight:800;font-size:12px}
.hras-chat-replybar .snip{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.hras-quote{border-left:3px solid rgba(0,0,0,.0);border-left-color:color-mix(in srgb, var(--hras-chat-accent, #1AB6DC) 55%, transparent);padding:6px 8px;margin-bottom:8px;border-radius:10px;background:color-mix(in srgb, var(--hras-chat-accent, #1AB6DC) 10%, transparent)}
.hras-quote .who{font-weight:800;font-size:12px;margin-bottom:2px}
.hras-quote .qbody{font-size:12px;color:var(--hras-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.hras-msg{position:relative}
.hras-msg-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:6px;opacity:.0;transition:opacity .15s ease}
.hras-msg:hover .hras-msg-actions{opacity:1}
.hras-msg-actions .hras-btn{padding:6px 8px;font-size:12px;line-height:1;border-radius:10px}

.hras-msg-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px}
.hras-ticks{font-size:12px;color:var(--hras-muted);font-weight:800}



/* Chat contacts / online (Messenger-like) */
.hras-chat-online-wrap{padding:10px 10px 0 10px;}
.hras-chat-section-title{padding:10px 10px 6px 10px;font-size:12px;font-weight:700;opacity:.75;text-transform:uppercase;letter-spacing:.04em}
.hras-chat-online{display:flex;gap:10px;overflow:auto;padding:6px 0 10px 0}
.hras-chat-online::-webkit-scrollbar{height:6px}
.hras-chat-person{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:58px;cursor:pointer;user-select:none}
.hras-chat-person .hras-chat-avatar{position:relative;width:44px;height:44px;border-radius:50%;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.08);background:#fff}
.hras-chat-person .hras-chat-avatar img{width:100%;height:100%;object-fit:cover}
.hras-chat-person .hras-chat-dot{position:absolute;right:2px;bottom:2px;width:10px;height:10px;border-radius:50%;background:#22c55e;border:2px solid #fff}
.hras-chat-person .hras-chat-name{font-size:11px;max-width:70px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.85}
.hras-chat-search input#hras-chat-contact-search{width:100%}


/* General UX improvements */
@media (hover:hover){
  .hras-card{transition:transform .12s ease, box-shadow .12s ease}
  .hras-card:hover{transform:translateY(-1px);box-shadow:0 10px 30px rgba(2,6,23,.08)}
}
.hras-table thead th{position:sticky;top:0;z-index:1;background:var(--hras-card)}


/* ===============================
   Chat Pro Theme (WhatsApp/Telegram-like)
   =============================== */
.hras-chat{background:var(--hras-chat-main-bg, #fff);box-shadow:0 10px 30px rgba(2,6,23,.06)}
.hras-chat-sidebar{background:var(--hras-chat-sidebar-bg, #fff);backdrop-filter:none;-webkit-backdrop-filter:none}
.hras-chat-head{position:sticky;top:0;z-index:2;background:var(--hras-chat-header-bg, rgba(255,255,255,.96));backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px)}
.hras-chat-peer{display:flex;align-items:center;gap:10px;min-width:0}
.hras-chat-peerwrap{display:flex;align-items:center;gap:10px;min-width:0}
.hras-chat-peerwrap .av{width:38px;height:38px;border-radius:999px;object-fit:cover;border:1px solid rgba(0,0,0,.08);background:#fff;flex:0 0 auto}
.hras-chat-peerwrap .av.group{display:flex;align-items:center;justify-content:center;font-weight:900;background:rgba(18,38,120,.08);color:rgba(18,38,120,.9);border-radius:14px}
.hras-chat-peerwrap .meta{min-width:0;display:flex;flex-direction:column;gap:2px}
.hras-chat-peerwrap .name{font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-peerwrap .sub{font-size:12px;color:var(--hras-chat-muted, var(--hras-muted));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hras-chat-peerwrap .sub .online{color:#16a34a;font-weight:800}

.hras-chat-messages{background:var(--hras-chat-message-bg, #eef2f7)}

.hras-chat-back{display:none}

/* Date separators */
.hras-daysep{display:flex;justify-content:center;margin:12px 0}
.hras-daysep span{font-size:12px;font-weight:900;color:var(--hras-muted);background:rgba(255,255,255,.78);border:1px solid rgba(0,0,0,.06);padding:4px 10px;border-radius:999px;box-shadow:0 1px 2px rgba(0,0,0,.06)}

/* Message layout */
.hras-msg{margin:8px 0}
.hras-msg.cont{margin-top:2px}
.hras-msg-avatar-spacer{width:28px;height:28px;flex:0 0 auto}

/* DM: hide avatars like WhatsApp/Telegram */
.hras-chat[data-thread-type="dm"] .hras-msg img{display:none}
.hras-chat[data-thread-type="dm"] .hras-msg-avatar-spacer{display:none}

/* Bubble styling */
.hras-bubble{max-width:78%;border-radius:18px;box-shadow:0 1px 2px rgba(2,6,23,.08);border:1px solid rgba(15,23,42,.08);padding:9px 12px;position:relative}
.hras-msg.me .hras-bubble{background:var(--hras-chat-bubble-me-bg, rgba(26,182,220,.14));color:var(--hras-chat-bubble-me-text, var(--hras-text));border-color:rgba(26,182,220,.18)}
.hras-msg:not(.me) .hras-bubble{background:var(--hras-chat-bubble-other-bg, #fff);color:var(--hras-chat-bubble-other-text, var(--hras-text))}

/* Bubble tails (only for non-continuations) */
.hras-msg.tail:not(.me) .hras-bubble:after{content:"";position:absolute;left:-6px;bottom:8px;width:12px;height:12px;background:inherit;border-left:1px solid rgba(15,23,42,.08);border-bottom:1px solid rgba(15,23,42,.08);transform:rotate(45deg);border-bottom-left-radius:3px}
.hras-msg.tail.me .hras-bubble:after{content:"";position:absolute;right:-6px;bottom:8px;width:12px;height:12px;background:inherit;border-right:1px solid rgba(26,182,220,.18);border-bottom:1px solid rgba(26,182,220,.18);transform:rotate(45deg);border-bottom-right-radius:3px}

/* Sender name (group chats) */
.hras-msg-sender{font-weight:900;font-size:12px;margin-bottom:4px;color:rgba(18,38,120,.88)}

/* Meta line (time + ticks) inside bubble */
.hras-meta{display:flex;gap:6px;align-items:center;justify-content:flex-end;margin-top:6px;font-size:11px;color:rgba(100,116,139,.95)}
.hras-meta .ticks{font-weight:900;letter-spacing:-.02em}
.hras-meta .ticks.read{color:var(--hras-chat-accent, #1AB6DC)}

/* Reactions: make more subtle */
.hras-reaction{background:rgba(255,255,255,.9)}

/* Composer: Telegram-like */
.hras-chat-compose{position:relative;gap:8px}
.hras-chat-compose textarea{border-radius:999px;min-height:44px;padding:12px 14px}
.hras-chat-compose textarea:focus{box-shadow:var(--hras-ring)}

/* Emoji panel */
.hras-emoji-panel{position:absolute;left:10px;bottom:60px;z-index:5;width:min(320px,92%);background:#fff;border:1px solid rgba(0,0,0,.10);border-radius:16px;box-shadow:0 20px 60px rgba(2,6,23,.18);padding:10px;display:none}
.hras-emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px}
.hras-emoji{border:1px solid rgba(0,0,0,.06);border-radius:12px;background:rgba(255,255,255,.96);padding:8px;cursor:pointer;line-height:1;text-align:center;font-size:18px}
.hras-emoji:hover{background:rgba(26,182,220,.10)}

/* Mobile: list <-> thread like WhatsApp */
@media (max-width: 820px){
  .hras-chat{min-height:640px}
  .hras-chat.hras-chat-has-thread .hras-chat-sidebar{display:none}
  /* Mobile: in the full layout, hide the chat area until a thread is selected (Messenger-like).
     In window-only layout we keep the main area visible so it can show the placeholder. */
  .hras-chat[data-layout="full"]:not(.hras-chat-has-thread) .hras-chat-main{display:none}
  .hras-chat-back{display:inline-flex !important}
}


/* Seen-at tooltip for ticks */
.hras-meta .ticks{position:relative;cursor:default}
.hras-meta .ticks[data-tip]:hover:after{content:attr(data-tip);position:absolute;right:0;bottom:18px;white-space:nowrap;background:rgba(2,6,23,.86);color:#fff;padding:6px 10px;border-radius:10px;font-size:12px;font-weight:800;box-shadow:0 12px 30px rgba(0,0,0,.18);z-index:5}
.hras-meta .ticks[data-tip]:hover:before{content:'';position:absolute;right:10px;bottom:12px;border:6px solid transparent;border-top-color:rgba(2,6,23,.86);z-index:5}


/* Attachments: Telegram-like */
.hras-attachments.imgs{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
.hras-attachment-img{display:block;border-radius:14px;overflow:hidden;border:1px solid rgba(15,23,42,.10);background:#fff;box-shadow:0 1px 2px rgba(2,6,23,.08);transition:transform .12s ease, box-shadow .12s ease}
.hras-attachment-img:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(2,6,23,.10)}
.hras-attachment-img img.img{width:100%;height:140px;object-fit:cover;display:block}
.hras-attachment .icon{width:44px;height:44px;border-radius:12px;border:1px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;font-size:20px;background:rgba(255,255,255,.92)}


/* Image lightbox */
.hras-lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:100000}
.hras-lightbox .hras-lightbox-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72)}
.hras-lightbox .hras-lightbox-card{position:relative;max-width:min(980px,94vw);max-height:min(92vh,92svh);background:#0b1220;border:1px solid rgba(255,255,255,.12);border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.45);overflow:hidden;display:flex;flex-direction:column}
.hras-lightbox .hras-lightbox-img{max-width:100%;max-height:calc(min(92vh,92svh) - 54px);object-fit:contain;background:#000}
.hras-lightbox .hras-lightbox-cap{padding:10px 12px;color:rgba(255,255,255,.85);font-size:12px}
.hras-lightbox .hras-lightbox-close{position:absolute;top:10px;right:10px;width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(0,0,0,.35);color:#fff;font-weight:900;cursor:pointer}
.hras-lightbox .hras-lightbox-close:hover{background:rgba(0,0,0,.55)}


/* Mobile friendliness */
.hras-chat-compose{position:sticky;bottom:0;z-index:3;padding-bottom:calc(10px + env(safe-area-inset-bottom))}
.hras-chat-messages{-webkit-overflow-scrolling:touch}
@media (max-width: 820px){
  .hras-chat{height:calc(100svh - 120px);max-height:calc(100svh - 120px);min-height:520px}
  .hras-chat-messages{padding:12px 10px}
  .hras-chat-compose{padding:10px 10px calc(10px + env(safe-area-inset-bottom)) 10px}
  .hras-chat-compose textarea{padding:12px 14px}
}

/* ===============================
   Premium UI/UX polish
   - Empty states
   - Skeleton loaders
   - Toast notifications
   - Theme mode + density + presets
   =============================== */

/* Empty state component */
.hras-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:18px 14px;text-align:center;color:var(--hras-muted);}
.hras-empty .icon{width:44px;height:44px;border-radius:16px;background:rgba(26,182,220,.14);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 8px 20px rgba(2,6,23,.08)}
.hras-empty .title{font-weight:900;color:var(--hras-text);letter-spacing:-.01em}
.hras-empty .desc{font-size:13px;line-height:1.35;max-width:320px}
.hras-empty .actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}

/* Skeleton shimmer */
.hras-skel{position:relative;overflow:hidden;background:rgba(148,163,184,.22);border-radius:14px}
.hras-skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:hras-shimmer 1.15s infinite}
@keyframes hras-shimmer{to{transform:translateX(100%)}}
.hras-skel-row{display:flex;gap:10px;align-items:center;padding:10px 12px}
.hras-skel-av{width:40px;height:40px;border-radius:999px}
.hras-skel-lines{flex:1;display:flex;flex-direction:column;gap:8px}
.hras-skel-line{height:10px;border-radius:10px}
.hras-skel-line.sm{width:56%}
.hras-skel-line.md{width:78%}
.hras-skel-line.lg{width:92%}

/* Chat message skeleton */
.hras-skel-bubble{height:44px;border-radius:18px;margin:10px 0;width:min(72%,420px)}
.hras-skel-bubble.me{margin-left:auto}

/* Toasts */
.hras-toasts{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:10px;z-index:100000;pointer-events:none}
.hras-toast{pointer-events:auto;min-width:260px;max-width:380px;border-radius:16px;padding:12px 14px;box-shadow:0 22px 70px rgba(2,6,23,.24);display:flex;gap:10px;align-items:flex-start;animation:hras-toast-in .18s ease;background:rgba(2,6,23,.88);color:#fff;border:1px solid rgba(255,255,255,.10)}
.hras-toast.success{background:rgba(6,95,70,.92)}
.hras-toast.error{background:rgba(153,27,27,.92)}
.hras-toast.warn{background:rgba(154,52,18,.92)}
.hras-toast .t{font-weight:900;line-height:1.1}
.hras-toast .m{font-size:13px;opacity:.92;margin-top:2px;line-height:1.3}
.hras-toast .x{margin-left:auto;background:transparent;border:0;color:inherit;cursor:pointer;font-size:16px;line-height:1;opacity:.85}
.hras-toast .x:hover{opacity:1}
@keyframes hras-toast-in{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Subtle scrollbars (WebKit) */
.hras-chat *::-webkit-scrollbar{width:10px;height:10px}
.hras-chat *::-webkit-scrollbar-thumb{background:rgba(148,163,184,.45);border-radius:999px;border:2px solid rgba(255,255,255,.55)}
.hras-chat *::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.65)}

/* Modal motion */
.hras-modal-card{animation:hras-modal-in .16s ease}
@keyframes hras-modal-in{from{transform:translate(-50%,-48%) scale(.98);opacity:.0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .hras-shell *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}

/* Theme mode overrides (class beats Appearance inline rules due to higher specificity) */
.hras-shell.hras-theme-dark{
  --hras-text:#e5e7eb;
  --hras-bg:#0b1020;
  --hras-card:#0f172a;
  --hras-border:#243044;
  --hras-muted:#94a3b8;
  --hras-soft:#111827;
  --hras-table-head-bg:#111827;
  --hras-shadow:0 10px 25px rgba(0,0,0,.35);
  --hras-shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --hras-ring:0 0 0 4px rgba(59,130,246,.25);

  --hras-glass-bg:rgba(15,23,42,.64);
  --hras-glass-border:rgba(255,255,255,.08);
  --hras-glass-blur:16px;

  /* Chat surfaces */
  --hras-chat-sidebar-bg:rgba(15,23,42,.82);
  --hras-chat-main-bg:rgba(15,23,42,.72);
  --hras-chat-message-bg:rgba(2,6,23,.22);
}
.hras-shell.hras-theme-dark .hras-chat-search input,
.hras-shell.hras-theme-dark .hras-chat-compose textarea,
.hras-shell.hras-theme-dark .hras-modal-card,
.hras-shell.hras-theme-dark .hras-emoji-panel{background:rgba(2,6,23,.55);color:var(--hras-text);border-color:rgba(255,255,255,.10)}
.hras-shell.hras-theme-dark .hras-chat-head{background:rgba(15,23,42,.88)}

/* Density */
.hras-shell.hras-density-compact{
  --hras-card-padding:12px;
  --hras-btn-padding-y:8px;
  --hras-btn-padding-x:12px;
  --hras-table-cell-padding:10px;
  --hras-font-size:13px;
  --hras-h2-size:20px;
  --hras-h3-size:15px;
}

/* Chat presets */
.hras-chat[data-preset="whatsapp"]{--hras-chat-message-bg:#e8dfd7;}
.hras-chat[data-preset="whatsapp"] .hras-chat-messages{background:var(--hras-chat-message-bg)}
.hras-chat[data-preset="whatsapp"] .hras-msg.me .hras-bubble{border-radius:18px 18px 6px 18px}
.hras-chat[data-preset="whatsapp"] .hras-msg:not(.me) .hras-bubble{border-radius:18px 18px 18px 6px}
.hras-chat[data-preset="whatsapp"] .hras-chat-compose textarea{border-radius:22px}

.hras-chat[data-preset="telegram"]{--hras-chat-message-bg:#eef2f7;}
.hras-chat[data-preset="telegram"] .hras-chat-messages{background:var(--hras-chat-message-bg)}
.hras-chat[data-preset="telegram"] .hras-bubble{border-radius:20px}


/* Button aliases used in chat widgets */
.hras-btn.hras-btn-primary{background:var(--hras-primary);color:#fff !important}
