

/* ---- extracted from index.html ---- */

#bg-layer-1, #bg-layer-2 { position: fixed; inset: 0; z-index: -2; background-size: cover; background-position: center; background-attachment: fixed; transition: opacity 1.8s ease-in-out; }
    #bg-overlay { position: fixed; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(15,23,42,0.4) 0%, rgba(15,23,42,0.85) 100%); pointer-events: none; }
    
    body { background-color: transparent; margin: 0; padding: 96px 0 50px; display: flex; justify-content: center; font-family: system-ui, -apple-system, sans-serif; color: #fff; -webkit-font-smoothing: antialiased;}
    
    ::-webkit-scrollbar { width: 6px; height: 6px; } 
    ::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.25); border-radius: 4px; }
    ::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.4); }
    ::-webkit-scrollbar-track { background: transparent; }
    
    .top-bar { position: fixed; top: 16px; left: 50%; transform: translateX(-50%); width: min(920px, 92vw); box-sizing: border-box; font-size: 14px; background: rgba(0,0,0,0.4); padding: 12px 20px; border-radius: 30px; backdrop-filter: blur(16px) saturate(150%); z-index: 10; border: 1px solid rgba(255,255,255,0.1); box-shadow: 0 8px 28px rgba(0,0,0,0.28); display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; transition: all 0.3s;}
    .top-bar span, .top-bar a, .top-bar b { color: #fff; text-decoration: none; cursor: pointer; opacity: 0.8; transition: 0.2s; position: relative; font-weight: 500; white-space: nowrap;} 
    .top-bar a:hover{ opacity: 1; text-shadow: 0 0 10px rgba(255,255,255,0.6); }

    .card { width: min(920px, 92vw); padding: 40px 35px; border-radius: 28px; background: rgba(15, 23, 42, 0.4); box-shadow: 0 30px 60px -15px rgba(0,0,0,0.6), inset 0 0 0 1px rgba(255,255,255,0.06); backdrop-filter: blur(12px) saturate(180%); -webkit-backdrop-filter: blur(12px) saturate(180%); text-align: center; transition: opacity 0.3s ease; overflow: hidden; }
    
    .title{ font-size: 58px; font-weight: 900; margin: 6px 0; line-height: 1.1; letter-spacing: -1.5px; text-shadow: 0 8px 24px rgba(0,0,0,0.5);}
    .life { font-size: 28px; margin: 12px 0; font-weight: 800; transition: color 0.4s; text-shadow: 0 4px 16px rgba(0,0,0,0.5);}
    .alive { color: #4ade80; } .away { color: #facc15; } .dead { color: #f87171; }
    
    .sectionTitle{ margin-top: 30px; font-size: 16px; opacity: 0.95; text-align: left; display: flex; justify-content: space-between; align-items: center; font-weight: 600; padding-bottom: 8px;}
    .box{ margin-top: 10px; padding: 18px; border-radius: 16px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); text-align: left; font-size: 14.5px; white-space: pre-wrap; line-height: 1.7; transition: 0.2s; box-shadow: inset 0 2px 4px rgba(0,0,0,0.15);}
    .box:hover { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.12);}
    
    .btn-small { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); color: #fff; padding: 6px 14px; border-radius: 8px; cursor: pointer; font-size: 13px; font-weight: 500; transition: all 0.2s; white-space: nowrap;}
    .btn-small:hover { background: rgba(255,255,255,0.15); transform: translateY(-1px); box-shadow: 0 4px 8px rgba(0,0,0,0.2);}
    .btn-small:active { transform: translateY(0);}
    .btn-small:disabled { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none;}

    input, textarea { font: inherit; border-radius: 12px; border: 1px solid rgba(255,255,255,0.1); background: rgba(0,0,0,0.2); color: #fff; padding: 14px 18px; outline: none; width: 100%; box-sizing: border-box; margin-top: 10px; transition: all 0.2s;}
    input:focus, textarea:focus { border-color: rgba(74, 222, 128, 0.6); background: rgba(0,0,0,0.35); box-shadow: 0 0 0 3px rgba(74, 222, 128, 0.15);}
    
    button.primary-btn { cursor: pointer; background: linear-gradient(135deg, #4ade80, #22c55e); color: #064e3b; font-weight: 700; border: none; padding: 12px 16px; width: 100%; border-radius: 12px; font-size: 15px; box-shadow: 0 4px 12px rgba(74, 222, 128, 0.3); transition: all 0.2s ease; white-space: nowrap;} 
    button.primary-btn:hover{ filter: brightness(1.1); transform: translateY(-1px); box-shadow: 0 6px 16px rgba(74, 222, 128, 0.4); }
    button.primary-btn:active{ transform: translateY(0); box-shadow: 0 2px 6px rgba(74, 222, 128, 0.3); }
    
    .msg-tabs { display: flex; gap: 24px; margin-top: 30px; border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: 12px; align-items: center; flex-wrap: wrap;}
    .msg-tabs span { font-size: 15px; opacity: 0.6; cursor: pointer; transition: 0.2s; position: relative; font-weight: 500; white-space: nowrap;}
    .msg-tabs span:hover { opacity: 1; }
    .msg-tabs span.active { opacity: 1; font-weight: 700; color: #fff;}
    .msg-tabs span.active::after { content: ''; position: absolute; left: 0; bottom: -13px; width: 100%; height: 3px; background: #4ade80; border-radius: 3px; box-shadow: 0 -2px 8px rgba(74,222,128,0.5);}

    .search-wrapper { margin-left: auto; position: relative; }
    .search-wrapper input { margin-top: 0; padding: 8px 14px 8px 34px; border-radius: 20px; font-size: 13px; width: 160px; transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1); border-color: rgba(255,255,255,0.1); background: rgba(0,0,0,0.3);}
    .search-wrapper input:focus { width: 220px; border-color: rgba(255,255,255,0.3);}
    .search-wrapper::before { content: "🔍"; position: absolute; left: 12px; top: 50%; transform: translateY(-50%); font-size: 13px; opacity: 0.6; pointer-events: none;}

    @keyframes slideUpStagger { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
    
    .msgItem { animation: slideUpStagger 0.5s cubic-bezier(0.16, 1, 0.3, 1) both; padding: 22px; margin-top: 16px; border-radius: 20px; background: rgba(255,255,255,0.02); text-align: left; position: relative; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04), 0 4px 6px -1px rgba(0,0,0,0.1); transition: all 0.3s ease;}
    .msgItem:hover { background: rgba(255,255,255,0.04); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08), 0 10px 20px -5px rgba(0,0,0,0.2); transform: translateY(-2px);}
    .msgItem.featured { background: rgba(255, 152, 0, 0.03); box-shadow: inset 0 0 0 1px rgba(255, 152, 0, 0.15); }
    .featured-badge { position: absolute; top: 16px; right: 20px; font-size: 22px; opacity: 0.9; filter: drop-shadow(0 0 8px rgba(255,152,0,0.6));}
    
    .msgHead { display: flex; align-items: center; gap: 12px; font-size: 14.5px; opacity: 0.9; margin-bottom: 14px; flex-wrap: wrap;}
    
    .avatar-wrapper { position: relative; display: inline-block; flex-shrink: 0;}
    .avatar { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: bold; font-size: 16px; text-transform: uppercase; color: #fff; box-shadow: 0 4px 10px rgba(0,0,0,0.4); text-shadow: 0 1px 2px rgba(0,0,0,0.3); transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); cursor: default; background-size: cover; background-position: center;}
    .avatar:hover { transform: scale(1.15) rotate(5deg); box-shadow: 0 8px 16px rgba(0,0,0,0.5); }
    .online-dot { position: absolute; bottom: -2px; right: -2px; width: 12px; height: 12px; background-color: #4ade80; border-radius: 50%; border: 2.5px solid #0f172a; box-shadow: 0 0 6px rgba(74, 222, 128, 0.6);}
    
    .time-txt { font-size: 12px; opacity: 0.5; margin-left: auto; letter-spacing: 0.5px; white-space: nowrap;}
    .pinned-badge { font-size: 11px; font-weight: bold; color: #ef4444; border: 1px solid rgba(239,68,68,0.4); padding: 2px 6px; border-radius: 6px; background: rgba(239,68,68,0.1); margin-left: 6px; white-space: nowrap;}
    
    .msg-content { margin-bottom: 16px;}
    .msg-actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap;}

    audio::-webkit-media-controls-panel { background: rgba(255, 255, 255, 0.1); border-radius: 12px; }

    .reply-list { margin-top: 18px; padding-left: 18px; border-left: 2px solid rgba(255,255,255,0.08); display: flex; flex-direction: column; gap: 12px;}
    .reply-item { font-size: 14px; padding: 12px 16px; background: rgba(0,0,0,0.25); border-radius: 12px; line-height: 1.55;}
    .reply-item.is-admin { border-left: 3px solid #4ade80; background: rgba(74, 222, 128, 0.05); }
    .admin-badge { background: #4ade80; color: #000; padding: 2px 6px; border-radius: 4px; font-weight: bold; margin-left: 8px; font-size: 10px; vertical-align: baseline; position: relative; top: -1px; box-shadow: 0 2px 4px rgba(0,0,0,0.2); white-space: nowrap;}
    .op-badge { background: #60a5fa; color: #000; } 

    @keyframes modalFadeIn { from { opacity: 0; backdrop-filter: blur(0); } to { opacity: 1; backdrop-filter: blur(12px); } }
    @keyframes modalScaleUp { from { transform: scale(0.95); opacity: 0; } to { transform: scale(1); opacity: 1; } }
    
    .modal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 100; align-items: center; justify-content: center; animation: modalFadeIn 0.3s forwards;}
    .modal-content { background: rgba(15,23,42,0.85); padding: 35px; border-radius: 24px; width: 360px; text-align: center; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.6), inset 0 0 0 1px rgba(255,255,255,0.1); max-height: 85vh; overflow-y: auto; animation: modalScaleUp 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;}
    
    .view-stats { margin-top: 40px; font-size: 13.5px; opacity: 0.8; background: rgba(0,0,0,0.2); padding: 14px 24px; border-radius: 16px; display: inline-block; border: 1px solid rgba(255,255,255,0.05);}
    .icon-btn { cursor: pointer; opacity: 0.6; transition: 0.2s; font-size: 14px; margin-left: 8px; }
    .icon-btn:hover { opacity: 1; transform: scale(1.15); display: inline-block;}
    
    .profile-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin: 25px 0 15px; }
    .profile-tabs button { flex: 1 1 calc(50% - 8px); margin: 0; padding: 10px; border-radius: 12px; background: rgba(255,255,255,0.04); border: 1px solid transparent; color:#94a3b8; font-size:13.5px; transition: 0.2s; cursor: pointer; white-space: nowrap;}
    .profile-tabs button:hover { background: rgba(255,255,255,0.08); color: #fff; }
    .profile-tabs button.active { background: rgba(74, 222, 128, 0.1); color:#4ade80; border-color: rgba(74, 222, 128, 0.25); font-weight:bold;}
    
    .p-item { text-align: left; background: rgba(0,0,0,0.2); border: 1px solid rgba(255,255,255,0.05); padding: 16px; border-radius: 14px; margin-bottom: 12px; font-size: 14px; transition: 0.2s; position: relative;}
    .p-item:hover { background: rgba(0,0,0,0.3); border-color: rgba(255,255,255,0.1); }
    .p-item .delete-btn { position: absolute; right: 12px; top: 12px; background: rgba(248, 113, 113, 0.1); color: #f87171; border: 1px solid rgba(248, 113, 113, 0.2); padding: 4px 10px; border-radius: 6px; font-size: 12px; cursor: pointer; opacity: 0; transition: 0.2s; white-space: nowrap;}
    .p-item:hover .delete-btn { opacity: 1; }
    .p-item .delete-btn:hover { background: rgba(248, 113, 113, 0.25); }
    
    .proc-tag { background: rgba(255,255,255,0.1); padding: 3px 8px; border-radius: 6px; font-size: 12px; margin-right: 8px; color: #fcd34d; font-family: ui-monospace, monospace; border: 1px solid rgba(255,255,255,0.05); white-space: nowrap;}
    
    .form-group { text-align: left; margin-bottom: 20px; }
    .form-group label { display: block; font-size: 13.5px; color: #94a3b8; margin-bottom: 8px; padding-left: 4px; font-weight: 500;}
    .form-group input { margin-top: 0; }
    
    .unread-badge { background: #ef4444; color: #fff; border-radius: 10px; padding: 2px 6px; font-size: 11px; font-weight: bold; margin-left: 6px; box-shadow: 0 0 8px rgba(239, 68, 68, 0.5); white-space: nowrap;}

    #backToTop { position: fixed; bottom: 30px; right: 30px; width: 50px; height: 50px; background: rgba(0,0,0,0.5); border: 1px solid rgba(255,255,255,0.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; opacity: 0; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); pointer-events: none; backdrop-filter: blur(12px); z-index: 99; font-size: 24px; box-shadow: 0 4px 16px rgba(0,0,0,0.3); color: rgba(255,255,255,0.8);}
    #backToTop:hover { background: rgba(255,255,255,0.15); transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,0.4); color:#fff;}
    
    .highlight-search { background-color: rgba(245, 158, 11, 0.4); color: #fff; border-radius: 3px; padding: 0 2px; }
    
    .recording-pulse { animation: pulseRed 1s infinite alternate; }
    @keyframes pulseRed { from { color: #ef4444; transform: scale(1); } to { color: #b91c1c; transform: scale(1.1); } }

    .summary-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 28px 0 10px; }
    .summary-chip { text-align:left; padding: 14px 16px; border-radius: 16px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); box-shadow: inset 0 1px 0 rgba(255,255,255,0.04); }
    .summary-chip small { display:block; font-size: 12px; color:#94a3b8; margin-bottom: 6px; }
    .summary-chip b { font-size: 21px; color:#fff; letter-spacing: -0.3px; }
    .summary-chip em { font-style: normal; color:#4ade80; font-size: 12px; }
    .msg-summary-bar { display:flex; flex-wrap:wrap; gap:10px; margin-top: 16px; text-align:left; }
    .msg-summary-pill { padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); color:#cbd5e1; font-size: 12.5px; }
    .composer-meta-row { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top: 12px; font-size: 12.5px; color:#94a3b8; flex-wrap: wrap; }
    .composer-meta-row b { color:#e2e8f0; }
    .msg-summary-inline { display:flex; flex-wrap:wrap; gap:8px; margin: -2px 0 14px; }
    .msg-summary-inline span { font-size: 12px; color:#94a3b8; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.05); padding: 4px 9px; border-radius: 999px; }
    .reply-meta { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom: 6px; flex-wrap: wrap; }
    .reply-user-line { display:flex; align-items:center; flex-wrap:wrap; gap:6px; }
    .reply-time { font-size: 11.5px; color:#94a3b8; white-space: nowrap; }
    .reply-body { color:#f1f5f9; font-size: 14.5px; }
    .msg-empty-state { padding:50px 24px; opacity:0.65; font-size:15px; text-align:center; border: 1px dashed rgba(255,255,255,0.1); border-radius: 18px; background: rgba(255,255,255,0.02); }

    @media (max-width: 768px) {
      #bg-layer-1, #bg-layer-2 { background-attachment: scroll; transition: none; }
      .top-bar { width: calc(100vw - 28px); top: 10px; backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(0,0,0,0.65); }
      .card { backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(15, 23, 42, 0.95); padding: 25px 20px; box-shadow: 0 10px 30px rgba(0,0,0,0.5); }
      .title { font-size: 42px; }
      .summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .msg-summary-bar { gap: 8px; }
      .composer-meta-row { align-items:flex-start; }
    }
    
    /* Markdown & LaTeX 样式适配 */
    .markdown-body { font-size: 15px; line-height: 1.6; color: #f8fafc; word-break: break-word; }
    .markdown-body p { margin-top: 0; margin-bottom: 12px; }
    .markdown-body p:last-child { margin-bottom: 0; }
    .markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4 { margin-top: 16px; margin-bottom: 12px; font-weight: 700; color: #fff; }
    .markdown-body h1 { font-size: 1.8em; border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 6px; }
    .markdown-body h2 { font-size: 1.5em; border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 6px; }
    .markdown-body h3 { font-size: 1.25em; }
    .markdown-body a { color: #4ade80; text-decoration: none; transition: 0.2s;}
    .markdown-body a:hover { text-decoration: underline; text-shadow: 0 0 5px rgba(74,222,128,0.5); }
    .markdown-body blockquote { border-left: 4px solid #4ade80; margin: 12px 0; padding: 8px 12px; color: #cbd5e1; background: rgba(74, 222, 128, 0.05); border-radius: 4px; }
    .markdown-body code { font-family: ui-monospace, monospace; background: rgba(255,255,255,0.1); padding: 3px 6px; border-radius: 4px; font-size: 0.9em; }
    .markdown-body pre { background: rgba(0,0,0,0.4); padding: 16px; border-radius: 12px; overflow-x: auto; border: 1px solid rgba(255,255,255,0.05); margin: 12px 0; }
    .markdown-body pre code { background: transparent; padding: 0; border-radius: 0; font-size: 0.9em; color: #e2e8f0; }
    .markdown-body ul, .markdown-body ol { padding-left: 24px; margin-top: 0; margin-bottom: 12px; }
    .markdown-body li { margin-bottom: 4px; }
    .markdown-body table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 14px; }
    .markdown-body th, .markdown-body td { border: 1px solid rgba(255,255,255,0.15); padding: 10px 14px; text-align: left; }
    .markdown-body th { background: rgba(0,0,0,0.3); font-weight: 600; color: #94a3b8; }
    .markdown-body tr:nth-child(even) { background: rgba(255,255,255,0.02); }
    .markdown-body img { max-width: 100%; max-height: 280px; border-radius: 12px; margin: 12px 0; border: 1px solid rgba(255,255,255,0.1); display: block;}
    .markdown-body input[type="checkbox"] { margin-right: 6px; accent-color: #4ade80; cursor: not-allowed; }
    mjx-container { outline: none; }


/* ---- 2026 polish layer: keeps the original layout, improves depth and readability ---- */
:root {
  --glass-strong: rgba(15, 23, 42, 0.58);
  --glass-soft: rgba(255,255,255,0.055);
  --ring-soft: rgba(255,255,255,0.12);
  --glow-alive: rgba(74, 222, 128, 0.35);
  --glow-away: rgba(250, 204, 21, 0.32);
  --glow-dead: rgba(248, 113, 113, 0.34);
}

body::before,
body::after {
  content: "";
  position: fixed;
  pointer-events: none;
  z-index: -1;
}

body::before {
  inset: -20%;
  background:
    radial-gradient(circle at 18% 18%, rgba(74,222,128,0.14), transparent 24%),
    radial-gradient(circle at 82% 12%, rgba(96,165,250,0.12), transparent 28%),
    radial-gradient(circle at 50% 85%, rgba(168,85,247,0.13), transparent 30%);
  filter: blur(24px);
  transform: translateZ(0);
  animation: ambientFloat 16s ease-in-out infinite alternate;
}

body::after {
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(to bottom, transparent, black 18%, black 70%, transparent);
  opacity: 0.38;
}

@keyframes ambientFloat {
  from { transform: translate3d(-1.5%, -1%, 0) scale(1); }
  to { transform: translate3d(1.5%, 1%, 0) scale(1.04); }
}

#bg-overlay {
  background:
    linear-gradient(180deg, rgba(2,6,23,0.22) 0%, rgba(15,23,42,0.78) 52%, rgba(2,6,23,0.92) 100%),
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.12), transparent 38%);
}

.top-bar {
  background: rgba(2, 6, 23, 0.48);
  border-color: rgba(255,255,255,0.14);
  box-shadow: 0 16px 48px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.08);
}

.card {
  position: relative;
  background:
    linear-gradient(145deg, rgba(15,23,42,0.64), rgba(15,23,42,0.36)),
    rgba(15, 23, 42, 0.40);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow:
    0 34px 90px -34px rgba(0,0,0,0.88),
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 0 0 1px rgba(255,255,255,0.03);
  animation: cardRise 540ms cubic-bezier(.16,1,.3,1) both;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(255,255,255,0.24), transparent 28%, rgba(74,222,128,0.20), transparent 62%, rgba(96,165,250,0.18));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

.card::after {
  content: "";
  position: absolute;
  top: -120px;
  left: 10%;
  width: 80%;
  height: 180px;
  background: radial-gradient(ellipse at center, rgba(255,255,255,0.11), transparent 62%);
  filter: blur(18px);
  pointer-events: none;
}

.card > * { position: relative; z-index: 1; }

@keyframes cardRise {
  from { opacity: 0; transform: translateY(14px) scale(0.985); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.title {
  background: linear-gradient(180deg, #fff, #cbd5e1 78%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.title rt {
  color: rgba(255,255,255,0.72);
  font-size: 0.22em;
  letter-spacing: 0.04em;
}

.life {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 128px;
  padding: 10px 22px;
  border-radius: 999px;
  background: rgba(0,0,0,0.18);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.life::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 16px currentColor;
  animation: statusBlink 1.8s ease-in-out infinite;
}

@keyframes statusBlink {
  0%, 100% { opacity: .65; transform: scale(.86); }
  50% { opacity: 1; transform: scale(1.12); }
}

body[data-life="alive"] .card { box-shadow: 0 34px 90px -34px rgba(0,0,0,0.88), 0 0 64px -38px var(--glow-alive), inset 0 1px 0 rgba(255,255,255,0.08); }
body[data-life="away"] .card { box-shadow: 0 34px 90px -34px rgba(0,0,0,0.88), 0 0 64px -38px var(--glow-away), inset 0 1px 0 rgba(255,255,255,0.08); }
body[data-life="dead"] .card { box-shadow: 0 34px 90px -34px rgba(0,0,0,0.88), 0 0 64px -38px var(--glow-dead), inset 0 1px 0 rgba(255,255,255,0.08); }

.summary-chip,
.box,
.msg-summary-pill,
.modal-content {
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
}

.summary-chip {
  background: linear-gradient(145deg, rgba(255,255,255,0.075), rgba(255,255,255,0.026));
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.summary-chip:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.16);
  background: linear-gradient(145deg, rgba(255,255,255,0.105), rgba(255,255,255,0.035));
}

.sectionTitle {
  letter-spacing: 0.01em;
}

.box {
  background: rgba(2,6,23,0.22);
  border-color: rgba(255,255,255,0.095);
}

#tipBox {
  position: relative;
  overflow: hidden;
}

#tipBox::before {
  content: "TIP";
  position: absolute;
  right: 16px;
  top: 12px;
  color: rgba(255,255,255,0.05);
  font-weight: 900;
  font-size: 42px;
  letter-spacing: -0.06em;
  pointer-events: none;
}

#winlist {
  padding: 12px;
  max-height: 32vh !important;
}

.window-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 10px;
  margin-bottom: 8px;
  border-radius: 14px;
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.055);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.window-row:hover {
  transform: translateX(2px);
  background: rgba(255,255,255,0.062);
  border-color: rgba(255,255,255,0.12);
}

.window-main {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 8px;
}

.window-title {
  opacity: 0.92;
  flex: 1;
  min-width: 0;
  padding-top: 1px;
  font-size: 13.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.runtime-chip {
  flex: 0 0 auto;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11.5px;
  color: #bae6fd;
  background: rgba(14,165,233,0.10);
  border: 1px solid rgba(14,165,233,0.16);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.empty-state {
  text-align: center;
  color: rgba(255,255,255,0.54);
  padding: 18px 0;
  border: 1px dashed rgba(255,255,255,0.14);
  border-radius: 14px;
  background: rgba(255,255,255,0.025);
}

.proc-tag {
  background: rgba(250,204,21,0.10);
  border-color: rgba(250,204,21,0.18);
  color: #fde68a;
}

.msg-tabs span.active::after {
  box-shadow: 0 0 16px rgba(74,222,128,0.55);
}

button.primary-btn,
.btn-small {
  will-change: transform;
}

@media (max-width: 768px) {
  body { padding-top: 112px; }
  .card { padding: 30px 20px; border-radius: 24px; }
  .title { font-size: 46px; }
  .life { font-size: 23px; min-width: 112px; }
  .window-row { grid-template-columns: 1fr; align-items: start; gap: 6px; }
  .window-main { align-items: flex-start; flex-direction: column; }
  .window-title { white-space: normal; }
  .runtime-chip { width: fit-content; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; }
}

/* Announcement history */
.announcement-title-row { align-items: center; gap: 12px; }
.announcement-meta { font-size: 12px; color: #94a3b8; font-weight: 500; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); padding: 5px 9px; border-radius: 999px; }
.announcement-box { position: relative; overflow: hidden; }
.announcement-history { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 10px; margin-top: 12px; text-align: left; }
.announcement-history-card { cursor: pointer; padding: 12px 14px; border-radius: 16px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); transition: transform .2s, border-color .2s, background .2s; }
.announcement-history-card:hover { transform: translateY(-2px); background: rgba(255,255,255,0.07); border-color: rgba(74,222,128,0.25); }
.announcement-history-card.active { background: rgba(74,222,128,0.10); border-color: rgba(74,222,128,0.35); box-shadow: 0 10px 28px -18px rgba(74,222,128,0.6); }
.announcement-history-title { display:flex; align-items:center; gap:7px; color:#fff; font-weight:800; font-size: 13.5px; margin-bottom: 6px; }
.announcement-history-title span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.announcement-history-time { font-size: 11.5px; color:#94a3b8; margin-bottom: 6px; }
.announcement-history-preview { font-size: 12px; color:#cbd5e1; line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.announcement-pin-badge { color:#fcd34d; font-size:11px; font-weight:900; background: rgba(250,204,21,0.12); border:1px solid rgba(250,204,21,0.22); border-radius:999px; padding:1px 6px; flex-shrink:0; }
@media (max-width: 768px) {
  .announcement-history { grid-template-columns: 1fr; }
  .announcement-title-row { align-items: flex-start; }
}


/* Mobile smooth-scroll performance pass */
html { min-height: 100%; background: #0f172a; }
body { background-color: #0f172a; }
#backToTop.visible { opacity: 1; pointer-events: auto; transform: translate3d(0, 0, 0); }

html.is-mobile,
html.is-mobile body {
  overscroll-behavior-y: none;
  -webkit-overflow-scrolling: touch;
}

html.is-mobile body::before,
html.is-mobile body::after,
html.is-mobile .card::after {
  display: none !important;
  animation: none !important;
  filter: none !important;
}

html.is-mobile #bg-layer-1,
html.is-mobile #bg-layer-2 {
  position: fixed;
  background-attachment: scroll !important;
  transition: none !important;
  transform: translate3d(0, 0, 0);
  will-change: auto;
}

html.is-mobile #bg-overlay {
  background: linear-gradient(180deg, rgba(15,23,42,0.62), rgba(2,6,23,0.94));
}

html.is-mobile .top-bar,
html.is-mobile .card,
html.is-mobile .summary-chip,
html.is-mobile .box,
html.is-mobile .msg-summary-pill,
html.is-mobile .modal,
html.is-mobile .modal-content,
html.is-mobile #backToTop,
html.is-mobile #lightbox {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

html.is-mobile .card {
  contain: paint;
  animation: none !important;
  transform: translate3d(0, 0, 0);
}

html.is-mobile .summary-chip,
html.is-mobile .box,
html.is-mobile .window-row,
html.is-mobile .announcement-history-card,
html.is-mobile .msgItem,
html.is-mobile .reply-item {
  box-shadow: none !important;
}

html.is-mobile .msgItem {
  animation: none !important;
  transition: background .15s ease, border-color .15s ease !important;
  contain: layout paint;
}

html.is-mobile .msgItem:hover,
html.is-mobile .announcement-history-card:hover,
html.is-mobile .summary-chip:hover,
html.is-mobile .window-row:hover,
html.is-mobile .avatar:hover,
html.is-mobile .btn-small:hover,
html.is-mobile button.primary-btn:hover,
html.is-mobile #backToTop:hover {
  transform: none !important;
  filter: none !important;
}

html.is-mobile .featured-badge {
  filter: none !important;
}

html.is-mobile .card::before {
  display: none !important;
}

html.is-mobile .markdown-body img {
  max-height: 220px;
  object-fit: contain;
}

html.is-mobile #backToTop {
  width: 44px;
  height: 44px;
  right: 18px;
  bottom: calc(18px + env(safe-area-inset-bottom));
  transform: translate3d(0, 8px, 0);
}

html.is-mobile input,
html.is-mobile textarea,
html.is-mobile button,
html.is-mobile .btn-small {
  touch-action: manipulation;
}

html.is-mobile .msg-tabs,
html.is-mobile .msg-actions,
html.is-mobile .composer-meta-row {
  gap: 10px;
}

html.is-mobile .msgItem,
html.is-mobile .announcement-history-card,
html.is-mobile .box {
  border-color: rgba(255,255,255,0.08);
}

html,
body {
  overflow-x: hidden;
  min-height: 100%;
}

html {
  background: #0f172a;
}

body {
  /* Keep body transparent so negative z-index bg layers remain visible.
     The html fallback color prevents white flashes while images load. */
  background: transparent;
}

#bg-layer-1,
#bg-layer-2 {
  background-attachment: scroll !important;
  background-size: cover;
  background-position: center;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

@media (min-width: 1024px) and (pointer: fine) {
  html:not(.perf-mode) #bg-layer-1,
  html:not(.perf-mode) #bg-layer-2 {
    background-attachment: fixed !important;
  }
}

.top-bar {
  transform: translate3d(-50%, 0, 0);
  backface-visibility: hidden;
}

.card,
#bg-overlay {
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#perfBtn.active {
  opacity: 1;
  color: #fde68a !important;
  text-shadow: 0 0 12px rgba(250, 204, 21, 0.55);
}

@media (max-width: 768px) {
  .top-bar {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: rgba(2, 6, 23, 0.78);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.22);
  }

  .card {
    background: rgba(15, 23, 42, 0.58);
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: 0 18px 38px -20px rgba(0, 0, 0, 0.70), inset 0 0 0 1px rgba(255,255,255,0.07) !important;
  }

  #bg-overlay {
    /* Keep the background visible; only slightly reduce detail/contrast on mobile. */
    background: linear-gradient(180deg, rgba(15,23,42,0.48) 0%, rgba(2,6,23,0.86) 100%) !important;
  }
}

html.perf-mode #bg-layer-2 {
  opacity: 0 !important;
}

html.perf-mode #bg-layer-1 {
  opacity: 1;
}

html.perf-mode #bg-layer-1,
html.perf-mode #bg-layer-2 {
  transition: none !important;
  will-change: auto !important;
}

html.perf-mode .life::before,
html.perf-mode .msgItem,
html.perf-mode .modal,
html.perf-mode .modal-content,
html.perf-mode .summary-chip,
html.perf-mode .window-row,
html.perf-mode .announcement-history-card,
html.perf-mode .avatar,
html.perf-mode .btn-small,
html.perf-mode button.primary-btn {
  animation: none !important;
  transition-property: background, border-color, color, opacity !important;
  transition-duration: .12s !important;
}

html.perf-mode .top-bar,
html.perf-mode .card,
html.perf-mode .summary-chip,
html.perf-mode .box,
html.perf-mode .msg-summary-pill,
html.perf-mode .modal-content,
html.perf-mode #lightbox {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}

:root {
  --entry-bg: #121212;
  --entry-bg-soft: #171717;
  --entry-panel: #202020;
  --entry-panel-hover: #262626;
  --entry-panel-subtle: #1a1a1a;
  --entry-border: rgba(255,255,255,0.075);
  --entry-border-strong: rgba(255,255,255,0.14);
  --entry-text: #e8e8e8;
  --entry-muted: #9a9a9a;
  --entry-faint: #707070;
  --entry-green: #4f8b61;
  --entry-green-strong: #71a47b;
  --entry-green-soft: rgba(79,139,97,0.18);
  --entry-yellow: #b58a3b;
  color-scheme: dark;
}

html {
  background: var(--entry-bg) !important;
  scroll-behavior: smooth;
}

body {
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  min-height: 100vh;
  color: var(--entry-text) !important;
  background: var(--entry-bg) !important;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif !important;
  letter-spacing: 0;
}

body::before,
body::after,
.card::before,
.card::after {
  display: none !important;
}

#bg-layer-1,
#bg-layer-2 {
  z-index: -3 !important;
  opacity: .24;
  filter: saturate(.72) brightness(.54) contrast(.96);
  transition: opacity .6s ease !important;
}

#bg-overlay {
  z-index: -2 !important;
  background:
    radial-gradient(circle at 76% 8%, rgba(79,139,97,0.10), transparent 31%),
    linear-gradient(90deg, rgba(18,18,18,0.96) 0%, rgba(18,18,18,0.91) 44%, rgba(18,18,18,0.83) 100%) !important;
}

.top-bar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  min-height: 72px;
  box-sizing: border-box;
  transform: none !important;
  border-radius: 0 !important;
  background: rgba(18,18,18,0.94) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--entry-border) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 0 max(28px, calc((100vw - 1280px) / 2 + 28px)) !important;
  display: grid !important;
  grid-template-columns: auto minmax(220px, 1fr) auto;
  align-items: center;
  gap: 22px;
  z-index: 50;
}

.top-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  color: var(--entry-text);
  font-size: 16px;
  font-weight: 780;
  white-space: nowrap;
}

.brand-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  background: var(--entry-green);
  box-shadow: none;
}

.top-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.top-nav a,
.top-bar a,
.top-bar span,
.top-bar b {
  color: var(--entry-muted) !important;
  opacity: 1 !important;
  text-shadow: none !important;
  text-decoration: none;
}

.top-nav a,
.top-actions a,
#authBar a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 13.5px;
  font-weight: 620;
  color: var(--entry-muted) !important;
  background: transparent;
  border: 1px solid transparent;
  transition: background .14s ease, color .14s ease, border-color .14s ease;
}

.top-nav a:hover,
.top-actions a:hover,
#authBar a:hover {
  color: var(--entry-text) !important;
  background: rgba(255,255,255,0.055);
  border-color: rgba(255,255,255,0.06);
}

.top-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  min-width: 0;
  flex-wrap: wrap;
}

#perfBtn.active {
  color: #d7be7e !important;
  background: rgba(181,138,59,0.14) !important;
  text-shadow: none !important;
}

.card.app-shell {
  width: min(1280px, calc(100vw - 56px)) !important;
  margin: 0 auto !important;
  padding: 104px 0 56px !important;
  display: grid !important;
  grid-template-columns: 320px minmax(0, 820px);
  justify-content: center;
  align-items: start;
  gap: 36px;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  text-align: left !important;
  overflow: visible !important;
  animation: none !important;
  transition: none !important;
}

body[data-life="alive"] .card.app-shell,
body[data-life="away"] .card.app-shell,
body[data-life="dead"] .card.app-shell {
  box-shadow: none !important;
}

.sidebar-column {
  position: sticky;
  top: 96px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
}

.profile-panel,
.sidebar-stats,
.side-nav,
.sidebar-note,
.feed-panel,
.site-footer {
  background: rgba(32,32,32,0.94);
  border: 1px solid var(--entry-border);
  border-radius: 20px;
  box-shadow: none;
}

.profile-panel {
  padding: 22px 22px 20px;
}

.profile-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
}

.profile-name {
  font-size: 18px;
  font-weight: 820;
  letter-spacing: -.02em;
  color: var(--entry-text);
}

.profile-pro {
  font-size: 11px;
  font-weight: 780;
  letter-spacing: .04em;
  padding: 2px 6px;
  border-radius: 5px;
  background: #d8d8d8;
  color: #191919;
}

.title {
  margin: 0 0 8px !important;
  color: var(--entry-text) !important;
  background: none !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  font-size: 38px !important;
  line-height: 1.05 !important;
  font-weight: 860 !important;
  letter-spacing: -.06em !important;
  text-shadow: none !important;
}

.title rt {
  color: var(--entry-muted) !important;
}

.sub,
#statusSub,
.status-subtext {
  color: var(--entry-muted) !important;
  font-size: 13px !important;
  opacity: 1 !important;
  margin: 0 0 14px !important;
}

.life {
  display: inline-flex !important;
  width: auto;
  min-width: auto !important;
  padding: 7px 12px !important;
  margin: 0 0 12px !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,0.045) !important;
  border: 1px solid var(--entry-border) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  font-size: 15px !important;
  font-weight: 720 !important;
}

.life::before {
  width: 8px !important;
  height: 8px !important;
  box-shadow: none !important;
  animation: none !important;
}

.alive { color: #80b989 !important; }
.away { color: #d2b76a !important; }
.dead { color: #d78282 !important; }

.sidebar-stats {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap: 0 !important;
  margin: 0 !important;
  overflow: hidden;
}

.sidebar-stats .summary-chip,
.summary-chip {
  padding: 16px !important;
  border-radius: 0 !important;
  border: 0 !important;
  border-right: 1px solid var(--entry-border) !important;
  border-bottom: 1px solid var(--entry-border) !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transition: background .14s ease !important;
}

.sidebar-stats .summary-chip:nth-child(2n),
.summary-chip:nth-child(2n) { border-right: 0 !important; }
.sidebar-stats .summary-chip:nth-last-child(-n+2),
.summary-chip:nth-last-child(-n+2) { border-bottom: 0 !important; }

.summary-chip:hover {
  transform: none !important;
  background: rgba(255,255,255,0.035) !important;
}

.summary-chip small {
  display: block;
  margin-bottom: 6px;
  color: var(--entry-muted) !important;
  font-size: 11.5px !important;
  letter-spacing: .02em;
}

.summary-chip b {
  color: var(--entry-text) !important;
  font-size: 26px !important;
  line-height: 1;
  letter-spacing: -.04em;
}

.summary-chip em {
  color: var(--entry-green-strong) !important;
}

.side-nav {
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.side-nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 44px;
  padding: 0 14px;
  border-radius: 12px;
  color: var(--entry-text);
  text-decoration: none;
  font-weight: 680;
  transition: background .14s ease, color .14s ease;
}

.side-nav a span {
  width: 18px;
  color: var(--entry-muted);
  font-size: 12px;
}

.side-nav a:hover,
.side-nav a.active {
  background: rgba(79,139,97,0.72);
  color: white;
}

.side-nav a:hover span,
.side-nav a.active span { color: white; }

.sidebar-note {
  padding: 16px;
  color: var(--entry-muted);
  font-size: 13px;
  line-height: 1.65;
}

.sidebar-note-muted {
  margin-top: 8px;
  color: var(--entry-faint);
}

.content-column {
  width: 100%;
  min-width: 0;
}

.feed-panel {
  padding: 22px !important;
  margin: 0 0 14px !important;
  border-radius: 18px !important;
  background: rgba(32,32,32,0.95) !important;
  transition: background .14s ease, border-color .14s ease;
}

.feed-panel:hover {
  background: rgba(35,35,35,0.96) !important;
  border-color: rgba(255,255,255,0.105);
}

.sectionTitle {
  margin: 0 0 14px !important;
  padding: 0 !important;
  font-size: 15px !important;
  line-height: 1.3;
  opacity: 1 !important;
  color: var(--entry-muted) !important;
  font-weight: 720 !important;
  border: 0 !important;
}

.sectionTitle > span:first-child {
  color: var(--entry-text);
  font-size: 16px;
}

.message-title-row {
  margin-bottom: 8px !important;
}

.message-subtitle {
  color: var(--entry-faint) !important;
  font-size: 12px !important;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.box,
#tipBox,
#winlist,
.announcement-box {
  margin-top: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--entry-text) !important;
  line-height: 1.78;
  font-size: 15px;
  white-space: pre-wrap;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.box:hover { background: transparent !important; border-color: transparent !important; }

.announcement-meta {
  max-width: 62%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--entry-muted) !important;
  background: rgba(255,255,255,0.045) !important;
  border: 1px solid var(--entry-border) !important;
  border-radius: 999px;
  padding: 5px 10px;
}

.announcement-history {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap: 10px !important;
  margin-top: 18px !important;
}

.announcement-history-card {
  padding: 13px 14px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid var(--entry-border) !important;
  box-shadow: none !important;
  transition: background .14s ease, border-color .14s ease !important;
}

.announcement-history-card:hover {
  transform: none !important;
  background: rgba(255,255,255,0.055) !important;
  border-color: rgba(255,255,255,0.13) !important;
}

.announcement-history-card.active {
  background: var(--entry-green-soft) !important;
  border-color: rgba(113,164,123,0.38) !important;
  box-shadow: none !important;
}

.announcement-history-title { color: var(--entry-text) !important; font-weight: 760 !important; }
.announcement-history-time { color: var(--entry-faint) !important; }
.announcement-history-preview { color: var(--entry-muted) !important; }
.announcement-pin-badge {
  background: rgba(181,138,59,0.16) !important;
  border-color: rgba(181,138,59,0.28) !important;
  color: #d6b26f !important;
}

.ghost-btn {
  appearance: none;
  border: 1px solid var(--entry-border);
  color: var(--entry-muted);
  background: rgba(255,255,255,0.035);
  border-radius: 10px;
  height: 32px;
  padding: 0 12px;
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 650;
}

.ghost-btn:hover { color: var(--entry-text); background: rgba(255,255,255,0.06); }

#tipBox::before { display: none !important; }

#winlist {
  max-height: none !important;
  overflow: visible !important;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.window-row {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px !important;
  margin: 0 !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid var(--entry-border) !important;
  transition: background .14s ease, border-color .14s ease !important;
}

.window-row:hover {
  transform: none !important;
  background: rgba(255,255,255,0.055) !important;
  border-color: rgba(255,255,255,0.12) !important;
}

.proc-tag {
  color: #bba16a !important;
  background: rgba(181,138,59,0.12) !important;
  border-color: rgba(181,138,59,0.18) !important;
  border-radius: 8px !important;
  font-size: 11.5px !important;
}

.runtime-chip {
  color: var(--entry-muted) !important;
  background: rgba(255,255,255,0.04) !important;
  border-color: var(--entry-border) !important;
}

.entry-composer {
  margin: 16px 0 18px !important;
  padding: 18px !important;
  border-radius: 18px !important;
  background: rgba(28,28,28,0.98) !important;
  border: 1px solid var(--entry-border) !important;
  box-shadow: none !important;
}

.composer-tabs {
  display: flex;
  gap: 16px;
  margin-bottom: 10px;
  color: var(--entry-muted);
  font-size: 13px;
  font-weight: 700;
}

.composer-tabs span {
  cursor: pointer;
}

#tabEditMsg { color: var(--entry-green-strong) !important; }
#tabPreviewMsg { color: var(--entry-muted) !important; }

#msgContent {
  min-height: 92px;
  margin-top: 0 !important;
  padding: 12px 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--entry-text) !important;
  resize: vertical;
  font-family: inherit !important;
  font-size: 16px !important;
  line-height: 1.65;
}

#msgContent::placeholder { color: #a8a8a8; }

#msgPreviewArea {
  display: none;
  min-height: 78px;
  padding: 13px;
  border-radius: 12px;
  border: 1px dashed var(--entry-border-strong);
  background: rgba(255,255,255,0.025);
  text-align: left;
}

.composer-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 14px;
}

.composer-icon {
  cursor: pointer;
  font-size: 18px;
  opacity: .72;
  transition: opacity .14s ease;
}

.composer-icon:hover { opacity: 1; }

button.primary-btn {
  width: auto !important;
  min-height: 38px;
  padding: 0 18px !important;
  border-radius: 10px !important;
  color: #f3f7f2 !important;
  background: #477a56 !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  box-shadow: none !important;
  font-size: 14px !important;
  font-weight: 730 !important;
}

button.primary-btn:hover {
  transform: none !important;
  filter: none !important;
  background: #568c64 !important;
  box-shadow: none !important;
}

#msgLoginPrompt {
  display: none;
  padding: 18px;
  border-radius: 16px;
  border: 1px dashed var(--entry-border-strong);
  background: rgba(255,255,255,0.025);
  color: var(--entry-muted);
  font-size: 14px;
}

.msg-summary-bar {
  gap: 8px !important;
  margin-top: 0 !important;
}

.msg-summary-pill,
.msg-summary-inline span {
  background: rgba(255,255,255,0.035) !important;
  border-color: var(--entry-border) !important;
  color: var(--entry-muted) !important;
  border-radius: 999px;
}

.msg-tabs {
  margin-top: 20px !important;
  padding-bottom: 10px !important;
  gap: 18px !important;
  border-bottom: 1px solid var(--entry-border) !important;
}

.msg-tabs span {
  color: var(--entry-muted) !important;
  opacity: 1 !important;
  font-weight: 650 !important;
}

.msg-tabs span.active {
  color: var(--entry-text) !important;
}

.msg-tabs span.active::after {
  bottom: -11px !important;
  background: var(--entry-green) !important;
  box-shadow: none !important;
}

.search-wrapper input,
input,
textarea {
  background: rgba(255,255,255,0.045) !important;
  color: var(--entry-text) !important;
  border: 1px solid var(--entry-border) !important;
  border-radius: 11px !important;
  box-shadow: none !important;
}

.search-wrapper input {
  width: 176px !important;
  margin-top: 0 !important;
  height: 34px;
}

input:focus,
textarea:focus,
.search-wrapper input:focus {
  border-color: rgba(113,164,123,0.48) !important;
  background: rgba(255,255,255,0.062) !important;
  box-shadow: 0 0 0 3px rgba(79,139,97,0.13) !important;
}

#msgArea {
  margin-top: 14px !important;
}

.msgItem {
  margin-top: 12px !important;
  padding: 22px !important;
  border-radius: 18px !important;
  background: rgba(32,32,32,0.96) !important;
  border: 1px solid var(--entry-border) !important;
  box-shadow: none !important;
  animation: none !important;
  transition: background .14s ease, border-color .14s ease !important;
}

.msgItem:hover {
  transform: none !important;
  background: rgba(37,37,37,0.98) !important;
  border-color: rgba(255,255,255,0.11) !important;
  box-shadow: none !important;
}

.msgItem.featured {
  background: rgba(36,32,25,0.96) !important;
  border-color: rgba(181,138,59,0.25) !important;
}

.featured-badge {
  top: 18px !important;
  right: 20px !important;
  font-size: 16px !important;
  filter: none !important;
}

.msgHead {
  gap: 10px !important;
  margin-bottom: 12px !important;
  opacity: 1 !important;
}

.msgHead b,
.reply-user-line b {
  color: var(--entry-text) !important;
  font-weight: 760 !important;
}

.avatar {
  width: 34px !important;
  height: 34px !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  text-shadow: none !important;
  color: white !important;
  font-size: 14px !important;
}

.avatar:hover { transform: none !important; box-shadow: none !important; }

.online-dot {
  width: 10px !important;
  height: 10px !important;
  border: 2px solid var(--entry-panel) !important;
  box-shadow: none !important;
  background: var(--entry-green-strong) !important;
}

.time-txt {
  color: var(--entry-faint) !important;
  opacity: 1 !important;
  letter-spacing: 0 !important;
}

.pinned-badge {
  color: #d6b26f !important;
  border-color: rgba(181,138,59,0.28) !important;
  background: rgba(181,138,59,0.14) !important;
}

.msg-content {
  margin-bottom: 14px !important;
  color: var(--entry-text);
  line-height: 1.78;
  font-size: 15.5px;
}

.btn-small {
  color: var(--entry-muted) !important;
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid var(--entry-border) !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  transition: background .14s ease, color .14s ease, border-color .14s ease !important;
}

.btn-small:hover {
  color: var(--entry-text) !important;
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.13) !important;
  transform: none !important;
  box-shadow: none !important;
}

.reply-list {
  margin-top: 16px !important;
  padding-left: 14px !important;
  border-left: 2px solid var(--entry-border) !important;
}

.reply-item {
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid var(--entry-border) !important;
  border-radius: 12px !important;
  color: var(--entry-text) !important;
}

.reply-item.is-admin {
  border-left: 3px solid var(--entry-green) !important;
  background: rgba(79,139,97,0.10) !important;
}

.reply-body { color: var(--entry-text) !important; }
.reply-time { color: var(--entry-faint) !important; }

.admin-badge,
.op-badge {
  box-shadow: none !important;
  border-radius: 5px !important;
}

.admin-badge { background: var(--entry-green-strong) !important; color: #101510 !important; }
.op-badge { background: #7f9ab8 !important; color: #101010 !important; }

.markdown-body,
.markdown-body h1,
.markdown-body h2,
.markdown-body h3,
.markdown-body h4 {
  color: var(--entry-text) !important;
}

.markdown-body a {
  color: #8fbf98 !important;
  text-shadow: none !important;
}

.markdown-body blockquote {
  border-left-color: var(--entry-green) !important;
  background: rgba(79,139,97,0.10) !important;
  color: #cfcfcf !important;
}

.markdown-body code {
  background: rgba(255,255,255,0.075) !important;
}

.markdown-body pre {
  background: #171717 !important;
  border-color: var(--entry-border) !important;
}

.markdown-body th,
.markdown-body td {
  border-color: var(--entry-border-strong) !important;
}

.markdown-body th {
  background: rgba(255,255,255,0.04) !important;
  color: var(--entry-muted) !important;
}

.markdown-body img {
  border-color: var(--entry-border) !important;
  border-radius: 12px !important;
}

.site-footer {
  padding: 18px 20px;
  color: var(--entry-muted);
  font-size: 13px;
  text-align: center;
}

.view-stats {
  margin-top: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--entry-muted) !important;
  opacity: 1 !important;
}

.view-stats b {
  color: var(--entry-green-strong) !important;
}

.foot {
  color: var(--entry-faint) !important;
  margin-top: 8px !important;
}

.modal {
  background: rgba(0,0,0,0.58) !important;
  animation: none !important;
}

.modal-content {
  background: #202020 !important;
  border: 1px solid var(--entry-border) !important;
  box-shadow: 0 24px 80px rgba(0,0,0,0.45) !important;
  border-radius: 18px !important;
  animation: none !important;
  color: var(--entry-text) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.profile-modal-content {
  width: 520px !important;
  max-width: 90vw !important;
  padding: 32px !important;
}

.profile-tabs button {
  background: rgba(255,255,255,0.04) !important;
  color: var(--entry-muted) !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.profile-tabs button.active {
  color: #d5e8d4 !important;
  background: rgba(79,139,97,0.18) !important;
  border-color: rgba(113,164,123,0.24) !important;
}

.p-item {
  background: rgba(255,255,255,0.035) !important;
  border-color: var(--entry-border) !important;
  box-shadow: none !important;
}

#backToTop {
  width: 42px !important;
  height: 42px !important;
  right: 24px !important;
  bottom: 24px !important;
  border-radius: 14px !important;
  background: rgba(32,32,32,0.94) !important;
  border-color: var(--entry-border) !important;
  box-shadow: none !important;
  color: var(--entry-muted) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  font-size: 18px !important;
}

#backToTop:hover {
  transform: none !important;
  color: var(--entry-text) !important;
  background: rgba(40,40,40,0.98) !important;
}

html.perf-mode #bg-layer-1,
html.perf-mode #bg-layer-2,
html.is-mobile #bg-layer-1,
html.is-mobile #bg-layer-2 {
  filter: saturate(.66) brightness(.50) contrast(.94);
}

@media (max-width: 1100px) {
  .card.app-shell {
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 24px;
    width: min(1000px, calc(100vw - 36px)) !important;
  }
  .top-nav { justify-content: flex-start; overflow-x: auto; }
}

@media (max-width: 820px) {
  .top-bar {
    min-height: auto;
    padding: 10px 14px !important;
    grid-template-columns: 1fr auto;
    gap: 8px 12px;
  }
  .top-brand { font-size: 15px; }
  .top-nav {
    order: 3;
    grid-column: 1 / -1;
    justify-content: flex-start;
    padding-bottom: 2px;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .top-nav::-webkit-scrollbar { display: none; }
  .top-nav a,
  .top-actions a,
  #authBar a {
    min-height: 30px;
    padding: 0 9px;
    font-size: 12.5px;
  }
  .top-actions { gap: 4px; }
  .card.app-shell {
    display: block !important;
    width: calc(100vw - 24px) !important;
    padding: 110px 0 34px !important;
  }
  .sidebar-column {
    position: static;
    gap: 12px;
    margin-bottom: 14px;
  }
  .profile-panel,
  .sidebar-stats,
  .side-nav,
  .sidebar-note,
  .feed-panel,
  .site-footer {
    border-radius: 16px !important;
  }
  .profile-panel { padding: 18px; }
  .title { font-size: 34px !important; }
  .side-nav {
    flex-direction: row;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .side-nav::-webkit-scrollbar { display: none; }
  .side-nav a {
    flex: 0 0 auto;
    height: 38px;
    padding: 0 12px;
    font-size: 13px;
  }
  .sidebar-note { display: none; }
  .feed-panel { padding: 18px !important; }
  .announcement-history { grid-template-columns: 1fr !important; }
  .announcement-meta { max-width: 100%; }
  .announcement-title-row { align-items: flex-start; flex-direction: column; }
  .window-row { grid-template-columns: 1fr; }
  .window-main { align-items: flex-start; flex-direction: column; }
  .window-title { white-space: normal; }
  .msg-tabs { gap: 14px !important; }
  .search-wrapper {
    width: 100%;
    margin-left: 0 !important;
  }
  .search-wrapper input {
    width: 100% !important;
  }
  .msgItem { padding: 18px !important; }
  .composer-actions { justify-content: space-between; }
  .site-footer { margin-bottom: calc(env(safe-area-inset-bottom) + 8px); }
  #bg-overlay {
    background: linear-gradient(180deg, rgba(18,18,18,0.90), rgba(18,18,18,0.98)) !important;
  }
}

@media (max-width: 420px) {
  .card.app-shell {
    width: calc(100vw - 18px) !important;
  }
  .sidebar-stats {
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }
  .summary-chip { padding: 14px !important; }
  .summary-chip b { font-size: 23px !important; }
  .top-actions {
    max-width: 100%;
  }
  .account-trigger .account-role { display: none; }
  .msgHead { align-items: flex-start !important; }
  .time-txt { margin-left: 0 !important; width: 100%; }
}

/* Keep bg pool visible: html provides the fallback color, body stays transparent. */
body { background: transparent !important; }
.feed-panel,
.profile-panel,
.sidebar-stats,
.side-nav,
.sidebar-note,
.site-footer { scroll-margin-top: 92px; }


:root {
  --flomo-bg: #0d0d0d;
  --flomo-panel: rgba(29, 29, 29, 0.94);
  --flomo-panel-2: rgba(35, 35, 35, 0.96);
  --flomo-border: rgba(255, 255, 255, 0.075);
  --flomo-border-strong: rgba(255, 255, 255, 0.14);
  --flomo-text: #e8e8e8;
  --flomo-muted: #9a9a9a;
  --flomo-dim: #6f6f6f;
  --flomo-green: #4f8d64;
  --flomo-green-strong: #5ba972;
  --flomo-blue: #2f7cc8;
}

html {
  background: #070707;
  color-scheme: dark;
}

body {
  background-color: transparent !important;
  padding-top: 88px;
  color: var(--flomo-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
}

#bg-layer-1,
#bg-layer-2 {
  filter: saturate(0.58) brightness(0.46) blur(2px);
}

#bg-overlay {
  background:
    radial-gradient(circle at 12% 48%, rgba(55, 125, 76, 0.22), transparent 27%),
    linear-gradient(90deg, rgba(6, 6, 6, 0.86), rgba(10, 10, 10, 0.78) 35%, rgba(6, 6, 6, 0.92));
}

.top-bar {
  width: min(1320px, calc(100vw - 72px));
  top: 18px;
  background: rgba(18, 18, 18, 0.86) !important;
  border: 1px solid var(--flomo-border);
  border-radius: 18px;
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(18px) saturate(110%);
  -webkit-backdrop-filter: blur(18px) saturate(110%);
}

.top-brand {
  gap: 10px;
  letter-spacing: -0.02em;
}

.top-brand strong {
  font-size: 16px;
}

.brand-dot {
  width: 9px;
  height: 9px;
  background: var(--flomo-green);
  box-shadow: none;
}

.top-nav {
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.055);
  padding: 4px;
  border-radius: 13px;
}

.top-nav a,
.top-actions a,
.account-login {
  color: var(--flomo-muted);
  text-decoration: none;
  border-radius: 10px;
  padding: 8px 11px;
  transition: background 0.16s ease, color 0.16s ease;
}

.top-nav a:hover,
.top-actions a:hover,
.account-login:hover {
  color: var(--flomo-text);
  background: rgba(255,255,255,0.075);
}

#perfBtn.active {
  background: rgba(79, 141, 100, 0.22);
  color: #dff3e4;
}

.card.app-shell {
  width: min(1320px, calc(100vw - 72px));
  display: grid;
  grid-template-columns: 340px minmax(0, 1fr);
  gap: 34px;
  padding: 0;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.sidebar-column {
  position: sticky;
  top: 92px;
  align-self: start;
  height: calc(100vh - 112px);
  overflow-y: auto;
  padding-right: 8px;
}

.profile-panel,
.sidebar-stats,
.activity-card,
.side-nav,
.sidebar-note,
.feed-panel,
.site-footer {
  background: var(--flomo-panel);
  border: 1px solid var(--flomo-border);
  border-radius: 18px;
  box-shadow: none;
}

.profile-panel {
  padding: 22px;
}

.profile-title-row {
  margin-bottom: 12px;
}

.profile-name {
  font-size: 20px;
  color: #f2f2f2;
}

.profile-pro {
  color: #d8d8d8;
  background: rgba(255,255,255,0.12);
  border: 0;
}

.title {
  font-size: 34px;
  line-height: 1.08;
  letter-spacing: -0.04em;
  color: #f0f0f0;
}

.sub,
.status-subtext {
  color: var(--flomo-muted);
}

.life {
  border: 0;
  box-shadow: none;
  border-radius: 12px;
  background: rgba(255,255,255,0.06);
}

.life.alive {
  background: rgba(79, 141, 100, 0.24);
  color: #cbe9d3;
}

.life.away {
  background: rgba(154, 126, 65, 0.24);
  color: #ead6a8;
}

.life.dead {
  background: rgba(150, 74, 72, 0.22);
  color: #e7b5b5;
}

.sidebar-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 16px;
  gap: 10px;
}

.summary-chip {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.045);
  border-radius: 14px;
  padding: 12px;
}

.summary-chip small {
  color: var(--flomo-muted);
}

.summary-chip b {
  color: #eeeeee;
  font-size: 24px;
}

.summary-chip em {
  color: var(--flomo-dim);
  font-style: normal;
  font-size: 13px;
}

.activity-card {
  padding: 16px;
  margin-top: 14px;
}

.activity-title-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--flomo-text);
  margin-bottom: 14px;
  font-weight: 650;
}

.activity-title-row small {
  font-weight: 500;
  color: var(--flomo-muted);
}

.activity-heatmap {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 6px;
}

.activity-dot {
  aspect-ratio: 1 / 1;
  border-radius: 5px;
  background: rgba(255,255,255,0.105);
  border: 1px solid rgba(255,255,255,0.025);
}

.activity-dot.level-1 { background: rgba(79, 141, 100, 0.28); }
.activity-dot.level-2 { background: rgba(79, 141, 100, 0.42); }
.activity-dot.level-3 { background: rgba(79, 141, 100, 0.64); }
.activity-dot.level-4 { background: rgba(79, 141, 100, 0.88); }

.activity-empty {
  color: var(--flomo-muted);
  font-size: 13px;
}

.side-nav {
  padding: 8px;
  gap: 4px;
}

.side-nav a {
  color: #d6d6d6;
  border-radius: 12px;
  padding: 12px 14px;
}

.side-nav a.active,
.side-nav a:hover {
  background: rgba(79, 141, 100, 0.62);
  color: #fff;
}

.side-nav span {
  opacity: 0.7;
  color: inherit;
}

.sidebar-note {
  color: #c9c9c9;
  padding: 16px;
  line-height: 1.55;
}

.sidebar-note-muted {
  color: var(--flomo-muted);
  margin-top: 8px;
}

.content-column {
  gap: 14px;
}

.feed-panel {
  padding: 22px;
}

.sectionTitle {
  color: #f1f1f1;
  font-size: 17px;
  margin-bottom: 14px;
}

.sectionTitle::before {
  display: none;
}

.announcement-meta,
.message-subtitle {
  color: var(--flomo-muted);
  font-weight: 500;
}

.box,
.announcement-box,
#tipBox,
#winlist {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.announcement-history {
  border-top: 1px solid rgba(255,255,255,0.075);
  margin-top: 18px;
  padding-top: 14px;
}

.announcement-history-card,
.announcement-history-item {
  background: rgba(255,255,255,0.045) !important;
  border: 1px solid rgba(255,255,255,0.055) !important;
  border-radius: 14px !important;
}

.ghost-btn,
.btn-small,
.primary-btn {
  border-radius: 12px !important;
  box-shadow: none !important;
}

.primary-btn {
  background: var(--flomo-green) !important;
  color: #fff !important;
}

.primary-btn:hover {
  background: var(--flomo-green-strong) !important;
}

.entry-composer {
  background: var(--flomo-panel-2) !important;
  border: 1px solid var(--flomo-border-strong) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  box-shadow: none !important;
}

.composer-tabs span,
.msg-tabs span {
  color: var(--flomo-muted);
}

.composer-tabs span.active,
.msg-tabs span.active {
  color: var(--flomo-text);
  background: rgba(255,255,255,0.07);
}

#msgContent,
#frontMsgSearch,
input,
textarea {
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 13px !important;
  color: #eee !important;
  box-shadow: none !important;
}

#msgContent {
  background: transparent !important;
  border: 0 !important;
  padding: 12px 0 !important;
}

.composer-actions {
  border-top: 1px solid rgba(255,255,255,0.07);
  padding-top: 12px;
}

.composer-icon {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: none;
}

.msg-summary-bar {
  gap: 8px;
}

.msg-summary-pill {
  background: rgba(255,255,255,0.055);
  border: 1px solid rgba(255,255,255,0.06);
  color: var(--flomo-muted);
}

.msg-tabs {
  background: transparent;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding-bottom: 12px;
}

.search-wrapper {
  background: transparent;
}

.msgItem {
  background: var(--flomo-panel-2) !important;
  border: 1px solid var(--flomo-border) !important;
  border-radius: 18px !important;
  box-shadow: none !important;
}

.msgItem:hover {
  transform: none !important;
  border-color: rgba(255,255,255,0.14) !important;
}

.msgItem.featured {
  background: rgba(35, 35, 35, 0.98) !important;
  border-color: rgba(79, 141, 100, 0.38) !important;
}

.msgHead b {
  color: #ededed !important;
}

.avatar {
  box-shadow: none !important;
  border: 1px solid rgba(255,255,255,0.12);
}

.pinned-badge,
.featured-badge {
  background: rgba(79, 141, 100, 0.18);
  color: #d8f0df;
  border: 1px solid rgba(79, 141, 100, 0.25);
}

.reply-list {
  border-left-color: rgba(255,255,255,0.1) !important;
}

.reply-item {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.045) !important;
  border-radius: 12px !important;
}

.site-footer {
  color: var(--flomo-muted);
  padding: 18px 22px;
}

.modal {
  background: rgba(0,0,0,0.56) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.modal-content {
  background: rgba(20,20,20,0.98) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 22px !important;
  box-shadow: 0 32px 90px rgba(0,0,0,0.55) !important;
}

.profile-modal-content {
  max-width: 780px;
}

.profile-tabs {
  background: rgba(255,255,255,0.045);
  border-radius: 14px;
  padding: 4px;
}

.profile-tabs button {
  border-radius: 11px;
}

.profile-tabs button.active {
  background: rgba(255,255,255,0.10);
}

.account-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.account-trigger,
.account-login {
  appearance: none;
  border: 0;
  cursor: pointer;
  color: var(--flomo-text);
  background: rgba(255,255,255,0.055);
  border-radius: 999px;
  padding: 7px 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.account-avatar {
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--flomo-green);
  color: white;
  font-size: 12px;
  font-weight: 800;
}

.account-name {
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.account-role {
  font-size: 11px;
  color: #d9d9d9;
  background: rgba(255,255,255,0.13);
  border-radius: 6px;
  padding: 2px 5px;
}

.account-chevron {
  color: var(--flomo-muted);
  font-size: 16px;
  line-height: 1;
}

.account-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: 220px;
  display: none;
  flex-direction: column;
  background: rgba(41,41,41,0.98);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  padding: 8px;
  box-shadow: 0 22px 60px rgba(0,0,0,0.45);
  z-index: 30;
}

.account-dropdown.show {
  display: flex;
}

.account-dropdown a,
.account-dropdown button {
  text-align: left;
  width: 100%;
  border: 0;
  background: transparent;
  color: #e7e7e7;
  text-decoration: none;
  padding: 11px 12px;
  border-radius: 10px;
  cursor: pointer;
  font: inherit;
}

.account-dropdown a:hover,
.account-dropdown button:hover {
  background: rgba(255,255,255,0.08);
}

@media (max-width: 980px) {
  body {
    padding-top: 78px;
  }

  .top-bar {
    width: calc(100vw - 24px);
    top: 10px;
    border-radius: 16px;
    padding: 10px;
  }

  .top-nav {
    display: none;
  }

  .card.app-shell {
    width: calc(100vw - 24px);
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .sidebar-column {
    position: static;
    height: auto;
    overflow: visible;
    padding-right: 0;
  }

  .profile-panel {
    padding: 18px;
  }

  .sidebar-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    overflow-x: auto;
  }

  .summary-chip {
    min-width: 86px;
  }

  .side-nav {
    display: flex;
    flex-direction: row;
    overflow-x: auto;
    white-space: nowrap;
  }

  .side-nav a {
    flex: 0 0 auto;
  }

  .activity-heatmap {
    grid-template-columns: repeat(14, 1fr);
  }
}

@media (max-width: 640px) {
  body {
    padding-top: 72px;
  }

  .top-bar {
    width: calc(100vw - 16px);
    font-size: 13px;
  }

  .top-brand strong {
    max-width: 118px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .top-actions {
    gap: 4px;
  }

  .top-actions a {
    padding: 7px 8px;
  }

  .card.app-shell {
    width: calc(100vw - 16px);
  }

  .title {
    font-size: 29px;
  }

  .sidebar-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .feed-panel {
    padding: 17px;
    border-radius: 16px;
  }

  .activity-heatmap {
    gap: 4px;
  }

  .modal-content {
    width: min(94vw, 520px) !important;
    border-radius: 18px !important;
  }
}


:root {
  --shell-alpha: 0.72;
  --panel-alpha: 0.68;
}

#bg-layer-1,
#bg-layer-2 {
  opacity: 1;
  filter: saturate(0.95) brightness(0.88) contrast(1.02) !important;
  background-color: #0b0b0b;
}

#bg-overlay {
  background:
    radial-gradient(circle at 11% 48%, rgba(79,141,100,0.18), transparent 24%),
    radial-gradient(circle at 80% 18%, rgba(255,255,255,0.055), transparent 26%),
    linear-gradient(90deg, rgba(5,5,5,0.34) 0%, rgba(8,8,8,0.50) 42%, rgba(5,5,5,0.64) 100%) !important;
}

.card.app-shell {
  background: rgba(18,18,18,var(--shell-alpha)) !important;
  border-color: rgba(255,255,255,0.11) !important;
}

.feed-panel,
.profile-panel,
.activity-card,
.sidebar-stats,
.side-nav,
.sidebar-note,
.site-footer,
.entry-composer,
.msgItem {
  background: rgba(29,29,29,var(--panel-alpha)) !important;
}

.box,
.window-row,
.summary-chip,
.announcement-history-card,
.msg-summary-pill {
  background: rgba(255,255,255,0.052) !important;
}

.content-column,
.sidebar-column {
  min-height: 0;
}

.sidebar-column {
  max-height: calc(100vh - 118px);
  overflow-y: auto;
  scrollbar-gutter: stable;
}

#windowsPanel #winlist,
#announcementHistory,
#msgArea,
.profile-modal-content #profileContentArea {
  max-height: min(58vh, 680px);
  overflow-y: auto;
  scrollbar-gutter: stable;
}

#announcementHistory {
  padding-right: 4px;
}

.modal-content {
  max-height: min(88vh, 860px) !important;
  overflow-y: auto !important;
  scrollbar-gutter: stable;
}

.profile-modal-content {
  width: min(920px, 94vw) !important;
}

@media (max-width: 980px) {
  .sidebar-column {
    max-height: none;
    overflow: visible;
  }
  #windowsPanel #winlist,
  #announcementHistory,
  #msgArea {
    max-height: none;
    overflow-y: visible;
  }
}

@media (max-width: 768px) {
  #bg-layer-1,
  #bg-layer-2,
  html.perf-mode #bg-layer-1,
  html.perf-mode #bg-layer-2,
  html.is-mobile #bg-layer-1,
  html.is-mobile #bg-layer-2 {
    filter: saturate(0.9) brightness(0.82) contrast(1) !important;
  }

  #bg-overlay,
  html.is-mobile #bg-overlay {
    background:
      linear-gradient(180deg, rgba(5,5,5,0.32) 0%, rgba(8,8,8,0.68) 100%) !important;
  }

  .card.app-shell {
    background: rgba(18,18,18,0.78) !important;
  }

  .feed-panel,
  .profile-panel,
  .activity-card,
  .sidebar-stats,
  .side-nav,
  .sidebar-note,
  .site-footer,
  .entry-composer,
  .msgItem {
    background: rgba(29,29,29,0.72) !important;
  }
}


:root {
  --matte-bg: #111111;
  --matte-panel: rgba(31,31,31,0.76);
  --matte-panel-strong: rgba(32,32,32,0.88);
  --matte-border: rgba(255,255,255,0.10);
  --matte-muted: #9a9a9a;
  --matte-text: #e9e9e9;
  --matte-green: #4f8d64;
}

/* remove broken glass globally */
.top-bar,
.card,
.card.app-shell,
.feed-panel,
.profile-panel,
.activity-card,
.sidebar-stats,
.side-nav,
.sidebar-note,
.site-footer,
.entry-composer,
.msgItem,
.box,
.summary-chip,
.modal,
.modal-content,
.account-dropdown,
#backToTop,
#lightbox,
.window-row,
.msg-summary-pill,
.announcement-history-card {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

#bg-overlay {
  background:
    radial-gradient(circle at 8% 42%, rgba(79,141,100,0.12), transparent 22%),
    linear-gradient(90deg, rgba(5,5,5,0.20) 0%, rgba(7,7,7,0.36) 54%, rgba(5,5,5,0.52) 100%) !important;
}

#bg-layer-1,
#bg-layer-2 {
  filter: saturate(0.98) brightness(0.94) contrast(1.02) !important;
}

.card.app-shell {
  background: rgba(18,18,18,var(--shell-alpha, 0.66)) !important;
  border: 1px solid var(--matte-border) !important;
  box-shadow: 0 24px 80px rgba(0,0,0,0.34) !important;
}

.feed-panel,
.profile-panel,
.activity-card,
.sidebar-stats,
.side-nav,
.sidebar-note,
.site-footer,
.entry-composer,
.msgItem {
  background: rgba(31,31,31,var(--panel-alpha, 0.70)) !important;
  box-shadow: none !important;
}

.top-bar {
  background: rgba(18,18,18,0.78) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 18px 42px rgba(0,0,0,0.25) !important;
}

/* P1: running list gets its own scroll area */
#windowsPanel {
  min-height: 0;
}

#windowsPanel #winlist {
  max-height: clamp(220px, 32vh, 340px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 8px !important;
  border-radius: 16px !important;
  scrollbar-gutter: stable;
  background: rgba(255,255,255,0.035) !important;
}

.window-row {
  min-height: 46px;
  padding: 8px 10px !important;
  border-radius: 12px !important;
  grid-template-columns: auto minmax(0,1fr) auto !important;
  background: transparent !important;
  border: 1px solid transparent !important;
}

.window-row + .window-row {
  border-top-color: rgba(255,255,255,0.055) !important;
}

.window-row:hover {
  background: rgba(255,255,255,0.045) !important;
  border-color: rgba(255,255,255,0.08) !important;
}

.window-main {
  display: contents !important;
}

.proc-tag {
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.window-title {
  min-width: 0;
  white-space: nowrap !important;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* account dropdown and dialogs closer to flomo */
.account-dropdown {
  width: 276px !important;
  padding: 8px !important;
  border-radius: 14px !important;
  background: #2b2b2b !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  box-shadow: 0 28px 70px rgba(0,0,0,0.50) !important;
}

.account-dropdown a,
.account-dropdown button {
  display: grid !important;
  grid-template-columns: 24px minmax(0,1fr) auto;
  gap: 10px;
  align-items: center;
  color: #d7d7d7 !important;
  padding: 11px 12px !important;
  border-radius: 10px !important;
}

.account-dropdown a:hover,
.account-dropdown button:hover {
  background: rgba(255,255,255,0.08) !important;
}

.modal {
  background: rgba(0,0,0,0.62) !important;
  padding: 24px !important;
}

.modal-content {
  background: #171717 !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  box-shadow: 0 36px 90px rgba(0,0,0,0.52) !important;
  border-radius: 18px !important;
  text-align: left !important;
}

.profile-modal-content {
  width: min(860px, 94vw) !important;
  padding: 30px !important;
}

.profile-modal-content > div:first-child h3 {
  width: 100%;
  text-align: center;
  font-size: 20px !important;
  letter-spacing: -0.02em;
}

.profile-tabs {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 4px;
  background: #242424 !important;
  border-radius: 14px !important;
  padding: 5px !important;
  margin: 20px 0 14px !important;
}

.profile-tabs button {
  height: 38px;
  border: 0 !important;
  border-radius: 10px !important;
  background: transparent !important;
  color: #a9a9a9 !important;
  font-weight: 650 !important;
}

.profile-tabs button.active {
  background: #333 !important;
  color: #f4f4f4 !important;
}

#profileContentArea {
  background: #202020;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 12px;
  max-height: min(58vh, 640px) !important;
}

.p-item {
  background: #262626 !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 14px !important;
  box-shadow: none !important;
}

.profile-settings-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.profile-setting-row {
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(260px, 45%);
  gap: 18px;
  align-items: center;
  padding: 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.profile-setting-row:last-child {
  border-bottom: 0;
}

.profile-setting-row b {
  display: block;
  color: #eeeeee;
  font-size: 15px;
  margin-bottom: 5px;
}

.profile-setting-row p {
  margin: 0;
  color: #8f8f8f;
  font-size: 13px;
  line-height: 1.5;
}

.profile-setting-control {
  display: flex;
  align-items: center;
  gap: 10px;
}

.profile-setting-stack {
  flex-direction: column;
  align-items: stretch;
}

.profile-setting-control input[type="range"] {
  flex: 1;
  accent-color: var(--matte-green);
}

.profile-setting-control input:not([type="range"]) {
  width: 100%;
  margin: 0 !important;
}

.profile-setting-control button,
.inline-actions button,
.danger-row button {
  min-height: 38px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.12);
  background: #303030;
  color: #e8e8e8;
  padding: 0 14px;
  cursor: pointer;
}

.inline-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.danger-row button {
  background: rgba(239,68,68,0.10);
  border-color: rgba(239,68,68,0.28);
  color: #ff8a8a;
}

/* fixed immersive mode */
body.zen-mode {
  padding: 0 !important;
  min-height: 100vh;
  overflow: hidden;
  background: transparent !important;
}

body.zen-mode .app-shell,
body.zen-mode .top-brand,
body.zen-mode .top-nav,
body.zen-mode #authBar,
body.zen-mode #perfBtn,
body.zen-mode #backToTop {
  display: none !important;
}

body.zen-mode .top-bar {
  left: auto !important;
  right: 18px !important;
  top: 18px !important;
  transform: none !important;
  width: auto !important;
  min-width: 0 !important;
  padding: 8px !important;
  background: rgba(18,18,18,0.34) !important;
  border-color: rgba(255,255,255,0.08) !important;
  box-shadow: none !important;
}

body.zen-mode #zenBtn {
  display: inline-flex !important;
  color: #fff !important;
  opacity: .9 !important;
  background: rgba(255,255,255,0.10) !important;
  border-radius: 999px !important;
  padding: 8px 12px !important;
}

@media (max-width: 980px) {
  #windowsPanel #winlist {
    max-height: min(42vh, 360px) !important;
    overflow-y: auto !important;
  }

  .window-row {
    grid-template-columns: 1fr auto !important;
  }

  .window-main {
    display: flex !important;
    flex-direction: column;
    gap: 6px;
  }

  .profile-setting-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .profile-tabs {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }

  .modal {
    padding: 10px !important;
  }

  #profileContentArea {
    max-height: 62vh !important;
  }
}


*, *::before, *::after { box-sizing: border-box; }
html, body { width: 100%; max-width: 100%; overflow-x: hidden !important; }
img, video, canvas, svg, iframe { max-width: 100%; }
.top-bar, .app-shell, .sidebar-column, .content-column, .feed-panel { max-width: 100%; }

/* hard-disable any old glass remnants from earlier layers */
*, *::before, *::after {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Running app rows: never overflow horizontally, but keep desktop compactness. */
#windowsPanel #winlist {
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}
.window-row,
.window-main,
.window-title,
.proc-tag,
.runtime-chip {
  min-width: 0;
  max-width: 100%;
}
.proc-tag,
.runtime-chip {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.window-title {
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Account dropdown must be clipped to the viewport on small screens. */
.account-menu { min-width: 0; }
.account-trigger { max-width: 100%; min-width: 0; }
.account-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.account-dropdown {
  max-height: min(72vh, 560px);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
}

@media (max-width: 760px) {
  body {
    padding-top: calc(72px + env(safe-area-inset-top)) !important;
  }

  .top-bar {
    left: max(8px, env(safe-area-inset-left)) !important;
    right: max(8px, env(safe-area-inset-right)) !important;
    top: max(8px, env(safe-area-inset-top)) !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 54px !important;
    padding: 7px 9px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 6px 8px !important;
    border-radius: 16px !important;
    overflow: visible !important;
  }

  .top-brand {
    min-width: 0 !important;
    max-width: 100% !important;
    gap: 8px !important;
  }

  .top-brand strong {
    display: block;
    max-width: clamp(106px, 34vw, 170px) !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 15px !important;
  }

  .top-actions {
    min-width: 0 !important;
    max-width: 100% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 4px !important;
    flex-wrap: nowrap !important;
    overflow: visible !important;
  }

  #authBar {
    display: contents !important;
  }

  .account-trigger,
  .account-login,
  #perfBtn,
  #zenBtn {
    min-height: 34px !important;
    height: 34px !important;
    padding: 0 8px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    flex: 0 0 auto !important;
  }

  .account-trigger {
    max-width: min(44vw, 172px) !important;
    gap: 6px !important;
  }

  .account-avatar {
    width: 24px !important;
    height: 24px !important;
    flex: 0 0 24px !important;
    font-size: 12px !important;
  }

  .account-name {
    max-width: 58px !important;
  }

  .account-chevron {
    font-size: 14px !important;
  }

  .top-nav {
    display: none !important;
  }

  .card.app-shell {
    width: calc(100vw - 16px) !important;
    margin-top: 0 !important;
    padding: 0 0 30px !important;
  }

  .sidebar-column,
  .content-column {
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  .profile-panel,
  .sidebar-stats,
  .activity-card,
  .side-nav,
  .feed-panel,
  .site-footer {
    width: 100% !important;
    max-width: 100% !important;
  }

  .side-nav {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .side-nav::-webkit-scrollbar { display: none; }

  .activity-heatmap {
    grid-template-columns: repeat(12, minmax(12px, 1fr)) !important;
  }

  .feed-panel {
    padding: 16px !important;
  }

  #windowsPanel #winlist {
    max-height: min(44vh, 340px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 6px !important;
  }

  .window-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 7px !important;
    padding: 10px !important;
  }

  .window-main {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 7px !important;
    min-width: 0 !important;
  }

  .proc-tag {
    max-width: 100% !important;
  }

  .window-title {
    width: 100%;
    white-space: normal !important;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }

  .runtime-chip {
    justify-self: start;
    width: fit-content;
  }

  .msg-tabs {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .msg-tabs::-webkit-scrollbar { display: none; }

  .search-wrapper {
    flex: 1 0 100% !important;
    width: 100% !important;
  }

  .composer-meta-row,
  .composer-actions,
  .msg-actions,
  .msgHead {
    min-width: 0;
  }

  .msgItem,
  .reply-item,
  .p-item {
    overflow-wrap: anywhere;
  }

  .modal {
    padding: max(10px, env(safe-area-inset-top)) 10px max(10px, env(safe-area-inset-bottom)) !important;
    align-items: center !important;
  }

  .modal-content,
  .profile-modal-content {
    width: min(100%, 560px) !important;
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 24px) !important;
    padding: 20px !important;
    overflow-y: auto !important;
  }

  #profileContentArea {
    max-height: min(62dvh, 620px) !important;
  }

  .profile-setting-row {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .profile-setting-control,
  .inline-actions {
    width: 100%;
  }

  .profile-setting-control button,
  .inline-actions button,
  .danger-row button {
    flex: 1 1 auto;
  }

  .account-dropdown {
    position: fixed !important;
    left: max(10px, env(safe-area-inset-left)) !important;
    right: max(10px, env(safe-area-inset-right)) !important;
    top: calc(max(8px, env(safe-area-inset-top)) + 58px) !important;
    width: auto !important;
    max-width: none !important;
    max-height: min(68dvh, 520px) !important;
    border-radius: 16px !important;
    z-index: 80 !important;
    transform: none !important;
  }

  .account-dropdown a,
  .account-dropdown button {
    grid-template-columns: 24px minmax(0, 1fr) auto !important;
  }
}

@media (max-width: 390px) {
  .top-brand strong { max-width: 92px !important; }
  .account-trigger { max-width: 138px !important; }
  .account-name { max-width: 44px !important; }
  .account-role { display: none !important; }
  #perfBtn, #zenBtn { padding: 0 7px !important; font-size: 12px !important; }
  .brand-dot { width: 8px !important; height: 8px !important; }
}

/* Immersive mode on mobile: show only a small exit pill; no offscreen top bar. */
body.zen-mode .top-bar {
  left: auto !important;
  right: max(10px, env(safe-area-inset-right)) !important;
  top: max(10px, env(safe-area-inset-top)) !important;
  width: auto !important;
  display: inline-flex !important;
  grid-template-columns: none !important;
}
body.zen-mode #zenBtn { height: 36px !important; }


.account-dropdown b,
.account-dropdown span,
.account-dropdown a,
.account-dropdown button {
  visibility: visible !important;
  opacity: 1 !important;
  color: #eeeeee !important;
  text-shadow: none !important;
}
.account-dropdown b {
  display: block !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-weight: 560 !important;
}
.account-dropdown span:first-child {
  display: inline-grid !important;
  place-items: center !important;
  width: 24px !important;
  min-width: 24px !important;
  color: #bdbdbd !important;
}

@media (max-width: 760px) {
  body {
    padding-top: calc(76px + env(safe-area-inset-top)) !important;
  }

  .top-bar {
    grid-template-columns: minmax(0, 1fr) auto !important;
    overflow: visible !important;
  }

  .top-actions {
    max-width: min(58vw, 260px) !important;
  }

  .account-trigger {
    max-width: min(38vw, 150px) !important;
  }

  .account-role {
    display: none !important;
  }

  .account-dropdown.show {
    display: flex !important;
  }

  .account-dropdown {
    position: fixed !important;
    left: max(12px, env(safe-area-inset-left)) !important;
    right: max(12px, env(safe-area-inset-right)) !important;
    top: calc(max(8px, env(safe-area-inset-top)) + 64px) !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    max-height: min(56dvh, 380px) !important;
    padding: 8px !important;
    border-radius: 18px !important;
    background: rgba(34,34,34,0.98) !important;
    box-shadow: 0 22px 60px rgba(0,0,0,0.42) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    z-index: 90 !important;
  }

  .account-dropdown a,
  .account-dropdown button {
    display: grid !important;
    grid-template-columns: 28px minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 46px !important;
    width: 100% !important;
    padding: 0 12px !important;
    text-align: left !important;
    border-radius: 12px !important;
    background: transparent !important;
  }

  .account-dropdown a:active,
  .account-dropdown button:active {
    background: rgba(255,255,255,0.08) !important;
  }

  .card.app-shell {
    display: block !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  .profile-panel,
  .sidebar-stats,
  .activity-card,
  .side-nav,
  .feed-panel,
  .site-footer {
    background: rgba(31,31,31,0.74) !important;
    border-color: rgba(255,255,255,0.10) !important;
    overflow: hidden !important;
  }

  .profile-panel *,
  .sidebar-stats *,
  .activity-card *,
  .side-nav *,
  .feed-panel *,
  .site-footer *,
  .modal-content * {
    max-width: 100%;
  }

  .side-nav a {
    color: #e7e7e7 !important;
  }

  .side-nav a span {
    display: inline-block !important;
    opacity: 0.85 !important;
  }

  .profile-title-row,
  .sectionTitle,
  .message-title-row,
  .activity-title-row {
    min-width: 0 !important;
  }

  .title,
  .sub,
  .status-subtext,
  .sectionTitle,
  .box,
  .markdown-body,
  .msgItem,
  .reply-item {
    overflow-wrap: anywhere !important;
  }

  /* Top action text remains visible, but the trigger is compact enough for phones. */
  #perfBtn,
  #zenBtn {
    white-space: nowrap !important;
  }
}

@media (max-width: 430px) {
  .top-brand strong {
    max-width: clamp(118px, 36vw, 156px) !important;
  }
  .account-trigger {
    max-width: 128px !important;
  }
  .account-name {
    max-width: 54px !important;
  }
  #perfBtn,
  #zenBtn {
    padding: 0 8px !important;
  }
}

@media (max-width: 370px) {
  .top-brand strong {
    max-width: 96px !important;
  }
  .account-trigger {
    max-width: 112px !important;
  }
  .account-name {
    max-width: 42px !important;
  }
  #perfBtn {
    max-width: 44px !important;
    overflow: hidden !important;
  }
}

.journal-panel .journal-featured-box {
  text-align: left;
  line-height: 1.75;
}
.journal-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-top: 14px;
  text-align: left;
}
.journal-card {
  cursor: pointer;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  transition: transform .2s, border-color .2s, background .2s;
}
.journal-card:hover,
.journal-card.active {
  transform: translateY(-2px);
  background: rgba(74,222,128,0.10);
  border-color: rgba(74,222,128,0.32);
}
.journal-card-title {
  display: flex;
  align-items: center;
  gap: 7px;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  margin-bottom: 6px;
}
.journal-card-title span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.journal-card-time {
  font-size: 11.5px;
  color: #94a3b8;
  margin-bottom: 7px;
}
.journal-card-preview {
  font-size: 12.5px;
  color: #cbd5e1;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.process-activity-list {
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.07);
  font-size: 12.5px;
  color: #cbd5e1;
  line-height: 1.55;
  text-align: left;
}
.process-activity-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #f8fafc;
  font-weight: 800;
  margin-bottom: 8px;
}
.process-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 5px 0;
  border-top: 1px solid rgba(255,255,255,0.05);
}
.process-row:first-of-type { border-top: 0; }
.process-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 155px;
  color: #e2e8f0;
}
.process-duration {
  color: #86efac;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  white-space: nowrap;
}
.activity-dot {
  cursor: pointer;
}
.activity-dot.selected {
  outline: 2px solid rgba(255,255,255,0.85);
  outline-offset: 2px;
}
.account-avatar-wrap {
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
}
.account-avatar-wrap .online-dot {
  width: 9px;
  height: 9px;
  right: -1px;
  bottom: -1px;
  border-width: 2px;
}
@media (max-width: 700px) {
  .journal-list { grid-template-columns: 1fr; }
  .process-name { max-width: 118px; }
}

.front-view {
  display: none;
  animation: frontViewFade .18s ease-out;
}
.front-view.active {
  display: block;
}
.front-tab-link.active,
.top-nav .front-tab-link.active,
.side-nav .front-tab-link.active {
  color: #fff !important;
  background: rgba(74, 222, 128, 0.14) !important;
  border-color: rgba(74, 222, 128, 0.22) !important;
  opacity: 1 !important;
}
.side-nav .front-tab-link.active span {
  color: #4ade80;
}
@keyframes frontViewFade {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}


/* v14: top tabs own page navigation; the left column only shows contextual panels. */
.side-nav,
.sidebar-note,
#frontSummaryGrid {
  display: none !important;
}

.sidebar-context-panel {
  display: none !important;
}

.sidebar-context-panel.active {
  display: block !important;
}

.journal-side-panel {
  padding: 16px;
  background: var(--flomo-panel, rgba(32, 32, 32, 0.94));
  border: 1px solid var(--flomo-border, rgba(255,255,255,0.08));
  border-radius: 18px;
  box-shadow: none;
}

.journal-side-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
  color: var(--flomo-text, #f2f2f2);
}

.journal-side-head strong {
  display: block;
  font-size: 15px;
  letter-spacing: -0.01em;
}

.journal-side-head small {
  display: block;
  margin-top: 4px;
  color: var(--flomo-muted, #a1a1aa);
  font-size: 12px;
}

.journal-side-search {
  position: relative;
  margin-bottom: 12px;
}

.journal-side-search::before {
  content: "搜索";
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--flomo-muted, #a1a1aa);
  font-size: 12px;
  pointer-events: none;
}

.journal-side-search input {
  width: 100%;
  height: 40px;
  margin: 0;
  padding: 10px 12px 10px 44px;
  border-radius: 14px;
  font-size: 13px;
  color: #f8fafc;
  background: rgba(255,255,255,0.055);
  border: 1px solid rgba(255,255,255,0.07);
  outline: none;
}

.journal-side-search input:focus {
  border-color: rgba(74,222,128,0.38);
  background: rgba(255,255,255,0.075);
}

.journal-side-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
  max-height: min(54vh, 560px);
  overflow-y: auto;
  padding-right: 2px;
}

.journal-side-item {
  width: 100%;
  text-align: left;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.035);
  color: inherit;
  border-radius: 15px;
  padding: 12px 13px;
  transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

.journal-side-item:hover,
.journal-side-item.active {
  background: rgba(74,222,128,0.10);
  border-color: rgba(74,222,128,0.32);
  transform: translateY(-1px);
}

.journal-side-title {
  display: flex;
  align-items: center;
  gap: 7px;
  color: #f8fafc;
  font-size: 13.5px;
  font-weight: 800;
  line-height: 1.35;
}

.journal-side-title span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.journal-side-title .announcement-pin-badge {
  flex-shrink: 0;
}

.journal-side-time {
  display: block;
  margin-top: 5px;
  font-size: 11px;
  color: var(--flomo-muted, #94a3b8);
}

.journal-side-preview {
  display: -webkit-box;
  margin-top: 6px;
  color: #cbd5e1;
  font-size: 12px;
  line-height: 1.45;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.journal-side-empty,
.journal-empty-state {
  padding: 18px 10px;
  color: var(--flomo-muted, #94a3b8);
  text-align: center;
  font-size: 13px;
  border: 1px dashed rgba(255,255,255,0.12);
  border-radius: 14px;
}


.journal-panel .journal-featured-box {
  min-height: 360px;
  padding: 26px !important;
  font-size: 15px;
  line-height: 1.85;
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 18px !important;
}

.journal-panel .journal-featured-box h3 {
  font-size: clamp(24px, 3vw, 34px);
  letter-spacing: -0.04em;
  margin-bottom: 18px;
}

@media (max-width: 980px) {
  .top-nav {
    display: flex !important;
    grid-column: 1 / -1 !important;
    order: 3 !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
    white-space: nowrap !important;
    scrollbar-width: none;
  }

  .top-nav::-webkit-scrollbar {
    display: none;
  }

  .journal-side-list {
    max-height: none;
    overflow: visible;
  }
}

@media (max-width: 640px) {
  .journal-panel .journal-featured-box {
    min-height: 260px;
    padding: 20px !important;
  }

  .journal-side-panel {
    padding: 14px;
  }
}

/* Better MathJax blocks: keep long formulas readable without breaking the page. */
.markdown-body mjx-container[display="true"] {
  display: block;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 8px 0 10px;
}

.markdown-body mjx-container {
  line-height: 1.55;
}

/* v17: tunnel-safe stats and mobile top-bar spacing fixes */
:root {
  --topbar-offset: 96px;
}

body {
  padding-top: var(--topbar-offset) !important;
}

.view-stats b {
  min-width: 1.2em;
  display: inline-block;
  text-align: center;
}

@media (max-width: 980px) {
  body {
    padding-top: var(--topbar-offset) !important;
  }

  .top-bar {
    align-items: stretch !important;
  }

  .top-nav {
    display: flex !important;
    grid-column: 1 / -1 !important;
    order: 3 !important;
    width: 100% !important;
    gap: 8px !important;
    padding-top: 6px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: nowrap !important;
    scrollbar-width: none;
  }

  .top-nav::-webkit-scrollbar {
    display: none;
  }

  .top-nav .front-tab-link {
    flex: 1 0 auto !important;
    text-align: center !important;
    justify-content: center !important;
    padding: 8px 12px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.055);
    border: 1px solid rgba(255,255,255,0.07);
  }

  .profile-panel {
    scroll-margin-top: calc(var(--topbar-offset) + 12px) !important;
  }
}

@media (max-width: 760px) {
  .top-bar {
    grid-template-columns: minmax(0, 1fr) auto !important;
    min-height: 0 !important;
  }

  .top-brand,
  .top-actions {
    align-self: center !important;
  }

  .top-actions {
    max-width: min(60vw, 260px) !important;
  }

  .top-nav .front-tab-link {
    font-size: 13px !important;
    min-height: 34px !important;
    display: inline-flex !important;
    align-items: center !important;
  }

  .card.app-shell {
    margin-top: 0 !important;
  }
}

@media (max-width: 390px) {
  .top-actions {
    max-width: min(56vw, 220px) !important;
  }

  #perfBtn {
    display: none !important;
  }
}

/* Iteration: isolated status updates, data dashboard, Tip comments, long-content folding */
.data-panel { position: relative; overflow: hidden; }
.data-title-row { align-items: center; }
.data-summary-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:14px; margin-bottom:18px; }
.data-card { border:1px solid rgba(255,255,255,0.08); background:rgba(15,23,42,0.42); border-radius:18px; padding:16px; min-width:0; box-shadow: inset 0 1px 0 rgba(255,255,255,0.05); }
.data-card small { display:block; color:var(--entry-muted); font-size:12px; margin-bottom:8px; }
.data-card b { display:block; color:var(--entry-text); font-size:22px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.data-card em { display:block; margin-top:6px; color:var(--entry-muted); font-style:normal; font-size:12px; }
.data-chart-block { margin-top:16px; padding:18px; border:1px solid rgba(255,255,255,0.08); background:rgba(15,23,42,0.34); border-radius:20px; }
.data-chart-head { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:14px; color:var(--entry-text); }
.data-chart-head small { color:var(--entry-muted); font-size:12px; }
.usage-bar-chart { display:flex; align-items:end; gap:6px; height:190px; padding:16px 6px 4px; border-radius:16px; background:rgba(0,0,0,0.18); overflow-x:auto; }
.usage-bar-item { min-width:22px; flex:1; height:100%; display:flex; flex-direction:column; justify-content:flex-end; align-items:center; gap:6px; }
.usage-bar-item span { width:100%; max-width:28px; min-height:3px; border-radius:999px 999px 4px 4px; background:linear-gradient(180deg, rgba(125,211,252,0.95), rgba(74,222,128,0.65)); box-shadow:0 8px 18px rgba(0,0,0,0.22); }
.usage-bar-item small { height:16px; font-size:10px; color:var(--entry-muted); white-space:nowrap; }
.usage-pie-layout { display:grid; grid-template-columns:180px minmax(0, 1fr); gap:20px; align-items:center; }
.usage-pie-chart { width:170px; height:170px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,0.06); box-shadow: inset 0 0 0 18px rgba(15,23,42,0.65), 0 18px 36px rgba(0,0,0,0.22); }
.usage-pie-chart span { width:104px; height:104px; border-radius:50%; display:flex; align-items:center; justify-content:center; text-align:center; padding:12px; color:var(--entry-text); background:rgba(15,23,42,0.86); font-weight:700; font-size:14px; }
.usage-pie-legend { display:flex; flex-direction:column; gap:10px; min-width:0; }
.usage-pie-legend-item { display:grid; grid-template-columns:12px minmax(0, 1fr) auto; align-items:center; gap:10px; color:var(--entry-muted); font-size:13px; }
.usage-pie-legend-item i { width:10px; height:10px; border-radius:50%; display:block; }
.usage-pie-legend-item span { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--entry-text); }
.usage-pie-legend-item b { font-weight:600; white-space:nowrap; color:var(--entry-muted); }
.data-empty { color:var(--entry-muted); padding:24px 12px; text-align:center; width:100%; }
.tip-display-card { cursor:pointer; border-radius:18px; transition: background .18s ease, transform .18s ease; }
.tip-display-card:hover { background:rgba(255,255,255,0.035); transform:translateY(-1px); }
.tip-content { color:var(--entry-text); line-height:1.65; }
.tip-source { font-size:13px; color:var(--entry-muted); margin-top:10px; }
.tip-author { font-size:12.5px; color:#64748b; margin-top:6px; }
.tip-actions { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:16px; }
.tip-detail-modal-content { width:min(680px, calc(100vw - 32px)) !important; text-align:left !important; }
.tip-detail-card { padding:16px; border-radius:18px; background:rgba(255,255,255,0.045); border:1px solid rgba(255,255,255,0.08); }
.tip-detail-content { color:var(--entry-text); line-height:1.7; }
.tip-comment-count { color:var(--entry-muted); font-size:13px; }
.tip-login-hint { display:flex; align-items:center; justify-content:space-between; gap:12px; margin:16px 0; padding:12px 14px; color:var(--entry-muted); border:1px dashed rgba(255,255,255,0.16); border-radius:14px; }
.tip-comment-composer { display:flex; flex-direction:column; gap:10px; margin:16px 0; }
.tip-comment-composer textarea { width:100%; box-sizing:border-box; resize:vertical; }
.tip-comments-list { display:flex; flex-direction:column; gap:12px; margin-top:14px; }
.tip-comment-item { display:flex; align-items:flex-start; gap:10px; padding:13px; border-radius:16px; background:rgba(0,0,0,0.18); border:1px solid rgba(255,255,255,0.06); }
.tip-comment-main { min-width:0; flex:1; }
.tip-comment-meta { display:flex; align-items:center; gap:8px; margin-bottom:6px; color:var(--entry-muted); font-size:12.5px; }
.tip-comment-meta b { color:var(--entry-text); font-size:13.5px; }
.tip-comment-delete { margin-left:auto; border:0; background:transparent; color:#f87171; cursor:pointer; opacity:.72; }
.tip-comment-body { color:var(--entry-text); font-size:14px; line-height:1.62; }
.tip-comment-empty { padding:24px; text-align:center; color:var(--entry-muted); }
.collapsible-content { position:relative; overflow:visible; }
.collapsible-content.collapsed { max-height:9.6em; overflow:hidden; }
.collapsible-content.collapsed::after { content:""; position:absolute; left:0; right:0; bottom:0; height:3.2em; background:linear-gradient(180deg, rgba(15,23,42,0), rgba(15,23,42,0.94)); pointer-events:none; }
.collapse-toggle { margin-top:8px; padding:4px 10px; border-radius:999px; border:1px solid rgba(255,255,255,0.12); background:rgba(255,255,255,0.05); color:var(--entry-muted); cursor:pointer; font-size:12.5px; }
.collapse-toggle:hover { color:var(--entry-text); background:rgba(255,255,255,0.09); }
@media (max-width: 760px) {
  .data-summary-grid { grid-template-columns:1fr; }
  .usage-pie-layout { grid-template-columns:1fr; justify-items:center; }
  .usage-pie-legend { width:100%; }
  .usage-bar-chart { gap:4px; }
  .usage-bar-item { min-width:18px; }
}

/* v13: minimized windows are still visible, but visually marked as not counting time. */
.runtime-area {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 7px;
  min-width: 0;
}
.window-state-chip {
  flex: 0 0 auto;
  padding: 3px 7px;
  border-radius: 999px;
  font-size: 11px;
  line-height: 1;
  color: rgba(255,255,255,0.56);
  background: rgba(255,255,255,0.055);
  border: 1px solid rgba(255,255,255,0.075);
  white-space: nowrap;
}
.window-row.is-minimized,
.window-row.is-paused {
  opacity: 0.68;
}
.window-row.is-minimized .window-title {
  font-style: italic;
}
.window-row.is-minimized .runtime-chip,
.window-row.is-paused .runtime-chip {
  color: #cbd5e1;
  background: rgba(148,163,184,0.10);
  border-color: rgba(148,163,184,0.18);
}
.window-row.is-minimized .window-state-chip {
  color: #d6d3d1;
  background: rgba(120,113,108,0.16);
  border-color: rgba(120,113,108,0.24);
}
.window-row:not(.is-paused) .window-state-chip {
  color: #bbf7d0;
  background: rgba(34,197,94,0.10);
  border-color: rgba(34,197,94,0.18);
}
@media (max-width: 768px) {
  .runtime-area { justify-content: flex-start; flex-wrap: wrap; }
}


/* v14: GitHub-style process heatmap, filled vertically by weekday. */
.activity-heatmap {
  display: block !important;
  width: 100%;
  overflow: hidden;
}
.activity-month-row {
  display: grid;
  grid-template-columns: 34px repeat(var(--activity-weeks, 12), minmax(13px, 1fr));
  gap: 6px;
  align-items: end;
  margin-bottom: 6px;
  min-height: 18px;
}
.activity-month-label {
  color: var(--flomo-muted);
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
}
.activity-calendar {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 6px;
  align-items: stretch;
}
.activity-weekdays {
  display: grid;
  grid-template-rows: repeat(7, minmax(13px, 1fr));
  gap: 6px;
  color: var(--flomo-muted);
  font-size: 11px;
  line-height: 1;
  text-align: right;
}
.activity-weekdays span {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 13px;
}
.activity-grid {
  display: grid;
  grid-template-columns: repeat(var(--activity-weeks, 12), minmax(13px, 1fr));
  grid-template-rows: repeat(7, minmax(13px, 1fr));
  grid-auto-flow: column;
  gap: 6px;
  min-width: 0;
}
.activity-grid .activity-dot {
  width: 100%;
  min-width: 0;
  aspect-ratio: 1 / 1;
  border-radius: 5px;
  padding: 0;
  cursor: pointer;
  transition: transform .14s ease, outline-color .14s ease, background .14s ease;
}
.activity-grid .activity-dot:hover {
  transform: translateY(-1px) scale(1.04);
}
.activity-grid .activity-dot.selected {
  outline: 2px solid rgba(167, 243, 208, .9);
  outline-offset: 2px;
}
.activity-grid .activity-dot.future {
  opacity: .35;
  border-style: dashed;
}
.activity-legend {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 5px;
  margin-top: 10px;
  color: var(--flomo-muted);
  font-size: 11px;
}
.activity-legend i {
  width: 11px;
  height: 11px;
  border-radius: 3px;
  background: rgba(255,255,255,0.105);
  border: 1px solid rgba(255,255,255,0.035);
}
.activity-legend i.level-1 { background: rgba(79, 141, 100, 0.28); }
.activity-legend i.level-2 { background: rgba(79, 141, 100, 0.42); }
.activity-legend i.level-3 { background: rgba(79, 141, 100, 0.64); }
.activity-legend i.level-4 { background: rgba(79, 141, 100, 0.88); }

/* v14: front-end AI insight cards for the data tab. */
.ai-panel {
  margin: 18px 0;
  padding: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(16,185,129,0.10), rgba(59,130,246,0.06) 42%, rgba(15,23,42,0.36));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}
.ai-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}
.ai-kicker {
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(16,185,129,0.14);
  color: #86efac;
  font-size: 11px;
  letter-spacing: .08em;
  font-weight: 800;
}
.ai-panel-head h3 { margin: 8px 0 4px; color: var(--entry-text); font-size: 22px; }
.ai-panel-head p { margin: 0; color: var(--entry-muted); font-size: 13px; line-height: 1.55; }
.ai-grid { display:grid; grid-template-columns: 1.2fr 1fr; gap: 14px; }
.ai-card {
  min-height: 132px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(15,23,42,0.42);
}
.ai-card h4 { margin: 10px 0 8px; color: var(--entry-text); font-size: 18px; }
.ai-card p { margin: 0; color: var(--entry-muted); line-height: 1.7; }
.ai-label { display:inline-flex; padding:5px 9px; border-radius:999px; background:rgba(125,211,252,0.12); color:#bae6fd; font-size:12px; font-weight:750; }
.ai-list { list-style:none; margin:12px 0 0; padding:0; display:flex; flex-direction:column; gap:8px; }
.ai-list li { color:var(--entry-muted); line-height:1.55; padding:9px 10px; border-radius:12px; background:rgba(255,255,255,0.04); }
.ai-list li.warning { color:#fde68a; background:rgba(245,158,11,0.10); }
.ai-list li.ok { color:#bbf7d0; background:rgba(34,197,94,0.10); }
.category-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.category-chip { display:inline-flex; align-items:center; max-width:100%; padding:7px 10px; border-radius:999px; background:rgba(255,255,255,0.06); color:var(--entry-text); font-size:12.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ai-model-meta { display:block; margin-top:12px; color:var(--entry-muted); line-height:1.5; }
.soft-btn { border:0; border-radius:14px; padding:10px 14px; background:rgba(16,185,129,0.14); color:#a7f3d0; font-weight:800; cursor:pointer; }
.soft-btn:hover { background:rgba(16,185,129,0.22); }
@media (max-width: 760px) {
  .activity-month-row { grid-template-columns: 22px repeat(var(--activity-weeks, 12), minmax(10px, 1fr)); gap: 4px; }
  .activity-calendar { grid-template-columns: 22px minmax(0, 1fr); gap: 4px; }
  .activity-weekdays, .activity-grid { gap: 4px; }
  .activity-weekdays { font-size: 10px; }
  .activity-grid { grid-template-columns: repeat(var(--activity-weeks, 12), minmax(10px, 1fr)); }
  .activity-grid .activity-dot { border-radius: 4px; }
  .ai-panel-head { flex-direction: column; }
  .ai-grid { grid-template-columns: 1fr; }
}

/* v15: second-stage AI widgets. */
.ai-second-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.ai-report-card { grid-column: auto; }
.ai-insight-stack {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-top: 12px;
  color: var(--entry-muted);
  line-height: 1.55;
}
.ai-insight-item {
  padding: 10px 11px;
  border-radius: 13px;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.055);
}
.ai-insight-item b {
  display: block;
  color: var(--entry-text);
  margin-bottom: 4px;
}
.ai-insight-item small {
  display: block;
  color: var(--entry-muted);
  margin-top: 5px;
}
.ai-insight-item.warning { background: rgba(245,158,11,0.10); border-color: rgba(245,158,11,0.18); }
.ai-insight-item.ok { background: rgba(16,185,129,0.10); border-color: rgba(16,185,129,0.18); }
.ai-report-content {
  max-height: 116px;
  overflow: auto;
  white-space: pre-wrap;
  font-size: 12.5px;
}
@media (max-width: 900px) {
  .ai-second-grid { grid-template-columns: 1fr; }
}

/* v16: AI stage-3 explanation, timeline, feedback widgets. */
.ai-third-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.ai-feedback-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.045);
  color: var(--entry-muted);
}
.soft-btn-muted { background: rgba(148,163,184,0.14); color: #dbeafe; }
.ai-feedback-bar small { color: var(--entry-muted); }
.ai-insight-item.info { background: rgba(59,130,246,0.10); border-color: rgba(59,130,246,0.18); }
@media (max-width: 1100px) {
  .ai-third-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .ai-third-grid { grid-template-columns: 1fr; }
}


/* Posts and public user profile refinements */
.post-composer {
  margin-bottom: 16px;
  text-align: left;
}
.post-composer input,
.post-composer textarea {
  width: 100%;
  box-sizing: border-box;
}
.post-composer textarea {
  resize: vertical;
  min-height: 118px;
}
.post-featured-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.post-featured-head h3 {
  margin: 0 !important;
  overflow-wrap: anywhere;
}
.post-featured-head span {
  flex-shrink: 0;
  color: var(--entry-muted);
  font-size: 12.5px;
  text-align: right;
}
.inline-user-link {
  appearance: none;
  border: none;
  background: transparent;
  color: #86efac;
  padding: 0;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}
.inline-user-link:hover { text-decoration: underline; }
.user-clickable { cursor: pointer; }
.journal-load-more {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 16px;
  min-height: 32px;
  color: var(--entry-muted);
}
.journal-load-more small { color: var(--entry-muted); }
.journal-list {
  display: grid !important;
}
.public-user-modal-content {
  width: min(760px, calc(100vw - 32px)) !important;
  text-align: left !important;
}
.public-user-area {
  margin-top: 18px;
  max-height: 70vh;
  overflow-y: auto;
  padding-right: 4px;
}
.public-user-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
}
.public-user-head b { display: block; color: #fff; font-size: 18px; }
.public-user-head span,
.public-user-head small { display: block; color: var(--entry-muted); margin-top: 3px; }
.public-user-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0 18px;
}
.public-user-stats span {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.16);
  color: #dcfce7;
  font-size: 13px;
  text-align: center;
}
.public-user-area h4 {
  margin: 18px 0 10px;
  color: #f8fafc;
}
.public-user-item {
  padding: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.07);
  margin-bottom: 10px;
}
.public-user-item b,
.public-user-item small { display: block; margin-bottom: 7px; color: var(--entry-muted); }
@media (max-width: 700px) {
  .post-featured-head { flex-direction: column; }
  .post-featured-head span { text-align: left; }
  .public-user-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* v18: paged personal/public user lists and clickable detail entries. */
.public-user-tabs,
.profile-list-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0;
  flex-wrap: wrap;
}
.public-user-tabs button {
  flex: 1 1 110px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.045);
  color: var(--entry-muted);
  border-radius: 12px;
  padding: 10px 12px;
  cursor: pointer;
  transition: 0.2s;
}
.public-user-tabs button:hover,
.public-user-tabs button.active {
  background: rgba(74,222,128,0.10);
  border-color: rgba(74,222,128,0.24);
  color: #86efac;
}
.public-user-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0 14px;
}
.public-user-toolbar input,
.profile-list-toolbar input {
  flex: 1 1 220px;
  min-width: 0;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.20);
  color: var(--entry-text);
  border-radius: 12px;
  padding: 10px 12px;
  outline: none;
}
.public-user-toolbar input:focus,
.profile-list-toolbar input:focus {
  border-color: rgba(134,239,172,0.35);
  box-shadow: 0 0 0 3px rgba(34,197,94,0.08);
}
.public-user-toolbar small,
.profile-list-toolbar small {
  color: var(--entry-muted);
  white-space: nowrap;
}
.public-user-list {
  display: grid;
  gap: 10px;
}
.public-user-open-item,
.profile-post-open {
  appearance: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  color: inherit;
  font: inherit;
}
.public-user-open-item:hover,
.profile-post-open:hover,
.profile-click-body:hover {
  border-color: rgba(134,239,172,0.24);
  background: rgba(34,197,94,0.07);
}
.profile-post-open {
  border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.035);
  border-radius: 12px;
  padding: 12px;
}
.profile-post-open b,
.profile-post-open span {
  display: block;
}
.profile-post-open b {
  color: #f8fafc;
  margin-bottom: 8px;
}
.profile-post-open span {
  color: var(--entry-muted);
  line-height: 1.55;
  overflow-wrap: anywhere;
}
.profile-click-body {
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 8px 10px;
  margin: 0 -10px;
  cursor: pointer;
  color: #f8fafc;
  line-height: 1.6;
}
.profile-item-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 12px;
  color: #fcd34d;
  font-size: 13px;
}
.profile-open-link {
  margin-left: auto;
}
.profile-load-more {
  display: flex;
  justify-content: center;
  margin: 14px 0 2px;
  color: var(--entry-muted);
}
@media (max-width: 640px) {
  .public-user-toolbar,
  .profile-list-toolbar {
    align-items: stretch;
    flex-direction: column;
  }
  .public-user-toolbar small,
  .profile-list-toolbar small {
    white-space: normal;
  }
}


/* v19: independent post URLs, compact post list and front-end image upload. */
.journal-card,
.journal-side-item,
.public-user-open-item,
.profile-post-open {
  display: block;
  text-decoration: none !important;
}
.journal-card-preview,
.journal-side-preview {
  -webkit-line-clamp: 1;
}
.post-upload-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin: 10px 0 14px;
  color: var(--entry-muted);
  font-size: 12.5px;
}
.post-upload-row .soft-btn {
  padding: 8px 12px;
  border-radius: 999px;
}
.post-composer.drag-over {
  border-color: rgba(134,239,172,0.45) !important;
  box-shadow: 0 0 0 3px rgba(34,197,94,0.12), inset 0 0 24px rgba(34,197,94,0.08);
}
.post-back-btn {
  appearance: none;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.05);
  color: #bbf7d0;
  border-radius: 999px;
  padding: 6px 10px;
  margin-bottom: 12px;
  cursor: pointer;
}
.post-back-btn:hover { background: rgba(34,197,94,0.14); }
.post-detail-link {
  color: #93c5fd;
  text-decoration: none;
  font-size: 12px;
}
.post-detail-link:hover { text-decoration: underline; }

/* v20: stronger Tip submission and floating post composer. */
.section-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.tip-title-row,
.journal-title-row {
  gap: 12px;
}

.tip-submit-cta,
.post-compose-trigger {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .01em;
  color: #06130b;
  background: linear-gradient(135deg, #bbf7d0, #4ade80 58%, #22c55e);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 10px 26px rgba(34,197,94,0.26), inset 0 1px 0 rgba(255,255,255,0.35);
  transition: transform .18s ease, filter .18s ease, box-shadow .18s ease;
}

.tip-submit-cta::before { content: "✦"; font-size: 12px; }
.post-compose-trigger::before { content: "＋"; font-size: 14px; line-height: 1; }

.tip-submit-cta:hover,
.post-compose-trigger:hover {
  transform: translateY(-1px);
  filter: brightness(1.06);
  box-shadow: 0 14px 30px rgba(34,197,94,0.32), inset 0 1px 0 rgba(255,255,255,0.42);
}

.post-compose-trigger.login-needed {
  color: #dbeafe;
  background: rgba(59,130,246,0.14);
  border-color: rgba(147,197,253,0.22);
  box-shadow: none;
}

.post-composer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 8998;
  background: rgba(2,6,23,0.48);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.floating-post-composer {
  position: fixed !important;
  top: max(88px, calc(var(--topbar-offset, 96px) + 12px));
  right: max(18px, calc((100vw - min(920px, 92vw)) / 2));
  width: min(560px, calc(100vw - 32px));
  max-height: calc(100vh - max(110px, var(--topbar-offset, 96px)) - 24px);
  overflow-y: auto;
  z-index: 8999;
  margin: 0 !important;
  padding: 20px !important;
  border-radius: 24px !important;
  background: rgba(20,20,20,0.96) !important;
  border: 1px solid rgba(134,239,172,0.22) !important;
  box-shadow: 0 28px 80px rgba(0,0,0,0.52), 0 0 0 1px rgba(255,255,255,0.04) inset !important;
  animation: postComposerIn .18s ease-out;
}

.post-composer-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.post-composer-head h3 {
  margin: 0;
  color: #f8fafc;
  font-size: 20px;
  letter-spacing: -0.03em;
}

.post-composer-head p {
  margin: 6px 0 0;
  color: var(--entry-muted);
  font-size: 12.5px;
  line-height: 1.55;
}

.post-compose-close {
  appearance: none;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.055);
  color: #e5e7eb;
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.post-compose-close:hover {
  background: rgba(248,113,113,0.14);
  border-color: rgba(248,113,113,0.24);
  color: #fecaca;
}

.post-login-inline {
  margin-top: 8px;
  color: var(--entry-muted);
  font-size: 12.5px;
}

@keyframes postComposerIn {
  from { opacity: 0; transform: translateY(10px) scale(.985); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@media (max-width: 640px) {
  .section-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .journal-actions .announcement-meta {
    order: 2;
    max-width: 100%;
  }

  .floating-post-composer {
    left: 12px;
    right: 12px;
    top: max(96px, calc(var(--topbar-offset, 96px) + 8px));
    width: auto;
    max-height: calc(100vh - max(118px, var(--topbar-offset, 96px)) - 16px);
    padding: 16px !important;
  }
}


/* v21: data-tab active record card. */
.activity-record-card {
  padding: 20px;
  border-radius: 24px;
  background: rgba(15, 23, 42, 0.36);
  border-color: rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 18px 44px rgba(0,0,0,0.18);
}
.activity-record-head {
  margin-bottom: 16px;
}
.activity-record-head strong {
  font-size: 18px;
  letter-spacing: -0.02em;
}
.activity-record-head small {
  font-size: 16px;
  color: rgba(226,232,240,0.72);
}
.activity-record-card .activity-heatmap {
  padding: 2px 0 0;
}
.activity-empty {
  display: block;
  padding: 18px 0;
  color: var(--entry-muted);
  text-align: center;
}
.activity-month-spacer {
  min-width: 0;
}
.activity-record-card .process-activity-list {
  margin-top: 16px;
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255,255,255,0.045);
  border-color: rgba(255,255,255,0.09);
}
.activity-record-card .process-activity-title {
  font-size: 16px;
  padding-bottom: 10px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.activity-record-card .process-activity-title small {
  color: #f8fafc;
  font-weight: 800;
}
.activity-record-card .process-row {
  padding: 8px 0;
  font-size: 14px;
}
.activity-record-card .process-name {
  max-width: min(320px, 62vw);
  font-weight: 700;
}
.activity-record-card .process-duration {
  font-weight: 900;
  font-size: 15px;
}
@media (max-width: 760px) {
  .activity-record-card { padding: 16px; }
  .activity-record-head small { font-size: 14px; }
}

/* Security/features patch: post comments and owner editing */
.content-edit-modal-content { width:min(720px, calc(100vw - 32px)) !important; text-align:left !important; }
.content-edit-modal-content input,
.content-edit-modal-content textarea { width:100%; box-sizing:border-box; }
.content-edit-modal-content textarea { resize:vertical; min-height:220px; }
.post-detail-actions { display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:flex-end; margin:-4px 0 14px; }
.danger-action { color:#fecaca !important; border-color:rgba(248,113,113,.28) !important; background:rgba(248,113,113,.08) !important; }
.post-comments-panel { margin-top:22px; padding:16px; border-radius:20px; background:rgba(15,23,42,0.34); border:1px solid rgba(255,255,255,0.08); }
.post-comments-head { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:12px; color:var(--entry-text); }
.post-comments-head span { color:var(--entry-muted); font-size:13px; }
.post-comment-composer { display:flex; flex-direction:column; gap:10px; margin:14px 0; }
.post-comment-composer textarea { width:100%; box-sizing:border-box; resize:vertical; }
.post-comments-list { display:flex; flex-direction:column; gap:12px; margin-top:14px; }
.profile-item-actions { flex-wrap:wrap; justify-content:flex-start; }
.profile-item-actions > span { margin-right:auto; }
