/* ============================================================
   LinkedOut – Main Stylesheet
   Font: DM Sans + DM Serif Display
   Palette: Deep Navy · Slate · Gold accent
   ============================================================ */

:root {
  --navy:      #0d1b2a;
  --navy-mid:  #1b2d3f;
  --slate:     #3d5a73;
  --slate-lt:  #6b8fa8;
  --gold:      #d4a843;
  --gold-lt:   #f0cc7a;
  --surface:   #f4f6f8;
  --white:     #ffffff;
  --border:    #dde3ea;
  --text:      #1a2a38;
  --text-mute: #6b7f8e;
  --danger:    #c0392b;
  --success:   #1e8449;
  --radius:    10px;
  --shadow:    0 2px 12px rgba(13,27,42,.08);
  --font-body: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Oxygen, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  --font-head: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Oxygen, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--surface);
  color: var(--text);
  min-height: 100vh;
  font-size: 15px;
  line-height: 1.6;
}

a { color: var(--slate); text-decoration: none; }
a:hover { color: var(--navy); }

img { max-width: 100%; display: block; }

/* ── Navbar ────────────────────────────────────────────────── */
.navbar {
  position: sticky; top: 0; z-index: 100;
  background: var(--white);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  padding: 0 1rem; height: 60px;
  box-shadow: var(--shadow);
}
.navbar-inner {
  display: flex; align-items: center; gap: 1.25rem;
  width: 100%; max-width: 1100px;
}

.navbar-inner {
  display: flex; align-items: center; gap: 1.25rem;
  width: 100%; max-width: 1100px;
}

.navbar-brand {
  display: flex; align-items: center; gap: .5rem;
  color: var(--navy); font-weight: 700;
}
.brand-icon {
  background: var(--navy);
  color: var(--gold);
  font-family: var(--font-head);
  width: 34px; height: 34px;
  border-radius: 8px;
  display: grid; place-items: center;
  font-size: 1.2rem; font-weight: 900;
  flex-shrink: 0;
}
.navbar-brand .brand-logo { height: 32px; max-width: 180px; border-radius: 6px; object-fit: contain; display: block; }
.brand-text { font-size: 1.15rem; font-weight: 700; letter-spacing: -.3px; }

.nav-search { flex: 1; max-width: 340px; }
.nav-search form input {
  width: 100%;
  padding: .5rem 1rem;
  border: 1.5px solid var(--border);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: .9rem;
  background: var(--surface);
  transition: border-color .2s;
}
.nav-search form input:focus { outline: none; border-color: var(--slate); }

.nav-links {
  display: flex; list-style: none; gap: .25rem;
}
.nav-links li { position: relative; }
.nav-icon {
  display: flex; flex-direction: column; align-items: center;
  gap: 2px; padding: .4rem .75rem;
  color: var(--text-mute); font-size: .7rem; font-weight: 600;
  border-radius: var(--radius); transition: color .2s, background .2s;
  position: relative;
}
.nav-icon svg {
  width: 22px; height: 22px; fill: none;
  stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.nav-icon:hover { color: var(--navy); background: var(--surface); }
.nav-icon.active { color: var(--navy); }

.badge {
  position: absolute; top: 4px; right: 4px;
  background: var(--gold); color: var(--navy);
  font-size: .6rem; font-weight: 700;
  border-radius: 999px; padding: 1px 5px; min-width: 16px; text-align: center;
}

.nav-profile { position: relative; cursor: pointer; }
.nav-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); }
.nav-dropdown {
  display: none; position: absolute; right: 0; top: 100%;
  padding-top: 8px; /* invisible bridge — keeps hover alive */
  background: transparent;
  z-index: 999;
}
.nav-dropdown-inner {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow);
  min-width: 170px; overflow: hidden;
}
.nav-dropdown a {
  display: block; padding: .65rem 1rem; font-size: .9rem; color: var(--text);
}
.nav-dropdown a:hover { background: var(--surface); }
.nav-dropdown hr { border: none; border-top: 1px solid var(--border); margin: .25rem 0; }
.nav-profile:hover .nav-dropdown { display: block; }

/* ── Layout ────────────────────────────────────────────────── */
.main-content { max-width: 1100px; margin: 0 auto; padding: 1.5rem 1rem; }
.page-grid { display: grid; grid-template-columns: 240px 1fr 280px; gap: 1.25rem; }
.page-grid-2 { display: grid; grid-template-columns: 240px 1fr; gap: 1.25rem; }
.page-grid-wide { display: grid; grid-template-columns: 1fr 300px; gap: 1.25rem; }

/* ── Cards ─────────────────────────────────────────────────── */
.card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden;
}
.card-body { padding: 1.25rem; }
.card-title { font-family: var(--font-head); font-size: 1.1rem; margin-bottom: .75rem; }
.card-section { padding: 1rem 1.25rem; border-top: 1px solid var(--border); }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .5rem 1.25rem; border-radius: 999px;
  font-family: var(--font-body); font-size: .88rem; font-weight: 600;
  cursor: pointer; border: none; transition: all .2s;
}
.btn-primary   { background: var(--navy); color: var(--white); }
.btn-primary:hover { background: var(--navy-mid); color: var(--white); }
.btn-outline   { background: transparent; border: 2px solid var(--navy); color: var(--navy); }
.btn-outline:hover { background: var(--navy); color: var(--white); }
.btn-gold      { background: var(--gold); color: var(--navy); }
.btn-gold:hover{ background: var(--gold-lt); }
.btn-sm        { padding: .35rem .9rem; font-size: .82rem; }
.btn-danger    { background: var(--danger); color: #fff; }
.btn-success   { background: var(--success); color: #fff; }
.btn-ghost     { background: transparent; color: var(--text-mute); }
.btn-ghost:hover { background: var(--surface); color: var(--text); }

/* ── Forms ─────────────────────────────────────────────────── */
.form-group { margin-bottom: 1rem; }
.form-group label { display: block; font-weight: 600; margin-bottom: .35rem; font-size: .88rem; }
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%; padding: .6rem .9rem;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  font-family: var(--font-body); font-size: .93rem;
  background: var(--white); transition: border-color .2s;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { outline: none; border-color: var(--slate); }
.form-group textarea { resize: vertical; min-height: 90px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* ── Alert banners ─────────────────────────────────────────── */
.alert { padding: .75rem 1rem; border-radius: var(--radius); margin-bottom: 1rem; font-size: .9rem; }
.alert-error   { background: #fde8e8; color: var(--danger); border: 1px solid #f5c6c6; }
.alert-success { background: #e8f8ee; color: var(--success); border: 1px solid #b2dfcb; }
.alert-info    { background: #e8f0f8; color: var(--slate); border: 1px solid #b0c8df; }

/* ── Profile cover + avatar ────────────────────────────────── */
.profile-cover { width: 100%; height: 180px; object-fit: cover; display: block; }
.profile-header-body {
  padding: 0 1.5rem 1.25rem;
  display: flex; gap: 1.25rem; align-items: flex-end;
  position: relative; margin-top: -52px;
}
.profile-avatar-wrap { position: relative; flex-shrink: 0; }
.profile-avatar {
  width: 104px; height: 104px; border-radius: 50%; object-fit: cover;
  border: 4px solid var(--white); background: var(--white);
}
.profile-meta { flex: 1; padding-top: 56px; }
.profile-name { font-family: var(--font-head); font-size: 1.5rem; line-height: 1.2; }
.profile-headline { color: var(--text-mute); margin-top: .2rem; }
.profile-location { color: var(--text-mute); font-size: .85rem; margin-top: .2rem; }
.profile-stats { display: flex; gap: 1.5rem; margin-top: .5rem; }
.profile-stats span { font-size: .85rem; color: var(--text-mute); }
.profile-stats strong { color: var(--text); }

/* ── Feed / Post ───────────────────────────────────────────── */
.post-compose { padding: 1rem; display: flex; gap: .75rem; align-items: center; }
.post-compose input[type="text"],
.post-compose input[type="search"] {
  flex: 1; padding: .6rem 1rem; border: 1.5px solid var(--border);
  border-radius: 999px; font-family: var(--font-body); font-size: .93rem;
  background: var(--surface); cursor: pointer;
}
.post { border-top: 1px solid var(--border); }
.post-header { padding: .9rem 1rem .4rem; display: flex; gap: .75rem; }
.post-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.post-user-info a { font-weight: 600; color: var(--text); font-size: .95rem; }
.post-user-info .post-time { font-size: .8rem; color: var(--text-mute); }
.post-content { padding: .3rem 1rem .7rem; white-space: pre-wrap; }
.post-image { width: 100%; max-height: 450px; object-fit: cover; }
.post-actions {
  padding: .5rem 1rem; border-top: 1px solid var(--border);
  display: flex; gap: .25rem;
}
.post-actions .btn { color: var(--text-mute); font-weight: 600; }
.post-actions .btn:hover { color: var(--navy); background: var(--surface); }
.post-actions .btn.liked { color: var(--gold); }
.post-comments { background: var(--surface); border-top: 1px solid var(--border); }
.comment { display: flex; gap: .65rem; padding: .65rem 1rem; border-top: 1px solid var(--border); }
.comment:first-child { border-top: none; }
.comment-avatar { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.comment-body { background: var(--white); border-radius: var(--radius); padding: .5rem .8rem; flex: 1; }
.comment-author { font-weight: 600; font-size: .87rem; }
.comment-text { font-size: .9rem; }
.comment-form { display: flex; gap: .65rem; padding: .65rem 1rem; }
.comment-form input { flex: 1; padding: .5rem .9rem; border: 1.5px solid var(--border); border-radius: 999px; font-family: var(--font-body); font-size: .9rem; }

/* ── Job cards ─────────────────────────────────────────────── */
.job-card { padding: 1.25rem; border-top: 1px solid var(--border); display: flex; gap: 1rem; }
.job-card:first-child { border-top: none; }
.job-logo { width: 54px; height: 54px; border-radius: var(--radius); object-fit: cover; flex-shrink: 0; border: 1px solid var(--border); }
.job-info .job-title { font-weight: 700; font-size: 1rem; color: var(--navy); }
.job-info .job-company { color: var(--text-mute); font-size: .88rem; }
.job-meta { display: flex; gap: .75rem; margin-top: .35rem; flex-wrap: wrap; }
.job-tag { font-size: .75rem; padding: .2rem .6rem; border-radius: 999px; background: var(--surface); color: var(--slate); border: 1px solid var(--border); }

/* ── Company cards ─────────────────────────────────────────── */
.company-card { padding: 1.25rem; text-align: center; }
.company-logo { width: 64px; height: 64px; border-radius: var(--radius); object-fit: cover; margin: 0 auto .5rem; border: 1px solid var(--border); }
.company-name { font-weight: 700; font-size: .97rem; color: var(--navy); }
.company-industry { font-size: .83rem; color: var(--text-mute); margin-top: .15rem; }

/* ── People cards ──────────────────────────────────────────── */
.people-card { padding: 1rem; display: flex; gap: .9rem; align-items: center; border-top: 1px solid var(--border); }
.people-card:first-child { border-top: none; }
.people-avatar { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.people-info .people-name { font-weight: 600; color: var(--text); }
.people-info .people-headline { font-size: .83rem; color: var(--text-mute); }

/* ── Messages ──────────────────────────────────────────────── */
.messages-main {
  max-width: 1100px;
  height: calc(100dvh - 72px);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.msg-layout {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 0;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}
.msg-sidebar { border-right: 1px solid var(--border); overflow-y: auto; min-height: 0; }
.msg-thread { font-size: .9rem; padding: .85rem 1rem; display: flex; gap: .75rem; border-bottom: 1px solid var(--border); cursor: pointer; transition: background .15s; }
.msg-thread:hover,.msg-thread.active { background: var(--surface); }
.msg-thread-avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.msg-thread-name { font-weight: 600; color: var(--text); }
.msg-thread-preview { color: var(--text-mute); font-size: .82rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 180px; }
.msg-unread .msg-thread-name::after { content: '•'; color: var(--gold); margin-left: .3rem; }
.msg-window { display: flex; flex-direction: column; min-width: 0; min-height: 0; }
.msg-header { padding: .9rem 1.25rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: .75rem; font-weight: 600; }
.msg-body { flex: 1; min-height: 0; overflow-y: auto; padding: 1rem; display: flex; flex-direction: column; gap: .6rem; background: var(--surface); }
.msg-bubble { max-width: 68%; padding: .6rem .9rem; border-radius: 18px; font-size: .92rem; line-height: 1.45; }
.msg-bubble.sent { background: var(--navy); color: #fff; align-self: flex-end; border-bottom-right-radius: 4px; }
.msg-bubble.recv { background: var(--white); color: var(--text); align-self: flex-start; border: 1px solid var(--border); border-bottom-left-radius: 4px; }
.msg-time { font-size: .7rem; color: var(--text-mute); text-align: center; margin: .5rem 0; }
.msg-input-bar { padding: .9rem 1.25rem; border-top: 1px solid var(--border); display: flex; gap: .75rem; background: var(--white); flex-shrink: 0; }
.msg-input-bar input { flex: 1; padding: .6rem 1rem; border: 1.5px solid var(--border); border-radius: 999px; font-family: var(--font-body); font-size: .93rem; }

/* ── Auth pages ────────────────────────────────────────────── */
.auth-wrap { min-height: 100vh; display: grid; place-items: center; background: var(--navy); }
.auth-card { background: var(--white); border-radius: 18px; padding: 2.5rem; width: 100%; max-width: 420px; box-shadow: 0 8px 40px rgba(0,0,0,.3); }
.auth-logo { text-align: center; margin-bottom: 1.75rem; }
.auth-logo .brand-icon { width: 52px; height: 52px; font-size: 2rem; margin: 0 auto .5rem; }
.auth-logo h1 { font-family: var(--font-head); font-size: 1.8rem; }
.auth-footer { text-align: center; margin-top: 1.25rem; font-size: .88rem; color: var(--text-mute); }

/* ── Sidebar widgets ───────────────────────────────────────── */
.widget-title { font-weight: 700; font-size: .88rem; color: var(--text-mute); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .75rem; }

/* ── Notifications ─────────────────────────────────────────── */
.notif-item { padding: .8rem 1rem; display: flex; gap: .75rem; border-bottom: 1px solid var(--border); transition: background .15s; }
.notif-item.unread { background: #f0f6ff; }
.notif-item:hover { background: var(--surface); }
.notif-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.notif-text { font-size: .9rem; color: var(--text); }
.notif-time { font-size: .78rem; color: var(--text-mute); margin-top: .15rem; }

/* ── Page headings ─────────────────────────────────────────── */
.page-title { font-family: var(--font-head); font-size: 1.6rem; margin-bottom: 1rem; }
.section-title { font-weight: 700; font-size: 1rem; margin-bottom: .75rem; padding-bottom: .4rem; border-bottom: 2px solid var(--gold); display: inline-block; }

/* ── Tabs ──────────────────────────────────────────────────── */
.tabs { display: flex; border-bottom: 2px solid var(--border); margin-bottom: 1.25rem; }
.tab { padding: .65rem 1.25rem; font-weight: 600; font-size: .9rem; color: var(--text-mute); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: all .2s; }
.tab.active, .tab:hover { color: var(--navy); border-bottom-color: var(--navy); }

/* ── Open to work badge ────────────────────────────────────── */
.otw-badge { display: inline-block; background: var(--success); color: #fff; font-size: .75rem; font-weight: 700; padding: .2rem .65rem; border-radius: 999px; margin-top: .35rem; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .page-grid, .page-grid-2 { grid-template-columns: 1fr; }
  .page-grid > :first-child, .page-grid > :last-child { display: none; }
  .page-grid-wide { grid-template-columns: 1fr; }
  .messages-main { height: calc(100dvh - 64px); padding: .75rem; }
  .msg-layout { grid-template-columns: 1fr; grid-template-rows: minmax(120px, 32%) minmax(0, 1fr); height: 100%; }
  .msg-sidebar { height: auto; border-right: none; border-bottom: 1px solid var(--border); }
}
@media (max-width: 600px) {
  .navbar { padding: 0 1rem; gap: .75rem; }
  .nav-search { display: none; }
  .messages-main { height: calc(100dvh - 58px); padding: .5rem; }
  .msg-layout { border-radius: 12px; }
  .msg-header { padding: .75rem; }
  .msg-body { padding: .75rem; }
  .msg-bubble { max-width: 85%; }
  .msg-input-bar { padding: .65rem; gap: .5rem; }
  .msg-input-bar input { min-width: 0; }
  .form-row { grid-template-columns: 1fr; }
}



/* ── Language switcher ─────────────────────────────────────── */
.lang-switcher { }  /* inherits post-menu-wrap positioning */
.lang-btn {
  display: flex; align-items: center; gap: .35rem;
  background: none; border: 1.5px solid var(--border);
  border-radius: 999px; padding: .3rem .75rem;
  font-family: var(--font-body); font-size: .82rem; font-weight: 600;
  color: var(--text); cursor: pointer; transition: all .2s; white-space: nowrap;
}
.lang-btn:hover { border-color: var(--slate); color: var(--navy); }
.lang-menu { min-width: 180px; background: transparent !important;
             border: none !important; box-shadow: none !important; padding: 0 !important; }
.active-lang { background: var(--surface) !important; font-weight: 700; }


.lang-flag-img{width:20px;height:14px;border-radius:2px;object-fit:cover;display:inline-block;flex:0 0 auto;box-shadow:0 0 0 1px rgba(13,27,42,.12)}
.lang-flag-fallback{display:inline-flex;align-items:center;justify-content:center;width:20px;height:14px;font-size:.75rem;line-height:1}
.lang-menu .post-menu-item{gap:.6rem;align-items:center}
.lang-menu .post-menu-item span{white-space:nowrap}
.lang-btn .lang-flag-img{width:18px;height:13px}

/* ── Post action menu (···) ────────────────────────────────── */
.post-menu-wrap { position: relative; margin-left: auto; }
.post-menu-btn {
  background: none; border: none; cursor: pointer;
  font-size: 1.3rem; color: var(--text-mute); padding: .25rem .6rem;
  border-radius: var(--radius); line-height: 1; letter-spacing: .05em;
  transition: background .15s, color .15s;
}
.post-menu-btn:hover { background: var(--surface); color: var(--text); }
.post-menu {
  display: none; position: absolute; right: 0; top: calc(100% + 4px);
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: 0 4px 20px rgba(13,27,42,.13);
  min-width: 220px; z-index: 200; overflow: hidden;
  padding: .35rem 0;
}
.post-menu.open { display: block; }
.post-menu-item {
  display: flex; align-items: center; gap: .75rem;
  padding: .65rem 1rem; font-size: .92rem; color: var(--text);
  cursor: pointer; background: none; border: none; width: 100%;
  text-align: left; font-family: var(--font-body); transition: background .12s;
}
.post-menu-item:hover { background: var(--surface); }
.post-menu-item svg { width: 18px; height: 18px; flex-shrink: 0; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.post-menu-item.danger { color: var(--danger); }
.post-menu-divider { border: none; border-top: 1px solid var(--border); margin: .3rem 0; }

/* ── Comment action menu ───────────────────────────────────── */
.comment-menu-wrap { position: relative; margin-left: auto; flex-shrink: 0; }
.comment-menu-btn {
  background: none; border: none; cursor: pointer; font-size: 1rem;
  color: var(--text-mute); padding: .15rem .4rem; border-radius: 6px;
  letter-spacing: .05em; transition: background .15s;
}
.comment-menu-btn:hover { background: var(--border); }
.comment-menu {
  display: none; position: absolute; right: 0; top: calc(100% + 2px);
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: 0 4px 16px rgba(13,27,42,.12);
  min-width: 160px; z-index: 200; overflow: hidden; padding: .3rem 0;
}
.comment-menu.open { display: block; }

/* ── Footer ────────────────────────────────────────────────── */
.site-footer { background: var(--navy); color: #aaa; font-size: .82rem; margin-top: 3rem; }
.footer-inner { max-width: 1100px; margin: 0 auto; padding: 1.25rem 1rem; display: flex; gap: 1.25rem; align-items: center; flex-wrap: wrap; }
.footer-inner .brand-text { color: var(--gold); font-weight: 700; }
.footer-inner nav a { color: #aaa; margin-left: .75rem; }
.footer-inner nav a:hover { color: var(--white); }

/* ── Post compose trigger ──────────────────────────────────── */
.compose-trigger {
  flex: 1; text-align: left; padding: .6rem 1rem;
  border: 1.5px solid var(--border); border-radius: 999px;
  background: var(--surface); color: var(--text-mute);
  font-family: var(--font-body); font-size: .93rem;
  cursor: pointer; transition: border-color .2s, background .2s;
}
.compose-trigger:hover { border-color: var(--slate); background: #fff; }

/* ── Modal ─────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
  animation: fadeIn .15s ease;
}
@keyframes fadeIn { from { opacity:0 } to { opacity:1 } }
.modal-box {
  background: #fff; border-radius: 16px;
  width: 100%; max-width: 560px;
  box-shadow: 0 8px 40px rgba(0,0,0,.2);
  display: flex; flex-direction: column;
  max-height: 90vh; overflow: hidden;
  animation: slideUp .2s ease;
}
@keyframes slideUp { from { transform:translateY(20px);opacity:0 } to { transform:translateY(0);opacity:1 } }
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem; border-bottom: 1px solid var(--border);
}
.modal-close {
  background: none; border: none; font-size: 1.1rem; cursor: pointer;
  color: var(--text-mute); width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center; transition: background .15s;
}
.modal-close:hover { background: var(--surface); color: var(--text); }
.modal-body { padding: 1rem 1.25rem; flex: 1; overflow-y: auto; }
.modal-textarea {
  width: 100%; min-height: 140px; border: none; resize: none;
  font-family: var(--font-body); font-size: 1rem; line-height: 1.6;
  color: var(--text); outline: none;
}
.modal-textarea::placeholder { color: var(--text-mute); }
.modal-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: .75rem 1.25rem; border-top: 1px solid var(--border);
}

/* ── Comment modal ─────────────────────────────────────────── */
.comment-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.45);
  display: flex; align-items: flex-end; justify-content: center;
  padding: 0; animation: fadeIn .15s ease;
}
.comment-modal-box {
  background: #fff; border-radius: 16px 16px 0 0;
  width: 100%; max-width: 600px;
  box-shadow: 0 -4px 24px rgba(0,0,0,.15);
  animation: slideUp .2s ease;
}
.comment-modal-header {
  padding: .75rem 1.25rem; border-bottom: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
  font-weight: 700; font-size: .95rem;
}
.comment-modal-body { padding: .75rem 1.25rem; display: flex; gap: .75rem; }
.comment-modal-footer {
  padding: .75rem 1.25rem; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}

/* ── Emoji picker ──────────────────────────────────────────── */
.emoji-btn {
  background: none; border: none; cursor: pointer; font-size: 1.25rem;
  padding: .25rem; border-radius: 50%; transition: background .15s;
  line-height: 1;
}
.emoji-btn:hover { background: var(--surface); }
.emoji-picker {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: 0 4px 20px rgba(0,0,0,.12);
  padding: .5rem; width: 280px;
}
.emoji-picker-grid {
  display: grid; grid-template-columns: repeat(8,1fr); gap: 2px;
  max-height: 200px; overflow-y: auto;
}
.emoji-picker-grid button {
  background: none; border: none; cursor: pointer;
  font-size: 1.3rem; padding: .2rem; border-radius: 6px;
  transition: background .1s; line-height: 1;
}
.emoji-picker-grid button:hover { background: var(--surface); }
.emoji-picker-cats {
  display: flex; gap: .25rem; margin-bottom: .4rem;
  border-bottom: 1px solid var(--border); padding-bottom: .4rem;
}
.emoji-cat-btn {
  background: none; border: none; cursor: pointer; font-size: 1rem;
  padding: .2rem .4rem; border-radius: 6px; opacity: .6; transition: all .15s;
}
.emoji-cat-btn.active, .emoji-cat-btn:hover { opacity: 1; background: var(--surface); }

/* ── Bookmark / save button ────────────────────────────────── */
.save-post-btn { color: var(--text-mute); font-size: .85rem; }
.save-post-btn.saved { color: var(--gold); }
.save-post-btn:hover { color: var(--gold); }

/* v5.3 Company owner dashboard */
.company-dashboard-layout{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:260px minmax(0,1fr);gap:1.25rem;align-items:start}.company-admin-sidebar{overflow:hidden;position:sticky;top:88px}.company-admin-cover{height:76px;background:var(--navy);overflow:hidden}.company-admin-cover img{width:100%;height:100%;object-fit:cover}.company-admin-profile{padding:0 1rem 1rem;margin-top:-30px}.company-admin-logo{width:72px;height:72px;border-radius:50%;object-fit:cover;background:#fff;border:3px solid #fff;box-shadow:0 1px 4px rgba(15,23,42,.14)}.company-admin-profile h2{font-size:1.1rem;line-height:1.25;margin:.5rem 0 .15rem;color:var(--text)}.company-admin-improve{display:block;font-size:.82rem;font-weight:700;color:var(--accent);margin-bottom:.35rem}.company-admin-followers{font-size:.82rem;color:var(--text-mute);margin-bottom:.75rem}.company-admin-create,.company-admin-view{width:100%;justify-content:center;margin-bottom:.45rem}.company-admin-nav{display:flex;flex-direction:column;border-top:1px solid var(--border);padding:.55rem 0}.company-admin-nav a{padding:.72rem 1rem;color:var(--text);font-weight:600;font-size:.9rem}.company-admin-nav a:hover,.company-admin-nav a.active{background:#eef7f1;color:var(--success);box-shadow:inset 3px 0 0 var(--success);text-decoration:none}.company-admin-main{display:grid;gap:1rem}.company-action-card h1,.company-stats-card h2,.company-posts-card h2{font-size:1.15rem;margin:0;color:var(--text)}.muted{color:var(--text-mute);font-size:.9rem;margin:.25rem 0 .75rem}.company-action-list{display:grid;gap:.75rem}.company-action-item{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:1rem;align-items:center;border:1px solid var(--border);border-radius:10px;padding:1rem;background:#fff}.company-action-item strong{display:block;margin-bottom:.2rem}.company-action-item p{margin:0;color:var(--text-mute);font-size:.86rem}.company-action-item a{font-weight:700;font-size:.85rem}.company-action-item button{border:0;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-mute)}.company-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.company-stat-box{border:1px solid var(--border);border-radius:10px;padding:1rem;background:#fff}.company-stat-box strong{display:block;font-size:1.6rem;color:var(--text)}.company-stat-box span{display:block;font-weight:700;color:var(--slate);font-size:.86rem}.company-stat-box small{display:block;color:var(--danger);font-size:.76rem;margin-top:.2rem}.company-section-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.company-post-carousel{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,1fr);gap:.8rem;overflow-x:auto;padding-bottom:.35rem;scroll-snap-type:x proximity}.company-post-preview{border:1px solid var(--border);border-radius:10px;background:#fff;overflow:hidden;min-height:280px;scroll-snap-align:start}.company-post-boost{padding:.75rem;border-bottom:1px solid var(--border);font-size:.78rem;color:var(--text);background:#f8fafc}.company-post-boost button{float:right;border:1px solid var(--slate);background:#fff;color:var(--slate);border-radius:999px;font-weight:700;padding:.2rem .55rem}.company-post-head{display:flex;align-items:center;gap:.55rem;padding:.75rem}.company-post-head img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}.company-post-head small{display:block;color:var(--text-mute);font-size:.75rem}.company-post-head span{margin-left:auto;color:var(--text-mute);font-weight:700}.company-post-preview p{padding:0 .75rem;margin:0 0 .7rem;font-size:.88rem;line-height:1.45}.company-post-image{width:100%;height:140px;object-fit:cover;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.company-post-metrics{padding:.65rem .75rem;color:var(--text-mute);font-size:.82rem}.company-empty-state{border:1px dashed var(--border);border-radius:10px;padding:1rem;color:var(--text-mute);background:#f8fafc}.company-feed-link{display:block;text-align:center;margin-top:.9rem;color:var(--text);font-weight:700}.company-conversation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.company-conversation-card{border:1px solid var(--border);border-radius:10px;background:#fff;padding:1rem;min-height:150px}.company-conversation-card p{font-size:.86rem;color:var(--text);margin:.5rem 0 1rem}.company-conversation-card small{color:var(--text-mute)}
@media(max-width:900px){.company-dashboard-layout{grid-template-columns:1fr}.company-admin-sidebar{position:static}.company-admin-nav{display:grid;grid-template-columns:repeat(2,1fr)}.company-stat-grid,.company-conversation-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.company-action-item{grid-template-columns:1fr}.company-stat-grid,.company-conversation-grid{grid-template-columns:1fr}.company-section-head{display:block}.company-post-carousel{grid-auto-columns:86%}}

/* v5.5 company page contributions management */
.company-posts-admin-layout{grid-template-columns:260px minmax(0,560px) 260px;align-items:start}.company-page-posts-main{min-width:0}.company-page-posts-panel{overflow:hidden}.company-page-tabs-head{padding:1rem 1.25rem .5rem}.company-page-tabs-head h1{font-size:1.2rem;margin:0;color:var(--text)}.company-page-tabs-head p{margin:.25rem 0 0;color:var(--text-mute);font-size:.86rem}.company-page-tabs{display:flex;gap:1.25rem;border-bottom:1px solid var(--border);padding:0 1.25rem}.company-page-tabs span{padding:.75rem 0;font-weight:700;font-size:.9rem;color:var(--text-mute)}.company-page-tabs span.active{color:var(--success);border-bottom:3px solid var(--success)}.company-page-composer{padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:#fff}.company-page-composer-row{display:flex;gap:.75rem;align-items:flex-start}.company-page-composer-row img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}.company-page-composer-row textarea{flex:1;border:1px solid var(--border);border-radius:999px;resize:vertical;min-height:44px;padding:.75rem 1rem;font:inherit}.company-page-composer-actions{display:flex;gap:1rem;align-items:center;justify-content:flex-end;margin-top:.8rem;color:var(--slate);font-size:.86rem;font-weight:700}.company-page-composer-actions label{cursor:pointer}.company-managed-post{border-top:1px solid var(--border);background:#fff}.company-post-boost-line{font-size:.78rem;color:var(--text-mute);background:#f8fafc;border-bottom:1px solid var(--border);padding:.65rem 1rem}.company-post-boost-line button{float:right;border:1px solid var(--slate);background:#fff;color:var(--slate);border-radius:999px;padding:.2rem .6rem;font-weight:700}.company-managed-post-inner{padding:.85rem 1rem}.company-post-author-line{font-size:.78rem;color:var(--text-mute);margin-bottom:.55rem}.company-post-author-line span{float:right;font-weight:700}.company-post-head.big{padding:0;margin-bottom:.7rem}.company-post-head.big img{width:42px;height:42px}.company-managed-content{font-size:.92rem;line-height:1.5;margin:.4rem 0 .8rem}.company-managed-image{width:100%;max-height:380px;object-fit:cover;border:1px solid var(--border);border-radius:8px;background:#f8fafc}.company-managed-metrics{font-size:.8rem;color:var(--text-mute);padding:.65rem 0;border-bottom:1px solid var(--border)}.company-managed-actions{display:flex;justify-content:space-around;border-bottom:1px solid var(--border);padding:.5rem 0}.company-managed-actions button{border:0;background:transparent;color:var(--text-mute);font-weight:700;cursor:pointer}.company-comment-preview{padding:.7rem 0}.company-comment-preview input{width:100%;border:1px solid var(--border);border-radius:999px;padding:.55rem .85rem}.company-small-comment{font-size:.8rem;margin-top:.55rem;background:#f8fafc;border-radius:8px;padding:.55rem}.company-post-footer-line{display:flex;justify-content:space-between;gap:1rem;color:var(--text-mute);font-size:.76rem;padding-top:.55rem}.company-page-posts-side{display:grid;gap:1rem;position:sticky;top:88px}.company-page-posts-side h3{font-size:1rem;margin:0 0 .25rem;color:var(--text)}.company-side-top-post{display:flex;gap:.6rem;align-items:flex-start;margin:.75rem 0}.company-side-top-post img{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}.company-side-top-post small{display:block;color:var(--text-mute);font-size:.75rem;margin-top:.25rem}@media(max-width:1100px){.company-posts-admin-layout{grid-template-columns:220px minmax(0,1fr)}.company-page-posts-side{grid-column:2;position:static}}@media(max-width:820px){.company-posts-admin-layout{grid-template-columns:1fr}.company-page-posts-side{grid-column:auto}.company-page-composer-actions{justify-content:flex-start;flex-wrap:wrap}.company-post-footer-line{display:block}.company-admin-sidebar{position:static}}

/* v5.8 video posts */
.post-video{width:100%;max-height:520px;background:#000;display:block;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.company-managed-video{width:100%;max-height:520px;background:#000;display:block;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* Company public page more menu */
.company-public-actions .company-public-more { margin-left: 0; display: inline-flex; }
.company-public-actions .company-more-btn { min-width: 48px; padding-left: 1rem; padding-right: 1rem; font-weight: 800; }
.company-public-actions .company-public-menu { min-width: 250px; top: calc(100% + 8px); border-radius: 14px; }
.company-public-actions .company-public-menu a.post-menu-item { text-decoration: none; }
@media (max-width: 640px) {
  .company-public-actions .company-public-more { width: auto; }
  .company-public-actions .company-public-menu { right: auto; left: 0; }
}

/* v6.7 company public menu layering fix */
.company-public-layout,
.company-public-main,
.company-public-hero,
.company-public-info,
.company-public-actions,
.company-public-tabs {
  overflow: visible;
}
.company-public-hero {
  position: relative;
  z-index: 30;
}
.company-public-tabs {
  position: relative;
  z-index: 1;
}
.company-public-actions .company-public-more {
  position: relative;
  z-index: 80;
}
.company-public-actions .company-public-menu {
  z-index: 9999;
  background: var(--white);
  box-shadow: 0 14px 36px rgba(13,27,42,.18);
}
.company-public-actions .company-public-menu.open {
  display: block;
}
.company-public-layout .card:not(.company-public-hero) {
  position: relative;
  z-index: 1;
}

/* v6.8 definitive company public more-menu clipping fix */
.card.company-public-hero,
.company-public-hero,
.company-public-info,
.company-public-actions,
.company-public-more {
  overflow: visible !important;
}
.company-public-hero {
  position: relative !important;
  z-index: 50 !important;
}
.company-public-actions {
  position: relative !important;
  z-index: 80 !important;
}
.company-public-more {
  position: relative !important;
  z-index: 120 !important;
}
.company-public-menu {
  z-index: 99999 !important;
  top: calc(100% + 8px) !important;
  right: 0 !important;
  left: auto !important;
}

/* v7.2: keep company conversation cards in original compact 3-card style */
.company-conversation-card{display:block;text-decoration:none;color:var(--text);border:1px solid var(--border);border-radius:12px;background:#fff;padding:1.15rem 1.25rem;min-height:150px;overflow:hidden}
.company-conversation-card:hover{text-decoration:none;box-shadow:0 6px 18px rgba(15,23,42,.08);transform:translateY(-1px)}
.company-conversation-card strong{display:block;font-size:1.05rem;line-height:1.3;margin-bottom:.55rem;color:var(--text)}
.company-conversation-card p{font-size:.98rem;line-height:1.48;color:var(--text);margin:0 0 1rem}
.company-conversation-card small{display:block;color:var(--text-mute);font-size:.88rem;margin-top:auto}
.company-member-post-head,.company-member-post-media{display:none!important}

/* Chat photo/video attachments */
.msg-input-bar{gap:.55rem;align-items:flex-end}
.msg-input-wrap{flex:1;min-width:0;display:grid;gap:.35rem}
.msg-attach-btn{width:38px;height:38px;border:1px solid var(--border);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--slate);cursor:pointer;font-size:1rem;flex:0 0 auto}
.msg-attach-btn:hover{background:#f8fafc;border-color:var(--primary)}
.msg-attachment-preview{display:flex;align-items:center;justify-content:space-between;gap:.5rem;border:1px solid var(--border);border-radius:999px;background:#fff;padding:.35rem .55rem;font-size:.82rem;color:var(--text-mute);max-width:100%}
.msg-clear-attachment{border:0;background:transparent;color:var(--danger);font-size:1.05rem;line-height:1;cursor:pointer;font-weight:700}
.msg-bubble .msg-text + .msg-media{margin-top:.45rem}
.msg-media{display:block;border-radius:12px;max-width:min(360px,70vw);background:#000;overflow:hidden}
.msg-image{max-height:360px;object-fit:cover;border:1px solid rgba(15,23,42,.08)}
.msg-video{max-height:360px;width:min(360px,70vw)}
.msg-bubble.sent .msg-media{margin-left:auto}
.msg-bubble.recv .msg-media{margin-right:auto}
.msg-bubble[data-pending="1"]{opacity:.72}
@media(max-width:640px){.msg-media,.msg-video{max-width:72vw}.msg-attach-btn{width:34px;height:34px}.msg-input-bar{padding:.55rem}}

/* Chat UX fixes: hide empty attachment preview, emoji picker, message likes */
.msg-attachment-preview[hidden], .msg-emoji-picker[hidden]{display:none!important}
.msg-emoji-btn{width:38px;height:38px;border:1px solid var(--border);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--slate);cursor:pointer;font-size:1rem;flex:0 0 auto}
.msg-emoji-btn:hover{background:#f8fafc;border-color:var(--primary)}
.msg-input-wrap{position:relative}
.msg-emoji-picker{position:absolute;left:0;bottom:calc(100% + 8px);display:grid;grid-template-columns:repeat(6,32px);gap:.25rem;padding:.5rem;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);z-index:50}
.msg-emoji-picker button{border:0;background:transparent;border-radius:8px;width:32px;height:32px;cursor:pointer;font-size:1.1rem;line-height:1}
.msg-emoji-picker button:hover{background:#f1f5f9}
.msg-bubble-wrap{display:flex;flex-direction:column;max-width:68%;gap:.2rem}
.msg-bubble-wrap.sent{align-self:flex-end;align-items:flex-end}
.msg-bubble-wrap.recv{align-self:flex-start;align-items:flex-start}
.msg-bubble-wrap .msg-bubble{max-width:100%;align-self:unset}
.msg-bubble-wrap[data-pending="1"]{opacity:.72}
.msg-like-btn{border:0;background:transparent;color:var(--text-mute);font-size:.78rem;line-height:1;cursor:pointer;padding:.15rem .35rem;border-radius:999px;opacity:.75}
.msg-like-btn:hover,.msg-like-btn.liked{background:#eef2f7;color:var(--primary);opacity:1}
.msg-like-btn span:empty{display:none}
@media(max-width:640px){.msg-bubble-wrap{max-width:85%}.msg-emoji-btn{width:34px;height:34px}.msg-emoji-picker{grid-template-columns:repeat(4,32px)}}

/* v7.9 post media zoom modal */
.post-image,
.post-video,
.company-managed-image,
.company-managed-video,
.company-post-image,
.company-public-post-media,
.li-feature-card img,
.li-feature-card video,
.li-activity-card img.media,
.li-activity-card video.media {
  cursor: zoom-in;
}
.media-zoom-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, .86);
  padding: 28px;
}
.media-zoom-modal.is-open { display: flex; }
.media-zoom-dialog {
  position: relative;
  width: min(1180px, 96vw);
  max-height: 92vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.media-zoom-content img,
.media-zoom-content video {
  max-width: 100%;
  max-height: 92vh;
  border-radius: 14px;
  background: #000;
  box-shadow: 0 24px 80px rgba(0,0,0,.35);
}
.media-zoom-content video { width: min(1100px, 94vw); }
.media-zoom-close {
  position: absolute;
  top: -18px;
  right: -18px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 0;
  background: #fff;
  color: #0f172a;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.media-zoom-hint {
  position: absolute;
  left: 50%;
  bottom: -34px;
  transform: translateX(-50%);
  color: rgba(255,255,255,.78);
  font-size: .85rem;
  white-space: nowrap;
}
@media(max-width:640px){
  .media-zoom-modal{padding:14px}
  .media-zoom-close{top:8px;right:8px}
  .media-zoom-hint{display:none}
  .media-zoom-content img,.media-zoom-content video{max-height:86vh;border-radius:10px}
}

.comment-profile-link { color: inherit; text-decoration: none; cursor: pointer; }
.comment-profile-link:hover .comment-avatar, .comment-profile-link.comment-author:hover { opacity: .9; text-decoration: underline; }

/* v8.2 comment replies, media, emoji and likes */
.comment { display:block; }
.comment-main-row { display:flex; gap:.65rem; width:100%; }
.comment-replies { margin-left:3rem; border-left:2px solid var(--border); padding-left:.65rem; }
.comment-reply-form-wrap { margin:.45rem 0 .2rem 3rem; }
.comment-actions-mini { display:flex; gap:.75rem; align-items:center; margin-top:.35rem; color:var(--text-mute); font-size:.8rem; }
.comment-actions-mini button { border:0; background:transparent; padding:0; color:var(--text-mute); font-weight:700; cursor:pointer; font-family:inherit; }
.comment-actions-mini button:hover, .comment-actions-mini button.liked { color:var(--gold); }
.comment-media { display:block; margin-top:.45rem; border-radius:12px; border:1px solid var(--border); background:#000; max-width:min(100%,420px); cursor:zoom-in; }
.comment-media-image { max-height:320px; object-fit:cover; }
.comment-media-video { max-height:320px; }
.enhanced-comment-form { align-items:flex-start; }
.comment-tool-btn { width:34px; height:34px; min-width:34px; border:1px solid var(--border); border-radius:50%; background:#fff; color:var(--navy); display:inline-flex; align-items:center; justify-content:center; cursor:pointer; font-size:1rem; }
.comment-tool-btn:hover { background:var(--surface); }
.comment-media-preview { margin-top:.45rem; position:relative; max-width:260px; }
.comment-media-preview img, .comment-media-preview video { max-width:260px; max-height:180px; border-radius:10px; border:1px solid var(--border); display:block; object-fit:cover; background:#000; }
.comment-preview-clear { position:absolute; top:4px; right:4px; width:24px; height:24px; border:0; border-radius:50%; background:rgba(0,0,0,.7); color:#fff; cursor:pointer; }
@media(max-width:640px){.comment-replies,.comment-reply-form-wrap{margin-left:1.2rem}.enhanced-comment-form{gap:.35rem}.comment-tool-btn{width:30px;height:30px;min-width:30px}.comment-media{max-width:100%}}
.comment { display:flex; flex-wrap:wrap; }
.comment > .comment-main-row { display:flex; gap:.65rem; width:100%; }
.comment > .comment-replies, .comment > .comment-reply-form-wrap { flex-basis:100%; }


/* v8.4 mentions + hashtags */
.mention-link,
.hashtag-link { color: var(--slate); font-weight: 700; text-decoration: none; }
.mention-link:hover,
.hashtag-link:hover { text-decoration: underline; }
.comment-text .mention-link,
.comment-text .hashtag-link,
.post-content .mention-link,
.post-content .hashtag-link { color: var(--slate); }
.modal-textarea::placeholder,
.comment-form input::placeholder { color: var(--text-mute); }
.hashtag-hint { display:inline-flex; align-items:center; gap:.35rem; border:1px solid var(--border); border-radius:999px; padding:.25rem .65rem; font-weight:700; color:var(--slate); background:#fff; cursor:pointer; }
.hashtag-hint:hover { background:#f8fafc; }

.company-mention-link{font-weight:800;}

/* v9.9 vacancy management + clearer unread messages */
.msg-thread-top { display:flex; align-items:center; gap:.45rem; min-width:0; }
.msg-thread-top .msg-thread-name { min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.msg-thread.msg-unread { background:#fff7e8; border-left:4px solid var(--gold); padding-left:calc(1rem - 4px); }
.msg-thread.msg-unread:hover,.msg-thread.msg-unread.active { background:#fff2d6; }
.msg-thread.msg-unread .msg-thread-name { font-weight:800; color:var(--navy); }
.msg-thread.msg-unread .msg-thread-preview { font-weight:700; color:var(--text); }
.msg-unread .msg-thread-name::after { content:'' !important; margin:0 !important; }
.msg-unread-badge { margin-left:auto; min-width:1.35rem; height:1.35rem; padding:0 .35rem; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; background:var(--gold); color:#fff; font-size:.72rem; font-weight:800; flex-shrink:0; }
.msg-new-label { margin-top:.2rem; display:inline-block; color:var(--gold); font-size:.74rem; font-weight:800; }

/* v9.9.1: robust unread chat badge */
.msg-thread { position: relative; }
.msg-thread.msg-unread { background:#eef6ff !important; border-left:4px solid var(--navy) !important; }
.msg-thread.msg-unread:hover,.msg-thread.msg-unread.active { background:#e3f0ff !important; }
.msg-thread.msg-unread .msg-thread-name,
.msg-thread.msg-unread .msg-thread-preview { font-weight:800 !important; color:var(--navy) !important; }
.msg-thread .msg-unread-badge { position:absolute !important; right:.85rem !important; top:.85rem !important; min-width:1.55rem !important; height:1.55rem !important; padding:0 .42rem !important; border-radius:999px !important; display:inline-flex !important; align-items:center !important; justify-content:center !important; background:var(--navy) !important; color:#fff !important; font-size:.78rem !important; font-weight:900 !important; line-height:1 !important; box-shadow:0 2px 6px rgba(15,59,99,.22) !important; z-index:2 !important; }
.msg-new-label { color:var(--navy) !important; font-size:.74rem !important; font-weight:800 !important; }


/* v10.0 mobile/PWA responsive improvements */
.mobile-nav-toggle{display:none;border:1px solid var(--border);background:#fff;color:var(--navy);border-radius:12px;width:40px;height:40px;font-size:1.35rem;font-weight:800;align-items:center;justify-content:center;cursor:pointer}
@media (max-width: 1024px){
  .main-content{max-width:100%;padding:1rem .85rem 5.5rem}
  .page-grid,.page-grid-2,.page-grid-wide{grid-template-columns:1fr;gap:1rem}
  .page-grid>aside,.page-grid-2>aside,.page-grid-wide>aside{order:2}
  .page-grid>main,.page-grid-2>main,.page-grid-wide>main{order:1}
  .card{border-radius:14px}
}
@media (max-width: 820px){
  body{font-size:16px;overflow-x:hidden}
  .navbar{height:64px;padding:0 .75rem}
  .navbar-inner{gap:.6rem;max-width:100%}
  .navbar-brand .brand-logo{height:34px;max-width:120px}.brand-text{display:none}.brand-icon{width:36px;height:36px;border-radius:50%}
  .nav-search{max-width:none;flex:1}.nav-search form input{height:42px;font-size:.94rem}
  .mobile-nav-toggle{display:inline-flex;order:9}
  .nav-links{position:fixed;left:0;right:0;bottom:0;z-index:1000;background:#fff;border-top:1px solid var(--border);box-shadow:0 -8px 22px rgba(13,27,42,.08);display:flex;justify-content:space-around;gap:0;padding:.35rem .25rem calc(.35rem + env(safe-area-inset-bottom));transform:none}
  .nav-links li{flex:1}.nav-icon{padding:.35rem .15rem;font-size:.64rem;border-radius:10px}.nav-icon svg{width:22px;height:22px}.badge{top:2px;right:22%}
  .lang-switcher{display:none}.nav-profile{order:8}.nav-avatar{width:38px;height:38px}
  .form-row{grid-template-columns:1fr}.btn{min-height:40px}.post-compose{align-items:flex-start}.post-compose input[type="text"]{min-height:44px}
  .profile-header-body{display:block;margin-top:-44px;padding:0 1rem 1rem}.profile-avatar{width:88px;height:88px}.profile-meta{padding-top:.5rem}.profile-actions{display:flex;flex-wrap:wrap;gap:.5rem}.profile-actions .btn{flex:1;justify-content:center}
  .company-admin-layout,.company-public-layout,.company-dashboard-layout{grid-template-columns:1fr!important;max-width:100%!important;padding:.75rem!important}
  .company-admin-sidebar,.company-public-sidebar{position:static!important;width:100%!important}.company-tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.company-tabs a{display:inline-flex}
  .messages-page,.messages-shell,.messages-container{height:calc(100vh - 84px - env(safe-area-inset-bottom))!important;min-height:560px;display:grid!important;grid-template-columns:1fr!important}.messages-sidebar,.messages-list{max-height:220px;overflow:auto;border-right:0!important;border-bottom:1px solid var(--border)}.message-pane,.chat-pane{min-height:0}.message-input,.chat-input,.message-form{position:sticky;bottom:calc(56px + env(safe-area-inset-bottom));background:#fff;z-index:20}
  .post-card img,.post-media img,.post-media video,.activity-media video,.activity-media img{max-height:62vh;object-fit:contain;background:#000}
}
@media (max-width: 560px){
  .main-content{padding:.75rem .55rem 5.25rem}.navbar{padding:0 .45rem}.nav-search form input{padding:.5rem .75rem}.nav-icon span:not(.badge){font-size:.58rem}.nav-icon svg{width:20px;height:20px}
  .card-body{padding:1rem}.card-section{padding:.85rem 1rem}.hero,.eu-section{padding-left:1rem!important;padding-right:1rem!important}.login-card{padding:1.25rem!important}.hero-text h1{font-size:2rem!important}
  .features-inner,.eu-section{grid-template-columns:1fr!important}.feature-item{padding:1.4rem 1rem!important}.jobs-cta{padding:2rem 1rem!important}
  .post-actions{display:flex;justify-content:space-around}.comment-main-row{gap:.45rem}.comment-replies,.comment-reply-form-wrap{margin-left:.75rem!important}
  .activity-feed,.profile-activity-list{display:block!important}.activity-card,.post-card{width:100%!important;margin-bottom:1rem}.activity-grid{grid-template-columns:1fr!important}
  .table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.hide-mobile{display:none!important}
}

/* v10.0.1 responsive navigation + mobile overflow fixes */
.mobile-nav-toggle { display:none !important; }
.mobile-nav-backdrop,
.mobile-nav-drawer { display:none; }

/* General overflow guard for all pages */
html, body { max-width:100%; overflow-x:hidden; }
*, *::before, *::after { box-sizing:border-box; }
img, video, iframe, canvas, svg { max-width:100%; }
.card, .post-card, .company-card, .profile-card, .sidebar-card,
.company-section, .profile-section, .messages-container, .messages-shell,
.post-menu, .modal, .modal-content { min-width:0; }
input, textarea, select, button { max-width:100%; }
pre, code { white-space:pre-wrap; word-break:break-word; }
.post-content, .comment-body, .msg-bubble, .profile-section, .company-section,
.company-about, .company-public-hero, .notification-card { overflow-wrap:anywhere; word-break:break-word; }
.table-responsive, .responsive-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; }

@media (min-width: 821px) {
  .mobile-nav-toggle { display:none !important; visibility:hidden !important; }
  body.mobile-nav-open { overflow:auto; }
  .mobile-nav-backdrop, .mobile-nav-drawer { display:none !important; }
}

@media (max-width: 820px) {
  .mobile-nav-toggle { display:inline-flex !important; }
  .mobile-nav-backdrop {
    display:block; position:fixed; inset:0; background:rgba(13,27,42,.34);
    opacity:0; pointer-events:none; transition:opacity .18s ease; z-index:1400;
  }
  .mobile-nav-drawer {
    display:flex; flex-direction:column; gap:.1rem; position:fixed; top:0; right:0;
    width:min(86vw, 340px); height:100dvh; background:#fff; z-index:1500;
    box-shadow:-18px 0 45px rgba(13,27,42,.18); transform:translateX(105%);
    transition:transform .2s ease; padding:1rem; overflow:auto;
  }
  body.mobile-nav-open { overflow:hidden; }
  body.mobile-nav-open .mobile-nav-backdrop { opacity:1; pointer-events:auto; }
  body.mobile-nav-open .mobile-nav-drawer { transform:translateX(0); }
  .mobile-drawer-head { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-bottom:.75rem; border-bottom:1px solid var(--border); }
  .mobile-drawer-close { border:0; background:var(--surface); color:var(--navy); width:38px; height:38px; border-radius:50%; font-size:1.5rem; line-height:1; cursor:pointer; }
  .mobile-drawer-user { display:flex; align-items:center; gap:.75rem; padding:1rem 0; border-bottom:1px solid var(--border); margin-bottom:.4rem; }
  .mobile-drawer-user img { width:48px; height:48px; border-radius:50%; object-fit:cover; border:1px solid var(--border); flex:0 0 auto; }
  .mobile-drawer-user small { display:block; color:var(--text-mute); line-height:1.3; }
  .mobile-nav-drawer a { display:block; padding:.85rem .4rem; color:var(--text); font-weight:700; text-decoration:none; border-radius:10px; }
  .mobile-nav-drawer a:hover { background:var(--surface); color:var(--navy); }
  .mobile-nav-drawer hr { width:100%; border:0; border-top:1px solid var(--border); margin:.5rem 0; }

  .navbar { width:100%; }
  .navbar-inner { min-width:0; }
  .navbar-brand { flex:0 0 auto; }
  .nav-search { min-width:0; }
  .nav-profile { flex:0 0 auto; }
  .nav-dropdown { display:none !important; }

  .main-content, .page-grid, .page-grid-2, .page-grid-wide,
  .company-dashboard-layout, .company-public-layout, .company-admin-layout,
  .profile-layout, .notifications-layout, .jobs-layout { width:100% !important; max-width:100% !important; }
  .feed-layout, .home-layout { grid-template-columns:1fr !important; }
  .right-sidebar, .left-sidebar { width:100% !important; max-width:100% !important; position:static !important; }

  .post-actions, .company-actions, .profile-actions, .card-actions { flex-wrap:wrap; }
  .post-actions > *, .company-actions > *, .profile-actions > * { min-width:0; }
  .company-page-tabs, .profile-tabs, .notification-tabs { overflow-x:auto; white-space:nowrap; -webkit-overflow-scrolling:touch; }

  .modal-content, .post-modal, .media-modal-content { width:calc(100vw - 1rem) !important; max-width:calc(100vw - 1rem) !important; }
  .media-lightbox img, .media-lightbox video { max-width:96vw; max-height:82dvh; object-fit:contain; }
}

@media (max-width: 560px) {
  .navbar-inner { gap:.45rem; }
  .nav-search form input { min-width:0; }
  .navbar-brand .brand-logo { max-width:42px; }
  .brand-logo { object-fit:contain; }
  .card, .post-card, .sidebar-card { border-radius:12px; }
  .company-stat-grid, .company-conversation-grid, .features-inner, .profile-stats-grid { grid-template-columns:1fr !important; }
  .post-media img, .post-media video, .company-managed-image, .company-managed-video { width:100%; height:auto; max-height:70dvh; object-fit:contain; }
  .messages-container, .messages-shell { border-radius:0 !important; margin:0 !important; width:100% !important; }
  .messages-sidebar, .messages-list { max-width:100% !important; }
}

/* v10.1 conservative responsive rollback/fix
   Keep desktop/tablet layout stable; only switch to mobile layout at smaller widths. */
@media (min-width: 901px) {
  .main-content { max-width:1100px !important; margin-left:auto !important; margin-right:auto !important; padding:1.5rem 1rem !important; }
  .page-grid { display:grid !important; grid-template-columns:240px minmax(0,1fr) 280px !important; gap:1.25rem !important; }
  .page-grid-2 { display:grid !important; grid-template-columns:240px minmax(0,1fr) !important; gap:1.25rem !important; }
  .page-grid-wide { display:grid !important; grid-template-columns:minmax(0,1fr) 300px !important; gap:1.25rem !important; }
  .page-grid > *, .page-grid-2 > *, .page-grid-wide > * { display:block !important; order:initial !important; }
  .feed-layout, .home-layout { grid-template-columns:240px minmax(0,1fr) 280px !important; }
  .left-sidebar, .right-sidebar { display:block !important; position:static !important; width:auto !important; max-width:none !important; }
  .nav-links { position:static !important; display:flex !important; transform:none !important; box-shadow:none !important; border-top:0 !important; padding:0 !important; background:transparent !important; }
  .mobile-nav-toggle, .mobile-nav-backdrop, .mobile-nav-drawer { display:none !important; visibility:hidden !important; }
  body { padding-bottom:0 !important; }
}

@media (max-width: 900px) {
  .main-content { max-width:720px !important; width:100% !important; padding:1rem .85rem 5rem !important; }
  .page-grid, .page-grid-2, .page-grid-wide,
  .feed-layout, .home-layout { display:grid !important; grid-template-columns:minmax(0,1fr) !important; gap:1rem !important; }
  .page-grid > :first-child, .page-grid > :last-child,
  .feed-layout > aside, .home-layout > aside,
  .left-sidebar, .right-sidebar { display:none !important; }
  .page-grid > main, .feed-layout > main, .home-layout > main { width:100% !important; max-width:100% !important; }
}

@media (max-width: 820px) {
  .navbar { height:60px !important; padding:0 .65rem !important; }
  .navbar-inner { gap:.55rem !important; max-width:100% !important; min-width:0 !important; }
  .navbar-brand { flex:0 0 auto !important; }
  .navbar-brand .brand-logo { height:34px !important; max-width:42px !important; object-fit:contain !important; }
  .brand-text { display:none !important; }
  .nav-search { flex:1 1 auto !important; min-width:0 !important; max-width:none !important; }
  .nav-search form input { height:42px !important; min-width:0 !important; }
  .nav-links { display:none !important; }
  .mobile-nav-toggle { display:inline-flex !important; visibility:visible !important; flex:0 0 40px !important; }
  .nav-profile { flex:0 0 auto !important; }
  .nav-avatar { width:36px !important; height:36px !important; max-width:36px !important; border-radius:50% !important; object-fit:cover !important; }
  .lang-switcher { display:none !important; }
  body { overflow-x:hidden !important; }
}

@media (max-width: 560px) {
  .main-content { padding:.75rem .55rem 4.75rem !important; }
  .card, .post-card, .sidebar-card { max-width:100% !important; overflow:hidden; }
  .post-card img, .post-card video, .post-media img, .post-media video { width:100% !important; height:auto !important; max-height:70dvh !important; object-fit:contain !important; }
  .post-actions, .comment-actions, .profile-actions, .company-actions { flex-wrap:wrap !important; gap:.4rem !important; }
}

/* Keep all common avatars from stretching on responsive pages. */
.nav-avatar, .avatar, .user-avatar, .profile-avatar, .post-avatar, .comment-avatar,
.msg-avatar, .company-logo, .company-admin-logo, .company-public-logo {
  object-fit:cover;
  flex-shrink:0;
}

/* v10.2 mobile-first stabilization and drawer fix
   Desktop remains untouched; these overrides only apply to small screens. */
@media (min-width: 821px) {
  .mobile-nav-toggle,
  .mobile-nav-backdrop,
  .mobile-nav-drawer { display:none !important; visibility:hidden !important; }
}

@media (max-width: 820px) {
  body { min-width:0 !important; overflow-x:hidden !important; }
  .navbar { height:58px !important; padding:0 .5rem !important; }
  .navbar-inner { width:100% !important; max-width:100% !important; gap:.45rem !important; }
  .navbar-brand { flex:0 0 36px !important; width:36px !important; overflow:hidden !important; }
  .navbar-brand .brand-logo,
  .brand-icon { width:34px !important; height:34px !important; min-width:34px !important; max-width:34px !important; border-radius:50% !important; object-fit:contain !important; }
  .brand-text { display:none !important; }
  .nav-search { flex:1 1 auto !important; min-width:0 !important; max-width:none !important; }
  .nav-search form input { width:100% !important; min-width:0 !important; height:40px !important; font-size:.92rem !important; padding:.45rem .75rem !important; }
  .nav-links { display:none !important; }
  .lang-switcher { display:none !important; }
  .nav-profile { display:none !important; }
  .mobile-nav-toggle { display:inline-flex !important; visibility:visible !important; flex:0 0 40px !important; width:40px !important; height:40px !important; position:relative !important; z-index:1601 !important; }

  .mobile-nav-backdrop { display:block !important; visibility:visible !important; position:fixed !important; inset:0 !important; background:rgba(13,27,42,.38) !important; opacity:0 !important; pointer-events:none !important; z-index:1400 !important; transition:opacity .18s ease !important; }
  .mobile-nav-drawer { display:flex !important; visibility:visible !important; flex-direction:column !important; position:fixed !important; top:0 !important; right:0 !important; width:min(88vw, 340px) !important; height:100dvh !important; max-height:100dvh !important; background:#fff !important; z-index:1500 !important; transform:translateX(105%) !important; transition:transform .22s ease !important; box-shadow:-18px 0 45px rgba(13,27,42,.22) !important; padding:1rem !important; overflow-y:auto !important; }
  body.mobile-nav-open { overflow:hidden !important; }
  body.mobile-nav-open .mobile-nav-backdrop { opacity:1 !important; pointer-events:auto !important; }
  body.mobile-nav-open .mobile-nav-drawer { transform:translateX(0) !important; }

  .main-content { width:100% !important; max-width:680px !important; margin:0 auto !important; padding:.75rem .55rem 4.75rem !important; }
  .page-grid,
  .page-grid-2,
  .page-grid-wide,
  .feed-layout,
  .home-layout,
  .profile-layout,
  .company-public-layout,
  .company-dashboard-layout,
  .notifications-layout,
  .jobs-layout { display:block !important; width:100% !important; max-width:100% !important; }
  .page-grid > aside,
  .feed-layout > aside,
  .home-layout > aside,
  .left-sidebar,
  .right-sidebar { display:none !important; }
  .page-grid > section,
  .page-grid > main,
  .feed-layout > main,
  .home-layout > main { width:100% !important; max-width:100% !important; }

  .card,
  .post-card,
  .sidebar-card,
  .profile-section,
  .company-section { width:100% !important; max-width:100% !important; border-radius:12px !important; overflow:hidden !important; }
  .post-compose { gap:.65rem !important; padding:.75rem !important; }
  .compose-trigger { min-width:0 !important; width:100% !important; height:auto !important; min-height:42px !important; font-size:.95rem !important; }
  .post-avatar,
  .comment-avatar { flex:0 0 auto !important; }
  .post-content,
  .comment-body,
  .msg-bubble { overflow-wrap:anywhere !important; word-break:break-word !important; }
  .post-actions { display:flex !important; justify-content:space-between !important; gap:.25rem !important; }
  .post-actions > * { flex:1 1 auto !important; min-width:0 !important; }
  .comment-replies { margin-left:.75rem !important; }
  .comment-main-row { gap:.45rem !important; }
  .post-media img,
  .post-media video,
  .activity-media img,
  .activity-media video { width:100% !important; height:auto !important; max-height:68dvh !important; object-fit:contain !important; background:#000 !important; }
}


/* v10.3 mobile UX polish + install prompt */
.pwa-install-card{position:fixed;left:12px;right:12px;bottom:calc(74px + env(safe-area-inset-bottom));z-index:1800;display:flex;align-items:center;gap:.75rem;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 12px 35px rgba(13,27,42,.22);padding:.75rem .9rem}
.pwa-install-card[hidden]{display:none!important}.pwa-install-icon img{width:42px;height:42px;border-radius:12px}.pwa-install-copy{display:flex;flex-direction:column;min-width:0;flex:1;line-height:1.25}.pwa-install-copy strong{color:var(--navy);font-size:.95rem}.pwa-install-copy span{color:var(--text-mute);font-size:.82rem}.pwa-install-close{border:0;background:var(--surface);color:var(--text-mute);width:30px;height:30px;border-radius:50%;font-size:1.15rem;line-height:1;cursor:pointer;flex:0 0 auto}
@media (min-width:821px){.pwa-install-card{left:auto;right:24px;bottom:24px;width:min(420px,calc(100vw - 48px))}}

@media (max-width:820px){
  .navbar{height:64px!important;padding:0 .7rem!important}.navbar-inner{justify-content:flex-start!important;gap:.65rem!important}.navbar-brand{flex:0 0 48px!important;width:48px!important}.navbar-brand .brand-logo,.brand-icon{width:46px!important;height:46px!important;max-width:46px!important}.nav-search{display:none!important}.mobile-nav-toggle{order:2!important;border:1px solid var(--border)!important;border-radius:14px!important;background:#fff!important;color:var(--navy)!important;width:52px!important;height:52px!important;font-size:1.8rem!important;box-shadow:0 2px 10px rgba(13,27,42,.06)!important}.mobile-nav-drawer{left:0!important;right:auto!important;transform:translateX(-105%)!important;width:min(88vw,360px)!important}.mobile-nav-open .mobile-nav-drawer{transform:translateX(0)!important}
  .main-content{padding:.85rem .75rem calc(5rem + env(safe-area-inset-bottom))!important;max-width:100%!important}.card,.post-card,.profile-section,.company-section{border-radius:16px!important}.card-body{padding:1rem!important}.post-compose{padding:1rem!important;gap:.75rem!important}.post-compose .post-avatar{width:46px!important;height:46px!important}.compose-trigger,.post-compose input[type="text"]{font-size:1rem!important;min-height:50px!important;border-radius:999px!important}.post-compose-actions{padding:.8rem 1rem!important;gap:1.1rem!important;display:flex!important;flex-wrap:wrap!important}
  .post-header{padding:1rem 1rem .45rem!important;gap:.75rem!important}.post-avatar{width:48px!important;height:48px!important}.post-content{font-size:1.05rem!important;line-height:1.45!important;padding:.45rem 1rem 1rem!important}.post-actions{padding:.75rem .65rem!important;gap:.2rem!important}.post-actions .btn{font-size:.98rem!important;padding:.55rem .35rem!important;justify-content:center!important;min-height:42px!important}.post-media img,.post-media video,.post-image,.post-video{width:100%!important;max-height:70vh!important;object-fit:contain!important;background:#000!important}
  .post-menu-wrap,.comment-menu-wrap{position:static!important}.post-menu.open,.comment-menu.open{position:fixed!important;left:12px!important;right:12px!important;top:auto!important;bottom:calc(12px + env(safe-area-inset-bottom))!important;width:auto!important;min-width:0!important;max-width:none!important;border-radius:18px!important;z-index:1900!important;box-shadow:0 -12px 35px rgba(13,27,42,.28)!important;overflow:hidden!important}.post-menu-item{font-size:1.05rem!important;padding:1rem 1.15rem!important;min-height:56px!important}.post-menu-btn,.comment-menu-btn{min-width:44px!important;min-height:38px!important}
  .post-comments{overflow:visible!important}.comment{padding:.75rem .75rem!important}.comment-main-row{gap:.6rem!important}.comment-avatar{width:40px!important;height:40px!important}.comment-body{padding:.7rem .85rem!important;border-radius:14px!important}.comment-text{font-size:.98rem!important}.comment-actions-mini{font-size:.92rem!important;gap:1rem!important}.comment-replies{margin-left:1.1rem!important;padding-left:.6rem!important}.enhanced-comment-form,.comment-form{display:grid!important;grid-template-columns:auto auto auto minmax(0,1fr) auto!important;align-items:center!important;gap:.4rem!important;padding:.75rem!important}.comment-form .comment-avatar{display:none!important}.comment-form input,.enhanced-comment-form input[name=content]{min-width:0!important;width:100%!important;height:48px!important;font-size:1rem!important}.comment-tool-btn,.emoji-btn{width:44px!important;height:44px!important;min-width:44px!important}.comment-form .btn,.enhanced-comment-form .btn{width:48px!important;min-width:48px!important;height:48px!important;padding:0!important;overflow:hidden!important;border-radius:50%!important;font-size:0!important}.comment-form .btn::before,.enhanced-comment-form .btn::before{content:'➤';font-size:1rem!important;color:inherit}.emoji-picker,.mention-dropdown{max-width:calc(100vw - 24px)!important}
  .msg-input-bar,.message-input,.chat-input,.message-form{gap:.45rem!important;padding:.7rem!important}.msg-input-bar input,.message-form input{height:48px!important;font-size:1rem!important}.msg-input-bar .btn,.message-form .btn{height:48px!important;min-width:52px!important;padding:.4rem .8rem!important}.msg-bubble{max-width:88%!important}.msg-layout,.messages-shell,.messages-container{width:100%!important;max-width:100%!important}
}
@media (max-width:420px){.main-content{padding-left:.55rem!important;padding-right:.55rem!important}.post-card,.card{border-radius:14px!important}.post-actions .btn{font-size:.92rem!important}.comment-form,.enhanced-comment-form{grid-template-columns:auto auto auto minmax(0,1fr) 46px!important;gap:.32rem!important}.comment-tool-btn,.emoji-btn{width:40px!important;height:40px!important;min-width:40px!important}.comment-form .btn,.enhanced-comment-form .btn{width:46px!important;min-width:46px!important}.post-menu.open,.comment-menu.open{left:8px!important;right:8px!important}}

/* v10.4 - modal editor for posts/comments */
.edit-content-modal-overlay { z-index: 2200; }
.edit-content-modal-box { max-width: 620px; }
.edit-content-modal-textarea {
  min-height: 220px;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: .9rem 1rem;
  background: #fff;
}
.edit-content-modal-textarea:focus { border-color: var(--brand); box-shadow: 0 0 0 3px rgba(10,102,194,.10); }
.edit-content-modal-footer { gap: .75rem; }
.edit-content-tools, .edit-content-actions { display:flex; align-items:center; gap:.5rem; }
.edit-content-actions .btn { min-width: 92px; }
@media (max-width: 640px) {
  .edit-content-modal-overlay {
    align-items: flex-end;
    padding: 0;
  }
  .edit-content-modal-box {
    width: 100%;
    max-width: none;
    border-radius: 18px 18px 0 0;
    max-height: 88vh;
  }
  .edit-content-modal-body { padding: .85rem; }
  .edit-content-modal-textarea {
    min-height: 34vh;
    font-size: 1rem;
    line-height: 1.55;
  }
  .edit-content-modal-footer {
    padding: .75rem .85rem calc(.75rem + env(safe-area-inset-bottom));
  }
  .edit-content-actions { flex:1; justify-content:flex-end; }
  .edit-content-actions .btn { min-height: 44px; }
}

/* v10.5 - Comment/reply create modal */
.comment-modal-context{
  padding:.65rem 1.25rem;
  font-size:.9rem;
  color:var(--text-mute);
  border-bottom:1px solid var(--border);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.comment-modal-input-wrap{flex:1;position:relative;min-width:0}
.comment-modal-input-wrap textarea{
  width:100%;
  min-height:140px;
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:.8rem 1rem;
  font-family:inherit;
  font-size:1rem;
  line-height:1.45;
  resize:vertical;
  outline:none;
  background:#fff;
}
.comment-modal-input-wrap textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(10,102,194,.08)}
.comment-modal-tools{display:flex;align-items:center;gap:.5rem}
.comment-modal-emoji{position:absolute;left:0;bottom:calc(100% + .5rem);z-index:1200}
.comment-modal-media-preview{margin-top:.75rem;max-width:100%}
.comment-modal-media-preview img,.comment-modal-media-preview video{max-width:100%;max-height:260px;border-radius:12px;border:1px solid var(--border);object-fit:contain;background:#000}
.js-open-comment-modal input[readonly]{cursor:pointer;background:#fff}
.js-open-comment-modal{cursor:pointer}
@media (min-width: 760px){
  .comment-modal-overlay{align-items:center;padding:1rem}
  .comment-modal-box{border-radius:18px;max-width:640px;box-shadow:0 18px 50px rgba(0,0,0,.22)}
}
@media (max-width: 640px){
  .comment-modal-box{max-height:calc(100vh - 24px);display:flex;flex-direction:column}
  .comment-modal-body{padding:.85rem;gap:.6rem;overflow:auto}
  .comment-modal-header,.comment-modal-footer{padding:.8rem .95rem}
  .comment-modal-context{padding:.6rem .95rem;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .comment-modal-input-wrap textarea{min-height:170px;font-size:1.05rem;border-radius:16px}
  .comment-modal-submit{min-width:92px;height:44px;border-radius:999px}
}

/* v10.6 chat message edit/delete + branded PWA polish */
.msg-bubble-tools{display:flex;align-items:center;gap:.25rem;position:relative;margin-top:.05rem}
.msg-bubble-wrap.sent .msg-bubble-tools{justify-content:flex-end}
.msg-more-btn{border:0;background:transparent;color:var(--text-mute);font-weight:900;letter-spacing:.08em;line-height:1;border-radius:999px;padding:.12rem .35rem;cursor:pointer;opacity:.72}
.msg-more-btn:hover{background:#eef2f7;color:var(--navy);opacity:1}
.msg-action-menu{position:absolute;right:0;bottom:1.7rem;min-width:150px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 30px rgba(15,23,42,.16);overflow:hidden;z-index:30}
.msg-action-menu button{display:block;width:100%;border:0;background:#fff;padding:.75rem .85rem;text-align:left;font-weight:750;color:var(--text);cursor:pointer;white-space:nowrap}
.msg-action-menu button:hover{background:#f3f6f9}
.msg-action-menu button.danger{color:#d93025}
.msg-edited-label{font-size:.68rem;opacity:.7;margin-top:.18rem;text-align:right}
.msg-deleted-text{font-style:italic;opacity:.72}
.msg-bubble-wrap.deleted .msg-bubble{background:#eef2f7!important;color:#6b7b8d!important;border:1px dashed var(--border)!important}
@media(max-width:640px){.msg-action-menu{position:fixed;left:1rem;right:1rem;bottom:calc(env(safe-area-inset-bottom,0px) + 1rem);min-width:0;border-radius:18px}.msg-action-menu button{font-size:1rem;padding:1rem 1.1rem}.msg-more-btn{min-width:36px;min-height:30px}}


/* v11.2.4 - compact open-to-work badge redesign */
.open-work-mini-badge,
.open-work-search-badge,
.li-profile-open-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: .38rem !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin-top: .35rem !important;
  padding: .28rem .58rem !important;
  border-radius: 999px !important;
  background: #eef8f1 !important;
  color: #157347 !important;
  border: 1px solid #caead6 !important;
  font-size: .76rem !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
  text-decoration: none !important;
  white-space: normal !important;
}
.open-work-mini-badge .work-badge-icon,
.open-work-search-badge .work-badge-icon,
.li-profile-open-badge .work-badge-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 16px !important;
  width: 16px !important;
  height: 16px !important;
  border-radius: 999px !important;
  background: #1a8f54 !important;
  color: #fff !important;
  font-size: .62rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}
.li-profile-open-badge:before { content: none !important; }
.open-work-widget-person {
  align-items: flex-start !important;
}
.open-work-widget-person > div {
  min-width: 0 !important;
}
.open-work-widget-person img,
.open-work-widget-person .avatar,
.open-work-widget-person .profile-avatar {
  flex: 0 0 auto !important;
}
@media (max-width: 700px) {
  .open-work-mini-badge,
  .open-work-search-badge,
  .li-profile-open-badge {
    font-size: .72rem !important;
    padding: .25rem .5rem !important;
  }
}


/* Release notes */
.release-page{max-width:920px;margin:0 auto;display:grid;gap:1rem}.release-hero{background:linear-gradient(135deg,var(--navy),var(--navy-mid));color:#fff;overflow:hidden}.release-hero h1{font-size:2rem;margin:.2rem 0 .4rem}.release-hero p{color:rgba(255,255,255,.82);margin:0}.release-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:800;color:var(--gold)!important}.release-list{display:grid;gap:1rem}.release-card{overflow:hidden}.release-sticky{border:1px solid rgba(212,168,67,.55);box-shadow:0 10px 28px rgba(13,27,42,.09)}.release-card-body{padding:1.25rem}.release-card-top{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.75rem}.release-version{font-weight:900;color:var(--navy);font-size:.95rem}.release-badge{display:inline-flex;align-items:center;gap:.25rem;border-radius:999px;padding:.2rem .55rem;background:#f3f6f8;color:var(--slate);font-size:.78rem;font-weight:800}.release-badge-sticky{background:#fff7db;color:#8a6500}.release-card h2{font-size:1.25rem;margin:0 0 .25rem;color:var(--text)}.release-date{font-size:.82rem;color:var(--text-mute);margin-bottom:.6rem}.release-summary{font-size:.95rem;color:var(--text);line-height:1.55}.release-body{color:var(--text);font-size:.92rem;line-height:1.6}.release-body h3{font-size:1rem;margin:1rem 0 .35rem}.release-body ul{margin:.4rem 0 .75rem;padding-left:1.25rem}.release-empty{text-align:center;color:var(--text-mute)}.release-sidebar-card strong{display:block;font-size:.95rem;line-height:1.3;margin:.15rem 0}.release-sidebar-card p{font-size:.84rem;color:var(--text-mute);line-height:1.45;margin:.4rem 0 .75rem}.release-sidebar-version{display:inline-flex;width:max-content;border-radius:999px;background:#eef7f1;color:var(--success);font-size:.76rem;font-weight:900;padding:.15rem .5rem;margin-bottom:.35rem}@media(max-width:680px){.release-page{padding:0 .25rem}.release-hero h1{font-size:1.55rem}.release-card-body{padding:1rem}}

/* v11.9.1 Comfinnity header logo polish */
.navbar-brand {
  display: flex;
  align-items: center;
  padding-right: 14px;
  min-width: 0;
}
.navbar-brand .brand-logo {
  height: 46px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  image-rendering: auto;
}
.navbar-brand .brand-icon {
  width: 46px;
  height: 46px;
}
@media (max-width: 820px) {
  .navbar-brand {
    flex: 0 0 52px !important;
    width: 52px !important;
    padding-right: 0 !important;
  }
  .navbar-brand .brand-logo,
  .navbar-brand .brand-icon {
    width: 48px !important;
    height: 48px !important;
    max-width: 48px !important;
    object-fit: contain !important;
  }
}
@media (max-width: 420px) {
  .navbar-brand {
    flex-basis: 46px !important;
    width: 46px !important;
  }
  .navbar-brand .brand-logo,
  .navbar-brand .brand-icon {
    width: 44px !important;
    height: 44px !important;
    max-width: 44px !important;
  }
}
