:root{--primary:#5b4bff;--primary2:#2b235a;--bg:#f5f6fb;--card:#fff;--text:#24243a;--muted:#73758b;--line:#e8e9f3;--bubble:#eef0ff;--mine:#5b4bff;--mineText:#fff;--danger:#f95d6a;--shadow:0 16px 40px rgba(29,24,63,.12)}
[data-theme="dark"]{--bg:#151621;--card:#202232;--text:#f2f3ff;--muted:#a7a9bd;--line:#303247;--bubble:#2a2d42;--mine:#6c63ff;--primary2:#1d1b35}
[data-palette="blue"]{--primary:#0d6efd;--primary2:#0a2540;--mine:#0d6efd}[data-palette="red"]{--primary:#c92a2a;--primary2:#2e1214;--mine:#c92a2a}[data-palette="green"]{--primary:#2f9e44;--primary2:#10251a;--mine:#2f9e44}[data-palette="graphite"]{--primary:#495057;--primary2:#181b1f;--mine:#495057}
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{border:0;background:var(--primary);color:white;border-radius:12px;padding:10px 14px;cursor:pointer;transition:.18s}button:hover{filter:brightness(1.05);transform:translateY(-1px)}input,select,textarea{border:1px solid var(--line);border-radius:12px;padding:11px 12px;background:var(--card);color:var(--text);outline:none}label{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:13px}.auth-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,var(--primary),var(--primary2) 45%,#10111c)}.auth-card{width:min(420px,92vw);background:rgba(255,255,255,.96);color:#222;border-radius:26px;padding:28px;box-shadow:var(--shadow)}.auth-card form{display:grid;gap:12px}.brand{display:flex;align-items:center;gap:12px;padding:18px}.brand.solo{padding:0 0 24px}.brand-mark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--primary),#22d3ee);display:grid;place-items:center;color:white;font-weight:900;font-size:24px}.brand small{display:block;color:var(--muted);font-size:12px}.alert,.success{padding:12px;border-radius:12px;margin:10px 0}.alert{background:#ffe3e7;color:#9f1239}.success{background:#dcfce7;color:#166534}.muted{color:var(--muted)}.app-shell{display:flex;height:100vh;overflow:hidden}.main-sidebar{width:260px;background:linear-gradient(180deg,var(--primary2),#141322);color:white;display:flex;flex-direction:column;height:100%;flex:none;overflow-y:auto}.main-sidebar .brand small{color:#c9c6e9}.main-sidebar nav{display:grid;gap:6px;padding:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:14px;color:#ecebff}.nav-item:hover{background:rgba(255,255,255,.09)}.nav-item.danger{margin-top:20px;color:#ffb3bc}.sidebar-user{margin-top:auto;padding:10px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:4px}.sidebar-user-info{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;color:#ecebff;min-width:0}.sidebar-user-info:hover{background:rgba(255,255,255,.09)}.sidebar-user-avatar{position:relative;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#22d3ee);display:grid;place-items:center;color:#fff;font-weight:800;font-size:12px;flex:none;overflow:visible}.sidebar-user-avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.sidebar-user-avatar .status-dot{position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;border:2px solid var(--primary2)}.sidebar-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.sidebar-user-logout{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:12px;color:#ffb3bc;font-size:13px}.sidebar-user-logout:hover{background:rgba(255,179,188,.12)}.status-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:#adb5bd;flex:none}.status-dot.status-online{background:#22c55e}.status-dot.status-away{background:#f5b400}.status-dot.status-busy{background:#ef4444}.status-picker{position:relative;border-radius:12px}.status-picker[open]{background:rgba(255,255,255,.07)}.status-picker>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;color:#ecebff;font-size:13px}.status-picker>summary::-webkit-details-marker{display:none}.status-picker>summary:hover{background:rgba(255,255,255,.09)}.status-picker>summary i{margin-left:auto;font-size:11px;opacity:.7;transition:transform .15s}.status-picker[open]>summary i{transform:rotate(180deg)}.status-picker .status-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-options{position:absolute;left:0;right:0;bottom:calc(100% + 4px);background:#23223a;border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 12px 24px rgba(0,0,0,.35);padding:4px;display:flex;flex-direction:column;gap:2px;z-index:5}.status-options button{background:transparent;color:#ecebff;justify-content:flex-start;text-align:left;display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;font-size:13px;width:100%;box-shadow:none}.status-options button:hover{background:rgba(255,255,255,.09);transform:none}.dot.status-online{background:#22c55e}.dot.status-away{background:#f5b400}.dot.status-busy{background:#ef4444}.chat-shell{flex:1;display:grid;grid-template-columns:360px 1fr;min-width:0;height:100%;overflow:hidden}.conversation-panel{border-right:1px solid var(--line);background:var(--card);padding:18px;display:flex;flex-direction:column;gap:14px;height:100%;min-height:0;overflow:hidden}.panel-title{display:flex;justify-content:space-between;align-items:center}.panel-title h2,.chat-header h2{margin:0}.search{width:100%}.conversation-list{display:grid;gap:8px;overflow-x:hidden;overflow-y:auto;min-width:0;flex:1 1 auto;min-height:0}.conv-item{display:flex;gap:12px;align-items:center;padding:12px;border-radius:16px;cursor:pointer;border:1px solid transparent;min-width:0;max-width:100%}.conv-item:hover,.conv-item.active{background:var(--bubble);border-color:var(--line)}.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#22d3ee);display:grid;place-items:center;color:white;font-weight:800;position:relative;flex:none}.dot{position:absolute;right:0;bottom:1px;width:11px;height:11px;border-radius:50%;border:2px solid var(--card);background:#adb5bd}.dot.online{background:#22c55e}.conv-meta{min-width:0;flex:1}.conv-meta strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-meta small{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.badge{background:var(--danger);color:white;border-radius:999px;font-size:12px;padding:2px 7px}.message-panel{display:flex;flex-direction:column;min-width:0;height:100%;min-height:0;overflow:hidden}.chat-header{height:76px;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 22px}.chat-header span{color:var(--muted);font-size:13px}.messages{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;gap:14px}.empty-state{display:grid;place-items:center;color:var(--muted)}.msg{max-width:min(760px,80%);display:flex;gap:10px;align-items:flex-end}.msg.mine{align-self:flex-end;flex-direction:row-reverse}.bubble{position:relative;background:var(--bubble);padding:12px 14px;border-radius:18px;box-shadow:0 8px 20px rgba(0,0,0,.04);min-width:120px}.mine .bubble{background:var(--mine);color:var(--mineText);border-bottom-right-radius:6px}.msg-head{font-size:12px;color:var(--muted);margin-bottom:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.msg-head .msg-name{font-weight:600}.mine .msg-head{color:rgba(255,255,255,.85)}.msg-status{font-size:11px;opacity:.85;display:inline-flex;align-items:center}.msg-time-inline{font-size:11px;color:var(--muted);opacity:0;transition:opacity .15s ease;margin-left:auto}.mine .msg-time-inline{color:rgba(255,255,255,.85)}.msg:hover .msg-time-inline,.msg:focus-within .msg-time-inline{opacity:.9}.deleted{font-style:italic;color:var(--muted)}.composer{position:relative;display:flex;align-items:flex-end;gap:10px;padding:16px 20px;background:var(--card);border-top:1px solid var(--line)}.composer textarea{flex:1;resize:none;min-height:46px;max-height:160px}.composer button,.attach-btn{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;padding:0}.attach-btn{background:var(--bubble);color:var(--primary);cursor:pointer}.emoji-box{position:absolute;left:20px;bottom:72px;background:var(--card);box-shadow:var(--shadow);padding:10px;border-radius:16px;display:flex;gap:6px}.emoji-box button{background:var(--bubble);font-size:18px}.hidden{display:none!important}.table-wrap{overflow:auto;max-width:100%;border:1px solid var(--line);border-radius:12px}.chat-table{border-collapse:collapse;background:var(--card);color:var(--text);font-size:13px}.chat-table td{border:1px solid var(--line);padding:8px 10px;white-space:nowrap}.attachment{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:rgba(255,255,255,.12)}.attachment img{max-width:260px;border-radius:12px;display:block}.reactions{margin-top:8px;display:flex;gap:5px;flex-wrap:wrap}.reaction{display:inline-flex;align-items:center;gap:4px;background:rgba(0,0,0,.08);color:var(--text);border-radius:999px;padding:3px 8px;font-size:13px;line-height:1}.reaction small{font-size:11px;opacity:.75}.mine .reaction{background:rgba(255,255,255,.22);color:#fff}.quick-actions{position:absolute;bottom:calc(100% + 6px);left:0;display:flex;gap:2px;align-items:center;padding:4px 6px;background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow);white-space:nowrap;opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease,visibility .15s;z-index:5}.mine .quick-actions{left:auto;right:0}.msg:hover .quick-actions,.msg:focus-within .quick-actions{opacity:1;visibility:visible;transform:translateY(0)}.quick-actions button{background:transparent;color:var(--text);padding:4px 8px;border-radius:999px;font-size:16px;line-height:1;box-shadow:none}.quick-actions button:hover{background:var(--bubble);filter:none;transform:none}@media(hover:none){.quick-actions{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:0;box-shadow:none;padding:0;margin-top:8px;flex-wrap:wrap;gap:6px}}.page-card{margin:24px;flex:1;background:var(--card);border-radius:26px;padding:26px;box-shadow:var(--shadow);overflow:auto}.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;max-width:900px}.check{flex-direction:row;align-items:center}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat,.admin-box{background:var(--bubble);border-radius:18px;padding:18px}.stat strong{font-size:34px;display:block}.stat span{color:var(--muted)}.admin-table{width:100%;border-collapse:collapse;margin-top:16px}.admin-table th,.admin-table td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}.admin-table input,.admin-table select{width:100%}.inline-form,.filter-form{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.mini-reset{display:flex;gap:6px;margin-top:6px}.mini-reset input{max-width:130px}@media(max-width:900px){.main-sidebar{width:78px}.main-sidebar span,.brand small,.brand strong{display:none}.chat-shell{grid-template-columns:1fr}.conversation-panel{display:none}.msg{max-width:95%}.status-picker,.sidebar-user-name{display:none}}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;padding:12px 16px;background:var(--primary);color:#fff;z-index:100;border-radius:12px;box-shadow:var(--shadow)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.search-row{display:flex;gap:8px;align-items:center;min-width:0}.search-mode{flex:0 0 auto;min-width:118px;border-radius:12px;padding:9px 10px}.flex-grow{flex:1;min-width:0;width:0}
.message-search-filters{display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--muted)}.message-search-filters label{display:flex;flex-direction:column;gap:4px;color:var(--muted)}.message-search-filters input[type="date"],.message-search-filters select{width:100%}
.btn-secondary{background:var(--bubble);color:var(--text);border:1px solid var(--line)}.btn-secondary:hover{filter:brightness(.98)}
.btn-danger-outline{background:transparent;color:var(--danger);border:2px solid var(--danger)}.btn-danger-outline:hover{filter:brightness(1.08);transform:translateY(-1px)}
.chat-header-text{display:flex;flex-direction:column;gap:4px;min-width:0}.chat-subtitle{color:var(--muted);font-size:13px}
.chat-header{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:76px;height:auto;padding-top:10px;padding-bottom:10px;gap:14px}
.chat-header-actions{margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:8px}
.btn-chat-admin{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;border-radius:12px}
@media (max-width:540px){.btn-chat-admin-label{display:none}}
.chat-header-lead{display:flex;align-items:center;gap:14px;min-width:0;flex:1}
.chat-header-profile-link{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
  flex:1;
  text-decoration:none;
  color:inherit;
  border-radius:16px;
  padding:4px 8px 4px 4px;
  margin:-4px -8px -4px -4px;
  transition:background .18s ease,box-shadow .18s ease;
}
.chat-header-profile-link--active{cursor:pointer}
.chat-header-profile-link--active:hover{
  background:color-mix(in srgb,var(--bubble) 88%,transparent);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 18%,transparent);
}
.chat-header-profile-link--active:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.chat-header-profile-link--inactive{cursor:default;pointer-events:none}
.chat-header-profile-link .chat-header-text{min-width:0;flex:1}
.chat-header-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;background:linear-gradient(145deg,var(--primary),#22d3ee);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;letter-spacing:.02em;position:relative;overflow:visible;box-shadow:0 4px 18px rgba(0,0,0,.14),0 0 0 2px var(--card),0 0 0 3px color-mix(in srgb,var(--line) 72%,transparent)}
[data-theme="dark"] .chat-header-avatar{box-shadow:0 6px 26px rgba(0,0,0,.45),0 0 0 2px var(--card),0 0 0 3px rgba(255,255,255,.1)}
.chat-header-inner{width:100%;height:100%;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}
.chat-header-inner img{width:100%;height:100%;object-fit:cover;display:block}
.chat-header-avatar--placeholder{background:var(--bubble);color:var(--muted);font-weight:700;box-shadow:none;border:1px dashed var(--line)}
.chat-header-initials{line-height:1;text-align:center;padding:0 2px}
.chat-header-avatar .header-status-dot{position:absolute;right:-1px;bottom:-1px;width:14px;height:14px;border-radius:50%;border:2px solid var(--card);background:#adb5bd;box-sizing:border-box;z-index:3;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.chat-header-avatar .header-status-dot.online{background:#22c55e}
.chat-header-avatar .header-status-dot.status-away{background:#f5b400}
.chat-header-avatar .header-status-dot.status-busy{background:#ef4444}
.chat-header h2{font-size:1.12rem;font-weight:700;letter-spacing:-.02em;line-height:1.25}
.conversation-list{align-content:start;grid-auto-rows:auto}
.conv-item{position:relative}
.conv-item .conv-meta{flex:1;min-width:0}
.conv-item-actions{
  flex-shrink:0;
  margin-left:auto;
  display:flex;
  align-items:center;
  align-self:stretch;
  position:relative;
  z-index:2;
  opacity:0;
  visibility:hidden;
  transition:opacity .16s ease,visibility .16s ease;
}
.conv-item:hover .conv-item-actions,
.conv-item:focus-within .conv-item-actions,
.conv-item.conv-item--menu-open .conv-item-actions{
  opacity:1;
  visibility:visible;
}
@media (hover:none){
  .conv-item-actions{
    opacity:.95;
    visibility:visible;
  }
}
.conv-item-menu-btn{
  width:34px;
  height:34px;
  border-radius:10px;
  display:grid;
  place-items:center;
  padding:0;
  margin:0;
  border:0;
  background:transparent;
  color:var(--muted);
  box-shadow:none;
  cursor:pointer;
  transition:background .14s ease,color .14s ease;
}
.conv-item-menu-btn:hover{
  background:color-mix(in srgb,var(--line) 55%,transparent);
  color:var(--text);
}
.conv-item-menu-btn:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.conv-item.active .conv-item-menu-btn:hover{
  background:color-mix(in srgb,var(--primary) 16%,transparent);
}
.conv-item-menu{
  position:absolute;
  right:0;
  top:calc(100% + 6px);
  min-width:210px;
  padding:6px;
  border-radius:14px;
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  z-index:40;
}
[data-theme="dark"] .conv-item-menu{
  background:#252838;
  border-color:rgba(255,255,255,.1);
  box-shadow:0 14px 40px rgba(0,0,0,.45);
}
.conv-item-menu-i{
  display:block;
  width:100%;
  text-align:left;
  padding:10px 12px;
  border-radius:10px;
  border:0;
  background:transparent;
  color:var(--text);
  font-size:13px;
  font-weight:500;
  cursor:pointer;
  box-shadow:none;
  transition:background .12s ease;
}
.conv-item-menu-i:hover{
  background:var(--bubble);
}
.conv-item-menu-i--danger{
  color:var(--danger);
}
.conv-item-menu-i--danger:hover{
  background:color-mix(in srgb,var(--danger) 12%,transparent);
}
.conv-item.conv-item--menu-open{
  z-index:5;
}
.conv-item .avatar,.msg .avatar{width:42px;height:42px;min-width:42px;min-height:42px;max-width:42px;max-height:42px;flex-shrink:0}
.avatar{overflow:visible;position:relative;display:flex;align-items:center;justify-content:center}
.avatar-inner{width:100%;height:100%;border-radius:50%;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.avatar-inner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.avatar > .dot{z-index:3;width:13px;height:13px;right:-2px;bottom:-2px;border-width:2px;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.typing-bar{flex:none;align-self:flex-start;max-width:min(560px,92%);min-height:0;padding:2px 20px 6px 76px;margin:0;font-size:12px;line-height:1.35;color:var(--muted)}.typing-bar:empty{padding:0;height:0;overflow:hidden;border:0}
.reply-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 20px;background:var(--bubble);border-top:1px solid var(--line);font-size:13px}.reply-banner-preview{color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:560px}.reply-banner-cancel{background:transparent;color:var(--muted);width:auto;height:auto;padding:4px 8px;border-radius:8px}.reply-banner-cancel:hover{color:var(--danger)}
.composer-input-wrap{flex:1;position:relative;min-width:0;display:flex}
.composer-input-wrap textarea{width:100%}
.composer-attach-preview{
  flex:none;
  align-self:stretch;
  display:flex;
  align-items:center;
  gap:12px;
  margin:0 20px 6px;
  padding:10px 14px;
  border-radius:14px;
  background:var(--bubble);
  border:1px solid var(--line);
  font-size:13px;
  min-height:0;
}
.composer-attach-preview.hidden{display:none!important}
.composer-attach-thumb{
  flex:none;
  width:44px;
  height:44px;
  border-radius:10px;
  overflow:hidden;
  background:var(--card);
  display:grid;
  place-items:center;
}
.composer-attach-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.composer-attach-thumb--doc{
  background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 22%,var(--bubble)),var(--bubble));
  color:var(--primary);
  font-size:1.2rem;
}
.composer-attach-meta{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.composer-attach-name{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.composer-attach-size{font-size:12px;color:var(--muted)}
.composer-attach-clear{
  flex:none;
  width:38px;
  height:38px;
  border-radius:10px;
  padding:0;
  display:grid;
  place-items:center;
  background:transparent;
  color:var(--muted);
  box-shadow:none;
}
.composer-attach-clear:hover{
  background:color-mix(in srgb,var(--danger) 12%,transparent);
  color:var(--danger);
  filter:none;
  transform:none;
}
.mention-suggest{position:absolute;left:0;right:0;bottom:calc(100% + 6px);background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);max-height:220px;overflow:auto;z-index:8;display:flex;flex-direction:column;padding:6px;gap:4px}.mention-suggest button{text-align:left;background:var(--bubble);color:var(--text);border-radius:10px;padding:8px 10px;width:100%;height:auto;box-shadow:none;justify-content:flex-start;font-size:13px}.mention-suggest button:hover,.mention-suggest button.active{background:var(--line)}.mention-suggest button small{color:var(--muted);margin-left:6px}
.msg-reply-quote{display:block;width:100%;text-align:left;background:rgba(0,0,0,.06);border-left:3px solid var(--primary);border-radius:10px;padding:8px 10px;margin:0 0 8px;font:inherit;color:inherit;cursor:pointer}.mine .msg-reply-quote{background:rgba(255,255,255,.18);border-left-color:rgba(255,255,255,.85)}.rq-author{display:block;font-weight:600;font-size:12px;margin-bottom:2px}.rq-snippet{display:block;font-size:12px;color:var(--muted)}.mine .rq-snippet{color:rgba(255,255,255,.85)}
.mention{color:var(--primary);font-weight:600}.mine .mention{color:#fff;text-decoration:underline;text-underline-offset:2px}
.msg-highlight{outline:2px solid var(--primary);outline-offset:2px;border-radius:14px}
.hit-snippet{display:block;margin-top:6px;color:var(--text);white-space:normal;line-height:1.35}
.search-hit{align-items:flex-start}
.messages .empty-msg{color:var(--muted)}
.chat-shell .notify-permission-bar{grid-column:1/-1;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 22%,var(--card)),var(--card));border-bottom:1px solid var(--line)}
.notify-permission-bar-text{margin:0;font-size:14px;color:var(--text);max-width:52rem;line-height:1.4}
.notify-permission-bar-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.notify-permission-bar.hidden{display:none!important}

.perfil-page{position:relative;isolation:isolate;width:100%;max-width:none;margin-inline:0}
.perfil-page::before{
  content:"";
  position:absolute;inset:-1px 0 auto 0;height:min(220px,28vh);
  border-radius:inherit;
  background:
    radial-gradient(ellipse 90% 80% at 12% -20%,color-mix(in srgb,var(--primary) 28%,transparent),transparent 55%),
    radial-gradient(ellipse 70% 50% at 88% 0%,color-mix(in srgb,#22d3ee 22%,transparent),transparent 50%),
    linear-gradient(180deg,color-mix(in srgb,var(--bubble) 55%,var(--card)) 0%,var(--card) 100%);
  pointer-events:none;z-index:0
}
.perfil-page__top,.perfil-form{position:relative;z-index:1}
main.page-card.perfil-page{
  flex:1;
  min-width:0;
  width:100%;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  margin:16px 12px;
  padding-top:18px;
  padding-bottom:16px
}
.perfil-page__top{flex-shrink:0}
.perfil-form{
  flex:1;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-gutter:stable;
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-top:4px;
  width:100%;
  max-width:none
}
@media (min-width:1180px) and (min-height:680px){
  .perfil-form{
    display:grid;
    grid-template-columns:1fr 1fr;
    column-gap:14px;
    row-gap:12px;
    align-content:start
  }
  .perfil-panel--id,.perfil-panel--dir,.perfil-panel--notify,.perfil-actions{grid-column:1/-1}
  .perfil-panel--look{grid-column:1}
  .perfil-panel--media{grid-column:2}
}
.perfil-hero{padding:2px 0 12px;margin-bottom:2px;border-bottom:1px solid color-mix(in srgb,var(--line) 88%,var(--primary) 12%)}
.perfil-eyebrow{
  margin:0 0 6px;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:var(--muted)
}
.perfil-page h1{margin:0 0 4px;font-size:clamp(1.45rem,2.2vw,1.85rem);font-weight:800;letter-spacing:-.03em;line-height:1.15}
.perfil-lead{margin:0;font-size:14px;line-height:1.45;max-width:min(52rem,100%)}
.perfil-flash{margin-top:8px}
.perfil-panel{
  padding:14px 16px;border-radius:18px;
  background:linear-gradient(155deg,color-mix(in srgb,var(--card) 94%,var(--primary) 6%),var(--card));
  border:1px solid color-mix(in srgb,var(--line) 92%,var(--primary) 8%);
  box-shadow:0 1px 0 rgba(255,255,255,.45) inset,0 12px 36px color-mix(in srgb,var(--primary) 6%,transparent)
}
[data-theme="dark"] .perfil-panel{
  background:linear-gradient(155deg,color-mix(in srgb,var(--card) 96%,var(--primary) 4%),var(--card));
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset,0 14px 40px rgba(0,0,0,.28)
}
.perfil-panel__title{
  margin:0 0 6px;font-size:14px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:12px;color:var(--text)
}
.perfil-panel__accent{
  width:4px;height:1.15em;border-radius:4px;flex-shrink:0;
  background:linear-gradient(180deg,var(--primary),#22d3ee);
  box-shadow:0 0 16px color-mix(in srgb,var(--primary) 45%,transparent)
}
.perfil-panel__hint{margin:0 0 10px;font-size:12px;line-height:1.4;max-width:min(56rem,100%)}
.perfil-panel__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,200px),1fr));gap:12px 14px}
.perfil-panel__grid--1{grid-template-columns:1fr}
.perfil-field--full{grid-column:1/-1}
.perfil-page textarea.perfil-bio{min-height:3.75rem;max-height:min(28vh,200px);resize:vertical;line-height:1.4}
.perfil-page .perfil-field input,.perfil-page .perfil-field select,.perfil-page .perfil-field textarea{
  transition:border-color .15s ease,box-shadow .15s ease,background .15s ease
}
.perfil-page .perfil-field input:focus,.perfil-page .perfil-field select:focus,.perfil-page .perfil-field textarea:focus{
  border-color:color-mix(in srgb,var(--primary) 45%,var(--line));
  box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)
}
.perfil-page .perfil-avatar-help{display:block;margin:0 0 10px;font-size:12px}
.perfil-page .perfil-avatar-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}
.perfil-page .perfil-avatar-hint{font-size:13px;flex:1;min-width:200px;line-height:1.4}
.perfil-avatar-btn{font-weight:600;border-radius:14px;padding:11px 18px}
.perfil-panel--notify .perfil-panel__title{margin-bottom:10px}
.perfil-notify-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:8px}
.perfil-chip.check{
  flex-direction:row;align-items:center;gap:10px;margin:0;padding:10px 12px;border-radius:14px;cursor:pointer;
  border:1px solid var(--line);background:color-mix(in srgb,var(--bubble) 65%,var(--card));
  font-size:14px;color:var(--text);font-weight:500;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease
}
.perfil-chip.check span{line-height:1.35}
.perfil-chip.check:has(input:checked){
  border-color:color-mix(in srgb,var(--primary) 38%,var(--line));
  background:color-mix(in srgb,var(--primary) 10%,var(--card));
  box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 18%,transparent)
}
.perfil-chip.check input{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.perfil-actions{margin-top:0;padding-top:2px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.perfil-save{
  min-width:min(100%,260px);padding:12px 24px;border-radius:14px;font-weight:700;font-size:14px;
  box-shadow:0 8px 28px color-mix(in srgb,var(--primary) 35%,transparent),inset 0 1px 0 rgba(255,255,255,.2)
}
.perfil-save:hover{transform:translateY(-2px);filter:brightness(1.06)}
@media (max-width:540px){
  .perfil-hero{padding-bottom:18px}
  .perfil-panel{padding:16px 18px}
}

/* Lembrete global de perfil incompleto (sidebar) */
.profile-nudge{
  position:relative;
  margin:10px 10px 6px;
  padding:14px 14px 16px;
  border-radius:20px;
  overflow:hidden;
  isolation:isolate;
  background:linear-gradient(145deg,color-mix(in srgb,var(--card) 88%,#fce4ff 12%),color-mix(in srgb,var(--bubble) 75%,var(--card)));
  border:1px solid color-mix(in srgb,var(--primary) 28%,var(--line));
  box-shadow:
    0 0 0 1px rgba(255,255,255,.5) inset,
    0 12px 32px color-mix(in srgb,var(--primary) 18%,transparent),
    0 4px 16px rgba(0,0,0,.06);
  animation:profile-nudge-in .55s cubic-bezier(.34,1.56,.64,1) both;
  max-width:100%;
}
[data-theme="dark"] .profile-nudge{
  background:linear-gradient(145deg,color-mix(in srgb,var(--card) 92%,var(--primary) 8%),var(--card));
  box-shadow:0 0 0 1px rgba(255,255,255,.06) inset,0 14px 36px rgba(0,0,0,.35);
}
.profile-nudge__shine{
  position:absolute;inset:-40% -20% auto -20%;height:120%;
  background:conic-gradient(from 120deg at 50% 0%,transparent 0deg,color-mix(in srgb,var(--primary) 25%,transparent) 40deg,transparent 70deg,transparent 360deg);
  opacity:.55;animation:profile-nudge-shimmer 8s linear infinite;pointer-events:none
}
.profile-nudge__close{
  position:absolute;top:8px;right:8px;width:32px;height:32px;padding:0;margin:0;
  display:grid;place-items:center;border-radius:10px;font-size:20px;line-height:1;
  background:color-mix(in srgb,var(--bubble) 80%,transparent)!important;
  color:var(--muted)!important;border:1px solid var(--line)!important;cursor:pointer;z-index:2;
  box-shadow:none!important;transition:background .15s ease,color .15s ease,transform .15s ease;
  filter:none!important
}
.profile-nudge__close:hover{background:var(--bubble)!important;color:var(--text)!important;transform:scale(1.06);filter:none!important}
.profile-nudge.profile-nudge--hidden{display:none!important}
.profile-nudge__head{display:flex;align-items:center;gap:8px;margin-bottom:8px;position:relative;z-index:1}
.profile-nudge__emoji{font-size:1.35rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.12))}
.profile-nudge__title{margin:0;font-size:14px;font-weight:800;letter-spacing:-.02em;color:var(--text);line-height:1.25}
.profile-nudge__lead{margin:0 0 10px;font-size:13px;line-height:1.45;color:var(--text);position:relative;z-index:1}
.profile-nudge__missing-label{margin:0 0 6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;position:relative;z-index:1}
.profile-nudge__chips{
  list-style:none;margin:0 0 12px;padding:0;display:flex;flex-wrap:wrap;gap:6px;
  position:relative;z-index:1
}
.profile-nudge__chips li{
  font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px;
  background:color-mix(in srgb,var(--primary) 14%,var(--card));
  color:color-mix(in srgb,var(--primary) 92%,var(--text));
  border:1px solid color-mix(in srgb,var(--primary) 22%,var(--line))
}
.profile-nudge__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:10px 14px;border-radius:14px;font-size:13px;font-weight:700;text-decoration:none;
  background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 65%,#22d3ee))!important;
  color:#fff!important;border:none!important;position:relative;z-index:1;
  box-shadow:0 6px 20px color-mix(in srgb,var(--primary) 38%,transparent),inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .18s ease,filter .18s ease,box-shadow .18s ease;
  filter:none!important
}
.profile-nudge__cta:hover{transform:translateY(-2px);filter:brightness(1.06)!important}
.profile-nudge--dismissed{animation:profile-nudge-out .42s ease forwards}
@keyframes profile-nudge-in{
  from{opacity:0;transform:translateY(12px) scale(.94)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes profile-nudge-out{
  to{opacity:0;transform:translateY(8px) scale(.96)}
}
@keyframes profile-nudge-shimmer{
  to{transform:rotate(360deg)}
}
@media (max-width:900px){
  .main-sidebar .profile-nudge{
    position:fixed;
    left:88px;
    right:12px;
    bottom:12px;
    width:auto;
    max-width:min(320px,calc(100vw - 104px));
    margin:0;
    z-index:45;
    animation:profile-nudge-in-mobile .5s cubic-bezier(.34,1.56,.64,1) both
  }
  @keyframes profile-nudge-in-mobile{
    from{opacity:0;transform:translateY(20px) scale(.94)}
    to{opacity:1;transform:translateY(0) scale(1)}
  }
}

/* Perfil incompleto: overlay após 3 dispensas do lembrete (4.ª vez = bloqueio) */
body.profile-nudge-fs-open{overflow:hidden}
.profile-nudge-fs{
  position:fixed;inset:0;z-index:10050;display:flex;align-items:center;justify-content:center;padding:20px 16px;
  box-sizing:border-box
}
.profile-nudge-fs.hidden{display:none!important}
.profile-nudge-fs__backdrop{
  position:absolute;inset:0;background:color-mix(in srgb,var(--bg) 55%,#0f172a);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)
}
.profile-nudge-fs__card{
  position:relative;z-index:1;
  width:100%;min-width:0;max-width:min(420px,calc(100vw - 40px));
  max-height:min(90vh,640px);
  overflow-x:hidden;overflow-y:auto;
  overscroll-behavior:contain;
  scrollbar-width:thin;
  scrollbar-color:color-mix(in srgb,var(--muted) 55%,transparent) transparent;
  padding:28px 22px 26px;border-radius:24px;
  background:linear-gradient(165deg,color-mix(in srgb,var(--card) 90%,#fce4ff 10%),var(--card));
  border:1px solid color-mix(in srgb,var(--primary) 32%,var(--line));
  box-shadow:
    0 0 0 1px rgba(255,255,255,.45) inset,
    0 24px 64px color-mix(in srgb,var(--primary) 22%,transparent),
    0 12px 40px rgba(0,0,0,.12);
  isolation:isolate
}
.profile-nudge-fs__card::-webkit-scrollbar{width:8px;height:0}
.profile-nudge-fs__card::-webkit-scrollbar-track{background:transparent}
.profile-nudge-fs__card::-webkit-scrollbar-thumb{
  background:color-mix(in srgb,var(--muted) 50%,transparent);border-radius:999px;border:2px solid transparent;background-clip:padding-box
}
.profile-nudge-fs__card::-webkit-scrollbar-thumb:hover{
  background:color-mix(in srgb,var(--muted) 70%,transparent);background-clip:padding-box
}
[data-theme="dark"] .profile-nudge-fs__card{
  background:linear-gradient(165deg,color-mix(in srgb,var(--card) 94%,var(--primary) 6%),var(--card));
  box-shadow:0 0 0 1px rgba(255,255,255,.06) inset,0 28px 72px rgba(0,0,0,.45);
  scrollbar-color:rgba(255,255,255,.22) transparent
}
[data-theme="dark"] .profile-nudge-fs__card::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,.22);background-clip:padding-box
}
[data-theme="dark"] .profile-nudge-fs__card::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.32);background-clip:padding-box}
.profile-nudge-fs__shine{
  position:absolute;left:0;right:0;top:0;height:52%;pointer-events:none;opacity:.4;border-radius:24px 24px 0 0;overflow:hidden;
  background:conic-gradient(from 100deg at 50% 0%,transparent 0deg,color-mix(in srgb,var(--primary) 22%,transparent) 45deg,transparent 75deg,transparent 360deg);
  animation:profile-nudge-shimmer 10s linear infinite
}
.profile-nudge-fs__icon{font-size:2.25rem;line-height:1;text-align:center;margin-bottom:10px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}
.profile-nudge-fs__title{margin:0 0 8px;font-size:1.35rem;font-weight:800;letter-spacing:-.03em;color:var(--text);text-align:center;line-height:1.2;overflow-wrap:break-word}
.profile-nudge-fs__lead{margin:0 0 12px;font-size:15px;line-height:1.5;color:var(--text);text-align:center;overflow-wrap:break-word}
.profile-nudge-fs__hint{margin:0 0 16px;font-size:13px;line-height:1.45;text-align:center;overflow-wrap:break-word}
.profile-nudge-fs__missing-label{margin:0 0 8px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;text-align:center}
.profile-nudge-fs__chips{
  list-style:none;margin:0 0 20px;padding:0;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:100%
}
.profile-nudge-fs__chips li{
  font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;
  background:color-mix(in srgb,var(--primary) 16%,var(--card));
  color:color-mix(in srgb,var(--primary) 90%,var(--text));
  border:1px solid color-mix(in srgb,var(--primary) 26%,var(--line))
}
.profile-nudge-fs__cta{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 18px;border-radius:16px;
  font-size:15px;font-weight:800;text-decoration:none;text-align:center;
  background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 62%,#22d3ee))!important;
  color:#fff!important;border:none!important;
  box-shadow:0 10px 32px color-mix(in srgb,var(--primary) 42%,transparent),inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .18s ease,filter .18s ease
}
.profile-nudge-fs__cta:hover{transform:translateY(-2px);filter:brightness(1.06)!important}

.avatar-crop-modal-card{width:min(560px,96vw);max-height:min(92vh,720px)}
.avatar-crop-wrap{max-height:min(58vh,480px);background:var(--bubble);border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.avatar-crop-wrap img{display:block;max-width:100%}
.avatar-crop-zoom-hint{margin:10px 20px 0;font-size:13px}
.avatar-crop-modal-card .modal-head{border-bottom:1px solid var(--line)}
.avatar-crop-modal-card .modal-actions{border-top:1px solid var(--line);margin-top:14px;padding-top:14px}

.conversation-panel.groups-mode #searchMode{display:none}
.conv-empty{padding:20px 14px;color:var(--muted);font-size:14px;line-height:1.5}.conv-empty p{margin:0 0 8px}
.conv-item-group .avatar{background:linear-gradient(135deg,#22d3ee,var(--primary))}

.modal-card.group-admin-modal{width:min(520px,96vw);max-height:min(90vh,760px)}
.group-admin-section-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:16px 0 8px;font-weight:600}
.group-admin-section-title:first-child{margin-top:0}
.group-admin-member-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.group-admin-member{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--bg);border-radius:12px;border:1px solid var(--line)}
.group-admin-member-main{display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-width:0}
.group-admin-member-main strong{font-size:14px}
.role-badge{font-size:11px;padding:3px 8px;border-radius:999px;background:var(--bubble);color:var(--muted);white-space:nowrap}
.role-badge.role-owner{background:rgba(91,75,255,.15);color:var(--primary)}
.role-badge.role-admin{background:rgba(34,211,238,.12);color:#0e7490}
.group-admin-member-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.group-admin-member-actions .group-admin-act{background:none;border:none;color:var(--primary);cursor:pointer;padding:4px 8px;font-size:13px;border-radius:8px;font-weight:600}
.group-admin-member-actions .group-admin-act:hover{text-decoration:underline}
.group-admin-member-actions .group-admin-act.danger{color:var(--danger)}

.modal-overlay{position:fixed;inset:0;background:rgba(15,18,32,.55);display:grid;place-items:center;z-index:50;padding:20px}.modal-overlay.hidden{display:none!important}
.modal-card{width:min(480px,100%);max-height:min(86vh,720px);background:var(--card);color:var(--text);border-radius:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--line)}
.welcome-popup-overlay{z-index:85;background:rgba(18,20,38,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.welcome-popup-card{width:min(440px,calc(100vw - 40px));max-height:none;border-radius:26px;border:1px solid color-mix(in srgb,var(--primary) 30%,var(--line));box-shadow:0 22px 60px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.1) inset,0 0 48px color-mix(in srgb,var(--primary) 18%,transparent);background:linear-gradient(168deg,color-mix(in srgb,var(--card) 88%,var(--bubble)),var(--card));overflow:visible}
[data-theme="dark"] .welcome-popup-card{box-shadow:0 24px 64px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06) inset,0 0 36px color-mix(in srgb,var(--primary) 22%,transparent)}
.welcome-popup-inner{padding:26px 24px 30px;text-align:center}
.welcome-popup-icon{font-size:2.85rem;line-height:1;margin-bottom:10px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.18))}
.welcome-popup-title{margin:0 0 12px;font-size:1.38rem;font-weight:800;letter-spacing:-.03em;line-height:1.22;color:var(--text)}
.welcome-popup-body{margin:0 0 22px;font-size:15px;line-height:1.55;color:var(--text);text-align:left;word-break:break-word}
.welcome-popup-body a{color:var(--primary);font-weight:600}
.welcome-popup-cta{
  width:100%;padding:14px 20px;border-radius:17px;font-size:16px;font-weight:800;letter-spacing:.015em;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 72%,#22d3ee));
  color:#fff!important;box-shadow:0 10px 28px color-mix(in srgb,var(--primary) 42%,transparent),inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .2s ease,filter .2s ease;filter:none!important
}
.welcome-popup-cta:hover{transform:translateY(-2px) scale(1.01);filter:brightness(1.07)!important}
.welcome-popup-cta:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 55%,transparent);outline-offset:2px}
.welcome-popup-overlay .welcome-popup-card{animation:welcome-popup-pop .52s cubic-bezier(.34,1.56,.64,1) both}
@keyframes welcome-popup-pop{
  from{opacity:0;transform:translateY(22px) scale(.94)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}.modal-head h2{margin:0;font-size:1.15rem}
.modal-close{background:transparent;color:var(--muted);width:40px;height:40px;padding:0;border-radius:12px;font-size:22px;line-height:1}.modal-close:hover{color:var(--text);background:var(--bubble)}
.modal-body{padding:18px 20px;display:flex;flex-direction:column;gap:14px;overflow:auto}.modal-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.modal-field input,.modal-field textarea{width:100%}
.modal-hint{font-size:12px;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;flex-wrap:wrap}
.user-pick-list{max-height:240px;overflow:auto;border:1px solid var(--line);border-radius:14px;padding:8px;display:flex;flex-direction:column;gap:4px;background:var(--bg)}
.user-pick-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:12px;cursor:pointer;font-size:13px;color:var(--text)}.user-pick-row:hover{background:var(--bubble)}.user-pick-row input{margin-top:3px;flex:none}.user-pick-row span{font-weight:600;display:block}.user-pick-row small{display:block;color:var(--muted);font-weight:400;margin-top:2px}.user-pick-row.hidden-pick{display:none}
.user-pick-loading{margin:12px;text-align:center}

/* Barra de reações / responder — visual próximo ao Teams */
@keyframes qa-emoji-pop{
  from{opacity:0;transform:translateY(10px) scale(.62)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.message-panel .messages{
  padding-top:52px;
  padding-bottom:max(24px,calc(12px + env(safe-area-inset-bottom,0px)));
  overflow-x:hidden;
  scroll-padding-bottom:28px;
}
.bubble{
  overflow:visible;
  position:relative;
  flex:0 1 auto;
  width:fit-content;
  max-width:100%;
  min-width:0;
}
.bubble::after{
  content:'';
  position:absolute;
  left:-18px;
  right:-18px;
  bottom:calc(100% - 6px);
  height:56px;
  z-index:7;
  pointer-events:auto;
}
.quick-actions{
  position:absolute;
  bottom:calc(100% - 6px);
  left:0;
  display:flex;
  align-items:center;
  flex-wrap:nowrap;
  gap:1px;
  padding:5px 6px 5px 8px;
  z-index:15;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(18px) scale(.91);
  transition:
    opacity .24s cubic-bezier(.16,1,.3,1),
    transform .32s cubic-bezier(.16,1,.3,1),
    visibility .32s;
  background:color-mix(in srgb,var(--card) 78%,transparent);
  backdrop-filter:blur(18px) saturate(1.45);
  -webkit-backdrop-filter:blur(18px) saturate(1.45);
  border:1px solid color-mix(in srgb,var(--line) 55%,transparent);
  border-radius:999px;
  box-shadow:
    0 12px 40px rgba(0,0,0,.12),
    0 4px 14px rgba(0,0,0,.06),
    inset 0 1px 0 rgba(255,255,255,.25);
}
[data-theme="dark"] .quick-actions{
  background:rgba(24,26,40,.82);
  border-color:rgba(255,255,255,.12);
  box-shadow:
    0 14px 44px rgba(0,0,0,.5),
    0 0 0 1px rgba(255,255,255,.04) inset,
    inset 0 1px 0 rgba(255,255,255,.08);
}
.mine .quick-actions{
  left:auto;
  right:0;
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.28);
  box-shadow:
    0 14px 36px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.22);
}
.msg:hover .quick-actions,
.msg:focus-within .quick-actions,
.msg.msg-actions-hover .quick-actions{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}
.msg:hover .quick-actions .qa-react,
.msg:focus-within .quick-actions .qa-react,
.msg.msg-actions-hover .quick-actions .qa-react{
  animation:qa-emoji-pop .44s cubic-bezier(.34,1.45,.64,1) backwards;
}
.msg:hover .quick-actions .qa-react:nth-child(1),
.msg:focus-within .quick-actions .qa-react:nth-child(1),
.msg.msg-actions-hover .quick-actions .qa-react:nth-child(1){animation-delay:.03s}
.msg:hover .quick-actions .qa-react:nth-child(2),
.msg:focus-within .quick-actions .qa-react:nth-child(2),
.msg.msg-actions-hover .quick-actions .qa-react:nth-child(2){animation-delay:.06s}
.msg:hover .quick-actions .qa-react:nth-child(3),
.msg:focus-within .quick-actions .qa-react:nth-child(3),
.msg.msg-actions-hover .quick-actions .qa-react:nth-child(3){animation-delay:.09s}
.msg:hover .quick-actions .qa-react:nth-child(4),
.msg:focus-within .quick-actions .qa-react:nth-child(4),
.msg.msg-actions-hover .quick-actions .qa-react:nth-child(4){animation-delay:.12s}
.msg:hover .quick-actions .qa-react:nth-child(5),
.msg:focus-within .quick-actions .qa-react:nth-child(5),
.msg.msg-actions-hover .quick-actions .qa-react:nth-child(5){animation-delay:.15s}
.msg:hover .quick-actions .qa-react:nth-child(6),
.msg:focus-within .quick-actions .qa-react:nth-child(6),
.msg.msg-actions-hover .quick-actions .qa-react:nth-child(6){animation-delay:.18s}
.msg:hover .quick-actions .qa-reply,
.msg:focus-within .quick-actions .qa-reply,
.msg.msg-actions-hover .quick-actions .qa-reply{
  animation:qa-emoji-pop .38s cubic-bezier(.34,1.45,.64,1) .14s backwards;
}
.msg:hover .quick-actions .qa-secondary,
.msg:focus-within .quick-actions .qa-secondary,
.msg.msg-actions-hover .quick-actions .qa-secondary{
  animation:qa-emoji-pop .34s cubic-bezier(.34,1.45,.64,1) .18s backwards;
}
.quick-actions .qa-react{
  width:38px;
  height:38px;
  padding:0;
  margin:0;
  display:grid;
  place-items:center;
  border-radius:50%;
  font-size:1.2rem;
  line-height:1;
  background:transparent!important;
  color:inherit!important;
  border:none!important;
  box-shadow:none!important;
  cursor:pointer;
  transition:transform .22s cubic-bezier(.34,1.56,.64,1),background .18s ease;
  filter:none!important;
}
.quick-actions .qa-react:hover{
  transform:scale(1.2);
  background:color-mix(in srgb,var(--primary) 16%,transparent)!important;
}
.quick-actions .qa-react:active{
  transform:scale(1.06);
}
.mine .quick-actions .qa-react:hover{
  background:rgba(255,255,255,.28)!important;
}
.quick-actions .qa-reply{
  position:relative;
  margin-left:8px;
  padding:8px 16px 8px 18px!important;
  border-radius:999px!important;
  border:none!important;
  font-size:12px!important;
  font-weight:600!important;
  letter-spacing:.02em;
  color:var(--primary)!important;
  background:transparent!important;
  box-shadow:none!important;
  cursor:pointer;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),background .18s ease,color .15s ease;
  filter:none!important;
}
.quick-actions .qa-reply::before{
  content:'';
  position:absolute;
  left:4px;
  top:50%;
  transform:translateY(-50%);
  width:1px;
  height:22px;
  border-radius:1px;
  background:color-mix(in srgb,var(--line) 80%,transparent);
  opacity:.95;
}
.mine .quick-actions .qa-reply::before{
  background:rgba(255,255,255,.35);
}
.mine .quick-actions .qa-reply{
  color:#fff!important;
}
.quick-actions .qa-reply:hover{
  transform:translateY(-2px);
  background:color-mix(in srgb,var(--primary) 14%,transparent)!important;
}
.mine .quick-actions .qa-reply:hover{
  background:rgba(255,255,255,.26)!important;
}
.quick-actions .qa-secondary{
  font-size:11px!important;
  font-weight:600!important;
  padding:8px 12px!important;
  border-radius:999px!important;
  margin-left:2px;
  color:var(--muted)!important;
  background:transparent!important;
  border:none!important;
  box-shadow:none!important;
  cursor:pointer;
  transition:color .15s ease,background .15s ease,transform .18s ease!important;
  filter:none!important;
}
.quick-actions .qa-secondary:hover{
  color:var(--text)!important;
  background:color-mix(in srgb,var(--bubble) 85%,transparent)!important;
  transform:translateY(-1px)!important;
}
.mine .quick-actions .qa-secondary{
  color:rgba(255,255,255,.88)!important;
}
.mine .quick-actions .qa-secondary:hover{
  background:rgba(255,255,255,.22)!important;
  color:#fff!important;
}
@media (prefers-reduced-motion:reduce){
  .quick-actions .qa-react,
  .quick-actions .qa-reply,
  .quick-actions .qa-secondary,
  .msg:hover .quick-actions .qa-react,
  .msg:focus-within .quick-actions .qa-react,
  .msg.msg-actions-hover .quick-actions .qa-react,
  .msg:hover .quick-actions .qa-reply,
  .msg:focus-within .quick-actions .qa-reply,
  .msg.msg-actions-hover .quick-actions .qa-reply,
  .msg:hover .quick-actions .qa-secondary,
  .msg:focus-within .quick-actions .qa-secondary,
  .msg.msg-actions-hover .quick-actions .qa-secondary{
    animation:none!important;
  }
  .quick-actions{
    transition-duration:.08s!important;
  }
}
@media (hover:none){
  .bubble::after{display:none}
  .quick-actions{
    position:static;
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:none;
    margin-top:10px;
    flex-wrap:wrap;
    gap:6px;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:var(--bubble);
    border:1px solid var(--line);
    box-shadow:0 4px 14px rgba(0,0,0,.06);
    justify-content:flex-start;
  }
  .mine .quick-actions{
    background:rgba(255,255,255,.14);
    border-color:rgba(255,255,255,.2);
  }
  .quick-actions .qa-reply::before{display:none}
  .quick-actions .qa-reply{margin-left:4px;padding-left:14px!important}
  .msg:hover .quick-actions .qa-react,
  .msg:focus-within .quick-actions .qa-react,
  .msg.msg-actions-hover .quick-actions .qa-react,
  .msg:hover .quick-actions .qa-reply,
  .msg:focus-within .quick-actions .qa-reply,
  .msg.msg-actions-hover .quick-actions .qa-reply,
  .msg:hover .quick-actions .qa-secondary,
  .msg:focus-within .quick-actions .qa-secondary,
  .msg.msg-actions-hover .quick-actions .qa-secondary{
    animation:none;
  }
}

/* Textos muito longos (sem espaços): não estourar a bolha nem o painel */
.msg{
  min-width:0;
}
.msg-head{
  min-width:0;
}
.msg-body{
  overflow-wrap:anywhere;
  word-break:break-word;
  max-width:100%;
}
.bubble .attachment-card{
  min-width:0;
  max-width:100%;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.bubble .attachment-card img{
  max-width:100%;
  height:auto;
}
.bubble .table-wrap{
  max-width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.msg-reply-quote .rq-snippet{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* Anexo — cartão estilo Teams */
.attachment-card{
  max-width:min(300px,100%);
  margin-top:4px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid color-mix(in srgb,var(--line) 65%,transparent);
  background:color-mix(in srgb,var(--card) 88%,var(--bubble));
  box-shadow:0 4px 20px rgba(0,0,0,.07);
}
[data-theme="dark"] .msg:not(.mine) .attachment-card{
  background:rgba(26,28,42,.92);
  border-color:rgba(255,255,255,.1);
  box-shadow:0 8px 28px rgba(0,0,0,.35);
}
.msg.mine .attachment-card{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.26);
  box-shadow:0 8px 28px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.12);
}
.attachment-preview-hit{
  display:block;
  text-decoration:none;
  color:inherit;
  outline:none;
}
.attachment-preview-hit:focus-visible .attachment-preview-frame{
  outline:2px solid var(--primary);
  outline-offset:-2px;
}
.attachment-preview-frame{
  display:flex;
  align-items:center;
  justify-content:center;
  max-height:200px;
  min-height:120px;
  background:rgba(0,0,0,.2);
}
[data-theme="dark"] .msg:not(.mine) .attachment-preview-frame{
  background:rgba(0,0,0,.35);
}
.msg.mine .attachment-preview-frame{
  background:rgba(0,0,0,.18);
}
.attachment-preview-frame img{
  max-width:100%;
  max-height:200px;
  width:auto;
  height:auto;
  object-fit:contain;
  vertical-align:middle;
}
.attachment-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:88px;
  font-size:36px;
  opacity:.85;
  background:color-mix(in srgb,var(--bubble) 70%,transparent);
}
[data-theme="dark"] .msg:not(.mine) .attachment-placeholder{
  background:rgba(0,0,0,.25);
}
.msg.mine .attachment-placeholder{
  background:rgba(0,0,0,.15);
  color:rgba(255,255,255,.9);
}
.attachment-card-body{
  padding:12px 14px 12px;
}
.attachment-file-row{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.attachment-file-ico{
  flex:none;
  width:40px;
  height:40px;
  border-radius:12px;
  display:grid;
  place-items:center;
  font-size:18px;
  background:color-mix(in srgb,var(--primary) 14%,transparent);
  color:var(--primary);
}
.msg.mine .attachment-file-ico{
  background:rgba(255,255,255,.22);
  color:#fff;
}
.attachment-file-text{
  min-width:0;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.attachment-filename{
  font-weight:600;
  font-size:14px;
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.attachment-filemeta{
  font-size:12px;
  color:var(--muted);
}
.msg.mine .attachment-filemeta{
  color:rgba(255,255,255,.78);
}
.attachment-actions{
  display:flex;
  gap:8px;
  margin-top:12px;
}
.attachment-action{
  flex:1;
  text-align:center;
  padding:9px 12px;
  border-radius:10px;
  font-size:12px;
  font-weight:600;
  text-decoration:none;
  color:var(--text);
  background:color-mix(in srgb,var(--bubble) 92%,transparent);
  border:1px solid color-mix(in srgb,var(--line) 55%,transparent);
  transition:background .15s ease,transform .12s ease;
}
.attachment-action:hover{
  background:color-mix(in srgb,var(--primary) 12%,var(--bubble));
  transform:translateY(-1px);
}
.msg.mine .attachment-action{
  color:rgba(255,255,255,.95);
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.28);
}
.msg.mine .attachment-action:hover{
  background:rgba(255,255,255,.28);
}
.attachment-action-strong{
  background:color-mix(in srgb,var(--primary) 18%,var(--card));
  border-color:color-mix(in srgb,var(--primary) 35%,transparent);
  color:var(--primary);
}
[data-theme="dark"] .attachment-action-strong{
  color:#e8e6ff;
}
.msg.mine .attachment-action-strong{
  background:rgba(255,255,255,.92);
  border-color:transparent;
  color:var(--mine)!important;
}
.msg.mine .attachment-action-strong:hover{
  background:#fff;
  filter:brightness(1.03);
}
button.attachment-action{
  cursor:pointer;
  font:inherit;
}
button.attachment-preview-hit{
  display:block;
  width:100%;
  padding:0;
  margin:0;
  border:0;
  background:transparent;
  cursor:zoom-in;
  font:inherit;
  color:inherit;
  text-align:left;
  border-radius:0;
}

/* Pré-visualização de links (URL + thumb OG) */
.msg-body .link-unfurl{
  display:block;
  max-width:min(320px,100%);
  margin-top:6px;
  text-decoration:none;
  color:inherit;
  border-radius:14px;
  overflow:hidden;
  border:1px solid color-mix(in srgb,var(--line) 65%,transparent);
  background:color-mix(in srgb,var(--card) 88%,var(--bubble));
  box-shadow:0 4px 18px rgba(0,0,0,.08);
  outline:none;
  transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease;
}
.msg-body .link-unfurl:first-child{margin-top:0}
.msg-body .link-unfurl:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 22px rgba(0,0,0,.12);
}
.msg-body .link-unfurl:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
[data-theme="dark"] .msg:not(.mine) .link-unfurl{
  background:rgba(26,28,42,.92);
  border-color:rgba(255,255,255,.1);
  box-shadow:0 8px 26px rgba(0,0,0,.35);
}
.msg.mine .link-unfurl{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.26);
  box-shadow:0 6px 22px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.1);
}
.msg.mine .link-unfurl:hover{
  background:rgba(255,255,255,.2);
}
.link-unfurl-hit{
  display:flex;
  align-items:stretch;
  gap:0;
  min-height:72px;
}
.link-unfurl-thumb{
  flex:none;
  width:108px;
  min-height:72px;
  background:rgba(0,0,0,.18);
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
[data-theme="dark"] .msg:not(.mine) .link-unfurl-thumb{
  background:rgba(0,0,0,.35);
}
.msg.mine .link-unfurl-thumb{
  background:rgba(0,0,0,.2);
}
.link-unfurl-thumb.has-image .link-unfurl-skel{display:none}
.link-unfurl-fallback-ico{
  position:absolute;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  font-size:26px;
  opacity:.48;
  pointer-events:none;
}
.link-unfurl-thumb--fallback:not(.has-image) .link-unfurl-skel{display:none}
.link-unfurl-thumb--fallback:not(.has-image) .link-unfurl-fallback-ico{display:flex}
.link-unfurl-thumb.has-image .link-unfurl-fallback-ico{display:none!important}
.link-unfurl-skel{
  width:36px;
  height:36px;
  border-radius:10px;
  background:color-mix(in srgb,var(--text) 12%,transparent);
  opacity:.45;
  animation:linkUnfurlPulse 1.2s ease-in-out infinite;
}
@keyframes linkUnfurlPulse{
  0%,100%{opacity:.35;transform:scale(1)}
  50%{opacity:.55;transform:scale(1.04)}
}
@media (prefers-reduced-motion:reduce){
  .link-unfurl-skel{animation:none}
}
.link-unfurl-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .2s ease;
}
.link-unfurl-img.is-visible{
  opacity:1;
}
.link-unfurl-body{
  flex:1;
  min-width:0;
  padding:10px 12px 10px 14px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
}
.link-unfurl-title{
  font-weight:600;
  font-size:13px;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.link-unfurl-line{
  font-size:12px;
  color:var(--muted);
  overflow-wrap:anywhere;
  word-break:break-word;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.msg.mine .link-unfurl-line{
  color:rgba(255,255,255,.78);
}
.link-unfurl-go{
  flex:none;
  display:flex;
  align-items:center;
  padding:0 12px 0 0;
  font-size:13px;
  opacity:.55;
}
.msg.mine .link-unfurl-go{
  color:rgba(255,255,255,.85);
}

/* Lightbox de imagem */
.image-lightbox{
  position:fixed;
  inset:0;
  z-index:120;
  display:grid;
  place-items:center;
  padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));
}
.image-lightbox.hidden{display:none!important}
.image-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(8,10,18,.88);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.image-lightbox-dialog{
  position:relative;
  z-index:1;
  max-width:96vw;
  max-height:92vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
}
.image-lightbox-img{
  max-width:96vw;
  max-height:calc(92vh - 56px);
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:12px;
  box-shadow:0 24px 80px rgba(0,0,0,.55);
}
.image-lightbox-caption{
  margin:0;
  max-width:min(560px,92vw);
  text-align:center;
  font-size:14px;
  color:rgba(255,255,255,.88);
  line-height:1.35;
  word-break:break-word;
}
.image-lightbox-close{
  position:fixed;
  top:max(12px,env(safe-area-inset-top));
  right:max(12px,env(safe-area-inset-right));
  z-index:3;
  width:46px;
  height:46px;
  border-radius:50%;
  border:0;
  background:rgba(255,255,255,.16);
  color:#fff;
  font-size:26px;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:background .15s ease;
  box-shadow:0 4px 24px rgba(0,0,0,.35);
}
.image-lightbox-close:hover{
  background:rgba(255,255,255,.3);
}

/* Mensagens próprias: sem nome no topo; envio/visualização só na última */
.msg-delivery-status{
  flex-shrink:0;
  align-self:center;
  width:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  line-height:1;
  opacity:.88;
  color:var(--muted);
}
.msg.mine .msg-delivery-status{
  color:rgba(255,255,255,.72);
}
.msg-foot-own{
  margin-top:8px;
  text-align:right;
}
.msg-time-own{
  font-size:11px;
  font-weight:500;
  opacity:.78;
  color:rgba(255,255,255,.82);
}

/* Diretório Pessoas + perfil público */
.people-page{
  position:relative;
  isolation:isolate;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-gutter:stable;
}
.people-page::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.55;
  background:
    radial-gradient(ellipse 70% 50% at 0% 0%,color-mix(in srgb,var(--primary) 16%,transparent),transparent 55%),
    radial-gradient(ellipse 55% 45% at 100% 10%,color-mix(in srgb,#22d3ee 12%,transparent),transparent 50%);
}
.people-page > *{position:relative;z-index:1}
.people-page-head{margin-bottom:6px;padding-bottom:14px;border-bottom:1px solid color-mix(in srgb,var(--line) 90%,var(--primary) 10%)}
.people-page-eyebrow{
  margin:0 0 6px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  color:var(--muted);
}
.people-page h1{margin:0 0 8px;font-size:clamp(1.5rem,2.4vw,1.85rem);font-weight:800;letter-spacing:-.03em;line-height:1.15}
.people-page-lead{margin:0;font-size:14px;line-height:1.45}
.people-back{margin:0 0 16px;font-size:14px}
.people-back a{text-decoration:none}
.people-back a:hover{text-decoration:underline}
.people-search{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:22px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid color-mix(in srgb,var(--line) 88%,var(--primary) 12%);
  background:linear-gradient(135deg,color-mix(in srgb,var(--bubble) 70%,var(--card)),var(--card));
  box-shadow:0 1px 0 rgba(255,255,255,.35) inset;
}
[data-theme="dark"] .people-search{
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset;
}
.people-search .search{flex:1;min-width:200px;border-radius:14px}
.people-search button{border-radius:14px;font-weight:700;padding:10px 18px}
.people-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,196px),1fr));
  gap:16px;
  align-items:stretch;
}
.people-card{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  padding:0;
  border-radius:20px;
  border:1px solid color-mix(in srgb,var(--line) 90%,var(--primary) 10%);
  background:linear-gradient(180deg,color-mix(in srgb,var(--card) 96%,var(--bubble)) 0%,var(--card) 38%,var(--card) 100%);
  text-decoration:none;
  color:inherit;
  transition:transform .24s cubic-bezier(.22,1,.36,1),box-shadow .28s ease,border-color .22s ease;
  min-width:0;
  min-height:228px;
  height:100%;
  box-sizing:border-box;
  overflow:hidden;
  opacity:0;
  animation:people-card-in .5s cubic-bezier(.22,1,.36,1) forwards;
  animation-delay:calc(0.035s * var(--people-stagger,0));
  box-shadow:0 1px 0 rgba(255,255,255,.45) inset,0 10px 32px rgba(0,0,0,.06);
}
[data-theme="dark"] .people-card{
  background:linear-gradient(180deg,color-mix(in srgb,var(--card) 94%,var(--primary) 6%) 0%,var(--card) 42%,var(--card) 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 12px 36px rgba(0,0,0,.28);
}
.people-card-accent{
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:min(120px,48%);
  height:3px;
  border-radius:0 0 10px 10px;
  background:linear-gradient(90deg,var(--primary),#22d3ee);
  opacity:.9;
  z-index:2;
  pointer-events:none;
}
.people-card-glow{
  position:absolute;
  inset:-20% -30% auto -30%;
  height:55%;
  background:radial-gradient(ellipse 80% 70% at 50% 0%,color-mix(in srgb,var(--primary) 18%,transparent),transparent 72%);
  opacity:0;
  transition:opacity .32s ease;
  pointer-events:none;
}
.people-card:hover .people-card-glow{opacity:1}
.people-card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 48px color-mix(in srgb,var(--primary) 16%,transparent),0 0 0 1px color-mix(in srgb,var(--primary) 26%,transparent);
  border-color:color-mix(in srgb,var(--primary) 35%,var(--line));
}
.people-card:focus-visible{
  outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);
  outline-offset:3px;
}
.people-card-visual{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:24px 12px 6px;
  flex-shrink:0;
}
.people-card-avatar{
  flex:none;
  width:76px;
  height:76px;
  border-radius:50%;
  overflow:hidden;
  background:linear-gradient(145deg,var(--primary),#22d3ee);
  color:#fff;
  font-weight:800;
  font-size:22px;
  display:grid;
  place-items:center;
  box-shadow:0 8px 28px color-mix(in srgb,var(--primary) 38%,transparent),0 0 0 3px color-mix(in srgb,var(--card) 92%,transparent);
  transition:transform .28s cubic-bezier(.34,1.56,.64,1),box-shadow .28s ease;
}
.people-card:hover .people-card-avatar{
  transform:scale(1.06);
  box-shadow:0 12px 36px color-mix(in srgb,var(--primary) 48%,transparent),0 0 0 3px var(--card);
}
.people-card-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.people-card-body{
  min-width:0;
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  padding:6px 14px 14px;
  gap:8px;
  overflow:hidden;
}
.people-card-name{
  font-size:15px;
  line-height:1.28;
  font-weight:800;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  letter-spacing:-.02em;
  margin:0;
  max-width:100%;
}
.people-card-meta-slot{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  width:100%;
  flex:1;
  justify-content:flex-start;
  min-height:0;
}
.people-card-meta-slot:not(.people-card-meta-slot--empty){
  min-height:3.25rem;
}
.people-card-meta-slot--empty{
  min-height:0;
}
.people-card-chip{
  display:inline-block;
  max-width:100%;
  padding:5px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.03em;
  line-height:1.2;
  background:color-mix(in srgb,var(--primary) 12%,var(--bubble));
  color:color-mix(in srgb,var(--text) 88%,var(--primary));
  border:1px solid color-mix(in srgb,var(--primary) 20%,var(--line));
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  box-sizing:border-box;
}
.people-card-job{
  font-size:12px;
  font-weight:500;
  line-height:1.4;
  color:var(--muted);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-align:center;
  max-width:100%;
  margin:0;
}
.people-card-cta-hint{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  margin-top:auto;
  padding-top:4px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  opacity:.55;
  transition:opacity .2s ease,color .2s ease,transform .2s ease;
}
.people-card-cta-hint i{font-size:10px;transition:transform .22s ease}
.people-card:hover .people-card-cta-hint{
  opacity:1;
  color:color-mix(in srgb,var(--primary) 85%,var(--muted));
}
.people-card:hover .people-card-cta-hint i{transform:translateX(4px)}
@keyframes people-card-in{
  from{opacity:0;transform:translateY(18px) scale(.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@media (prefers-reduced-motion:reduce){
  .people-card{
    animation:none;
    opacity:1;
    transform:none;
  }
  .people-card:hover{transform:none}
  .people-card:hover .people-card-avatar{transform:none}
  .people-card:hover .people-card-cta-hint i{transform:none}
}
.profile-public-page{
  position:relative;
}
.profile-public-page--immersive.page-card{
  margin:0;
  border-radius:0;
  box-shadow:none;
  flex:1;
  min-width:0;
  min-height:0;
  width:100%;
  max-width:none;
  overflow:auto;
  background:transparent;
  padding:0;
  position:relative;
  isolation:isolate;
}
.profile-public-bg{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 100% 70% at 0% 0%, color-mix(in srgb, var(--primary) 32%, transparent), transparent 52%),
    radial-gradient(ellipse 80% 55% at 100% 0%, rgba(34, 211, 238, 0.22), transparent 48%),
    radial-gradient(ellipse 60% 40% at 50% 100%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 55%),
    var(--bg);
}
.profile-public-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(120, 130, 180, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120, 130, 180, 0.06) 1px, transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 55%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 0%, #000 55%, transparent 100%);
  opacity:0.85;
}
[data-theme="dark"] .profile-public-bg::before{
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
}
.profile-public-scan{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(120, 140, 255, 0.03) 2px,
    rgba(120, 140, 255, 0.03) 4px
  );
  opacity:0.35;
  animation:profileScanDrift 14s linear infinite;
}
@keyframes profileScanDrift{
  from{transform:translateY(0)}
  to{transform:translateY(56px)}
}
.profile-public-inner{
  position:relative;
  z-index:1;
  width:100%;
  min-height:min(70vh, 100%);
  padding:clamp(10px, 1.8vw, 28px) clamp(14px, 2.8vw, 44px) clamp(28px, 4vw, 56px);
  animation:profileInnerIn 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes profileInnerIn{
  from{opacity:0; transform:translateY(12px)}
  to{opacity:1; transform:none}
}
.profile-public-page .profile-public-head{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:20px 16px;
  margin-bottom:8px;
  padding-bottom:22px;
  border-bottom:1px solid var(--line);
}
.profile-public-head-main{
  display:flex;
  gap:20px;
  align-items:center;
  min-width:0;
  flex:1 1 240px;
}
.profile-public-avatar{
  flex:none;
  width:104px;
  height:104px;
  border-radius:50%;
  overflow:hidden;
  background:linear-gradient(145deg,var(--primary),#22d3ee);
  color:#fff;
  font-weight:800;
  font-size:32px;
  display:grid;
  place-items:center;
  box-shadow:
    0 0 0 3px var(--card),
    0 0 0 5px color-mix(in srgb,var(--primary) 50%,#22d3ee),
    0 14px 36px rgba(0,0,0,.12);
}
[data-theme="dark"] .profile-public-avatar{
  box-shadow:
    0 0 0 3px var(--card),
    0 0 0 5px color-mix(in srgb,var(--primary) 42%,rgba(34,211,238,.55)),
    0 18px 44px rgba(0,0,0,.45);
}
.profile-public-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.profile-public-head-text{min-width:0;flex:1}
.profile-public-head-text h1{margin:0 0 8px;font-size:1.55rem;line-height:1.15;letter-spacing:-.02em}
.profile-public-email{margin:0 0 8px;font-size:14px}
.profile-public-email a{color:var(--primary);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--primary) 35%,transparent);transition:border-color .15s ease,color .15s ease}
.profile-public-email a:hover{border-bottom-color:var(--primary);color:color-mix(in srgb,var(--primary) 85%,var(--text))}
.profile-public-meta{margin:6px 0 0;font-size:15px;color:var(--text);font-weight:500;line-height:1.35}
.people-role-badge{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
  padding:4px 10px;
  border-radius:999px;
  background:color-mix(in srgb,var(--primary) 18%,transparent);
  color:var(--primary);
  margin-bottom:8px;
}
.profile-chat-btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 24px;
  border-radius:999px;
  font-size:15px;
  font-weight:700;
  letter-spacing:.02em;
  text-decoration:none;
  color:#fff!important;
  overflow:hidden;
  isolation:isolate;
  background:linear-gradient(135deg,var(--primary),#6f66ff 48%,#22d3ee);
  box-shadow:0 8px 26px color-mix(in srgb,var(--primary) 38%,transparent),inset 0 1px 0 rgba(255,255,255,.22);
  transition:transform .22s cubic-bezier(.34,1.45,.64,1),box-shadow .2s ease,filter .2s ease;
}
.profile-chat-btn:hover{
  transform:translateY(-3px) scale(1.03);
  box-shadow:0 14px 34px color-mix(in srgb,var(--primary) 50%,transparent),inset 0 1px 0 rgba(255,255,255,.28);
  filter:brightness(1.05);
}
.profile-chat-btn:active{
  transform:translateY(-1px) scale(.99);
}
.profile-chat-btn-glow{
  position:absolute;
  inset:-50%;
  background:conic-gradient(from 210deg at 50% 50%,transparent 0deg,rgba(255,255,255,.28) 60deg,transparent 120deg);
  animation:profileChatShine 3.5s linear infinite;
  opacity:.5;
  pointer-events:none;
  z-index:0;
}
.profile-chat-btn > i,
.profile-chat-btn > span:last-of-type{position:relative;z-index:1}
@keyframes profileChatShine{
  to{transform:rotate(360deg)}
}
@media (prefers-reduced-motion:reduce){
  .profile-chat-btn-glow{animation:none;opacity:0}
  .profile-chat-btn{transition:transform .12s ease,filter .12s ease,box-shadow .12s ease}
}
@media (max-width:520px){
  .profile-public-page .profile-public-head{
    flex-direction:column;
    align-items:stretch;
  }
  .profile-chat-btn{width:100%;justify-content:center}
}
.profile-bio-text{font-size:15px;line-height:1.6;white-space:pre-wrap;color:var(--text)}
.profile-admin-edit{
  margin-top:8px;
  padding-top:20px;
  border-top:1px dashed var(--line);
}
.profile-admin-edit h2{margin:0 0 8px;font-size:1.05rem}
.profile-admin-form{margin-top:12px}
.people-muted-small{font-size:13px;line-height:1.45;margin:0 0 14px}
.alert-soft{background:color-mix(in srgb,var(--primary) 12%,var(--card));color:var(--text);border:1px solid color-mix(in srgb,var(--primary) 22%,var(--line))}
.migrate-checklist{margin:0 0 18px;padding-left:1.35rem;line-height:1.75;color:var(--text)}
.profile-public-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) min(320px,32%);
  gap:clamp(20px,2.5vw,36px) clamp(20px,2.2vw,32px);
  align-items:start;
  margin-top:12px;
  animation:profileStagger 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.08s both;
}
@keyframes profileStagger{
  from{opacity:0; transform:translateY(20px)}
  to{opacity:1; transform:none}
}
.profile-public-main{display:flex;flex-direction:column;gap:22px;min-width:0;width:100%;max-width:100%}
.profile-public-hero-card{
  position:relative;
  border-radius:22px;
  padding:22px 22px 20px;
  background:linear-gradient(145deg,color-mix(in srgb,var(--card) 92%,var(--primary) 8%),var(--card));
  border:1px solid var(--line);
  box-shadow:0 14px 40px rgba(29,24,63,.08);
  overflow:hidden;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.profile-public-hero-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  z-index:0;
  background:radial-gradient(
    ellipse 95% 75% at 100% 0%,
    color-mix(in srgb,var(--primary) 36%,transparent) 0%,
    color-mix(in srgb,var(--primary) 14%,transparent) 45%,
    transparent 72%
  );
  opacity:.5;
  pointer-events:none;
  animation:profileHeroBlob 16s ease-in-out infinite alternate;
}
@keyframes profileHeroBlob{
  from{opacity:.42;transform:scale(1)}
  to{opacity:.58;transform:scale(1.02)}
}
@media (prefers-reduced-motion:reduce){
  .profile-public-hero-card::before{animation:none}
}
.profile-public-hero-card > *{position:relative;z-index:1}
.profile-public-avatar--float{
  animation:profileAvatarIn .55s cubic-bezier(.34,1.2,.64,1) both;
}
@keyframes profileAvatarIn{
  from{opacity:0;transform:translateY(10px) scale(.94)}
  to{opacity:1;transform:none}
}
.profile-public-badges{display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center;margin-top:6px}
.profile-public-pill-row{display:inline-flex;flex-wrap:wrap;gap:8px;align-items:center}
.profile-pill{
  font-size:12px;
  font-weight:600;
  padding:5px 12px;
  border-radius:999px;
  background:color-mix(in srgb,var(--bubble) 88%,var(--primary) 12%);
  color:var(--text);
  border:1px solid var(--line);
}
.profile-pill-accent{
  background:color-mix(in srgb,var(--primary) 16%,transparent);
  color:var(--primary);
  border-color:color-mix(in srgb,var(--primary) 28%,var(--line));
}
.profile-contact-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));
  gap:12px;
  margin-top:22px;
}
.profile-contact-tile{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:0 6px 18px rgba(0,0,0,.05);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
  min-height:88px;
}
[data-theme="dark"] .profile-contact-tile{box-shadow:0 8px 22px rgba(0,0,0,.28)}
.profile-contact-tile--link{
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
.profile-contact-tile--link:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(29,24,63,.12);
  border-color:color-mix(in srgb,var(--primary) 35%,var(--line));
}
.profile-contact-icon-wrap{
  flex:none;
  width:52px;
  height:52px;
  border-radius:16px;
  display:grid;
  place-items:center;
  font-size:1.1rem;
  color:#fff;
  position:relative;
  overflow:hidden;
  box-shadow:
    0 10px 28px color-mix(in srgb, var(--primary) 42%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
  isolation:isolate;
  animation:profileIconPop 0.6s cubic-bezier(0.34, 1.45, 0.64, 1) backwards;
}
.profile-contact-tile:nth-child(1) .profile-contact-icon-wrap{animation-delay:0.14s}
.profile-contact-tile:nth-child(2) .profile-contact-icon-wrap{animation-delay:0.22s}
.profile-contact-tile:nth-child(3) .profile-contact-icon-wrap{animation-delay:0.3s}
@keyframes profileIconPop{
  from{opacity:0; transform:scale(0.65) rotate(-8deg)}
  to{opacity:1; transform:none}
}
.profile-contact-icon-wrap::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:linear-gradient(115deg, transparent 35%, rgba(255, 255, 255, 0.28) 48%, transparent 62%);
  animation:profileIconSheen 3.2s ease-in-out infinite;
}
.profile-contact-icon-wrap > i{position:relative;z-index:1;filter:drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2))}
@keyframes profileIconSheen{
  0%, 100%{transform:translateX(-30%) translateY(10%) rotate(0deg)}
  50%{transform:translateX(35%) translateY(-5%) rotate(0deg)}
}
.profile-contact-icon-wrap--mail{
  background:linear-gradient(140deg, #6366f1 0%, var(--primary) 45%, #22d3ee 100%);
}
.profile-contact-icon-wrap--phone{
  background:linear-gradient(140deg, #0d9488 0%, #0891b2 50%, #6366f1 100%);
}
.profile-contact-icon-wrap--ramal{
  background:linear-gradient(140deg, #7c3aed 0%, #a855f7 40%, #ec4899 95%);
}
.profile-contact-body{min-width:0;flex:1;display:flex;flex-direction:column;gap:4px}
.profile-contact-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.profile-contact-value{font-size:15px;font-weight:600;word-break:break-word;line-height:1.35;color:var(--text)}
.profile-contact-value-link{color:var(--primary);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--primary) 35%,transparent)}
.profile-contact-value-link:hover{border-bottom-color:var(--primary)}
.profile-contact-empty{font-weight:500;color:var(--muted)}
.profile-contact-mono{font-variant-numeric:tabular-nums;letter-spacing:.02em}
.profile-contact-chevron{margin-left:auto;align-self:center;opacity:.45;font-size:13px}
.profile-public-bio-card{
  border-radius:20px;
  padding:22px 22px 24px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:0 8px 26px rgba(29,24,63,.06);
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.profile-bio-card-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:12px}
.profile-bio-card-head h2{margin:0;font-size:1.1rem;letter-spacing:-.02em}
.profile-bio-placeholder{margin:0;font-size:15px}
.profile-public-aside{min-width:0}
.profile-aside-card{
  position:sticky;
  top:18px;
  border-radius:20px;
  padding:22px 20px 20px;
  border:1px solid var(--line);
  background:linear-gradient(165deg,var(--card),color-mix(in srgb,var(--bubble) 55%,var(--card)));
  box-shadow:0 12px 34px rgba(29,24,63,.1);
  overflow:hidden;
}
.profile-aside-deco{
  position:absolute;
  inset:auto -30% -40% auto;
  width:180px;
  height:180px;
  border-radius:50%;
  background:conic-gradient(from 200deg,var(--primary),#22d3ee,var(--primary));
  opacity:.18;
  filter:blur(0);
  pointer-events:none;
}
.profile-aside-card > *:not(.profile-aside-deco){position:relative;z-index:1}
.profile-aside-kicker{margin:0 0 6px;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.profile-aside-title{margin:0 0 14px;font-size:1.05rem;font-weight:700;line-height:1.25;letter-spacing:-.02em}
.profile-aside-list{margin:0 0 18px;padding:0;list-style:none;display:grid;gap:10px;font-size:14px;line-height:1.4}
.profile-aside-list .muted{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.profile-chat-btn--block{width:100%;justify-content:center;margin-top:4px}
@media (max-width:900px){
  .profile-public-layout{grid-template-columns:1fr}
  .profile-aside-card{position:relative;top:0}
}
.profile-public-page .profile-public-head{margin-bottom:0;padding-bottom:0;border-bottom:0}
.people-back{margin:0 0 18px}
.people-back-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 18px;
  border-radius:999px;
  font-size:14px;
  font-weight:600;
  color:var(--text);
  text-decoration:none;
  background:color-mix(in srgb,var(--card) 82%,var(--primary) 10%);
  border:1px solid color-mix(in srgb,var(--primary) 22%,var(--line));
  box-shadow:0 4px 18px rgba(0,0,0,.07);
  transition:transform .22s cubic-bezier(.34,1.45,.64,1),box-shadow .2s ease,border-color .2s ease;
}
.people-back-link:hover{
  transform:translateX(-4px);
  border-color:color-mix(in srgb,var(--primary) 48%,var(--line));
  box-shadow:0 10px 28px color-mix(in srgb,var(--primary) 24%,transparent);
}
.people-back-link i{font-size:12px;opacity:.72}
.profile-public-page--immersive .profile-public-head-text h1{
  font-size:clamp(1.75rem,1.1vw + 1.4rem,2.55rem);
  font-weight:800;
  letter-spacing:-.04em;
  line-height:1.08;
  text-shadow:0 0 48px color-mix(in srgb,var(--primary) 28%,transparent);
}
.profile-public-page--immersive .profile-public-avatar{
  width:clamp(104px,11vw,132px);
  height:clamp(104px,11vw,132px);
  font-size:clamp(28px,2.6vw,38px);
}
.profile-public-page--immersive .profile-public-hero-card{
  backdrop-filter:saturate(1.15) blur(18px);
  -webkit-backdrop-filter:saturate(1.15) blur(18px);
  background:linear-gradient(145deg,color-mix(in srgb,var(--card) 70%,transparent),color-mix(in srgb,var(--card) 90%,var(--primary) 7%));
  border:1px solid color-mix(in srgb,var(--primary) 30%,var(--line));
  box-shadow:0 0 0 1px rgba(255,255,255,.1) inset,0 22px 60px rgba(15,23,42,.14);
  animation:profileHeroIn .68s cubic-bezier(.22,1,.36,1) both;
}
[data-theme="dark"] .profile-public-page--immersive .profile-public-hero-card{
  box-shadow:0 0 0 1px rgba(255,255,255,.07) inset,0 26px 64px rgba(0,0,0,.5);
}
@keyframes profileHeroIn{
  from{opacity:0;transform:translateY(16px) scale(.988)}
  to{opacity:1;transform:none}
}
.profile-public-page--immersive .profile-public-bio-card{
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  background:linear-gradient(180deg,color-mix(in srgb,var(--card) 82%,transparent),color-mix(in srgb,var(--card) 96%,var(--bubble)));
  border:1px solid color-mix(in srgb,var(--primary) 24%,var(--line));
  box-shadow:0 0 0 1px rgba(255,255,255,.08) inset,0 18px 46px rgba(29,24,63,.11);
  animation:profileBioCardIn .72s cubic-bezier(.22,1,.36,1) .16s both;
}
@keyframes profileBioCardIn{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:none}
}
.profile-bio-title-glow{
  background:linear-gradient(95deg,var(--text),color-mix(in srgb,var(--primary) 72%,var(--text)));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.profile-public-page--immersive .profile-aside-card{
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid color-mix(in srgb,var(--primary) 28%,var(--line));
  box-shadow:0 0 0 1px rgba(255,255,255,.08) inset,0 22px 56px rgba(29,24,63,.15);
  animation:profileAsideIn .74s cubic-bezier(.22,1,.36,1) .12s both;
}
@keyframes profileAsideIn{
  from{opacity:0;transform:translateX(18px)}
  to{opacity:1;transform:none}
}
.profile-public-page--immersive .profile-contact-tile{
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  background:color-mix(in srgb,var(--card) 88%,transparent);
  border:1px solid color-mix(in srgb,var(--primary) 18%,var(--line));
  animation:profileTileIn .58s cubic-bezier(.22,1,.36,1) backwards;
}
.profile-contact-tile:nth-child(1){animation-delay:.1s}
.profile-contact-tile:nth-child(2){animation-delay:.18s}
.profile-contact-tile:nth-child(3){animation-delay:.26s}
@keyframes profileTileIn{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:none}
}
@media (prefers-reduced-motion:reduce){
  .profile-public-inner,
  .profile-public-layout,
  .profile-public-page--immersive .profile-public-bio-card,
  .profile-public-page--immersive .profile-aside-card,
  .profile-public-page--immersive .profile-public-hero-card,
  .profile-contact-tile,
  .profile-contact-icon-wrap{
    animation:none!important;
  }
  .profile-public-avatar--float{animation:none!important}
  .profile-public-scan{animation:none!important}
  .profile-contact-icon-wrap::before{animation:none!important}
  .profile-public-hero-card::before{animation:none!important}
}
