/* ==========================================================================
   ClearMint Product Hub — UserJot-style workspace.
   Single light sidebar (COLLECT / MANAGE / WORKSPACE), black primary, popout
   menus. Fully scoped under .uj so it never touches the main app / lite.css.
   Loaded only by product-hub.html + admin-hub.html.
   ========================================================================== */
.uj{
  --uj-bg:#ffffff; --uj-side:#fbfbfa; --uj-ink:#18181b; --uj-ink-2:#3f3f46;
  --uj-muted:#71717a; --uj-faint:#a1a1aa; --uj-line:#ececec; --uj-line-2:#f4f4f5;
  --uj-hover:#f4f4f5; --uj-active:#f0f0ef; --uj-primary:#18181b; --uj-primary-hi:#000;
  --uj-blue:#2563eb;
  --uj-pending:#f59e0b; --uj-reviewing:#f97316; --uj-planned:#3b82f6; --uj-progress:#8b5cf6; --uj-done:#22c55e; --uj-closed:#a1a1aa;
  --uj-r:9px; --uj-r-lg:14px; --uj-shadow:0 1px 2px rgba(0,0,0,.04),0 4px 16px rgba(0,0,0,.06);
  --uj-shadow-lg:0 16px 50px rgba(0,0,0,.18);
  position:fixed; inset:0; display:flex; background:var(--uj-bg);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--uj-ink); font-size:14px; -webkit-font-smoothing:antialiased;
}
.uj *{ box-sizing:border-box; }
.uj a{ color:inherit; text-decoration:none; }
.uj button{ font-family:inherit; cursor:pointer; }
.uj ::-webkit-scrollbar{ width:10px; height:10px; }
.uj ::-webkit-scrollbar-thumb{ background:#e4e4e7; border-radius:9px; border:3px solid #fff; }
.uj-side ::-webkit-scrollbar-thumb{ border-color:var(--uj-side); }

/* --------------------------------------------------------------- sidebar */
.uj-side{ width:262px; flex:0 0 262px; background:var(--uj-side); border-right:1px solid var(--uj-line); display:flex; flex-direction:column; }
.uj-brand{ display:flex; align-items:center; gap:10px; padding:14px 14px; border-bottom:1px solid var(--uj-line); }
.uj-brand .logo{ width:34px; height:34px; border-radius:9px; background:#0f6b4f; display:flex; align-items:center; justify-content:center; overflow:hidden; flex:0 0 auto; }
.uj-brand .logo img{ width:100%; height:100%; object-fit:cover; }
.uj-brand .wsn{ min-width:0; flex:1; }
.uj-brand .wsn .n{ font-size:14px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uj-brand .wsn .p{ font-size:12px; color:var(--uj-done); font-weight:600; }
.uj-brand .sw{ color:var(--uj-faint); border:0; background:transparent; padding:4px; border-radius:6px; }
.uj-brand .sw:hover{ background:var(--uj-hover); color:var(--uj-ink); }

.uj-nav{ flex:1; overflow:auto; padding:10px 10px 4px; }
.uj-sec-label{ font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--uj-faint); padding:14px 8px 5px; }
.uj-item{ display:flex; align-items:center; gap:11px; width:100%; text-align:left; border:0; background:transparent; padding:8px 8px; border-radius:8px; font-size:13.5px; font-weight:500; color:var(--uj-ink-2); }
.uj-item:hover{ background:var(--uj-hover); }
.uj-item.active{ background:var(--uj-active); color:var(--uj-ink); font-weight:600; }
.uj-item .ic{ color:var(--uj-muted); display:flex; flex:0 0 auto; }
.uj-item.active .ic{ color:var(--uj-ink); }
.uj-item .lb{ flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uj-item .ct{ font-size:12px; color:var(--uj-faint); font-weight:600; background:#efefee; border-radius:6px; padding:1px 7px; min-width:20px; text-align:center; }
.uj-item.active .ct{ background:#e6e6e4; color:var(--uj-ink-2); }

.uj-foot{ border-top:1px solid var(--uj-line); padding:8px 10px; }
.uj-user{ display:flex; align-items:center; gap:10px; padding:8px; border-radius:9px; }
.uj-user:hover{ background:var(--uj-hover); }
.uj-user .av{ width:30px; height:30px; border-radius:50%; background:var(--uj-blue); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; flex:0 0 auto; }
.uj-user .nm{ flex:1; min-width:0; }
.uj-user .nm .n{ font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uj-user .nm .e{ font-size:11.5px; color:var(--uj-faint); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uj-user .gear{ color:var(--uj-faint); }

/* --------------------------------------------------------- status dots */
.uj-dot{ display:inline-flex; flex:0 0 auto; }

/* --------------------------------------------------------------- main */
.uj-main{ flex:1; min-width:0; display:flex; flex-direction:column; }
.uj-top{ height:56px; flex:0 0 56px; border-bottom:1px solid var(--uj-line); display:flex; align-items:center; gap:10px; padding:0 18px; }
.uj-top h2{ font-size:16px; font-weight:700; margin:0; }
.uj-top .sp{ flex:1; }
.uj-search{ display:flex; align-items:center; gap:7px; height:36px; padding:0 11px; border:1px solid var(--uj-line); border-radius:9px; background:#fff; color:var(--uj-muted); }
.uj-search input{ border:0; outline:none; font-size:13.5px; width:150px; background:transparent; color:var(--uj-ink); }
.uj-btn{ height:36px; padding:0 13px; border-radius:9px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-ink-2); font-size:13.5px; font-weight:600; display:inline-flex; align-items:center; gap:7px; }
.uj-btn:hover{ background:var(--uj-hover); }
.uj-btn.dark{ background:var(--uj-primary); border-color:var(--uj-primary); color:#fff; }
.uj-btn.dark:hover{ background:var(--uj-primary-hi); }
.uj-btn.sm{ height:30px; padding:0 10px; font-size:12.5px; border-radius:8px; }
.uj-btn.ghost{ border-color:transparent; background:transparent; }
.uj-btn.ghost:hover{ background:var(--uj-hover); }
.uj-btn[disabled]{ opacity:.5; cursor:default; }

.uj-content{ flex:1; overflow:auto; padding:20px 22px 60px; }
.uj-content.narrow{ max-width:840px; width:100%; margin:0 auto; }

/* filter chips row */
.uj-chips{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.uj-chip{ height:32px; padding:0 11px; border-radius:8px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-ink-2); font-size:12.5px; font-weight:600; display:inline-flex; align-items:center; gap:6px; }
.uj-chip:hover{ background:var(--uj-hover); }
.uj-chip.on{ border-color:var(--uj-ink); }
.uj-chip .x{ color:var(--uj-faint); }

/* --------------------------------------------------------- post rows */
.uj-post{ display:flex; gap:14px; padding:15px 12px; border-bottom:1px solid var(--uj-line-2); border-radius:10px; }
.uj-post:hover{ background:var(--uj-line-2); }
.uj-vote{ flex:0 0 auto; width:50px; height:54px; border-radius:10px; border:1px solid var(--uj-line); background:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1px; color:var(--uj-ink-2); }
.uj-vote:hover{ border-color:var(--uj-ink); }
.uj-vote.on{ border-color:var(--uj-ink); background:var(--uj-primary); color:#fff; }
.uj-vote b{ font-size:15px; font-weight:800; }
.uj-vote span{ font-size:9.5px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; }
.uj-post-b{ flex:1; min-width:0; }
.uj-post-t{ font-size:15px; font-weight:650; margin:0 0 3px; }
.uj-post-d{ font-size:13.5px; color:var(--uj-muted); line-height:1.5; margin:0 0 9px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.uj-post-m{ display:flex; align-items:center; gap:13px; flex-wrap:wrap; }
.uj-tag{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; color:var(--uj-ink-2); background:#fff; border:1px solid var(--uj-line); border-radius:7px; padding:3px 9px; }
.uj-mx{ display:inline-flex; align-items:center; gap:5px; font-size:12.5px; color:var(--uj-faint); font-weight:500; }
.uj-status-chip{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; }

/* --------------------------------------------------------- popout menu */
.uj-pop-wrap{ position:relative; display:inline-flex; }
.uj-menu{ position:absolute; z-index:80; min-width:200px; background:#fff; border:1px solid var(--uj-line); border-radius:11px; box-shadow:var(--uj-shadow-lg); padding:6px; max-height:320px; overflow:auto; }
.uj-menu.up{ bottom:calc(100% + 6px); } .uj-menu.down{ top:calc(100% + 6px); }
.uj-menu.right{ right:0; } .uj-menu.left{ left:0; }
.uj-mi{ display:flex; align-items:center; gap:10px; width:100%; text-align:left; border:0; background:transparent; padding:8px 9px; border-radius:8px; font-size:13.5px; color:var(--uj-ink-2); font-weight:500; }
.uj-mi:hover{ background:var(--uj-hover); }
.uj-mi.sel{ background:var(--uj-line-2); font-weight:600; color:var(--uj-ink); }
.uj-mi .ck{ margin-left:auto; color:var(--uj-ink); }
.uj-menu-label{ font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--uj-faint); padding:6px 9px 3px; }

/* selector button (board/status/tags in modal + toolbar) */
.uj-sel{ height:34px; padding:0 11px; border-radius:9px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-ink-2); font-size:13px; font-weight:600; display:inline-flex; align-items:center; gap:7px; }
.uj-sel:hover{ background:var(--uj-hover); }
.uj-sel .cv{ color:var(--uj-faint); margin-left:2px; }

/* --------------------------------------------------------- create modal */
.uj-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.32); backdrop-filter:blur(3px); display:flex; align-items:flex-start; justify-content:center; padding:9vh 16px 16px; z-index:90; overflow:auto; }
.uj-cmodal{ width:100%; max-width:640px; background:#fff; border-radius:16px; box-shadow:var(--uj-shadow-lg); overflow:visible; }
.uj-cm-head{ display:flex; align-items:center; gap:9px; padding:16px 18px 4px; }
.uj-cm-head .av{ width:34px; height:34px; border-radius:50%; background:var(--uj-blue); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; position:relative; }
.uj-cm-head .av .rk{ position:absolute; bottom:-3px; right:-3px; width:15px; height:15px; border-radius:50%; background:var(--uj-pending); border:2px solid #fff; }
.uj-cm-head .arw{ color:var(--uj-faint); }
.uj-cm-head .x{ margin-left:auto; border:0; background:transparent; color:var(--uj-faint); width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; }
.uj-cm-head .x:hover{ background:var(--uj-hover); color:var(--uj-ink); }
.uj-cm-body{ padding:6px 18px 4px; }
.uj-cm-title{ width:100%; border:0; outline:none; font-size:22px; font-weight:700; color:var(--uj-ink); padding:8px 0 6px; }
.uj-cm-title::placeholder{ color:#c4c4c8; }
.uj-cm-details{ width:100%; border:0; outline:none; font-size:14.5px; color:var(--uj-ink-2); resize:none; min-height:64px; padding:2px 0; line-height:1.55; font-family:inherit; }
.uj-cm-details::placeholder{ color:#c4c4c8; }
.uj-cm-foot{ display:flex; align-items:center; gap:8px; padding:12px 16px 14px; border-top:1px solid var(--uj-line-2); margin-top:6px; }
.uj-cm-foot .att{ width:34px; height:34px; border-radius:9px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-muted); display:inline-flex; align-items:center; justify-content:center; }
.uj-cm-foot .att:hover{ background:var(--uj-hover); }
.uj-cm-foot .sp{ flex:1; }

/* --------------------------------------------------------- roadmap board */
.uj-board{ display:grid; grid-auto-flow:column; grid-auto-columns:300px; gap:14px; overflow-x:auto; align-items:start; padding-bottom:8px; }
.uj-col-h{ display:flex; align-items:center; gap:8px; padding:4px 4px 12px; font-weight:700; font-size:13.5px; }
.uj-col-h .ct{ margin-left:auto; color:var(--uj-faint); }
.uj-rcard{ background:#fff; border:1px solid var(--uj-line); border-radius:11px; padding:13px; margin-bottom:10px; box-shadow:var(--uj-shadow); }
.uj-rcard .t{ font-weight:650; font-size:14px; margin:0 0 5px; }
.uj-rcard .d{ font-size:12.5px; color:var(--uj-muted); line-height:1.5; margin:0 0 8px; }

/* --------------------------------------------------------- changelog */
.uj-log{ border:1px solid var(--uj-line); border-radius:14px; background:#fff; padding:22px 24px; margin-bottom:18px; box-shadow:var(--uj-shadow); }
.uj-log-h{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.uj-ver{ font-family:"JetBrains Mono",ui-monospace,monospace; font-weight:600; font-size:12.5px; color:#fff; background:var(--uj-primary); padding:3px 10px; border-radius:7px; }
.uj-log h3{ font-size:18px; margin:0; font-weight:700; }
.uj-log-g{ margin-top:12px; } .uj-log-g .lab{ font-size:12.5px; font-weight:700; margin-bottom:5px; }
.uj-log-g ul{ margin:0; padding-left:20px; color:var(--uj-ink-2); font-size:14px; line-height:1.75; }

/* --------------------------------------------------------- detail */
.uj-detail{ display:grid; grid-template-columns:1fr 292px; gap:26px; align-items:start; }
.uj-back{ display:inline-flex; align-items:center; gap:6px; font-size:13px; color:var(--uj-muted); font-weight:600; margin-bottom:16px; }
.uj-back:hover{ color:var(--uj-ink); }
.uj-card{ border:1px solid var(--uj-line); border-radius:12px; padding:16px; background:#fff; box-shadow:var(--uj-shadow); }
.uj-card h4{ margin:0 0 12px; font-size:13px; font-weight:700; }
.uj-tl{ display:flex; align-items:center; gap:10px; padding:7px 0; font-size:13px; }
.uj-tl .when{ margin-left:auto; font-size:11.5px; color:var(--uj-faint); }
.uj-comment{ display:flex; gap:11px; padding:13px 0; border-top:1px solid var(--uj-line-2); }
.uj-av-sm{ width:32px; height:32px; border-radius:50%; background:#eef2ff; color:var(--uj-blue); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; flex:0 0 auto; }

/* --------------------------------------------------------- forms */
.uj-f{ margin-bottom:14px; }
.uj-f label{ display:block; font-size:13px; font-weight:600; color:var(--uj-ink-2); margin-bottom:6px; }
.uj-input,.uj-ta{ width:100%; padding:10px 12px; border:1px solid var(--uj-line); border-radius:9px; font-size:14px; font-family:inherit; color:var(--uj-ink); background:#fff; }
.uj-input:focus,.uj-ta:focus{ outline:none; border-color:var(--uj-ink); box-shadow:0 0 0 3px rgba(0,0,0,.06); }
.uj-ta{ resize:vertical; min-height:80px; }

/* modal (generic, for report bug / admin editors) */
.uj-modal{ width:100%; max-width:560px; background:#fff; border-radius:16px; box-shadow:var(--uj-shadow-lg); overflow:hidden; margin:auto; }
.uj-modal-h{ display:flex; align-items:center; padding:16px 20px; border-bottom:1px solid var(--uj-line); }
.uj-modal-h h3{ margin:0; font-size:17px; font-weight:700; }
.uj-modal-h .x{ margin-left:auto; border:0; background:transparent; font-size:22px; color:var(--uj-faint); line-height:1; }
.uj-modal-bd{ padding:20px; max-height:66vh; overflow:auto; }
.uj-modal-ft{ display:flex; justify-content:flex-end; gap:10px; padding:14px 20px; border-top:1px solid var(--uj-line); background:var(--uj-side); }

.uj-note{ background:#fffaf0; border:1px solid #f3e2c0; border-radius:10px; padding:11px 13px; margin:8px 0 14px; }
.uj-note .h{ font-size:12.5px; font-weight:700; color:#a9781f; margin-bottom:6px; }
.uj-note a{ display:block; font-size:13px; color:var(--uj-ink-2); padding:3px 0; font-weight:500; }
.uj-err{ background:#fdecea; border:1px solid #f5c6c2; color:#b23b32; border-radius:9px; padding:10px 12px; font-size:13px; margin-bottom:12px; }
.uj-empty{ text-align:center; color:var(--uj-muted); padding:46px 20px; }

/* get-started empty state */
.uj-gs{ max-width:720px; margin:14px auto; text-align:center; }
.uj-mock{ border:1px solid var(--uj-line); border-radius:14px; background:#fff; padding:16px 18px; text-align:left; box-shadow:0 10px 34px rgba(0,0,0,.07); }
.uj-mock-h{ display:flex; align-items:center; justify-content:space-between; padding-bottom:12px; border-bottom:1px solid var(--uj-line-2); margin-bottom:12px; font-size:13px; font-weight:700; }
.uj-mock-r{ display:flex; align-items:center; gap:14px; padding:8px 0; }
.uj-mock-v{ width:32px; height:38px; border-radius:8px; background:var(--uj-line-2); border:1px solid var(--uj-line); }
.uj-mock-bars{ flex:1; }
.uj-mock-bar{ height:9px; border-radius:6px; background:#eee; margin:6px 0; }
.uj-gs h3{ font-size:22px; font-weight:750; margin:22px 0 6px; }
.uj-gs p{ color:var(--uj-muted); font-size:14.5px; max-width:440px; margin:0 auto; }
.uj-gs-actions{ display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--uj-line); margin-top:24px; text-align:left; }
.uj-ga{ padding:22px 8px; }
.uj-ga:first-child{ border-right:1px solid var(--uj-line); padding-right:24px; }
.uj-ga:last-child{ padding-left:24px; }
.uj-ga .ic{ width:34px; height:34px; border-radius:9px; background:var(--uj-line-2); color:var(--uj-ink); display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.uj-ga h4{ font-size:15.5px; margin:0 0 5px; font-weight:700; }
.uj-ga p{ font-size:13.5px; color:var(--uj-muted); margin:0; }

/* stats/analytics */
.uj-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.uj-stat{ border:1px solid var(--uj-line); border-radius:12px; padding:16px; background:#fff; box-shadow:var(--uj-shadow); }
.uj-stat .l{ font-size:12.5px; color:var(--uj-muted); font-weight:600; }
.uj-stat .v{ font-size:27px; font-weight:800; margin-top:5px; }
.uj-bar-row{ display:flex; align-items:center; gap:10px; margin:5px 0; }
.uj-bar-row .l{ width:120px; font-size:12.5px; color:var(--uj-ink-2); }
.uj-bar-tk{ flex:1; height:18px; background:var(--uj-line-2); border-radius:6px; overflow:hidden; }
.uj-bar-fl{ height:100%; background:var(--uj-primary); }

/* notification popover */
.uj-npop{ position:absolute; right:16px; top:52px; width:340px; max-height:440px; overflow:auto; background:#fff; border:1px solid var(--uj-line); border-radius:12px; box-shadow:var(--uj-shadow-lg); z-index:85; }
.uj-npop-h{ display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid var(--uj-line); }
.uj-npop a{ display:block; padding:11px 14px; border-bottom:1px solid var(--uj-line-2); }
.uj-npop a:hover{ background:var(--uj-hover); }

/* table (admin) */
.uj-table{ width:100%; border-collapse:collapse; font-size:13.5px; }
.uj-table th{ text-align:left; color:var(--uj-faint); font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; padding:10px 12px; border-bottom:1px solid var(--uj-line); }
.uj-table td{ padding:11px 12px; border-bottom:1px solid var(--uj-line-2); vertical-align:middle; }
.uj-table tr:hover td{ background:var(--uj-line-2); }

/* mobile: collapsible sidebar */
.uj-burger{ display:none; }
@media(max-width:860px){
  .uj-side{ position:absolute; z-index:100; height:100%; transform:translateX(-100%); transition:.2s; box-shadow:var(--uj-shadow-lg); }
  .uj-side.open{ transform:none; }
  .uj-burger{ display:inline-flex; }
  .uj-detail{ grid-template-columns:1fr; }
  .uj-stats{ grid-template-columns:1fr 1fr; }
  .uj-gs-actions{ grid-template-columns:1fr; }
  .uj-ga:first-child{ border-right:0; border-bottom:1px solid var(--uj-line); padding:20px 0; }
  .uj-ga:last-child{ padding:20px 0; }
}
@media(max-width:520px){
  .uj-stats{ grid-template-columns:1fr; }
  .uj-content{ padding:14px; }
}

/* ============================ Glassmorphism ============================ */
/* Frosted-glass popouts (dropdown menus + notification popover) and the
   new-post modal. Translucent white + backdrop blur + soft inner highlight. */
.uj-menu, .uj-npop{
  background:rgba(255,255,255,.68);
  -webkit-backdrop-filter:blur(22px) saturate(180%);
  backdrop-filter:blur(22px) saturate(180%);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 20px 60px rgba(17,17,26,.22), inset 0 1px 0 rgba(255,255,255,.6);
}
.uj-menu .uj-mi:hover{ background:rgba(17,17,26,.055); }
.uj-menu .uj-mi.sel{ background:rgba(17,17,26,.07); }
.uj-npop a:hover{ background:rgba(17,17,26,.05); }
.uj-npop-h{ border-bottom-color:rgba(17,17,26,.08); }

/* New-post modal: heavier frost, brighter overlay blur behind it. */
.uj-overlay{ background:rgba(18,18,28,.30); -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px); }
.uj-cmodal{
  background:rgba(255,255,255,.74);
  -webkit-backdrop-filter:blur(30px) saturate(185%);
  backdrop-filter:blur(30px) saturate(185%);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 32px 90px rgba(17,17,26,.30), inset 0 1px 0 rgba(255,255,255,.7);
}
.uj-cmodal .uj-cm-foot{ border-top-color:rgba(17,17,26,.07); }
.uj-cmodal .uj-cm-title, .uj-cmodal .uj-cm-details{ background:transparent; }
/* selectors inside the modal + toolbar read as light glass too */
.uj-cmodal .uj-sel, .uj-cmodal .att{ background:rgba(255,255,255,.5); border-color:rgba(17,17,26,.1); }
.uj-cmodal .uj-sel:hover, .uj-cmodal .att:hover{ background:rgba(255,255,255,.8); }
/* graceful fallback where backdrop-filter is unsupported: stay opaque/legible */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .uj-menu, .uj-npop{ background:#fff; }
  .uj-cmodal{ background:#fff; }
}

/* ===================== UserJot tabs: rich recreation ===================== */
/* board pill (green dot) used on cards + detail */
.uj-boardpill{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; color:#137a4f; background:#e9f7ef; border:1px solid #cdeeda; border-radius:7px; padding:3px 9px; }
.uj-boardpill .d{ width:6px; height:6px; border-radius:50%; background:#1fae67; }
.uj-av-xs{ width:22px; height:22px; border-radius:50%; background:var(--uj-blue); color:#fff; display:inline-flex; align-items:center; justify-content:center; font-weight:700; font-size:10px; flex:0 0 auto; }
.uj-metric{ display:inline-flex; align-items:center; gap:5px; font-size:12.5px; color:var(--uj-muted); font-weight:600; }

/* roadmap kanban */
.uj-kb{ display:grid; grid-auto-flow:column; grid-auto-columns:288px; gap:14px; overflow-x:auto; align-items:start; height:100%; padding-bottom:10px; }
.uj-kb.collapsedcol{ grid-auto-columns:auto; }
.uj-kcol{ display:flex; flex-direction:column; min-width:0; }
.uj-kcol.col-collapsed{ width:52px; }
.uj-khead{ display:flex; align-items:center; gap:8px; padding:2px 2px 12px; }
.uj-spill{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:700; padding:4px 11px; border-radius:999px; }
.uj-khead .cnt{ color:var(--uj-faint); font-weight:700; font-size:13px; }
.uj-khead .sp{ flex:1; }
.uj-khead .ib{ width:26px; height:26px; border-radius:7px; border:0; background:transparent; color:var(--uj-faint); display:inline-flex; align-items:center; justify-content:center; }
.uj-khead .ib:hover{ background:var(--uj-hover); color:var(--uj-ink); }
.uj-kcard{ background:#fff; border:1px solid var(--uj-line); border-radius:12px; padding:14px; margin-bottom:10px; box-shadow:var(--uj-shadow); cursor:pointer; }
.uj-kcard:hover{ border-color:#dcdcdc; box-shadow:0 4px 14px rgba(0,0,0,.07); }
.uj-kcard .t{ font-weight:650; font-size:14.5px; margin:0 0 10px; color:var(--uj-ink); }
.uj-kcard .m{ display:flex; align-items:center; gap:10px; }
.uj-kcard .m .sp{ flex:1; }
.uj-vcol-lbl{ writing-mode:vertical-rl; transform:rotate(180deg); margin:8px auto; font-weight:700; font-size:12.5px; color:var(--uj-muted); }

/* post detail */
.uj-dwrap{ display:grid; grid-template-columns:1fr 300px; gap:28px; align-items:start; max-width:1100px; }
.uj-dtool{ display:flex; align-items:center; gap:6px; margin-bottom:18px; }
.uj-dtool .sp{ flex:1; }
.uj-iconbtn{ width:38px; height:38px; border-radius:9px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-ink-2); display:inline-flex; align-items:center; justify-content:center; }
.uj-iconbtn:hover{ background:var(--uj-hover); }
.uj-iconbtn.danger:hover{ background:#fdecec; color:#dc2626; border-color:#f6cfcf; }
.uj-dtitle{ font-size:26px; font-weight:750; letter-spacing:-.01em; margin:0 0 14px; }
.uj-ddesc{ font-size:15px; line-height:1.65; color:var(--uj-ink-2); white-space:pre-wrap; margin:0 0 16px; }
.uj-uppill{ display:inline-flex; align-items:center; gap:6px; height:34px; padding:0 14px; border:1px solid var(--uj-line); border-radius:999px; font-weight:700; font-size:13.5px; color:var(--uj-ink-2); background:#fff; }
.uj-uppill.on{ border-color:var(--uj-ink); background:var(--uj-primary); color:#fff; }
.uj-tabs{ display:flex; gap:22px; border-bottom:1px solid var(--uj-line); margin:22px 0 16px; }
.uj-tab{ border:0; background:transparent; padding:0 0 12px; font-size:14px; font-weight:600; color:var(--uj-faint); display:inline-flex; align-items:center; gap:7px; border-bottom:2px solid transparent; margin-bottom:-1px; }
.uj-tab.active{ color:var(--uj-ink); border-bottom-color:var(--uj-ink); }
.uj-composer{ border:1px solid var(--uj-line); border-radius:12px; padding:12px 14px; margin-bottom:20px; }
.uj-composer textarea{ width:100%; border:0; outline:none; resize:vertical; min-height:44px; font-size:14px; font-family:inherit; color:var(--uj-ink); }
.uj-composer-b{ display:flex; align-items:center; gap:10px; margin-top:8px; }
.uj-composer-b .tool{ color:var(--uj-faint); display:inline-flex; }
.uj-composer-b .sp{ flex:1; }
.uj-cmt{ display:flex; gap:12px; padding:16px 0; border-top:1px solid var(--uj-line-2); }
.uj-cmt .body{ flex:1; min-width:0; }
.uj-cmt .who{ font-weight:700; font-size:13.5px; }
.uj-cmt .who .t{ font-weight:500; color:var(--uj-faint); font-size:12px; margin-left:8px; }
.uj-cmt .txt{ font-size:14px; color:var(--uj-ink-2); margin-top:4px; line-height:1.55; }
.uj-cmt .foot{ display:flex; justify-content:flex-end; margin-top:8px; }
.uj-minipill{ display:inline-flex; align-items:center; gap:5px; height:28px; padding:0 11px; border:1px solid var(--uj-line); border-radius:999px; font-size:12.5px; font-weight:700; color:var(--uj-ink-2); background:#fff; }
.uj-reactions{ display:flex; gap:10px; flex-wrap:wrap; padding:6px 0 20px; }
.uj-react{ display:inline-flex; align-items:center; gap:7px; height:38px; padding:0 13px; border:1px solid var(--uj-line); border-radius:999px; background:#fff; font-size:15px; font-weight:600; color:var(--uj-ink-2); }
.uj-react:hover{ background:var(--uj-hover); }
.uj-react.on{ border-color:var(--uj-ink); background:var(--uj-line-2); }
.uj-react .c{ font-size:12.5px; color:var(--uj-muted); }

/* right meta panel */
.uj-meta-auth{ display:flex; align-items:center; gap:11px; margin-bottom:20px; }
.uj-meta-auth .av{ width:40px; height:40px; border-radius:50%; background:var(--uj-blue); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; }
.uj-meta-auth .n{ font-weight:700; font-size:14px; }
.uj-meta-auth .t{ font-size:12.5px; color:var(--uj-faint); }
.uj-meta-row{ display:flex; align-items:center; gap:10px; padding:9px 0; }
.uj-meta-row .k{ width:78px; font-size:13px; color:var(--uj-muted); font-weight:500; }
.uj-meta-row .v{ flex:1; }
.uj-meta-src{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:var(--uj-muted); background:var(--uj-line-2); border-radius:7px; padding:4px 9px; }
.uj-tagbox{ border:1px dashed var(--uj-line); border-radius:10px; padding:14px; text-align:center; color:var(--uj-muted); font-size:13px; font-weight:600; margin-top:8px; display:flex; align-items:center; justify-content:center; gap:7px; }
.uj-tags-hd{ display:flex; align-items:center; gap:7px; margin-top:22px; margin-bottom:4px; }
.uj-tags-hd .sp{ flex:1; }
.uj-tags-hd .ib{ color:var(--uj-faint); }

/* moderation bar */
.uj-modbar{ position:fixed; left:50%; bottom:22px; transform:translateX(-50%); display:flex; align-items:center; gap:4px; background:#18181b; color:#fff; border-radius:13px; padding:7px; box-shadow:0 16px 44px rgba(0,0,0,.3); z-index:70; }
.uj-modbar button{ display:inline-flex; align-items:center; gap:7px; height:38px; padding:0 15px; border:0; border-radius:9px; background:transparent; color:#e4e4e7; font-size:13.5px; font-weight:600; }
.uj-modbar button:hover{ background:#2a2a30; color:#fff; }
.uj-modbar button.accept{ background:#fff; color:#18181b; }
.uj-modbar button.accept:hover{ background:#f1f1f1; }
.uj-modbar .div{ width:1px; height:22px; background:#3a3a42; }

/* toggle switch */
.uj-switch{ position:relative; width:40px; height:23px; border-radius:999px; background:#d4d4d8; border:0; transition:.15s; flex:0 0 auto; }
.uj-switch.on{ background:var(--uj-primary); }
.uj-switch i{ position:absolute; top:2.5px; left:2.5px; width:18px; height:18px; border-radius:50%; background:#fff; transition:.15s; box-shadow:0 1px 2px rgba(0,0,0,.2); }
.uj-switch.on i{ left:19px; }

/* changelog editor */
.uj-cle{ display:grid; grid-template-columns:1fr 330px; gap:0; height:100%; }
.uj-cle-main{ padding:4px 6px 40px; overflow:auto; }
.uj-cle-head{ display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.uj-cle-head .sp{ flex:1; }
.uj-cle-tag{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; color:var(--uj-ink-2); background:var(--uj-line-2); border-radius:8px; padding:5px 11px; }
.uj-cle-title{ width:100%; border:0; outline:none; font-size:32px; font-weight:800; letter-spacing:-.02em; color:var(--uj-ink); padding:8px 0; }
.uj-cle-title::placeholder{ color:#c4c4c8; }
.uj-cle-body{ width:100%; border:0; outline:none; resize:none; min-height:280px; font-size:16px; line-height:1.7; color:var(--uj-ink-2); font-family:inherit; }
.uj-cle-body::placeholder{ color:#c4c4c8; }
.uj-cle-stats{ display:inline-flex; align-items:center; gap:14px; margin-top:16px; padding:8px 14px; border:1px solid var(--uj-line); border-radius:10px; font-size:12.5px; color:var(--uj-muted); font-weight:600; }
.uj-ai{ border-left:1px solid var(--uj-line); padding:6px 4px 20px 22px; overflow:auto; }
.uj-ai h3{ font-size:17px; margin:0 0 14px; font-weight:700; display:flex; align-items:center; }
.uj-ai .greet{ font-size:14.5px; color:var(--uj-ink-2); line-height:1.5; margin-bottom:18px; }
.uj-ai-btn{ display:flex; align-items:center; gap:11px; width:100%; text-align:left; border:1px solid var(--uj-line); background:#fff; border-radius:11px; padding:12px 14px; font-size:14px; font-weight:600; color:var(--uj-ink-2); margin-bottom:9px; }
.uj-ai-btn:hover{ background:var(--uj-hover); }
.uj-ai-btn .ic{ color:var(--uj-muted); display:inline-flex; }
.uj-ai-in{ margin-top:12px; border:1px solid var(--uj-line); border-radius:11px; padding:11px 13px; }
.uj-ai-in textarea{ width:100%; border:0; outline:none; resize:none; min-height:40px; font-size:13.5px; font-family:inherit; }

/* share tab */
.uj-share{ max-width:860px; }
.uj-share h2{ font-size:20px; font-weight:750; margin:0 0 4px; }
.uj-share .sub{ color:var(--uj-muted); font-size:14.5px; margin:0 0 22px; }
.uj-live{ border:1px solid var(--uj-line); border-radius:14px; padding:22px 24px; margin-bottom:28px; position:relative; overflow:hidden; }
.uj-live h4{ margin:0 0 8px; font-size:16px; font-weight:700; display:flex; align-items:center; gap:8px; }
.uj-live h4 .dot{ width:9px; height:9px; border-radius:50%; background:#22c55e; }
.uj-live p{ color:var(--uj-muted); font-size:14px; margin:0 0 14px; }
.uj-live a.link{ color:var(--uj-blue); font-weight:600; }
.uj-live-b{ display:flex; gap:10px; }
.uj-slabel{ font-size:11.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--uj-faint); margin:6px 0 4px; }
.uj-share .subtle{ color:var(--uj-muted); font-size:13.5px; margin:0 0 14px; }
.uj-social{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:28px; }
.uj-social a{ display:flex; align-items:center; gap:13px; border:1px solid var(--uj-line); border-radius:12px; padding:15px 16px; }
.uj-social a:hover{ background:var(--uj-hover); }
.uj-social .ico{ width:34px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; color:#fff; flex:0 0 auto; }
.uj-social .n{ font-weight:700; font-size:14.5px; }
.uj-social .d{ font-size:12.5px; color:var(--uj-muted); }
.uj-social .arw{ margin-left:auto; color:var(--uj-faint); }
.uj-sig{ border:1px solid var(--uj-line); border-radius:12px; padding:16px; font-size:13.5px; color:var(--uj-ink-2); background:var(--uj-side); }

@media(max-width:900px){ .uj-dwrap{ grid-template-columns:1fr; } .uj-cle{ grid-template-columns:1fr; } .uj-ai{ border-left:0; border-top:1px solid var(--uj-line); padding-left:4px; } .uj-social{ grid-template-columns:1fr; } }

/* ===================== Dark icon rail (admin modules) ===================== */
.uj-rail{ width:52px; flex:0 0 52px; background:#18181b; display:flex; flex-direction:column; align-items:center; padding:10px 0 12px; gap:3px; }
.uj-rail .rlogo{ width:34px; height:34px; border-radius:10px; background:#0f6b4f; overflow:hidden; display:flex; align-items:center; justify-content:center; color:#fff; margin-bottom:8px; flex:0 0 auto; }
.uj-rbtn{ width:38px; height:38px; border-radius:10px; border:0; background:transparent; color:#9a9aa5; display:flex; align-items:center; justify-content:center; position:relative; cursor:pointer; }
.uj-rbtn:hover{ background:#2a2a31; color:#fff; }
.uj-rbtn.on{ background:#2a2a31; color:#fff; }
.uj-rbtn.on::before{ content:""; position:absolute; left:-10px; top:9px; bottom:9px; width:3px; border-radius:3px; background:#6d6cf0; }
.uj-rbtn .rdot{ position:absolute; top:5px; right:5px; min-width:7px; height:7px; border-radius:9px; background:#ef4444; }
.uj-rail .rsp{ flex:1; }
/* On phones the slim brand rail only carries the logo (already shown in the drawer header)
   and, being position:absolute, sat on top of the top bar — hiding the hamburger. Drop it
   so the burger is tappable and the sidebar drawer slides in cleanly. */
@media(max-width:860px){ .uj-rail{ display:none; } }

/* directory table */
.uj-dir-empty{ text-align:center; color:#71717a; padding:60px 20px; }
/* survey type list + cards */
.uj-survey-card{ display:flex; align-items:center; gap:12px; border:1px solid var(--uj-line); border-radius:12px; padding:14px 16px; margin-bottom:10px; box-shadow:var(--uj-shadow); }
.uj-survey-card .dot{ width:10px; height:10px; border-radius:50%; flex:0 0 auto; }
/* AI tools panel */
.uj-ai-hero{ max-width:720px; margin:8vh auto 0; text-align:center; }
.uj-ai-hero h2{ font-size:26px; font-weight:750; margin:0 0 6px; }
.uj-ai-hero p{ color:var(--uj-muted); font-size:15px; margin:0 0 22px; }
.uj-ai-ask{ display:flex; align-items:center; gap:8px; border:1px solid var(--uj-line); border-radius:12px; padding:6px 6px 6px 16px; box-shadow:var(--uj-shadow); max-width:620px; margin:0 auto; }
.uj-ai-ask input{ flex:1; border:0; outline:none; font-size:14.5px; padding:10px 0; background:transparent; }
.uj-ai-ask .go{ width:38px; height:38px; border-radius:9px; border:0; background:var(--uj-primary); color:#fff; display:flex; align-items:center; justify-content:center; }
.uj-ai-chips{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-top:18px; }
.uj-ai-chip{ display:inline-flex; align-items:center; gap:7px; border:1px solid var(--uj-line); border-radius:999px; padding:8px 14px; font-size:13.5px; font-weight:600; color:var(--uj-ink-2); background:#fff; }
.uj-ai-chip:hover{ background:var(--uj-hover); }
.uj-ai-answer{ max-width:720px; margin:22px auto 0; text-align:left; border:1px solid var(--uj-line); border-radius:12px; padding:18px 20px; font-size:14.5px; line-height:1.7; color:var(--uj-ink-2); white-space:pre-wrap; box-shadow:var(--uj-shadow); }

/* module-title sidebar header (when the dark rail is present) */
.uj-side-hd{ display:flex; align-items:center; gap:8px; padding:15px 16px 12px; border-bottom:1px solid var(--uj-line); }
.uj-side-hd h1{ font-size:17px; font-weight:700; margin:0; letter-spacing:-.01em; flex:1; }
.uj-side-hd .ext{ width:30px; height:30px; border-radius:8px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-muted); display:flex; align-items:center; justify-content:center; }
.uj-side-hd .ext:hover{ background:var(--uj-hover); color:var(--uj-ink); }

/* ===================== Inbox (tabbed notifications) ===================== */
.uj-inbox{ position:absolute; right:0; top:52px; width:440px; max-width:92vw; max-height:560px; overflow:auto; background:#fff; border:1px solid var(--uj-line); border-radius:14px; box-shadow:var(--uj-shadow-lg); z-index:85; }
.uj-inbox-h{ display:flex; align-items:center; gap:8px; padding:14px 16px 10px; }
.uj-inbox-tabs{ display:flex; gap:18px; padding:0 16px; border-bottom:1px solid var(--uj-line); }
.uj-inbox-tab{ border:0; background:transparent; padding:0 0 11px; font-size:13.5px; font-weight:600; color:var(--uj-faint); border-bottom:2px solid transparent; margin-bottom:-1px; }
.uj-inbox-tab.on{ color:var(--uj-primary); border-bottom-color:var(--uj-primary); }
.uj-inbox-item{ display:block; padding:12px 16px; border-bottom:1px solid var(--uj-line-2); }
.uj-inbox-item:hover{ background:var(--uj-hover); }
.uj-inbox-empty{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; padding:70px 20px; color:var(--uj-muted); text-align:center; }
.uj-inbox-mock{ position:relative; width:200px; height:76px; }
.uj-inbox-mock span{ position:absolute; height:52px; border-radius:12px; background:#fff; border:1px solid var(--uj-line); box-shadow:var(--uj-shadow); }
.uj-inbox-mock .c1{ left:10px; top:0; width:150px; }
.uj-inbox-mock .c1::before{ content:""; position:absolute; left:14px; top:16px; width:20px; height:20px; border-radius:50%; border:1px solid #cfe0ff; background:#eef4ff; }
.uj-inbox-mock .c2{ left:44px; top:20px; width:170px; }
.uj-inbox-mock .c2::before{ content:""; position:absolute; left:14px; top:16px; width:20px; height:20px; border-radius:50%; border:1px solid #f5cccc; background:#fdecec; }

/* ===================== 4-column roadmap ===================== */
.uj-kb4{ grid-auto-columns:1fr; grid-auto-flow:column; }
.uj-kbody{ background:var(--uj-bg-2); border:1px solid var(--uj-line); border-radius:12px; min-height:220px; padding:10px; }
.uj-kempty{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; height:190px; color:var(--uj-faint); font-size:13px; font-weight:500; }
.uj-kempty .ic{ width:46px; height:46px; border-radius:12px; background:#efeefc; color:#8b87f0; display:flex; align-items:center; justify-content:center; }
@media(max-width:820px){ .uj-kb4{ grid-auto-flow:row; grid-auto-columns:auto; } }

/* ===================== User portal (top-nav layout) ===================== */
.ujp{ min-height:100vh; background:var(--uj-bg-2); font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif; color:var(--uj-ink); }
.ujp *{ box-sizing:border-box; }
.ujp a{ color:inherit; text-decoration:none; }
.ujp button{ font-family:inherit; cursor:pointer; }
.ujp-top{ background:#fff; border-bottom:1px solid var(--uj-line); }
.ujp-top .in{ max-width:1180px; margin:0 auto; padding:16px 24px 0; }
.ujp-row{ display:flex; align-items:center; gap:14px; }
.ujp-brand{ display:flex; align-items:center; gap:9px; font-weight:800; font-size:19px; letter-spacing:-.02em; }
/* bare leaf mark (matches the app's .brand .leaf — no green tile, uncropped) */
.ujp-brand .mk{ width:28px; height:28px; border-radius:0; background:transparent; overflow:visible; display:inline-flex; align-items:center; justify-content:center; }
/* "Essentials" pill — mirrors the app's .brand .tag */
.ujp-brand .tag{ font-size:10px; font-weight:700; color:var(--mint-600); background:var(--mint-100); padding:2px 7px; border-radius:999px; letter-spacing:.03em; }
.ujp.dark .ujp-brand .tag{ color:var(--mint-300,#8fd9b6); background:rgba(95,197,154,.18); }
.ujp-sp{ flex:1; }
.ujp-iconbtn{ width:38px; height:38px; border-radius:10px; border:1px solid var(--uj-line); background:#fff; color:var(--uj-ink-2); display:inline-flex; align-items:center; justify-content:center; }
.ujp-iconbtn:hover{ background:var(--uj-hover); }
.ujp-btn{ height:38px; padding:0 14px; border-radius:10px; border:1px solid var(--uj-line); background:#fff; font-size:13.5px; font-weight:600; color:var(--uj-ink-2); display:inline-flex; align-items:center; gap:7px; }
.ujp-btn:hover{ background:var(--uj-hover); }
.ujp-btn.indigo{ background:var(--fbx-indigo,#5b5bd6); border-color:#5b5bd6; color:#fff; box-shadow:0 1px 2px rgba(79,74,209,.3); }
.ujp-btn.indigo:hover{ background:#4f4ad1; }
.ujp-av{ width:38px; height:38px; border-radius:50%; background:#3f5233; color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; position:relative; }
.ujp-av .on{ position:absolute; bottom:0; right:0; width:11px; height:11px; border-radius:50%; background:#22c55e; border:2px solid #fff; }
.ujp-tabs{ display:flex; gap:6px; margin-top:14px; }
.ujp-tab{ display:inline-flex; align-items:center; gap:7px; padding:9px 14px; border-radius:9px 9px 0 0; font-size:14px; font-weight:600; color:var(--uj-muted); border-bottom:2px solid transparent; }
.ujp-tab.on{ color:var(--uj-ink); background:var(--uj-bg-2); border-bottom-color:var(--fbx-indigo,#5b5bd6); }
.ujp-wrap{ max-width:1180px; margin:0 auto; padding:24px; display:grid; grid-template-columns:1fr 300px; gap:28px; align-items:start; }
.ujp-wrap.full{ grid-template-columns:1fr; }
.ujp-banner{ background:#eef0ff; border:1px solid #e0e2fb; border-radius:14px; padding:18px 20px; margin-bottom:18px; }
.ujp-banner h3{ margin:0 0 4px; font-size:17px; font-weight:750; color:#2a2a6a; }
.ujp-banner p{ margin:0; font-size:14px; color:#5b5b8a; }
.ujp-toolbar{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.ujp-sort{ display:inline-flex; align-items:center; gap:6px; height:36px; padding:0 12px; border:1px solid var(--uj-line); border-radius:9px; background:#fff; font-size:13px; font-weight:600; color:var(--uj-ink-2); }
.ujp-sort.on{ border-color:var(--uj-ink); }
.ujp-sort:hover{ background:var(--uj-hover); }
.ujp-card{ background:#fff; border:1px solid var(--uj-line); border-radius:16px; box-shadow:var(--uj-shadow); }
.ujp-empty{ text-align:center; padding:48px 20px 40px; }
.ujp-empty h3{ font-size:19px; font-weight:750; margin:0 0 6px; }
.ujp-empty p{ color:var(--uj-muted); font-size:14px; margin:0 auto 16px; max-width:340px; line-height:1.5; }
.ujp-side h4{ font-size:14px; font-weight:700; margin:0 0 10px; padding-bottom:10px; border-bottom:1px solid var(--uj-line); }
.ujp-side .muted{ color:var(--uj-muted); font-size:13.5px; }
.ujp-powered{ margin-top:20px; font-size:12px; color:var(--uj-faint); text-align:center; }
/* avatar dropdown */
.ujp-menu{ position:absolute; right:0; top:46px; width:236px; background:#fff; border:1px solid var(--uj-line); border-radius:12px; box-shadow:var(--uj-shadow-lg); padding:6px; z-index:80; }
.ujp-menu .row{ display:flex; align-items:center; gap:11px; width:100%; padding:9px 10px; border-radius:8px; border:0; background:transparent; font-size:13.5px; font-weight:500; color:var(--uj-ink-2); text-align:left; }
.ujp-menu .row:hover{ background:var(--uj-hover); }
.ujp-menu .row .ic{ color:var(--uj-muted); display:inline-flex; }
.ujp-menu .row.awaymode{ justify-content:space-between; }
.ujp-menu .sep{ height:1px; background:var(--uj-line); margin:6px 4px; }
@media(max-width:820px){ .ujp-wrap{ grid-template-columns:1fr; } .ujp-side{ order:-1; } }

/* ===================== BETA badge ===================== */
.cm-beta{ display:inline-flex; align-items:center; font-size:10px; font-weight:800; letter-spacing:.06em; color:#a9781f; background:#faf4e8; border:1px solid #ecdcb8; border-radius:6px; padding:2px 6px; text-transform:uppercase; vertical-align:middle; line-height:1; }
.ujp-brand .cm-beta{ margin-left:2px; }

/* ===================== Portal dark mode ===================== */
/* Warm charcoal with a faint brand-mint undertone — dark, but not near-black, and in the same family as the rest of the brand palette rather than a generic neutral dark UI. */
.ujp.dark{ --uj-bg:#1c2420; --uj-bg-2:#182019; --uj-ink:#f4f4f5; --uj-ink-2:#d4d4d8; --uj-muted:#a1a1aa; --uj-faint:#71717a; --uj-line:#303a33; --uj-line-2:#2a332c; --uj-hover:#2a332c; --uj-side:#1c2420; background:#182019; color:#f4f4f5; min-height:100vh; }
.ujp.dark .ujp-top{ background:#1c2420; border-color:#303a33; }
.ujp.dark .ujp-card,.ujp.dark .uj-log,.ujp.dark .uj-card,.ujp.dark .uj-kbody,.ujp.dark .uj-kcard,.ujp.dark .uj-composer,.ujp.dark .uj-search,.ujp.dark .ujp-btn,.ujp.dark .ujp-iconbtn,.ujp.dark .ujp-sort,.ujp.dark .uj-vote,.ujp.dark .uj-tag,.ujp.dark .uj-boardpill,.ujp.dark .uj-inbox,.ujp.dark .ujp-menu,.ujp.dark .uj-menu,.ujp.dark .uj-cmodal,.ujp.dark .uj-modal,.ujp.dark .uj-input,.ujp.dark .uj-ta,.ujp.dark .uj-stat{ background:#212b24; border-color:#303a33; color:#e4e4e7; }
.ujp.dark .ujp-banner{ background:#1f2e28; border-color:#2f473c; }
.ujp.dark .ujp-banner h3{ color:#bfe8d3; } .ujp.dark .ujp-banner p{ color:#8fb8a2; }
.ujp.dark input,.ujp.dark textarea{ color:#f4f4f5; }
.ujp.dark .ujp-brand .mk{ background:transparent; }
.ujp.dark .uj-tab.active,.ujp.dark .uj-dtitle,.ujp.dark .ujp-empty h3{ color:#f4f4f5; }
.uj-rail .rlogo img{ width:100%; height:100%; object-fit:cover; display:block; }
.ujp-brand .mk img{ width:100%; height:100%; object-fit:contain; display:block; }
