/* ═══════════════════════════════════════════════════════════
   WebOS — Master Stylesheet
   Theme variables are injected at runtime by OS.Theme via
   document.documentElement.style.setProperty()
   ═══════════════════════════════════════════════════════════ */

/* ── CSS Reset & Base ─────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
/* Ensure [hidden] always hides even when an explicit display is set by a class */
[hidden] { display: none !important; }

:root {
  --bg-primary:    #2f3440;
  --bg-secondary:  #383c4a;
  --bg-tertiary:   #404552;
  --bg-elevated:   #3b4048;
  --accent:        #5294e2;
  --accent-hover:  #6ba3e8;
  --text-primary:  #d3dae3;
  --text-secondary:#9199a3;
  --text-muted:    #676e7d;
  --border:        #2c3040;
  --shadow:        0 8px 32px rgba(0,0,0,.5);
  --titlebar-bg:   #303642;
  --titlebar-text: #d3dae3;
  --taskbar-bg:    #2f3440;
  --taskbar-text:  #d3dae3;
  --desktop-bg:    #2f3440;
  --window-radius: 8px;
  --btn-close:     #ed4e4e;
  --btn-min:       #f4a22d;
  --btn-max:       #6ab04c;
  --scrollbar-bg:  #2f3440;
  --scrollbar-thumb: #5294e2;
  --input-bg:      #383c4a;
  --input-border:  #5294e2;
  --danger:        #ed4e4e;
  --font-ui:       system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-mono:     'Cascadia Code', 'Fira Code', 'Consolas', monospace;

  /* Derived aliases — always computed from the theme base vars above.
     These are used throughout app stylesheets and should not be set
     directly in theme objects; they stay in sync automatically. */
  --surface:        var(--bg-secondary);
  --surface-raised: var(--bg-elevated);
  --text:           var(--text-primary);
  --hover:          var(--bg-tertiary);
  --bg-base:        var(--bg-primary);
  --bg-overlay:     rgba(0,0,0,.62);

  /* Desktop icon tint — overridden per-theme and by user preference */
  --desktop-icon-color: rgba(255,255,255,.9);
  --desktop-icon-shadow: 0 1px 4px rgba(0,0,0,.7), 0 0 8px rgba(0,0,0,.4);
}

html, body {
  height: 100%; width: 100%;
  overflow: hidden;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--text-primary);
  background: var(--bg-primary);
  user-select: none;
}

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--scrollbar-bg); }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }

.hidden { display: none !important; }

/* ── Login Screen ─────────────────────────────────────── */
.login-screen {
  position: fixed; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  z-index: 9999;
}

.login-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #1a1f2e 0%, #2f3440 50%, #1a252f 100%);
  z-index: 0;
}

.login-center {
  position: relative; z-index: 1;
  display: flex; flex-direction: column;
  align-items: center; gap: 12px;
  width: 340px;
}

/* ── Login logo mark with animated rings ──────────────────── */
.login-logo-wrap {
  position: relative;
  width: 72px; height: 72px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}
.login-logo { position: relative; z-index: 2; display: flex; align-items: center; justify-content: center; }
.login-logo-custom {
  width: 72px; height: 72px; object-fit: contain; border-radius: 15px;
  display: none; position: relative; z-index: 3;
}
.login-logo-custom.visible { display: block; }
.login-logo-wrap.has-custom-logo .login-logo-ring { display: none; }
.login-logo-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid rgba(82,148,226,.35);
  animation: ll-ring-pulse 4s ease-in-out infinite;
  pointer-events: none;
}
.login-logo-ring-1 { inset: -14px; animation-delay: 0s; }
.login-logo-ring-2 { inset: -28px; opacity: .45; animation-delay: 2s; }
@keyframes ll-ring-pulse {
  0%, 100% { transform: scale(1);    opacity: .35; }
  50%       { transform: scale(1.04); opacity: .75; }
}

.login-os-name {
  font-size: 26px; font-weight: 300;
  letter-spacing: 5px; color: #fff;
  text-transform: uppercase;
}
.login-tagline {
  font-size: 11px; color: rgba(255,255,255,.38);
  letter-spacing: 2px; text-transform: uppercase;
  margin-top: -6px;
}

.user-select {
  display: flex; gap: 16px; flex-wrap: wrap;
  justify-content: center; margin: 8px 0;
}

.user-avatar-btn {
  display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  cursor: pointer; padding: 12px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  transition: background .2s, transform .15s;
  color: #d3dae3;
}
.user-avatar-btn:hover { background: rgba(82,148,226,.2); transform: translateY(-2px); }
.user-avatar-btn .avatar { font-size: 32px; }
.user-avatar-btn .uname  { font-size: 11px; }

.login-form {
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  width: 100%;
  max-height: 0; overflow: hidden;
  transition: max-height .3s ease;
}
.login-form.visible { max-height: 240px; }

.login-avatar { font-size: 40px; }
.login-uname  { font-size: 15px; color: #d3dae3; font-weight: 500; }

.login-input {
  width: 100%; padding: 10px 14px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px; color: #fff;
  font-size: 14px; outline: none;
  transition: border-color .2s;
}
.login-input:focus { border-color: var(--accent); }

.login-btn {
  width: 100%; padding: 10px;
  background: var(--accent); border: none;
  border-radius: 8px; color: #fff;
  font-size: 14px; font-weight: 600;
  cursor: pointer; transition: background .2s;
}
.login-btn:hover { background: var(--accent-hover); }

.login-error { color: #ed4e4e; font-size: 12px; min-height: 16px; }

/* ── 2FA Login Step ───────────────────────────────────────── */
.login-2fa {
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  width: 100%;
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease;
}
.login-2fa.visible { max-height: 400px; }

.twofa-body { width: 100%; display: flex; flex-direction: column; gap: 8px; }
.twofa-label { font-size: 13px; color: rgba(255,255,255,.65); text-align: center; }
.twofa-code-input { text-align: center; letter-spacing: 6px; font-size: 20px; font-weight: 700; }

.login-btn-link {
  background: none; border: none;
  color: rgba(255,255,255,.5); font-size: 12px;
  cursor: pointer; padding: 0; margin-top: 2px;
  text-decoration: underline;
}
.login-btn-link:hover { color: rgba(255,255,255,.85); }

/* ── "Create account" link on login screen ────────────────────────────── */
.login-register-link {
  display: flex; align-items: center; gap: 6px;
  color: rgba(255,255,255,.45); font-size: 12px;
  text-decoration: none; cursor: pointer;
  margin-top: 4px; letter-spacing: .02em;
  transition: color .2s;
}
.login-register-link:hover { color: rgba(82,148,226,.9); }
.login-register-link svg { opacity: .7; }

/* ── Registration panel ───────────────────────────────────────────────── */
.register-panel {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 10000;
  opacity: 0; pointer-events: none;
  transition: opacity .28s ease;
}
.register-panel.visible { opacity: 1; pointer-events: all; }

.reg-inner {
  width: 380px; max-width: 95vw;
  background: rgba(24,27,40,.97);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 28px 28px 22px;
  box-shadow: 0 24px 72px rgba(0,0,0,.6);
  max-height: 90vh; overflow-y: auto;
  display: flex; flex-direction: column; gap: 16px;
}

.reg-header {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 2px;
}
.reg-avatar-preview-wrap {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(82,148,226,.18);
  border: 2px solid rgba(82,148,226,.4);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: background .2s;
}
.reg-avatar-preview { font-size: 30px; line-height: 1; }
.reg-title { font-size: 18px; font-weight: 700; color: #fff; margin: 0; }
.reg-subtitle { font-size: 12px; color: rgba(255,255,255,.38); margin: 0; }

.reg-section-label {
  font-size: 11px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: rgba(255,255,255,.35);
}

.reg-avatar-picker {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.reg-avatar-opt {
  width: 36px; height: 36px; font-size: 20px;
  background: rgba(255,255,255,.06);
  border: 1.5px solid transparent;
  border-radius: 10px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: border-color .15s, background .15s, transform .1s;
  padding: 0;
}
.reg-avatar-opt:hover { background: rgba(82,148,226,.2); }
.reg-avatar-opt.selected {
  border-color: #5294e2;
  background: rgba(82,148,226,.25);
  transform: scale(1.12);
}

.reg-form { display: flex; flex-direction: column; gap: 10px; width: 100%; }

.reg-field-group { display: flex; flex-direction: column; gap: 4px; }
.reg-label {
  font-size: 11px; font-weight: 600; letter-spacing: .04em;
  text-transform: uppercase; color: rgba(255,255,255,.45);
}
.reg-optional { font-weight: 400; text-transform: none; font-size: 10px; }
.reg-input { margin: 0 !important; }
.reg-field-hint { font-size: 10px; color: rgba(255,255,255,.25); }

.reg-pwd-wrap { position: relative; display: flex; align-items: center; }
.reg-pwd-wrap .reg-input { padding-right: 40px; }
.reg-pwd-toggle {
  position: absolute; right: 10px;
  background: none; border: none; cursor: pointer;
  font-size: 16px; padding: 0; line-height: 1;
  color: rgba(255,255,255,.4);
  transition: color .15s;
}
.reg-pwd-toggle:hover { color: rgba(255,255,255,.7); }

.reg-error {
  font-size: 12px; color: #ed4e4e;
  min-height: 0; max-height: 0; overflow: hidden;
  transition: max-height .2s, opacity .2s;
  opacity: 0;
}
.reg-error.show { max-height: 60px; opacity: 1; }

.reg-submit-btn { margin-top: 4px; }

.reg-back-btn {
  background: none; border: none;
  color: rgba(255,255,255,.35); font-size: 12px;
  cursor: pointer; padding: 4px 0;
  display: flex; align-items: center; gap: 5px;
  transition: color .2s; align-self: center;
}
.reg-back-btn:hover { color: rgba(255,255,255,.7); }

/* When registration panel is open, dim the login centre */
.login-center.reg-mode { opacity: 0; pointer-events: none; transition: opacity .2s; }
.login-clock { pointer-events: none; }

.twofa-wa-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
}
.twofa-wa-btn:hover { background: rgba(255,255,255,.18); }

/* ── User Manager ─────────────────────────────────────────── */
.um-user-row { flex-wrap: wrap; gap: 8px; }
.ur-info { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.ur-sub  { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.ur-2fa-badge {
  display: inline-block;
  background: #2196f350; color: #90caf9;
  border: 1px solid #2196f380;
  border-radius: 4px; font-size: 10px;
  padding: 0 4px; vertical-align: middle;
  font-weight: 600;
}
.um-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.um-2fa-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px; margin-bottom: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px; flex-wrap: wrap;
}
.um-2fa-user { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 120px; }
.um-2fa-badges { display: flex; gap: 6px; }

/* ── 2FA Status Badges ───────────────────────────────────── */
.twofa-status-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px; background: var(--bg-secondary);
  border: 1px solid var(--border); border-radius: 8px;
}
.twofa-type-label { flex: 1; font-size: 13px; font-weight: 500; }
/* ── Language selector ───────────────────────────────────── */
.lang-selector { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
.lang-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 8px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 13px; cursor: pointer;
  transition: background .15s, border-color .15s;
}
.lang-btn:hover  { background: rgba(255,255,255,.08); }
.lang-btn.active { background: var(--accent)20; border-color: var(--accent); color: var(--accent); font-weight: 600; }
.lang-flag { font-size: 18px; line-height: 1; }

.twofa-badge {
  font-size: 11px; font-weight: 600; padding: 2px 8px;
  border-radius: 20px; border: 1px solid;
}
.twofa-badge.on  { background: #4caf5020; color: #81c784; border-color: #4caf5060; }
.twofa-badge.off { background: rgba(255,255,255,.05); color: var(--text-muted); border-color: var(--border); }

/* ── TOTP Setup Box ──────────────────────────────────────── */
.totp-setup-box {
  margin-top: 12px; padding: 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--accent);
  border-radius: 10px;
  font-size: 13px;
}
.totp-setup-box p { margin: 0 0 10px; color: var(--text-secondary); }
.totp-secret-code {
  display: block; font-family: monospace;
  font-size: 14px; font-weight: 700;
  letter-spacing: 3px;
  background: var(--bg-primary);
  padding: 8px 12px; border-radius: 6px;
  color: var(--accent); word-break: break-all;
  margin-top: 4px;
  user-select: all;
}

.login-clock {
  position: fixed; bottom: 32px;
  font-size: 14px; color: rgba(255,255,255,.5);
  letter-spacing: 1px;
}

/* ── Desktop ───────────────────────────────────────────── */
.desktop {
  position: fixed; inset: 0;
  display: flex; flex-direction: column;
  overflow: hidden;
}

.wallpaper {
  position: absolute; inset: 0;
  background-color: var(--desktop-bg);
  background-image:
    radial-gradient(circle at 20% 80%, rgba(82,148,226,.12) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(82,148,226,.08) 0%, transparent 50%);
  z-index: 0;
}

.wm-container {
  position: absolute; inset: 0;
  bottom: 40px;
  pointer-events: none;
  z-index: 10;
}

.desktop-icons {
  position: absolute; inset: 0; bottom: 40px;
  pointer-events: none; z-index: 5;
  overflow: hidden;
}

.desktop-icon {
  position: absolute;
  width: 80px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px; padding: 8px 4px;
  border-radius: 8px; cursor: pointer;
  transition: background .15s;
  pointer-events: all;
  user-select: none;
  box-sizing: border-box;
}
.desktop-icon:hover    { background: rgba(82,148,226,.25); }
.desktop-icon.selected { background: rgba(82,148,226,.4); }
.desktop-icon.di-dragging {
  opacity: .82; cursor: grabbing;
  transition: none;
  z-index: 1000;
  box-shadow: 0 4px 18px rgba(0,0,0,.45);
  background: rgba(82,148,226,.22);
}

/* Drop-target indicator shown during drag */
.di-drop-target {
  position: absolute;
  width: 80px; height: 88px;
  border: 2px dashed rgba(82,148,226,.55);
  border-radius: 8px;
  pointer-events: none;
  z-index: 4;
  transition: left .06s, top .06s;
}
/* Swap mode: target cell is occupied */
.di-drop-target.swap {
  border-color: rgba(226,162,82,.7);
  background: rgba(226,162,82,.07);
}
/* The icon that would be displaced */
.desktop-icon.di-swap-pending {
  opacity: .55;
  outline: 2px dashed rgba(226,162,82,.6);
  outline-offset: 3px;
  border-radius: 8px;
}
.di-icon  { font-size: 28px; position: relative; display: inline-block;
            color: var(--desktop-icon-color);
            filter: drop-shadow(var(--desktop-icon-shadow)); }

/* Special folder colours on desktop shortcuts */
.desktop-icon[data-folder-kind="home"]      .di-icon { color: #5294e2; }
.desktop-icon[data-folder-kind="documents"] .di-icon { color: #4fa3e0; }
.desktop-icon[data-folder-kind="downloads"] .di-icon { color: #f0a030; }
.desktop-icon[data-folder-kind="pictures"]  .di-icon { color: #e67e56; }
.desktop-icon[data-folder-kind="music"]     .di-icon { color: #b36cc8; }
.desktop-icon[data-folder-kind="videos"]    .di-icon { color: #e05a5a; }
.desktop-icon[data-folder-kind="desktop"]   .di-icon { color: #5cad8a; }
.desktop-icon[data-folder-kind="trash"]     .di-icon { color: #9e9e9e; }
.desktop-icon[data-folder-kind="public"]    .di-icon { color: #66bb8a; }
.desktop-icon[data-folder-kind="templates"] .di-icon { color: #78a0cc; }
.desktop-icon[data-folder-kind="code"]      .di-icon { color: #e0c456; }
.desktop-icon[data-folder-kind="games"]     .di-icon { color: #e87040; }
.desktop-icon[data-folder-kind="fonts"]     .di-icon { color: #7eb6b0; }
.desktop-icon[data-folder-kind="archives"]  .di-icon { color: #a08060; }

/* Shortcut arrow badge */
.di-shortcut-badge {
  position: absolute; bottom: -3px; right: -5px;
  font-size: 10px; font-style: normal;
  background: rgba(0,0,0,.72); color: #88c0d0;
  border-radius: 3px; padding: 0 3px; line-height: 14px;
  border: 1px solid rgba(136,192,208,.4);
  pointer-events: none;
}

/* Broken / missing shortcut target */
.desktop-icon.di-broken { opacity: .45; }
.desktop-icon.di-broken .di-shortcut-badge { background: rgba(200,0,0,.6); color: #ffa; }

.di-label {
  font-size: 11px; color: var(--desktop-icon-color); text-align: center;
  text-shadow: 0 1px 3px rgba(0,0,0,.8);
  max-width: 72px; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
}

/* ── Taskbar ───────────────────────────────────────────── */
.taskbar {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 40px;
  background: var(--taskbar-bg);
  border-top: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 -1px 0 rgba(0,0,0,.25), 0 -4px 24px rgba(0,0,0,.22);
  display: flex; align-items: center;
  gap: 4px; padding: 0 10px;
  z-index: 1000;
  backdrop-filter: blur(20px) saturate(1.4);
}

/* Left section: launcher + separator */
.taskbar-left {
  display: flex; align-items: center;
  gap: 6px; margin-right: 2px; flex-shrink: 0;
}
.taskbar-sep-v {
  width: 1px; height: 22px;
  background: rgba(255,255,255,.1);
  flex-shrink: 0;
}

/* Launcher / Start button */
.taskbar-launcher-btn {
  width: 30px; height: 30px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, box-shadow .15s, border-color .15s;
  color: var(--taskbar-text, #fff);
  flex-shrink: 0;
}
.taskbar-launcher-btn:hover {
  background: var(--accent);
  border-color: transparent;
  box-shadow: 0 0 14px color-mix(in srgb, var(--accent) 55%, transparent);
  color: #fff;
}
.taskbar-launcher-btn.active {
  background: var(--accent);
  border-color: transparent;
  color: #fff;
}

/* Window list */
.taskbar-windows {
  flex: 1; display: flex; align-items: center;
  gap: 3px; overflow-x: auto; overflow-y: hidden;
  padding: 0 2px;
}
.taskbar-windows::-webkit-scrollbar { height: 2px; }
.taskbar-windows::-webkit-scrollbar-track { background: transparent; }
.taskbar-windows::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 1px; }

/* Individual window button */
.taskbar-entry {
  position: relative;
  display: flex; align-items: center; gap: 6px;
  padding: 0 9px; min-width: 100px; max-width: 180px;
  height: 30px; border-radius: 7px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.07);
  color: var(--taskbar-text, #ccc); font-size: 12px;
  cursor: pointer;
  transition: background .14s, border-color .14s, color .14s;
  overflow: hidden; white-space: nowrap; flex-shrink: 0;
}
.taskbar-entry:hover {
  background: rgba(255,255,255,.13);
  border-color: rgba(255,255,255,.14);
  color: #fff;
}
.taskbar-entry.active {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 55%, transparent);
  color: #fff;
}
.taskbar-entry.minimized { opacity: .45; }
.taskbar-entry.minimized:hover { opacity: .8; }

/* App icon inside entry */
.te-icon  { font-size: 15px; flex-shrink: 0; line-height: 1; display: flex; align-items: center; }
.te-icon .wos-icon-app { width: 16px; height: 16px; }
.te-title { overflow: hidden; text-overflow: ellipsis; flex: 1; }

/* Active bottom-bar indicator */
.te-indicator {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 2px;
  background: var(--accent);
  border-radius: 2px 2px 0 0;
  transition: width .18s ease;
}
.taskbar-entry.active .te-indicator  { width: 60%; }
.taskbar-entry:hover  .te-indicator  { width: 30%; }

/* Tray section (right) */
.taskbar-tray {
  display: flex; align-items: center; gap: 4px;
  padding-left: 8px;
  border-left: 1px solid rgba(255,255,255,.1);
  flex-shrink: 0;
}
.tray-user {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text-secondary);
  cursor: pointer; padding: 3px 10px 3px 6px;
  border-radius: 20px;
  border: 1px solid transparent;
  transition: background .14s, border-color .14s, color .14s;
  user-select: none; position: relative;
}
.tray-user:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.10);
  color: var(--text-primary);
}
.tray-avatar { font-size: 22px; line-height: 1; display: inline-flex; align-items: center; justify-content: center; }
/* scale up the emoji to fill the 52 px start-menu avatar circle */
.luh-avatar .tray-avatar { font-size: 40px; }
.tray-avatar-img {
  width: 26px; height: 26px; border-radius: 50%;
  object-fit: cover; vertical-align: middle;
  border: 2px solid color-mix(in srgb, var(--accent) 70%, transparent);
  box-shadow: 0 0 0 1px rgba(0,0,0,.3);
}
.tray-name    { font-weight: 500; }
.tray-chevron { font-size: 10px; opacity: .5; }

/* ── Tray user dropdown menu ─────────────────────── */
.tray-user-menu {
  position: fixed;
  min-width: 180px;
  background: var(--bg-overlay, rgba(30,32,40,.96));
  backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 6px;
  box-shadow: 0 -4px 24px rgba(0,0,0,.4);
  z-index: 9990;
  animation: tray-menu-in .12s ease;
}
@keyframes tray-menu-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.tray-menu-item {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 8px 10px;
  background: none; border: none;
  color: var(--text-primary); font-size: 13px;
  border-radius: 7px; cursor: pointer;
  text-align: left; transition: background .12s;
}
.tray-menu-item:hover       { background: rgba(255,255,255,.08); }
.tray-menu-item.danger      { color: #ef5350; }
.tray-menu-item.danger:hover{ background: rgba(239,83,80,.12); }
.tray-menu-sep {
  height: 1px; background: var(--border);
  margin: 4px 0;
}
/* Two-line clock */
.tray-clock {
  display: flex; flex-direction: column; align-items: flex-end;
  min-width: 58px; cursor: default; user-select: none;
  padding: 2px 4px; border-radius: 6px;
  transition: background .14s;
}
.tray-clock:hover { background: rgba(255,255,255,.07); }
.tray-clock-time {
  font-size: 12.5px; font-weight: 600;
  color: var(--text-primary); line-height: 1.2;
  letter-spacing: .3px;
}
.tray-clock-date {
  font-size: 10px; color: var(--text-secondary);
  line-height: 1.2;
}

/* ── App Launcher ─────────────────────────────────────── */
.app-launcher {
  position: fixed; bottom: 52px; left: 8px;
  width: 400px; max-height: 540px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow);
  z-index: 999;
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: launcherIn .15s ease;
}
@keyframes launcherIn {
  from { opacity: 0; transform: translateY(8px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Launcher user hero ────────────────────────────────────── */
.launcher-user-hero {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(135deg, rgba(82,148,226,.10) 0%, transparent 100%);
}
.luh-avatar {
  flex-shrink: 0;
  width: 52px; height: 52px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--bg-elevated);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
  border: 2px solid var(--accent)60;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.luh-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.luh-details { flex: 1; min-width: 0; }
.luh-name  { font-size: 15px; font-weight: 600; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.luh-uname { font-size: 12px; color: var(--text-muted); }
.luh-settings-btn,
.luh-logout-btn {
  flex-shrink: 0;
  background: none; border: none; font-size: 18px; cursor: pointer;
  padding: 6px 8px; border-radius: 8px; color: var(--text-secondary);
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.luh-settings-btn:hover { background: rgba(255,255,255,.08); color: var(--text-primary); }
.luh-logout-btn { color: var(--text-muted); }
.luh-logout-btn:hover { background: rgba(220,60,60,.15); color: #e57373; }

.launcher-search {
  margin: 10px 12px 4px; padding: 8px 12px;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: 8px; color: var(--text-primary);
  font-size: 14px; outline: none;
}
.launcher-search:focus { border-color: var(--accent); }

.launcher-apps {
  flex: 1; overflow-y: auto;
  display: flex; flex-direction: column;
  padding: 4px 0 12px;
}

/* Section headers ("Applications" / "Files") */
.la-section-hdr {
  font-size: 10px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--text-muted);
  padding: 10px 14px 4px;
}
.la-section-hdr-row {
  display: flex; align-items: center; justify-content: space-between;
}
.la-all-apps-btn {
  background: none; border: none; color: var(--accent);
  font-size: 10px; font-weight: 600; letter-spacing: .04em;
  cursor: pointer; display: flex; align-items: center; gap: 2px; padding: 0;
  text-transform: uppercase;
}
.la-all-apps-btn svg { width: 12px; height: 12px; }
.la-all-apps-btn:hover { color: var(--accent-hover, var(--accent)); text-decoration: underline; }
.la-back-btn {
  background: none; border: none; color: var(--text-muted);
  font-size: 10px; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; gap: 2px; padding: 0; letter-spacing: .04em;
  text-transform: uppercase;
}
.la-back-btn svg { width: 12px; height: 12px; }
.la-back-btn:hover { color: var(--text-primary); }

/* App cards */
.launcher-app {
  display: flex; flex-direction: column;
  align-items: center; gap: 4px;
  padding: 10px 6px; border-radius: 8px;
  cursor: pointer; transition: background .15s;
  position: relative;
}
.launcher-app:hover { background: rgba(82,148,226,.2); }
[data-reorderable] .launcher-app { cursor: grab; }
[data-reorderable] .launcher-app:active { cursor: grabbing; }
.la-icon { font-size: 26px; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; }
.la-icon .wos-icon-app { width: 32px; height: 32px; }
.la-name { font-size: 11px; color: var(--text-primary); text-align: center; }
.la-empty {
  text-align: center; color: var(--text-muted);
  padding: 20px 14px; font-size: 13px;
}

/* Launcher "Ask AI" row */
.la-ai-row {
  width: 100%; display: flex; justify-content: center;
  padding: 6px 0 2px; margin-top: 4px;
}
.la-ai-search-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 16px; border-radius: 20px; border: none; cursor: pointer;
  font-size: 12.5px;
  background: rgba(108,79,240,.15);
  color: var(--text-primary);
  border: 1px solid rgba(108,79,240,.25);
  transition: background .15s, transform .1s;
}
.la-ai-search-btn:hover {
  background: rgba(108,79,240,.28);
  transform: translateY(-1px);
}
.la-ai-search-btn em { font-style: italic; color: var(--accent); }

/* Drag states */
.launcher-app.la-dragging {
  opacity: .35; transform: scale(.92);
  transition: opacity .1s, transform .1s;
}
/* Insert-before indicator: blue bar on the left */
.launcher-app.la-drag-before::before {
  content: ''; position: absolute;
  left: -3px; top: 4px; bottom: 4px; width: 3px;
  background: var(--accent); border-radius: 3px;
}
/* Insert-after indicator: blue bar on the right */
.launcher-app.la-drag-after::after {
  content: ''; position: absolute;
  right: -3px; top: 4px; bottom: 4px; width: 3px;
  background: var(--accent); border-radius: 3px;
}

/* Category headers in the grouped launcher view */
.la-cat-hdr {
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent);
  padding: 14px 14px 3px;
  border-top: 1px solid rgba(128,128,128,.15);
  margin-top: 4px;
}
.la-cat-hdr:first-child { border-top: none; margin-top: 0; }

/* Wrap consecutive .launcher-app elements in a grid */
.la-app-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 4px; padding: 0 12px;
}

/* File result rows */
.launcher-file {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 14px; cursor: pointer;
  transition: background .12s; border-radius: 0;
}
.launcher-file:hover { background: rgba(82,148,226,.15); }
.lf-icon  { font-size: 20px; flex-shrink: 0; width: 24px; text-align: center; }
.lf-info  { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.lf-name  { font-size: 13px; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lf-path  { font-size: 11px; color: var(--text-muted);    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Context Menu ─────────────────────────────────────── */
.context-menu {
  position: fixed; z-index: 9000;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 8px; padding: 4px;
  min-width: 160px;
  box-shadow: var(--shadow);
  animation: ctxIn .1s ease;
}
@keyframes ctxIn {
  from { opacity: 0; transform: scale(.95); }
  to   { opacity: 1; transform: scale(1); }
}

.ctx-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 12px; border-radius: 5px;
  cursor: pointer; color: var(--text-primary);
  font-size: 13px; transition: background .1s;
}
.ctx-item:hover { background: rgba(82,148,226,.2); color: var(--accent); }
.ctx-item.ctx-disabled { opacity: .38; cursor: default; pointer-events: none; }
.ctx-icon { font-size: 14px; width: 18px; text-align: center; }
.ctx-sep  { height: 1px; background: var(--border); margin: 3px 6px; }

/* ══════════════════════════════════════════════════════════
   Toast Notifications
   ══════════════════════════════════════════════════════════ */
.notifications {
  position: fixed; bottom: 54px; right: 14px;
  display: flex; flex-direction: column-reverse; gap: 8px;
  z-index: 9998; pointer-events: none;
  max-height: calc(100vh - 80px); overflow: visible;
}

/* Individual toast */
.notif-toast {
  display: flex; flex-direction: row;
  width: 330px; border-radius: 10px; overflow: hidden;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  box-shadow: 0 4px 24px rgba(0,0,0,.45), 0 1px 4px rgba(0,0,0,.25);
  pointer-events: all; cursor: default;
  opacity: 0; transform: translateX(16px) scale(.97);
  transition: opacity .28s cubic-bezier(.22,1,.36,1),
              transform .28s cubic-bezier(.22,1,.36,1);
}
.notif-toast.visible {
  opacity: 1; transform: translateX(0) scale(1);
}
.notif-toast.leaving {
  opacity: 0; transform: translateX(18px) scale(.97);
  transition: opacity .22s ease, transform .22s ease;
}

/* Left accent stripe */
.notif-stripe {
  width: 4px; flex-shrink: 0;
  background: var(--notif-color, var(--accent));
  border-radius: 0;
}

/* Content area */
.notif-body {
  flex: 1; min-width: 0;
  padding: 11px 12px 0 11px;
  display: flex; flex-direction: column; gap: 3px;
}
.notif-head  {
  display: flex; align-items: center; gap: 7px;
}
.notif-icon {
  flex-shrink: 0; color: var(--notif-color, var(--accent));
  display: flex; align-items: center;
}
.notif-icon .wos-icon { width: 14px; height: 14px; }
.notif-title {
  font-size: 12.5px; font-weight: 700;
  color: var(--text-primary); flex: 1;
  letter-spacing: .01em; line-height: 1.3;
}
/* App-origin badge in toast header */
.notif-app-icon {
  flex-shrink: 0; display: flex; align-items: center;
  opacity: .7; transition: opacity .15s;
  cursor: default;
}
.notif-app-icon:hover { opacity: 1; }
.notif-app-icon .wos-icon { width: 15px; height: 15px; }
.notif-msg {
  font-size: 12px; color: var(--text-secondary);
  line-height: 1.5; padding-left: 21px;
  word-break: break-word;
}
.notif-dismiss {
  background: none; border: none;
  color: var(--text-muted); cursor: pointer;
  padding: 0 3px; flex-shrink: 0;
  line-height: 1; transition: color .15s;
  display: flex; align-items: center;
}
.notif-dismiss .wos-icon { width: 13px; height: 13px; }
.notif-dismiss:hover { color: var(--text-primary); }

/* Progress bar at the bottom of the body area */
.notif-progress {
  height: 2px; margin-top: 8px;
  background: var(--border);
  border-radius: 0 0 0 0;
}
.notif-progress-fill {
  height: 100%; width: 100%;
  background: var(--notif-color, var(--accent));
  transition: none;
  opacity: .6;
}

/* Tray bell button */
.tray-notif-btn {
  position: relative; background: none; border: none;
  color: var(--text-secondary); cursor: pointer;
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  transition: background .14s, color .14s;
  flex-shrink: 0;
}
.tray-notif-btn:hover {
  background: rgba(255,255,255,.1);
  color: var(--text-primary);
}
.tray-notif-btn.has-unread { color: var(--accent); }
.tray-bell-icon { pointer-events: none; display: block; }

/* Badge */
.notif-badge {
  position: absolute; top: 2px; right: 2px;
  background: #ef5350; color: #fff;
  font-size: 9px; font-weight: 700; line-height: 1;
  min-width: 14px; height: 14px; padding: 0 3px;
  border-radius: 7px; display: flex; align-items: center; justify-content: center;
  pointer-events: none;
  box-shadow: 0 0 0 1.5px var(--taskbar-bg, #1c1c2e);
}
.notif-badge.hidden { display: none; }

/* Bell bounce animation on new notification */
@keyframes notif-bell-bounce {
  0%,100%{ transform: rotate(0deg);   }
  20%    { transform: rotate(-18deg); }
  40%    { transform: rotate(14deg);  }
  60%    { transform: rotate(-10deg); }
  80%    { transform: rotate(6deg);   }
}
.notif-bell-bounce { animation: notif-bell-bounce .55s ease; }

/* ══════════════════════════════════════════════════════════
   Notification Panel (slide-up from taskbar)
   ══════════════════════════════════════════════════════════ */
.notif-panel {
  position: fixed; bottom: 54px; right: 14px;
  width: 360px; max-height: 520px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 48px rgba(0,0,0,.6), 0 4px 16px rgba(0,0,0,.3);
  z-index: 9997;
  display: flex; flex-direction: column; overflow: hidden;
  animation: np-slide-in .18s cubic-bezier(.22,1,.36,1);
}
@keyframes np-slide-in {
  from { opacity: 0; transform: translateY(12px) scale(.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1);   }
}
.notif-panel.hidden { display: none; }

.notif-panel-header {
  display: flex; align-items: center; padding: 12px 14px 10px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-primary); flex-shrink: 0;
}
.notif-panel-title { flex: 1; font-size: 13px; font-weight: 700; color: var(--text-primary); }
.notif-panel-actions { display: flex; gap: 6px; }
.notif-panel-btn {
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-secondary); border-radius: 5px;
  font-size: 11px; padding: 4px 9px; cursor: pointer;
  transition: background .12s, color .12s;
}
.notif-panel-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }
.notif-panel-btn-clear:hover { background: rgba(237,78,78,.2); color: #ed4e4e; border-color: rgba(237,78,78,.4); }

.notif-panel-list { overflow-y: auto; flex: 1; padding: 6px 0; }
.notif-panel-list::-webkit-scrollbar { width: 4px; }
.notif-panel-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 2px; }

.np-empty {
  text-align: center; padding: 36px 16px;
  font-size: 12px; color: var(--text-muted); line-height: 2;
}

.np-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 14px; border-bottom: 1px solid rgba(255,255,255,.04);
  position: relative; transition: background .12s;
}
.np-item:hover { background: rgba(255,255,255,.04); }
.np-unread { background: rgba(82,148,226,.06); }
.np-unread:hover { background: rgba(82,148,226,.1); }

.np-item-bar {
  width: 3px; border-radius: 2px; flex-shrink: 0; align-self: stretch; min-height: 20px;
}
.np-item-icon  { font-size: 16px; flex-shrink: 0; padding-top: 1px; }
.np-item-body  { flex: 1; min-width: 0; }
.np-item-msg   { font-size: 12px; color: var(--text-primary); line-height: 1.4; word-break: break-word; }
.np-item-footer { display: flex; align-items: center; gap: 6px; margin-top: 3px; }
.np-item-time  { font-size: 10px; color: var(--text-muted); }
/* App-origin icon in the notification panel */
.np-item-app-icon {
  display: inline-flex; align-items: center;
  opacity: .5; transition: opacity .15s; cursor: default;
}
.np-item-app-icon:hover { opacity: 1; }
.np-item-app-icon .wos-icon { width: 13px; height: 13px; }
.np-item-del {
  background: none; border: none; color: var(--text-muted);
  font-size: 11px; cursor: pointer; padding: 2px 4px;
  border-radius: 4px; flex-shrink: 0;
  opacity: 0; transition: opacity .15s, color .15s;
}
.np-item:hover .np-item-del { opacity: 1; }
.np-item-del:hover { color: #ed4e4e; background: rgba(237,78,78,.15); }

/* ══════════════════════════════════════════════════════════
   WINDOW MANAGER
   ══════════════════════════════════════════════════════════ */

/* Snap preview ghost overlay */
.snap-preview {
  position: absolute; pointer-events: none; z-index: 99990;
  background: rgba(82, 148, 226, .15);
  border: 2px solid rgba(82, 148, 226, .55);
  border-radius: 8px;
  backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity .12s ease,
              left .1s cubic-bezier(.22,1,.36,1),
              top  .1s cubic-bezier(.22,1,.36,1),
              width .1s cubic-bezier(.22,1,.36,1),
              height .1s cubic-bezier(.22,1,.36,1);
}
.snap-preview.visible { opacity: 1; }

.window {
  position: absolute;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--window-radius);
  box-shadow: var(--shadow);
  display: flex; flex-direction: column;
  overflow: hidden;
  pointer-events: all;
  min-width: 240px; min-height: 140px;
  transition: box-shadow .15s, opacity .2s, transform .2s;
}
.window.focused { box-shadow: 0 12px 40px rgba(0,0,0,.65), 0 0 0 1px var(--accent); }
.window.minimized { opacity: 0; transform: scale(.9) translateY(20px); pointer-events: none; }
.window-open { animation: winOpen .15s ease; }
@keyframes winOpen {
  from { opacity: 0; transform: scale(.96) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.window-closing { opacity: 0; transform: scale(.93); pointer-events: none; }
.window.maximized { border-radius: 0 !important; border: none !important; }

/* Snapped windows animate into place */
.window.snapped {
  transition: left .18s cubic-bezier(.22,1,.36,1),
              top  .18s cubic-bezier(.22,1,.36,1),
              width  .18s cubic-bezier(.22,1,.36,1),
              height .18s cubic-bezier(.22,1,.36,1) !important;
  border-radius: 4px !important;
}
.window.dragging  { box-shadow: 0 20px 60px rgba(0,0,0,.7); }

/* Titlebar */
.window-titlebar {
  display: flex; align-items: center; gap: 8px;
  padding: 0 10px; height: 34px; flex-shrink: 0;
  background: var(--titlebar-bg);
  border-bottom: 1px solid var(--border);
  cursor: default;
}

.window-controls { display: flex; gap: 6px; flex-shrink: 0; }

.wbtn {
  width: 13px; height: 13px;
  border-radius: 50%; border: none;
  cursor: pointer; font-size: 0;
  display: flex; align-items: center; justify-content: center;
  transition: filter .15s;
  flex-shrink: 0;
}
.wbtn:hover  { filter: brightness(1.3); font-size: 8px; color: rgba(0,0,0,.6); }
.wbtn-close  { background: var(--btn-close); }
.wbtn-min    { background: var(--btn-min); }
.wbtn-max    { background: var(--btn-max); }

/* Pop-out button — lives at the far right of the titlebar */
.wbtn-popout {
  width: auto; height: 20px; border-radius: 4px;
  background: transparent; border: 1px solid transparent;
  padding: 0 5px; margin-left: auto; font-size: 0;
  color: var(--titlebar-text); opacity: 0; cursor: pointer;
  transition: opacity .15s, background .15s;
  display: flex; align-items: center; flex-shrink: 0;
}
.wbtn-popout svg { width: 11px; height: 11px; stroke-width: 2; }
.window-titlebar:hover .wbtn-popout { opacity: .5; }
.window-titlebar:hover .wbtn-popout:hover {
  opacity: 1; background: var(--hover); border-color: var(--border);
}

.window-title {
  flex: 1; font-size: 12px; font-weight: 500;
  color: var(--titlebar-text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
}
.window-icon { font-size: 14px; }

/* Window body */
.window-body {
  flex: 1; overflow: hidden;
  display: flex; flex-direction: column;
  background: var(--bg-primary);
}

/* ── Global input normalisation inside windows ─────────────────────────
   Ensures every plain <input>, <textarea> and <select> that has no
   dedicated app-specific class still gets consistent, theme-aware styling.
   Excluded: checkboxes, radios, ranges, colors, file pickers, hidden.     */
.window-body input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]):not([type="file"]):not([type="hidden"]):not([class]),
.window-body textarea:not([class]),
.window-body select:not([class]) {
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  color: var(--text-primary);
  border-radius: 7px;
  padding: 7px 10px;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  width: 100%;
  box-sizing: border-box;
  transition: border-color .15s;
}
.window-body input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]):not([type="file"]):not([type="hidden"]):not([class]):focus,
.window-body textarea:not([class]):focus,
.window-body select:not([class]):focus { border-color: var(--accent); }

/* Resize handles */
.resize-handle {
  position: absolute; z-index: 10;
}
.resize-n  { top: -3px; left: 8px; right: 8px; height: 6px; cursor: n-resize; }
.resize-s  { bottom: -3px; left: 8px; right: 8px; height: 6px; cursor: s-resize; }
.resize-e  { right: -3px; top: 8px; bottom: 8px; width: 6px; cursor: e-resize; }
.resize-w  { left: -3px; top: 8px; bottom: 8px; width: 6px; cursor: w-resize; }
.resize-ne { top: -3px; right: -3px; width: 12px; height: 12px; cursor: ne-resize; }
.resize-nw { top: -3px; left: -3px; width: 12px; height: 12px; cursor: nw-resize; }
.resize-se { bottom: -3px; right: -3px; width: 12px; height: 12px; cursor: se-resize; }
.resize-sw { bottom: -3px; left: -3px; width: 12px; height: 12px; cursor: sw-resize; }

/* ══════════════════════════════════════════════════════════
   TERMINAL APP
   ══════════════════════════════════════════════════════════ */
/* ── Ubuntu-style terminal ───────────────────────────── */
/* ══════════════════════════════════════════════════════════
   TERMINAL  v2 — profile-driven, CSS-variable-based
   ══════════════════════════════════════════════════════════ */

/* Default values (ubuntu scheme) — overridden per-instance via inline style */
.terminal-wrap {
  --term-bg:        #300a24;
  --term-fg:        #eeeeec;
  --term-user:      #4e9a06;
  --term-host:      #4e9a06;
  --term-dir:       #729fcf;
  --term-sep:       #eeeeec;
  --term-dollar:    #eeeeec;
  --term-err:       #ef2929;
  --term-ok:        #8ae234;
  --term-warn:      #fce94f;
  --term-muted:     #555753;
  --term-cursor:    #eeeeec;
  --term-selection: rgba(255,255,255,.15);
  --term-font:      'JetBrains Mono','Fira Code','Cascadia Code',Consolas,monospace;
  --term-font-size: 13px;
  --term-cursor-style: block;

  height: 100%; display: flex; flex-direction: column;
  background: var(--term-bg);
  color:      var(--term-fg);
  font-family: var(--term-font);
  font-size:   var(--term-font-size);
  line-height: 1;
}

.terminal-output {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 12px 16px 4px; outline: none;
  scrollbar-width: thin;
  scrollbar-color: var(--term-muted) transparent;
}
.terminal-output::-webkit-scrollbar        { width: 5px; }
.terminal-output::-webkit-scrollbar-track  { background: transparent; }
.terminal-output::-webkit-scrollbar-thumb  { background: var(--term-muted); border-radius: 3px; }

.terminal-input-row {
  display: flex; align-items: center;
  padding: 4px 16px 10px; gap: 0; flex-shrink: 0;
}

.terminal-prompt { white-space: nowrap; flex-shrink: 0; user-select: none; }

/* Prompt elements driven by CSS variables */
.tp-user   { color: var(--term-user); font-weight: 700; }
.tp-at     { color: var(--term-user); font-weight: 700; }
.tp-host   { color: var(--term-host); font-weight: 700; }
.tp-sep    { color: var(--term-sep); }
.tp-dir    { color: var(--term-dir); font-weight: 700; }
.tp-dollar { color: var(--term-dollar); }

.terminal-input {
  flex: 1; background: transparent; border: none;
  color: var(--term-fg); font-family: inherit;
  font-size: inherit; outline: none;
  caret-color: var(--term-cursor);
  padding: 0;
}

/* Cursor styles */
@keyframes term-blink { 0%,49%{opacity:1} 50%,100%{opacity:0} }

.terminal-wrap:focus-within .terminal-input {
  caret-color: var(--term-cursor);
}
/* Block cursor (default: browser default bar) */
.terminal-wrap[data-term-cursor="block"] .terminal-input { caret-shape: block; }
.terminal-wrap[data-term-cursor="underline"] .terminal-input { caret-shape: underscore; }
.terminal-wrap[data-term-cursor="bar"] .terminal-input { caret-shape: auto; }

/* Output lines */
.term-line { padding: 0; white-space: pre-wrap; word-break: break-word; line-height: 1.65; }
.term-echo  { opacity: .9; }
.term-err   { color: var(--term-err) !important; }
.term-error { color: var(--term-err) !important; }
.term-warn  { color: var(--term-warn) !important; }
.term-ok    { color: var(--term-ok) !important; }
.term-muted { color: var(--term-muted) !important; }
.term-cmd   { color: var(--term-fg); }

/* ls entry colours */
.ls-dir     { color: var(--term-dir); font-weight: 700; }
.ls-archive { color: var(--term-err); font-weight: 700; }
.ls-img     { color: #ad7fa8; }
.ls-exec    { color: var(--term-ok); font-weight: 700; }
.ls-doc     { color: var(--term-warn); }
.ls-file    { color: var(--term-fg); }

/* MOTD block */
.term-motd-ascii { color: var(--term-user); font-weight: 700; line-height: 1.4; }
.term-motd-hi    { color: var(--term-dir); font-weight: 600; }

/* grep match highlight */
.grep-match { background: var(--term-warn); color: #000 !important; border-radius: 2px; padding: 0 1px; }

/* ══════════════════════════════════════════════════════════
   FILE MANAGER
   ══════════════════════════════════════════════════════════ */
.fm-wrap {
  height: 100%; display: flex;
  background: var(--bg-primary);
}

.fm-sidebar {
  width: 160px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  padding: 8px 0; overflow-y: auto;
}

.fm-sidebar-item {
  padding: 7px 14px; cursor: pointer;
  color: var(--text-secondary); font-size: 12px;
  transition: background .1s, color .1s;
  border-radius: 0;
}
.fm-sidebar-item:hover { background: rgba(82,148,226,.15); color: var(--text-primary); }
.fm-sidebar-item.active { background: rgba(82,148,226,.25); color: var(--accent); }

.fm-main {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
}

.fm-toolbar {
  display: flex; align-items: center; gap: 4px;
  padding: 6px 10px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.fm-btn {
  padding: 4px 8px; border-radius: 5px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  color: var(--text-primary); font-size: 12px;
  cursor: pointer; transition: background .1s;
  white-space: nowrap;
}
.fm-btn:hover { background: rgba(82,148,226,.2); }

.fm-path-bar {
  flex: 1; padding: 4px 8px;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 5px; color: var(--text-primary);
  font-size: 12px; outline: none;
  font-family: var(--font-mono);
}
.fm-path-bar:focus { border-color: var(--accent); }

.fm-files {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 10px; min-height: 0;
  position: relative;
}

/* Grid view */
.fm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
  gap: 4px; align-content: start;
}
.fm-grid .fm-item {
  display: flex; flex-direction: column;
  align-items: center; gap: 5px;
  padding: 10px 6px; border-radius: 8px;
  cursor: pointer; transition: background .1s;
}
.fm-grid .fmi-icon  { font-size: 28px; }
.fm-grid .fmi-name  { font-size: 11px; color: var(--text-primary); text-align: center; word-break: break-word; max-width: 80px; }

/* List view */
.fm-list {
  display: flex; flex-direction: column; gap: 1px;
}
.fm-list .fm-item {
  display: flex; align-items: center; gap: 10px;
  padding: 5px 8px; border-radius: 4px;
  cursor: pointer; transition: background .1s;
}
.fm-list .fmi-icon { font-size: 16px; flex-shrink: 0; }
.fm-list .fmi-name { flex: 1; font-size: 12px; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fm-list .fmi-size { width: 64px; text-align: right; font-size: 11px; color: var(--text-muted); }
.fm-list .fmi-date { width: 90px; text-align: right; font-size: 11px; color: var(--text-muted); }

.fm-item:hover    { background: rgba(82,148,226,.12); }
.fm-item.selected { background: rgba(82,148,226,.28); outline: 1px solid rgba(82,148,226,.5); outline-offset: -1px; }

/* Rubber-band lasso selection rectangle */
.fm-lasso {
  position: fixed;
  display: none;          /* shown only once drag threshold is reached */
  border: 1.5px solid var(--accent);
  background: rgba(82,148,226,.15);
  pointer-events: none;
  z-index: 99999;
  border-radius: 3px;
}

/* In grid mode show a tiny check indicator on selected items */
.fm-grid .fm-item.selected .fmi-icon::after {
  content: '';
  position: absolute; top: 4px; right: 4px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 9px; background-repeat: no-repeat; background-position: center;
  pointer-events: none;
}
.fm-grid .fmi-icon { position: relative; }

/* ── Special folder icon colours (theme-neutral, uses currentColor tinting) ── */
.fm-item[data-folder-kind="home"]      .fmi-icon { color: #5294e2; }
.fm-item[data-folder-kind="documents"] .fmi-icon { color: #4fa3e0; }
.fm-item[data-folder-kind="downloads"] .fmi-icon { color: #f0a030; }
.fm-item[data-folder-kind="pictures"]  .fmi-icon { color: #e67e56; }
.fm-item[data-folder-kind="music"]     .fmi-icon { color: #b36cc8; }
.fm-item[data-folder-kind="videos"]    .fmi-icon { color: #e05a5a; }
.fm-item[data-folder-kind="desktop"]   .fmi-icon { color: #5cad8a; }
.fm-item[data-folder-kind="trash"]     .fmi-icon { color: #9e9e9e; }
.fm-item[data-folder-kind="public"]    .fmi-icon { color: #66bb8a; }
.fm-item[data-folder-kind="templates"] .fmi-icon { color: #78a0cc; }
.fm-item[data-folder-kind="code"]      .fmi-icon { color: #e0c456; }
.fm-item[data-folder-kind="games"]     .fmi-icon { color: #e87040; }
.fm-item[data-folder-kind="fonts"]     .fmi-icon { color: #7eb6b0; }
.fm-item[data-folder-kind="archives"]  .fmi-icon { color: #a08060; }

.fm-statusbar {
  padding: 4px 12px; font-size: 11px;
  color: var(--text-muted); border-top: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.fm-empty {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px;
  color: var(--text-muted);
  font-size: 13px;
  pointer-events: none;
  user-select: none;
}
.fm-empty-icon { opacity: .35; }
.fm-empty-icon svg { width: 48px; height: 48px; stroke: var(--text-muted); }
.fm-error  { color: #ed4e4e; padding: 16px; }
.fm-sidebar-sep { height: 1px; background: var(--border); margin: 6px 10px; }

/* File manager drag-and-drop zone */
.fm-drop-area {
  flex: 1; position: relative; overflow: hidden; min-height: 0;
  display: flex; flex-direction: column;
}
.fm-drop-area .fm-files { flex: 1; overflow-y: auto; }

.fm-drop-overlay {
  position: absolute; inset: 0; z-index: 20;
  background: rgba(var(--accent-rgb, 82,148,226), .13);
  border: 3px dashed var(--accent);
  border-radius: 6px; margin: 6px;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
  animation: dz-fade-in .12s ease;
}
.fm-drop-overlay.dz-deny {
  background: rgba(220,50,50,.12);
  border-color: #dc3232;
}
@keyframes dz-fade-in { from { opacity: 0; transform: scale(.97); } to { opacity: 1; transform: scale(1); } }

.fm-drop-inner { text-align: center; color: var(--accent); pointer-events: none; }
.fm-drop-inner .fm-drop-icon { font-size: 42px; margin-bottom: 8px; }
.fm-drop-inner .fm-drop-text { font-size: 15px; font-weight: 600; }
.fm-drop-overlay.dz-deny .fm-drop-inner { color: #dc3232; }

/* Desktop full-screen drag-and-drop overlay */
.desktop-drop-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
  animation: ddo-in .15s ease;
}
.desktop-drop-overlay.ddo-deny { background: rgba(180,20,20,.45); }
@keyframes ddo-in { from { opacity: 0; } to { opacity: 1; } }

.ddo-inner {
  background: var(--bg-primary);
  border: 3px dashed var(--accent);
  border-radius: 16px;
  padding: 48px 64px;
  text-align: center;
  color: var(--text-primary);
  box-shadow: 0 8px 40px rgba(0,0,0,.5);
  animation: ddo-bounce .15s ease;
}
.desktop-drop-overlay.ddo-deny .ddo-inner { border-color: #dc3232; }
@keyframes ddo-bounce { from { transform: scale(.93); } to { transform: scale(1); } }

.ddo-icon  { font-size: 56px; margin-bottom: 12px; }
.ddo-title { font-size: 22px; font-weight: 700; color: var(--accent); margin-bottom: 6px; }
.desktop-drop-overlay.ddo-deny .ddo-title { color: #dc3232; }
.ddo-sub   { font-size: 13px; color: var(--text-muted); }

/* ══════════════════════════════════════════════════════════
   TEXT EDITOR
   ══════════════════════════════════════════════════════════ */
.editor-wrap {
  height: 100%; display: flex; flex-direction: column;
  background: var(--bg-primary);
}

.editor-toolbar {
  display: flex; align-items: center; gap: 4px;
  padding: 5px 8px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.ed-btn {
  padding: 4px 8px; border-radius: 5px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 11px;
  cursor: pointer; transition: background .1s;
  white-space: nowrap;
}
.ed-btn:hover { background: rgba(82,148,226,.2); }
.ed-sep { width: 1px; height: 20px; background: var(--border); margin: 0 2px; }

.ed-lang {
  padding: 3px 6px; background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: 5px; color: var(--text-primary);
  font-size: 11px; outline: none;
}

.ed-path {
  font-size: 11px; color: var(--text-muted);
  font-family: var(--font-mono); margin-left: 4px;
}

.editor-find-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px; flex-shrink: 0;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border);
}
.ed-find-input, .ed-replace-input {
  padding: 3px 8px; flex: 1; max-width: 200px;
  background: var(--input-bg); border: 1px solid var(--border);
  border-radius: 5px; color: var(--text-primary); font-size: 12px; outline: none;
}
.ed-find-input:focus, .ed-replace-input:focus { border-color: var(--accent); }

.editor-container {
  flex: 1; display: flex; overflow: hidden;
}

/* Markdown mode: textarea + preview side by side */
.editor-container.ed-md-split .editor-textarea {
  flex: 1; min-width: 0;
  border-right: 1px solid var(--border);
}
.ed-md-toolbar { flex-shrink: 0; }
.ed-md-preview {
  flex: 1; min-width: 0;
  overflow-y: auto;
  padding: 12px 20px;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-size: 13.5px; line-height: 1.7;
}

.editor-line-numbers {
  width: 44px; flex-shrink: 0; overflow: hidden;
  padding: 10px 0; text-align: right;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  font-family: var(--font-mono); font-size: 13px;
  color: var(--text-muted); line-height: 1.6;
}
.editor-line-numbers .ln { padding: 0 8px; }

.editor-textarea {
  flex: 1; padding: 10px 12px;
  background: var(--bg-primary);
  border: none; outline: none; resize: none;
  color: var(--text-primary);
  font-family: var(--font-mono); font-size: 13px;
  line-height: 1.6; tab-size: 4;
  white-space: pre; overflow: auto;
  caret-color: var(--accent);
}

.editor-statusbar {
  display: flex; align-items: center; gap: 16px;
  padding: 3px 12px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  font-size: 11px; color: var(--text-muted);
}
.ed-status-modified { color: var(--accent); margin-left: auto; }

/* ══════════════════════════════════════════════════════════
   DOCUMENT EDITOR (Quill wrapping)
   ══════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════
   DOCUMENT EDITOR v2  (Markdown split-pane)
   ══════════════════════════════════════════════════════════ */

/* Mermaid diagram block */
.de-mermaid-wrap {
  margin: 1.4em 0; text-align: center;
  background: var(--bg-elevated); border-radius: 10px;
  padding: 20px; overflow-x: auto;
}
.de-mermaid-wrap svg { max-width: 100%; height: auto; }
.de-mermaid-wrap pre.mermaid-error {
  color: var(--danger); font-size: 12px; text-align: left;
}

/* KaTeX display math block */
.de-math-block {
  margin: 1.4em 0; text-align: center; overflow-x: auto;
}
.katex-display { overflow-x: auto; overflow-y: hidden; }

/* PDF export button */
.de-pdf-btn { color: var(--accent) !important; font-weight: 600; }
.de-pdf-btn:hover { background: var(--accent)22 !important; }

/* Math / Diagram toolbar buttons */
.de-math-btn    { font-size: 16px !important; font-weight: 700; }
.de-diagram-btn { font-size: 14px !important; }

.de-wrap {
  height: 100%; display: flex; flex-direction: column; overflow: hidden;
}

/* ── Toolbars ── */
.de-toolbar {
  display: flex; align-items: center; gap: 3px; flex-shrink: 0;
  padding: 4px 8px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.de-file-bar { padding: 5px 8px; }
.de-md-bar   { padding: 3px 8px; background: var(--bg-tertiary); gap: 2px; }

.de-tbtn   { font-size: 12px !important; padding: 3px 8px !important; }
.de-fmt-btn {
  font-size: 11px !important; padding: 2px 7px !important;
  min-width: 28px; text-align: center;
}
.de-fmt-btn code { font-size: 10px; background: none; padding: 0; }

/* Font pickers in markdown toolbar */
.de-font-sel {
  height: 24px;
  font-size: 11px;
  padding: 0 4px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--bg-primary);
  color: var(--text-primary);
  cursor: pointer;
  outline: none;
  max-width: 110px;
}
.de-font-size-sel { max-width: 62px; }
.de-font-sel:hover  { border-color: var(--accent); }
.de-font-sel:focus  { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 25%, transparent); }

/* View-mode toggle */
.de-view-grp {
  display: flex; border: 1px solid var(--border); border-radius: 4px; overflow: hidden;
}
.de-view-btn {
  background: transparent; border: none; color: var(--text-secondary);
  padding: 3px 8px; cursor: pointer; font-size: 13px; line-height: 1;
  transition: background .15s, color .15s;
}
.de-view-btn:hover  { background: var(--btn-hover); color: var(--text-primary); }
.de-view-btn.active { background: var(--accent); color: #fff; }

.de-mod-flag { font-size: 11px; color: var(--accent); white-space: nowrap; }

/* ── Header / Footer bar ── */
.de-hf-bar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 6px 12px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
}
.de-hf-bar.hidden { display: none; }
.de-hf-lbl  { font-size: 11px; color: var(--text-muted); white-space: nowrap; }
.de-hf-input {
  flex: 1; min-width: 160px; max-width: 340px;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: 4px; padding: 3px 8px; font-size: 12px;
  color: var(--text-primary);
}
.de-hf-vars { font-size: 11px; color: var(--text-muted); margin-left: auto; }
.de-hf-vars code { background: var(--bg-tertiary); padding: 1px 4px; border-radius: 3px; font-size: 10px; }

/* ── Image insert panel ── */
.de-img-panel {
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.de-img-panel.hidden { display: none; }

.de-img-panel-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 12px 4px;
  font-size: 12px; font-weight: 600; color: var(--text-primary);
}
.de-img-close {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); font-size: 13px; padding: 0 4px;
  line-height: 1;
}
.de-img-close:hover { color: var(--danger); }

.de-img-tabs {
  display: flex; padding: 0 12px; gap: 0;
  border-bottom: 1px solid var(--border);
}
.de-img-tab {
  padding: 4px 14px; background: none; border: none;
  border-bottom: 2px solid transparent;
  font-size: 12px; cursor: pointer; color: var(--text-muted);
  margin-bottom: -1px;
  transition: color .12s, border-color .12s;
}
.de-img-tab:hover  { color: var(--text-primary); }
.de-img-tab.active { color: var(--accent); border-bottom-color: var(--accent); }

.de-img-body { padding: 10px 12px; }
.de-img-tab-pane { }
.de-img-tab-pane.hidden { display: none; }

/* Upload area */
.de-img-upload-area {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 80px; border: 2px dashed var(--border);
  border-radius: 8px; cursor: pointer; padding: 8px;
  transition: border-color .15s, background .15s;
  position: relative; overflow: hidden;
}
.de-img-upload-area:hover,
.de-img-upload-area.drag-over {
  border-color: var(--accent); background: rgba(82,148,226,.06);
}
.de-img-drop-hint {
  font-size: 12px; color: var(--text-muted); text-align: center; pointer-events: none;
}
.de-img-thumb {
  max-height: 90px; max-width: 100%; border-radius: 5px;
  object-fit: contain; pointer-events: none;
}
.de-img-status { font-size: 11px; color: var(--text-muted); display: block; margin-top: 4px; }

/* VFS path label */
.de-img-vfs-path { font-size: 11px; color: var(--text-muted); font-family: monospace; }

/* Footer */
.de-img-footer {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 8px 12px 10px;
  border-top: 1px solid var(--border);
}
.de-img-alt-label {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text-secondary); flex: 1;
}
.de-img-alt-input { flex: 1; min-width: 160px; max-width: 300px; }

/* Make preview images in the rendered document responsive */
.de-page-body img { max-width: 100%; height: auto; border-radius: 4px; display: block; margin: .5em 0; }

/* ── Split area ── */
.de-main {
  flex: 1; display: flex; min-height: 0; overflow: hidden;
}
.de-src-pane {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
}
.de-src-pane textarea {
  flex: 1; width: 100%; height: 100%; resize: none;
  background: var(--bg-primary); color: var(--text-primary);
  border: none; outline: none;
  padding: 16px 20px; font-size: 13px; line-height: 1.7;
  font-family: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', Consolas, monospace;
  tab-size: 2;
  box-sizing: border-box;
}

/* Resizable divider */
.de-split-div {
  width: 5px; flex-shrink: 0; cursor: col-resize;
  background: var(--border);
  transition: background .15s;
}
.de-split-div:hover { background: var(--accent); }

/* ── Preview pane ── */
.de-prev-pane {
  flex: 1; overflow: hidden; display: flex; flex-direction: column; min-width: 0;
  position: relative;
}

/* Floating "Edit" button — visible only in full-preview mode */
.de-edit-fab {
  position: absolute;
  top: 12px; right: 16px;
  z-index: 10;
  display: flex; align-items: center; gap: 5px;
  padding: 5px 12px;
  font-size: 12px; font-weight: 600;
  background: var(--accent, #4a7fa5);
  color: #fff;
  border: none; border-radius: 20px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
  opacity: 0; pointer-events: none;
  transform: translateY(-4px);
  transition: opacity .18s ease, transform .18s ease;
}
.de-edit-fab svg { width: 14px; height: 14px; }
.de-edit-fab.visible { opacity: 1; pointer-events: all; transform: none; }
.de-edit-fab:hover { filter: brightness(1.12); }
.de-page-scroll {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  background: #c8c8c8;
  padding: 20px;
}
/* Dark-theme adjustment: lighter background for the "desk" */
.theme-arc-dark     .de-page-scroll,
.theme-gruvbox-dark .de-page-scroll,
.theme-solarized    .de-page-scroll { background: #3a3a3a; }

/* The white page sheet */
.de-page-sheet {
  max-width: 780px; min-height: 100%;
  margin: 0 auto;
  background: #fff; color: #1a1a1a;
  box-shadow: 0 2px 16px rgba(0,0,0,.35);
  border-radius: 2px;
  display: flex; flex-direction: column;
}

/* Header zone */
.de-page-hdr {
  padding: 10px 48px 8px;
  border-bottom: 1px solid #ddd;
  flex-shrink: 0;
}
.de-page-hdr[hidden], .de-page-ftr[hidden] { display: none; }

/* Body zone */
.de-page-body {
  flex: 1; padding: 36px 48px;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 11pt; line-height: 1.8; color: #1a1a1a;
}

/* Footer zone */
.de-page-ftr {
  padding: 8px 48px 10px;
  border-top: 1px solid #ddd;
  flex-shrink: 0;
}

/* Header / footer rendered text */
.de-hf-rendered {
  font-size: .8em; color: #777;
  text-align: center; line-height: 1.5;
}

/* ── Rendered Markdown styles ── */
.de-page-body h1 { font-size: 1.9em; border-bottom: 2px solid #e8e8e8; padding-bottom: .3em; margin-top: .5em; }
.de-page-body h2 { font-size: 1.45em; border-bottom: 1px solid #e8e8e8; padding-bottom: .2em; }
.de-page-body h3 { font-size: 1.2em; }
.de-page-body h4 { font-size: 1.05em; }
.de-page-body h1,.de-page-body h2,.de-page-body h3,.de-page-body h4,
.de-page-body h5,.de-page-body h6 {
  font-family: Georgia, serif; font-weight: 700; line-height: 1.3;
  margin-top: 1.4em; margin-bottom: .5em; color: #111;
}
.de-page-body p  { margin: .6em 0 1em; }
.de-page-body a  { color: #0055bb; }
.de-page-body a:hover { text-decoration: none; }
.de-page-body code {
  background: #f4f4f4; border: 1px solid #e0e0e0;
  padding: 1px 5px; border-radius: 3px;
  font-size: .88em; font-family: Consolas, monospace;
}
.de-page-body pre {
  background: #f6f8fa; border: 1px solid #e1e4e8;
  padding: 14px 18px; border-radius: 6px; overflow-x: auto; margin: 1em 0;
}
.de-page-body pre code { background: none; border: none; padding: 0; font-size: .9em; }
.de-page-body blockquote {
  border-left: 4px solid #ccc; margin: 1em 0;
  padding: .5em 1em; color: #666; font-style: italic;
}
.de-page-body table {
  border-collapse: collapse; width: 100%; margin: 1em 0; font-size: .95em;
}
.de-page-body th, .de-page-body td {
  border: 1px solid #ddd; padding: 7px 12px; text-align: left;
}
.de-page-body th { background: #f6f8fa; font-weight: 600; }
.de-page-body tr:nth-child(even) td { background: #fafafa; }
.de-page-body ul, .de-page-body ol { padding-left: 1.5em; margin: .5em 0 1em; }
.de-page-body li { margin: .25em 0; }
.de-page-body li input[type="checkbox"] { margin-right: .4em; }
.de-page-body hr { border: none; border-top: 1px solid #ddd; margin: 1.8em 0; }
.de-page-body img { max-width: 100%; height: auto; border-radius: 4px; }

/* ── Status bar ── */
.de-status-bar {
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
  padding: 3px 12px;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  font-size: 11px; color: var(--text-muted);
}
.de-status-path { color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.de-status-wc   { margin-left: auto; white-space: nowrap; }

.doceditor-loading {
  display: flex; align-items: center; justify-content: center;
  height: 100%; color: var(--text-muted); font-size: 14px;
}

/* ══════════════════════════════════════════════════════════
   SPREADSHEET
   ══════════════════════════════════════════════════════════ */
/* ══ SPREADSHEET ══════════════════════════════════════════════════════════ */
.ss-wrap {
  height: 100%; display: flex; flex-direction: column;
  background: var(--bg-primary); position: relative;
}

/* ── Toolbar ── */
.ss-toolbar {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 8px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.ss-sep { width: 1px; height: 20px; background: var(--border); flex-shrink: 0; }

/* Name box — editable cell address input */
.ss-namebox {
  font-family: var(--font-mono); font-size: 12px;
  width: 56px; padding: 2px 6px; text-align: center;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: 5px; color: var(--accent); outline: none; flex-shrink: 0;
}
.ss-namebox:focus { border-color: var(--accent); background: var(--bg-elevated); }

/* AutoSum Σ button */
.ss-autosum-btn {
  font-size: 14px; font-weight: 700; padding: 1px 8px;
  border: 1px solid var(--border); border-radius: 5px;
  background: var(--bg-elevated); color: var(--text-primary);
  cursor: pointer; flex-shrink: 0;
}
.ss-autosum-btn:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); border-color: var(--accent); color: var(--accent); }

/* fx button */
.ss-fx-btn {
  font-family: var(--font-mono); font-size: 12px; font-style: italic; font-weight: 700;
  padding: 2px 7px; border: 1px solid var(--border); border-radius: 5px;
  background: var(--bg-elevated); color: var(--accent); cursor: pointer; flex-shrink: 0;
}
.ss-fx-btn:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); border-color: var(--accent); }

/* Formula bar + autocomplete wrapper */
.ss-formula-wrap { position: relative; flex: 1; min-width: 0; }
.ss-formula-bar {
  width: 100%; padding: 3px 8px; box-sizing: border-box;
  background: var(--input-bg); border: 1px solid var(--border);
  border-radius: 5px; color: var(--text-primary);
  font-family: var(--font-mono); font-size: 12px; outline: none;
}
.ss-formula-bar:focus { border-color: var(--accent); }

/* Autocomplete dropdown — rich 3-column display */
.ss-ac {
  position: absolute; top: 100%; left: 0; width: 520px; max-width: 90vw;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 7px; box-shadow: 0 8px 28px rgba(0,0,0,.28);
  list-style: none; margin: 4px 0 0; padding: 4px 0;
  z-index: 200; font-size: 12px;
}
.ss-ac.hidden { display: none; }
.ss-ac li {
  display: grid; grid-template-columns: 100px 140px 1fr;
  align-items: center; gap: 6px;
  padding: 5px 12px; cursor: pointer; color: var(--text-primary);
  border-bottom: 1px solid color-mix(in srgb, var(--border) 40%, transparent);
}
.ss-ac li:last-child { border-bottom: none; }
.ss-ac li:hover, .ss-ac li.ss-ac-sel { background: color-mix(in srgb, var(--accent) 12%, transparent); }
.ss-ac li:hover .ss-ac-name, .ss-ac li.ss-ac-sel .ss-ac-name { color: var(--accent); }
.ss-ac-name { font-family: var(--font-mono); font-weight: 700; color: var(--text-primary); }
.ss-ac-args { font-family: var(--font-mono); font-size: 11px; color: var(--accent); opacity: .85; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ss-ac-desc { font-size: 11px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Function Picker Panel ── */
.ss-fn-picker {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 300px; z-index: 150;
  background: var(--bg-primary);
  border-top: 2px solid var(--accent);
  display: flex; flex-direction: column;
  box-shadow: 0 -4px 20px rgba(0,0,0,.18);
}
.ss-fn-picker.hidden { display: none; }

.ss-fnp-header {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; flex-shrink: 0;
  background: var(--bg-secondary); border-bottom: 1px solid var(--border);
}
.ss-fnp-title {
  font-size: 12px; font-weight: 600; color: var(--accent);
  white-space: nowrap; flex-shrink: 0;
}
.ss-fnp-search {
  flex: 1; padding: 4px 10px; font-size: 12px;
  background: var(--input-bg); border: 1px solid var(--border);
  border-radius: 5px; color: var(--text-primary); outline: none;
}
.ss-fnp-search:focus { border-color: var(--accent); }
.ss-fnp-close {
  padding: 2px 8px; font-size: 13px; font-weight: 700;
  background: none; border: 1px solid transparent; border-radius: 5px;
  color: var(--text-secondary); cursor: pointer; flex-shrink: 0; line-height: 1.4;
}
.ss-fnp-close:hover { background: color-mix(in srgb, var(--error,#e44) 12%, transparent); border-color: var(--error,#e44); color: var(--error,#e44); }

.ss-fnp-cats {
  display: flex; align-items: center; gap: 5px;
  padding: 6px 12px; flex-shrink: 0; overflow-x: auto;
  background: var(--bg-secondary); border-bottom: 1px solid var(--border);
  scrollbar-width: none;
}
.ss-fnp-cats::-webkit-scrollbar { display: none; }
.ss-fnp-cat {
  padding: 3px 10px; font-size: 11px; font-weight: 500; white-space: nowrap;
  border: 1px solid var(--border); border-radius: 12px;
  background: var(--bg-primary); color: var(--text-secondary); cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.ss-fnp-cat:hover { border-color: var(--accent); color: var(--accent); }
.ss-fnp-cat.active {
  background: var(--accent); border-color: var(--accent);
  color: #fff;
}

.ss-fnp-list {
  flex: 1; overflow-y: auto; padding: 4px 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  align-content: start; gap: 0;
}
.ss-fnp-item {
  padding: 8px 14px; cursor: pointer; border-bottom: 1px solid color-mix(in srgb, var(--border) 40%, transparent);
  transition: background .1s;
}
.ss-fnp-item:hover { background: color-mix(in srgb, var(--accent) 8%, transparent); }
.ss-fnp-item-top { display: flex; align-items: baseline; gap: 6px; margin-bottom: 2px; }
.ss-fnp-iname { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--text-primary); }
.ss-fnp-item:hover .ss-fnp-iname { color: var(--accent); }
.ss-fnp-iargs { font-family: var(--font-mono); font-size: 11px; color: var(--accent); opacity: .8; }
.ss-fnp-idesc { font-size: 11px; color: var(--text-secondary); line-height: 1.3; }
.ss-fnp-empty { grid-column: 1/-1; padding: 20px; text-align: center; color: var(--text-secondary); font-size: 13px; }

/* active state for fx button while picker is open */
.ss-fx-btn.active { background: color-mix(in srgb, var(--accent) 18%, transparent); border-color: var(--accent); }

/* Function hint bar */
.ss-fn-hint {
  padding: 4px 12px; font-size: 11px; font-family: var(--font-mono);
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-secondary));
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 20%, var(--border));
  color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex-shrink: 0;
}
.ss-fn-hint.hidden { display: none; }

#ss-modified { font-size: 11px; color: var(--accent); margin-left: 4px; }

/* ── Grid ── */
.ss-container { flex: 1; overflow: hidden; position: relative; }
.ss-table-wrap { height: 100%; overflow: auto; }
.ss-table { border-collapse: collapse; font-size: 12px; font-family: var(--font-mono); }

.ss-corner {
  width: 40px; height: 24px; background: var(--bg-tertiary);
  border: 1px solid var(--border); position: sticky; top: 0; left: 0; z-index: 3;
}
.ss-col-head {
  min-width: 80px; max-width: 120px; height: 24px;
  background: var(--bg-secondary); color: var(--text-secondary);
  border: 1px solid var(--border); text-align: center;
  position: sticky; top: 0; z-index: 2; font-weight: 500; user-select: none;
  transition: background .12s, color .12s;
}
.ss-col-head.ss-col-active { background: color-mix(in srgb, var(--accent) 18%, var(--bg-secondary)); color: var(--accent); }

.ss-row-head {
  width: 40px; background: var(--bg-secondary);
  color: var(--text-secondary); border: 1px solid var(--border);
  text-align: right; padding: 2px 6px;
  position: sticky; left: 0; z-index: 1; font-weight: 500; user-select: none;
  transition: background .12s, color .12s;
}
.ss-row-head.ss-row-active { background: color-mix(in srgb, var(--accent) 18%, var(--bg-secondary)); color: var(--accent); }

.ss-cell {
  min-width: 80px; max-width: 200px; height: 24px;
  border: 1px solid var(--border);
  padding: 2px 5px; outline: none;
  color: var(--text-primary); background: var(--bg-primary);
  overflow: hidden; white-space: nowrap; cursor: cell;
}
.ss-cell:focus          { background: var(--bg-elevated); }
.ss-cell.ss-selected    { outline: 2px solid var(--accent); outline-offset: -2px; background: rgba(82,148,226,.12); z-index: 1; position: relative; }
.ss-cell.ss-in-range    { background: rgba(82,148,226,.07); }
/* Suppress text-selection cursor while drag-selecting a range */
.ss-selecting .ss-cell  { user-select: none; cursor: crosshair !important; }
.ss-cell.ss-formula-cell{ background: color-mix(in srgb, var(--accent) 4%, var(--bg-primary)); }
.ss-cell.ss-num-cell    { text-align: right; }
.ss-cell.ss-err-cell    { color: #e53e3e; font-style: italic; text-align: center; }

/* Formula reference highlights — one color per distinct ref/range in the formula */
.ss-cell.ss-ref-hl-0 { outline: 2px solid #4e9af1; outline-offset: -2px; background: rgba(78,154,241,.15) !important; z-index: 2; position: relative; }
.ss-cell.ss-ref-hl-1 { outline: 2px solid #e05f3d; outline-offset: -2px; background: rgba(224, 95, 61,.15) !important; z-index: 2; position: relative; }
.ss-cell.ss-ref-hl-2 { outline: 2px solid #52b788; outline-offset: -2px; background: rgba(82,183,136,.15) !important; z-index: 2; position: relative; }
.ss-cell.ss-ref-hl-3 { outline: 2px solid #f4a22d; outline-offset: -2px; background: rgba(244,162, 45,.15) !important; z-index: 2; position: relative; }
.ss-cell.ss-ref-hl-4 { outline: 2px solid #b07ff5; outline-offset: -2px; background: rgba(176,127,245,.15) !important; z-index: 2; position: relative; }
.ss-cell.ss-ref-hl-5 { outline: 2px solid #e84393; outline-offset: -2px; background: rgba(232, 67,147,.15) !important; z-index: 2; position: relative; }

/* ── Status bar ── */
.ss-statusbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 2px 12px; font-size: 11px; flex-shrink: 0;
  background: var(--bg-secondary); border-top: 1px solid var(--border);
  color: var(--text-muted); height: 22px; gap: 16px;
}
.ss-status-agg { display: flex; gap: 16px; }
.ss-status-agg.hidden { display: none; }
.ss-status-agg span { font-family: var(--font-mono); }

/* ── Context menu ── */
.ss-ctx-menu {
  position: fixed; z-index: 9000; min-width: 180px;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 8px; box-shadow: 0 8px 28px rgba(0,0,0,.35);
  padding: 4px 0; font-size: 13px;
}
.ss-ctx-menu.hidden { display: none; }
.ss-ctx-item { padding: 6px 16px; cursor: pointer; color: var(--text-primary); }
.ss-ctx-item:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); color: var(--accent); }
.ss-ctx-item.ss-ctx-danger { color: #e53e3e; }
.ss-ctx-item.ss-ctx-danger:hover { background: rgba(229,62,62,.12); color: #e53e3e; }
.ss-ctx-sep { height: 1px; background: var(--border); margin: 3px 0; }

.ss-loading {
  display: flex; align-items: center; justify-content: center;
  height: 100%; color: var(--text-muted); font-size: 14px;
}

/* ══════════════════════════════════════════════════════════
   CHAT APP  — WhatsApp-style minimal design
   ══════════════════════════════════════════════════════════ */

/* ── Tray button ── */
/* ── Dev Console tray button ─────────────────────────────── */
.tray-dev-btn {
  position: relative; background: none; border: none; cursor: pointer;
  color: var(--text-muted); padding: 5px 7px; border-radius: 7px;
  display: flex; align-items: center; transition: color .15s, background .15s;
}
.tray-dev-btn:hover  { background: rgba(255,255,255,.08); color: var(--accent); }

.tray-chat-btn {
  position: relative; background: none; border: none; cursor: pointer;
  color: var(--text-muted); padding: 5px 7px; border-radius: 7px;
  display: flex; align-items: center; transition: color .15s, background .15s;
}
.tray-chat-btn:hover  { background: rgba(255,255,255,.08); color: var(--text-primary); }
.tray-chat-btn.tray-chat-unread { color: var(--accent); }
.chat-tray-badge {
  position: absolute; top: 2px; right: 2px;
  min-width: 14px; height: 14px; border-radius: 7px;
  background: var(--accent); color: #fff;
  font-size: 9px; font-weight: 700; line-height: 14px; text-align: center;
  padding: 0 3px;
}

/* ── Layout ── */
.ch-wrap {
  height: 100%; display: flex; overflow: hidden;
  background: var(--bg-primary); font-size: 13px;
}

/* ── Sidebar ── */
.ch-sidebar {
  width: 270px; min-width: 220px; flex-shrink: 0;
  display: flex; flex-direction: column;
  background: var(--bg-secondary); border-right: 1px solid var(--border);
  overflow: hidden;
}

/* Own profile card */
.ch-me-card {
  display: flex; align-items: center; gap: 11px;
  padding: 13px 14px 11px;
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-secondary));
  border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.ch-me-av {
  width: 42px; height: 42px; border-radius: 50%; overflow: hidden;
  background: var(--bg-elevated); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 24px;
}
.ch-av-img  { width: 100%; height: 100%; object-fit: cover; }
.ch-av-emoji{ line-height: 1; }
.ch-me-detail { display: flex; flex-direction: column; gap: 3px; min-width: 0; flex: 1; }
.ch-me-name   { font-weight: 700; font-size: 13.5px; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ch-status-sel {
  font-size: 11px; padding: 2px 0; background: transparent; border: none;
  color: var(--text-muted); cursor: pointer; width: 100%; outline: none;
  appearance: none; -webkit-appearance: none;
}
.ch-smsg-input { display: none; }

/* Search */
.ch-search-wrap { padding: 8px 12px 6px; flex-shrink: 0; }
.ch-search {
  width: 100%; box-sizing: border-box; padding: 7px 14px; font-size: 12.5px;
  background: var(--bg-elevated); border: 1px solid transparent;
  border-radius: 20px; color: var(--text-primary); outline: none;
}
.ch-search:focus { border-color: var(--accent); }

/* Contacts list */
.ch-contacts { flex: 1; overflow-y: auto; }
.ch-group { }
.ch-grp-hdr {
  font-size: 10px; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; color: var(--text-muted);
  padding: 10px 14px 4px; display: flex; align-items: center; gap: 5px;
}
.ch-grp-ct { background: var(--bg-elevated); border-radius: 8px; padding: 1px 5px; font-size: 10px; }
.ch-contact {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; cursor: pointer; transition: background .12s;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 40%, transparent);
}
.ch-contact:hover { background: color-mix(in srgb, var(--accent) 6%, transparent); }
.ch-contact-active { background: color-mix(in srgb, var(--accent) 13%, transparent) !important; }
.ch-c-av {
  position: relative; width: 44px; height: 44px; border-radius: 50%;
  overflow: visible; flex-shrink: 0;
  background: var(--bg-elevated);
  display: flex; align-items: center; justify-content: center; font-size: 24px;
}
.ch-c-av .ch-av-img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.ch-c-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.ch-c-name { font-size: 14px; font-weight: 500; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ch-c-smsg { font-size: 12px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ch-badge {
  min-width: 20px; height: 20px; border-radius: 10px;
  background: var(--accent); color: #fff;
  font-size: 11px; font-weight: 700; text-align: center; line-height: 20px; padding: 0 5px;
  flex-shrink: 0;
}
.ch-no-contacts { padding: 24px; text-align: center; color: var(--text-muted); font-size: 12px; }

/* Status dots */
.ch-dot {
  position: absolute; bottom: 0; right: 0;
  width: 12px; height: 12px; border-radius: 50%;
  border: 2px solid var(--bg-secondary);
}
.ch-dot-online  { background: #4caf50; }
.ch-dot-away    { background: #ffc107; }
.ch-dot-busy    { background: #f44336; }
.ch-dot-offline { background: #9e9e9e; }

/* ── Main conversation panel ── */
.ch-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

/* Empty state */
.ch-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 14px;
  color: var(--text-muted);
  background: color-mix(in srgb, var(--accent) 2%, var(--bg-primary));
}
.ch-empty-icon {
  width: 80px; height: 80px; border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-secondary));
  display: flex; align-items: center; justify-content: center; font-size: 38px;
}
.ch-empty-title { font-size: 18px; font-weight: 600; color: var(--text-secondary); }
.ch-empty-sub   { font-size: 13px; max-width: 220px; text-align: center; line-height: 1.5; }

/* Conversation header */
.ch-conv-hdr {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 16px; flex-shrink: 0;
  background: color-mix(in srgb, var(--accent) 6%, var(--bg-secondary));
  border-bottom: 1px solid var(--border);
}
.ch-conv-av {
  position: relative; width: 40px; height: 40px; border-radius: 50%;
  overflow: visible; flex-shrink: 0;
  background: var(--bg-elevated);
  display: flex; align-items: center; justify-content: center; font-size: 22px;
}
.ch-conv-av .ch-av-img { width: 40px; height: 40px; border-radius: 50%; }
.ch-conv-av .ch-dot    { width: 13px; height: 13px; border-width: 2px; }
.ch-conv-info  { flex: 1; min-width: 0; }
.ch-conv-name   { font-size: 15px; font-weight: 600; color: var(--text-primary); }
.ch-conv-status { font-size: 12px; color: color-mix(in srgb, var(--accent) 70%, var(--text-muted)); }

/* Nudge animation */
@keyframes ch-nudge { 0%,100%{transform:translate(0)} 20%{transform:translate(-5px,3px) rotate(-3deg)} 40%{transform:translate(5px,-3px) rotate(3deg)} 60%{transform:translate(-4px,2px)} 80%{transform:translate(4px,-2px)} }
.ch-nudge-anim { animation: ch-nudge .6s ease; }

/* Messages scroll area — subtle tiled background */
.ch-msgs {
  flex: 1; overflow-y: auto; padding: 14px 18px;
  display: flex; flex-direction: column; gap: 3px;
  background-color: color-mix(in srgb, var(--accent) 3%, var(--bg-primary));
  background-image: radial-gradient(circle, color-mix(in srgb, var(--accent) 8%, transparent) 1px, transparent 1px);
  background-size: 22px 22px;
}

/* Day separator — WhatsApp-style pill chip */
.ch-day-sep {
  align-self: center; margin: 10px 0;
}
.ch-day-sep span {
  background: color-mix(in srgb, var(--bg-secondary) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  padding: 3px 12px; border-radius: 12px;
  font-size: 11.5px; color: var(--text-muted);
  backdrop-filter: blur(4px);
}

/* Message rows */
.ch-row     { display: flex; flex-direction: column; max-width: 72%; margin: 1px 0; }
.ch-row-me  { align-self: flex-end; align-items: flex-end; }
.ch-row-them{ align-self: flex-start; align-items: flex-start; }
.ch-sender  { font-size: 11px; color: var(--accent); font-weight: 500; margin-bottom: 2px; padding: 0 10px; }

/* Bubbles — WhatsApp style */
.ch-bubble {
  padding: 7px 11px 5px 11px;
  border-radius: 8px; font-size: 13.5px; line-height: 1.5;
  position: relative; word-break: break-word; max-width: 100%;
  box-shadow: 0 1px 2px rgba(0,0,0,.14);
  overflow: visible;
}

/* Me bubble — accent colour, tail on right */
.ch-row-me .ch-bubble {
  background: var(--accent); color: #fff;
  border-radius: 12px 12px 3px 12px;
}
.ch-row-me .ch-bubble:not(.ch-bubble-first) { border-top-right-radius: 3px; }
.ch-row-me .ch-bubble.ch-bubble-last::after {
  content: ''; position: absolute;
  bottom: 0; right: -7px;
  width: 0; height: 0; border-style: solid;
  border-width: 10px 0 0 8px;
  border-color: transparent transparent transparent var(--accent);
}

/* Them bubble — elevated bg, tail on left */
.ch-row-them .ch-bubble {
  background: var(--bg-elevated); color: var(--text-primary);
  border-radius: 12px 12px 12px 3px;
}
.ch-row-them .ch-bubble:not(.ch-bubble-first) { border-top-left-radius: 3px; }
.ch-row-them .ch-bubble.ch-bubble-last::after {
  content: ''; position: absolute;
  bottom: 0; left: -7px;
  width: 0; height: 0; border-style: solid;
  border-width: 10px 8px 0 0;
  border-color: transparent var(--bg-elevated) transparent transparent;
}

/* Timestamp — inline at end of last bubble */
.ch-ts {
  display: inline-block; font-size: 10.5px; opacity: .75;
  margin-left: 8px; float: right; position: relative; top: 5px; margin-bottom: -2px;
}
.ch-row-me .ch-ts   { color: rgba(255,255,255,.9); }
.ch-row-them .ch-ts { color: var(--text-muted); }

/* Nudge message */
.ch-nudge {
  align-self: center; display: flex; align-items: center; gap: 6px;
  padding: 5px 16px; border-radius: 20px; font-size: 12px;
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-secondary));
  border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
  color: var(--text-secondary); margin: 6px auto;
}
.ch-nudge-icon { font-size: 15px; }

/* Start-of-conversation placeholder */
.ch-msg-start {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 10px;
  color: var(--text-muted); font-size: 13px; text-align: center;
}
.ch-msg-start-icon { font-size: 36px; opacity: .4; }

/* ── Input area ── */
.ch-input-area {
  border-top: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
  position: relative;
}

/* Emoji picker — spans full width above input */
.ch-emoji-panel {
  position: absolute; bottom: 100%; left: 0; right: 0;
  background: var(--bg-elevated); border-top: 1px solid var(--border);
  padding: 10px 14px; display: grid; grid-template-columns: repeat(10, 1fr);
  gap: 2px; z-index: 50;
}
.ch-emoji-panel.hidden { display: none; }
.ch-em {
  background: none; border: none; font-size: 20px; cursor: pointer;
  padding: 5px; border-radius: 6px; text-align: center;
  transition: background .1s; line-height: 1.2;
}
.ch-em:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); }

/* Input row — single clean bar */
.ch-input-row {
  display: flex; align-items: flex-end; gap: 6px;
  padding: 8px 12px 10px;
}
.ch-tool {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); width: 36px; height: 36px;
  border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: color .12s, background .12s;
}
.ch-tool:hover { color: var(--accent); background: color-mix(in srgb, var(--accent) 10%, transparent); }
.ch-input {
  flex: 1; padding: 8px 14px; font-size: 13.5px; resize: none;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 22px; color: var(--text-primary);
  outline: none; line-height: 1.45; min-height: 38px; max-height: 120px;
  font-family: var(--font-sans); overflow-y: auto;
  transition: border-color .15s;
}
.ch-input:focus { border-color: var(--accent); }
.ch-send {
  width: 38px; height: 38px; flex-shrink: 0;
  background: var(--accent); border: none; border-radius: 50%;
  color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: transform .1s, filter .12s;
  box-shadow: 0 2px 6px color-mix(in srgb, var(--accent) 40%, transparent);
}
.ch-send:hover  { filter: brightness(1.1); transform: scale(1.05); }
.ch-send:active { transform: scale(.93); }

/* ══════════════════════════════════════════════════════════
   TASKS APP
   ══════════════════════════════════════════════════════════ */
.tk-wrap { height:100%; display:flex; overflow:hidden; background:var(--bg-primary); }

/* Sidebar */
.tk-sidebar {
  width:210px; min-width:180px; flex-shrink:0;
  display:flex; flex-direction:column;
  background:var(--bg-secondary); border-right:1px solid var(--border);
  overflow-y:auto; padding:10px 0;
}
.tk-sidebar-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:4px 14px 8px; font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted);
}
.tk-sidebar-sep { height:1px; background:var(--border); margin:8px 0; }
.tk-icon-btn {
  background:none; border:none; cursor:pointer; color:var(--text-muted);
  font-size:18px; padding:2px 6px; border-radius:5px;
  transition:background .12s,color .12s;
}
.tk-icon-btn:hover { background:var(--bg-elevated); color:var(--text-primary); }
.tk-proj-item {
  display:flex; align-items:center; gap:8px; padding:7px 14px;
  cursor:pointer; border-radius:0; font-size:13px;
  color:var(--text-secondary); transition:background .12s;
}
.tk-proj-item:hover  { background:var(--bg-elevated); }
.tk-proj-item.active { background:var(--accent)1a; color:var(--accent); font-weight:600; }
.tk-proj-dot  { width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.tk-proj-label{ flex:1; }
.tk-proj-count{ font-size:11px; background:var(--bg-elevated); padding:1px 6px; border-radius:10px; }
.tk-nav-item {
  background:none; border:none; cursor:pointer; text-align:left;
  padding:7px 14px; font-size:13px; color:var(--text-secondary);
  transition:background .12s; margin:0;
}
.tk-nav-item:hover { background:var(--bg-elevated); color:var(--text-primary); }

/* Pomodoro */
.tk-pomo {
  display:flex; flex-direction:column; align-items:center;
  padding:12px 10px 6px; gap:6px;
}
.tk-pomo-label { font-size:11px; font-weight:700; text-transform:uppercase;
                 letter-spacing:.06em; color:var(--text-muted); }
.tk-pomo-ring  { position:relative; width:80px; height:80px; }
.tk-pomo-svg   { width:80px; height:80px; transform:rotate(-90deg); }
.tk-ring-bg    { fill:none; stroke:var(--bg-elevated); stroke-width:5; }
.tk-ring-fill  { fill:none; stroke:var(--accent); stroke-width:5;
                 stroke-linecap:round; transition:stroke-dashoffset .9s linear, stroke .3s; }
.tk-pomo-time  {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:16px; font-weight:700; font-variant-numeric:tabular-nums; color:var(--text-primary);
}
.tk-pomo-controls { display:flex; gap:6px; }
.tk-pomo-btn {
  background:var(--bg-elevated); border:none; border-radius:8px;
  padding:5px 10px; font-size:14px; cursor:pointer; color:var(--text-primary);
  transition:background .12s;
}
.tk-pomo-btn:hover { background:var(--accent)33; }
.tk-pomo-count { font-size:12px; color:var(--text-muted); }

/* Main task area */
.tk-main { flex:1; display:flex; overflow:hidden; }
.tk-task-panel,.tk-stats-panel {
  flex:1; display:flex; flex-direction:column; overflow:hidden;
}
.tk-task-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px 10px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.tk-proj-name { font-size:18px; font-weight:700; color:var(--text-primary); }
.tk-task-header-actions { display:flex; gap:8px; align-items:center; }
.tk-add-form {
  padding:10px 16px; border-bottom:1px solid var(--border);
  display:flex; flex-direction:column; gap:8px; background:var(--bg-secondary);
}
.tk-add-row { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.tk-input {
  background:var(--input-bg); border:1px solid var(--input-border);
  color:var(--text-primary); border-radius:7px; padding:7px 10px;
  font-size:13px; outline:none; transition:border-color .15s;
}
.tk-input:focus { border-color:var(--accent); }
.tk-task-name-input { width:100%; }
.tk-select {
  background:var(--input-bg); border:1px solid var(--input-border);
  color:var(--text-primary); border-radius:7px; padding:6px 10px;
  font-size:13px; outline:none; cursor:pointer;
}
.tk-small { font-size:12px; padding:5px 8px; }
.tk-btn {
  padding:7px 16px; border-radius:7px; border:none; cursor:pointer;
  font-size:13px; font-weight:500; transition:filter .13s;
  background:var(--bg-elevated); color:var(--text-primary);
}
.tk-btn.primary { background:var(--accent); color:#fff; padding: 8px 18px; font-weight: 600; box-shadow: 0 4px 8px rgba(0,0,0,0.2); }
.tk-btn.primary:hover,.tk-btn:hover { filter:brightness(1.15); transform: translateY(-1px); box-shadow: 0 6px 12px rgba(0,0,0,0.25); }
.tk-danger { background:var(--danger,#e74c3c)!important; color:#fff!important; }
.tk-task-list { flex:1; overflow-y:auto; padding:6px 0; }
.tk-empty { padding:32px; text-align:center; color:var(--text-muted); font-size:14px; }
.tk-task-row {
  display:flex; align-items:center; gap:10px;
  padding:9px 16px; cursor:pointer; border-radius:0;
  transition:background .12s; border-bottom:1px solid var(--border)44;
}
.tk-task-row:hover { background:var(--bg-elevated); }
.tk-task-row.done .tk-task-name { text-decoration:line-through; opacity:.5; }
.tk-task-row.overdue .tk-due { color:var(--danger,#e74c3c)!important; }
.tk-check-wrap { position:relative; flex-shrink:0; }
.tk-check-wrap input { opacity:0; position:absolute; inset:0; cursor:pointer; width:18px; height:18px; margin:0; }
.tk-check-box {
  width:18px; height:18px; border-radius:50%; border:2px solid var(--border);
  display:block; background:var(--bg-primary); transition:background .15s,border-color .15s;
}
.tk-check-wrap input:checked ~ .tk-check-box { background:var(--accent); border-color:var(--accent); }
.tk-check-wrap input:checked ~ .tk-check-box::after {
  content:'✓'; display:block; text-align:center; font-size:11px;
  line-height:14px; color:#fff; font-weight:700;
}
.tk-task-info { flex:1; min-width:0; }
.tk-task-name { font-size:14px; color:var(--text-primary); display:block; }
.tk-task-meta { display:flex; gap:8px; margin-top:2px; }
.tk-due       { font-size:11px; color:var(--text-muted); }
.tk-due-over  { color:var(--danger,#e74c3c)!important; font-weight:600; }
.tk-sub-count { font-size:11px; color:var(--text-muted); }
.tk-pri-badge { font-size:14px; flex-shrink:0; width:20px; text-align:center; }
.pri-dot { display:inline-block; width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.pri-high   { background:#ed4e4e; }
.pri-medium { background:#f4a22d; }
.pri-low    { background:#6ab04c; }

/* Detail panel */
.tk-detail {
  width:280px; border-left:1px solid var(--border);
  display:flex; flex-direction:column; background:var(--bg-secondary);
}
.tk-detail-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px; border-bottom:1px solid var(--border);
  font-weight:600; font-size:13px; flex-shrink:0;
}
.tk-detail-body { flex:1; overflow-y:auto; padding:12px 14px; display:flex; flex-direction:column; gap:10px; }
.tk-detail-title { width:100%; font-size:15px; font-weight:600; }
.tk-detail-row { display:flex; align-items:center; gap:8px; }
.tk-detail-row label { font-size:12px; color:var(--text-muted); width:55px; flex-shrink:0; }
.tk-detail-row .tk-select,.tk-detail-row .tk-input { flex:1; }
.tk-detail-label { font-size:12px; color:var(--text-muted); margin-top:4px; }
.tk-notes { width:100%; resize:vertical; min-height:80px; font-family:inherit; }
.tk-subtask-list { display:flex; flex-direction:column; gap:4px; }
.tk-sub-row { display:flex; align-items:center; gap:6px; font-size:13px; }
.tk-sub-row input[type=checkbox] { flex-shrink:0; cursor:pointer; }
.tk-sub-row span { flex:1; }
.tk-sub-done { text-decoration:line-through; opacity:.55; }
.tk-sub-del  { background:none; border:none; cursor:pointer; color:var(--text-muted); font-size:12px; padding:0 4px; }
.tk-sub-del:hover { color:var(--danger,#e74c3c); }

/* Stats panel */
.tk-stats-panel { overflow-y:auto; padding:20px; }
.tk-stats-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:16px; font-size:16px; font-weight:700; color:var(--text-primary);
}
.tk-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:20px; }
.tk-stat-card {
  background:var(--bg-secondary); border-radius:10px; padding:14px;
  text-align:center; border:1px solid var(--border);
}
.tk-stat-num { font-size:24px; font-weight:700; color:var(--accent); }
.tk-stat-lbl { font-size:12px; color:var(--text-muted); margin-top:4px; }
.tk-stats-section-title { font-size:12px; font-weight:700; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.06em; margin:14px 0 8px; }
.tk-heatmap-wrap { margin-bottom:8px; }
.tk-heatmap { display:flex; flex-wrap:wrap; gap:3px; }
.tk-heat-cell {
  width:14px; height:14px; border-radius:3px;
  background:var(--bg-elevated);
}
.tk-heat-cell[data-level="1"] { background:#5294e244; }
.tk-heat-cell[data-level="2"] { background:#5294e288; }
.tk-heat-cell[data-level="3"] { background:var(--accent); }
.tk-bar-chart { display:flex; align-items:flex-end; gap:4px; height:80px; }
.tk-bar-col { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; }
.tk-bar-fill { width:100%; background:var(--accent); border-radius:3px 3px 0 0; min-height:2px; transition:height .3s; }
.tk-bar-lbl { font-size:9px; color:var(--text-muted); margin-top:3px; }

/* ── Tasks: Views sidebar ──────────────────────────────────────── */
.tk-sidebar-section-hdr {
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  color:var(--text-muted); padding:10px 14px 4px;
}
.tk-view-btn {
  display:flex; align-items:center; gap:7px;
  background:none; border:none; cursor:pointer; text-align:left;
  padding:7px 14px; font-size:13px; color:var(--text-secondary);
  transition:background .12s; margin:0; width:100%; border-radius:0;
}
.tk-view-btn:hover { background:var(--bg-elevated); color:var(--text-primary); }
.tk-view-btn.active { background:var(--accent)1a; color:var(--accent); font-weight:600; }
.tk-view-btn svg { width:14px; height:14px; flex-shrink:0; }
.tk-vc {
  margin-left:auto; font-size:11px; background:var(--bg-elevated);
  padding:1px 6px; border-radius:10px; font-weight:500; color:var(--text-muted);
}
.tk-view-btn.active .tk-vc { background:var(--accent)22; color:var(--accent); }

/* ── Tasks: Projects + Epics sidebar ─────────────────────────── */
.tk-proj-group { display:flex; flex-direction:column; }
.tk-proj-expand {
  background:none; border:none; cursor:pointer; padding:0 4px;
  color:var(--text-muted); font-size:12px; flex-shrink:0;
  transition:transform .18s, color .12s; line-height:1;
}
.tk-proj-expand.open { transform:rotate(90deg); }
.tk-proj-expand:hover { color:var(--text-primary); }
.tk-proj-add-epic {
  opacity:0; transition:opacity .15s; flex-shrink:0;
  font-size:13px; padding:0 4px; margin-left:auto;
}
.tk-proj-item:hover .tk-proj-add-epic { opacity:1; }
.tk-epic-list { padding-left:20px; }
.tk-epic-item {
  display:flex; align-items:center; gap:7px;
  padding:5px 14px 5px 4px; cursor:pointer; font-size:12px;
  color:var(--text-secondary); transition:background .12s; border-radius:0;
}
.tk-epic-item:hover { background:var(--bg-elevated); color:var(--text-primary); }
.tk-epic-item.active { color:var(--accent); font-weight:600; }
.tk-epic-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.tk-epic-label { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ── Tasks: Header additions ──────────────────────────────────── */
.tk-proj-name-wrap { display:flex; align-items:center; gap:8px; min-width:0; }
.tk-proj-name-badge {
  font-size:11px; padding:2px 8px; border-radius:10px;
  background:var(--bg-elevated); color:var(--text-muted); flex-shrink:0;
}
.tk-btn-sm { padding:5px 10px; font-size:12px; }

/* ── Tasks: Type badges ───────────────────────────────────────── */
.tk-type-badge {
  width:18px; height:18px; border-radius:4px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:700; line-height:1;
}
.tk-type-task    { background:#5294e222; color:#5294e2; }
.tk-type-feature { background:#27ae6022; color:#27ae60; }
.tk-type-bug     { background:#e74c3c22; color:#e74c3c; }
.tk-type-story   { background:#9b59b622; color:#9b59b6; }

/* ── Tasks: Status pill ───────────────────────────────────────── */
.tk-status-pill {
  font-size:11px; font-weight:500; padding:3px 8px; border-radius:10px; cursor:pointer;
  color:var(--sc,var(--text-muted)); background:var(--sc,var(--text-muted))18;
  border:1px solid var(--sc,var(--text-muted))33; white-space:nowrap; flex-shrink:0;
  transition:filter .12s;
}
.tk-status-pill:hover { filter:brightness(1.15); }

/* ── Tasks: Epic + Label badges on rows ───────────────────────── */
.tk-epic-badge {
  font-size:10px; font-weight:500; padding:1px 6px; border-radius:10px;
  border:1px solid currentColor; opacity:.85;
}
.tk-label-badge {
  font-size:10px; font-weight:500; padding:1px 6px; border-radius:10px;
  border:1px solid currentColor; opacity:.85;
}
.tk-label-badge.sm { font-size:9px; padding:1px 4px; }

/* ── Tasks: Board (Kanban) view ───────────────────────────────── */
.tk-board-view {
  display:flex; gap:12px; padding:16px; overflow-x:auto; overflow-y:hidden;
  flex:1; align-items:flex-start; height:100%;
}
.tk-board-col {
  width:240px; min-width:200px; flex-shrink:0; display:flex;
  flex-direction:column; max-height:100%;
  background:var(--bg-secondary); border-radius:10px;
  border:1px solid var(--border);
}
.tk-board-col-hdr {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; font-size:12px; font-weight:700; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.06em; flex-shrink:0;
  border-top:3px solid var(--cc,var(--border)); border-radius:9px 9px 0 0;
}
.tk-board-col-count {
  font-size:11px; background:var(--bg-elevated); color:var(--text-muted);
  padding:1px 7px; border-radius:10px; font-weight:500;
}
.tk-board-col-body {
  flex:1; overflow-y:auto; padding:8px; display:flex; flex-direction:column; gap:6px;
}
.tk-board-col-body.drag-over { background:var(--accent)08; }
.tk-board-empty {
  text-align:center; font-size:12px; color:var(--text-muted);
  padding:16px 8px; border:1px dashed var(--border); border-radius:6px;
}
.tk-board-card {
  background:var(--bg-primary); border:1px solid var(--border); border-radius:8px;
  padding:10px 12px; cursor:pointer; display:flex; flex-direction:column; gap:6px;
  transition:box-shadow .14s, transform .1s;
}
.tk-board-card:hover { box-shadow:0 3px 10px var(--shadow); transform:translateY(-1px); }
.tk-board-card.dragging { opacity:.45; transform:scale(.97); }
.tk-board-card-hd { display:flex; align-items:flex-start; gap:6px; }
.tk-board-card-name { font-size:13px; color:var(--text-primary); line-height:1.35; flex:1; }
.tk-board-card-ft { display:flex; flex-wrap:wrap; gap:4px; }
.tk-card-epic { font-size:10px; font-weight:500; }
.tk-board-card-meta { display:flex; align-items:center; gap:6px; }
.tk-card-due { font-size:10px; color:var(--text-muted); }
.tk-card-due.overdue { color:var(--danger,#e74c3c); font-weight:600; }
.tk-card-proj-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* ── Tasks: Detail panel additions ───────────────────────────── */
.tk-detail-stat { font-size:11px; color:var(--text-muted); margin-top:2px; }
.tk-label-picker { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:6px; }
.tk-label-check { display:flex; align-items:center; gap:4px; cursor:pointer; }
.tk-label-check input[type=checkbox] { display:none; }
.tk-label-check span {
  font-size:11px; font-weight:500; padding:2px 8px; border-radius:4px; cursor:pointer;
  transition:opacity .12s;
}
.tk-label-check input:not(:checked) ~ span { opacity:.45; }
.tk-label-check input:checked  ~ span { opacity:1; }

/* ══════════════════════════════════════════════════════════
   CALENDAR APP
   ══════════════════════════════════════════════════════════ */
.cal-wrap { height:100%; display:flex; background:var(--bg-primary); overflow:hidden; }

/* Sidebar */
.cal-sidebar {
  width:200px; min-width:170px; flex-shrink:0;
  display:flex; flex-direction:column;
  background:var(--bg-secondary); border-right:1px solid var(--border);
  overflow-y:auto; padding:12px;
}
.cal-new-btn {
  background:var(--accent); color:#fff; border:none; border-radius:8px;
  padding:9px 12px; font-size:13px; font-weight:600; cursor:pointer;
  width:100%; margin-bottom:14px; transition:filter .13s;
}
.cal-new-btn:hover { filter:brightness(1.12); }
.cal-mini { margin-bottom:14px; }
.cal-mini-nav {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:6px;
}
.cal-mini-month { font-size:12px; font-weight:700; color:var(--text-primary); }
.cal-mini-arrow {
  background:none; border:none; cursor:pointer; color:var(--text-muted);
  padding:2px 5px; border-radius:4px; font-size:11px;
}
.cal-mini-arrow:hover { background:var(--bg-elevated); color:var(--text-primary); }
.cal-mini-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:1px; }
.cal-mini-dh { font-size:9px; color:var(--text-muted); text-align:center; padding:2px 0; font-weight:700; }
.cal-mini-day {
  font-size:11px; text-align:center; padding:3px 0; border-radius:50%;
  cursor:pointer; color:var(--text-secondary); transition:background .12s;
}
.cal-mini-day:hover { background:var(--bg-elevated); }
.cal-mini-day.today { background:var(--accent); color:#fff; font-weight:700; border-radius:50%; }
.cal-mini-day.has-ev { font-weight:700; color:var(--text-primary); }
.cal-upcoming-head { font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; color:var(--text-muted); margin-bottom:6px; }
.cal-upcoming { flex:1; overflow-y:auto; }
.cal-up-item {
  display:flex; align-items:flex-start; gap:8px;
  padding:6px 4px; cursor:pointer; border-radius:6px;
  transition:background .12s;
}
.cal-up-item:hover { background:var(--bg-elevated); }
.cal-up-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:4px; }
.cal-up-title { font-size:12px; color:var(--text-primary); font-weight:500; }
.cal-up-date  { font-size:10px; color:var(--text-muted); margin-top:1px; }
.cal-up-empty { font-size:12px; color:var(--text-muted); padding:4px; }

/* Main */
.cal-main { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.cal-toolbar {
  display:flex; align-items:center; gap:6px;
  padding:8px 14px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.cal-tbtn {
  background:var(--bg-elevated); border:none; border-radius:7px; padding:5px 11px;
  font-size:13px; cursor:pointer; color:var(--text-primary); transition:background .13s;
}
.cal-tbtn:hover { background:var(--accent)33; }
.cal-title { font-size:17px; font-weight:700; color:var(--text-primary); margin:0 8px; }
.cal-view-grp { display:flex; border-radius:7px; overflow:hidden; border:1px solid var(--border); }
.cal-view-btn {
  background:none; border:none; padding:5px 13px; font-size:12px; font-weight:600;
  cursor:pointer; color:var(--text-muted); transition:background .13s,color .13s;
}
.cal-view-btn.active { background:var(--accent); color:#fff; }
.cal-view-area { flex:1; overflow:auto; }

/* Month grid */
.cal-month-grid {
  display:grid; grid-template-columns:repeat(7,1fr);
  height:100%; min-height:400px;
}
.cal-month-dh {
  text-align:center; font-size:11px; font-weight:700; text-transform:uppercase;
  color:var(--text-muted); padding:6px 0; border-bottom:1px solid var(--border);
  position:sticky; top:0; background:var(--bg-secondary); z-index:1;
}
.cal-month-cell {
  min-height:90px; padding:4px; border-right:1px solid var(--border);
  border-bottom:1px solid var(--border); cursor:pointer;
  transition:background .12s; overflow:hidden;
}
.cal-month-cell:hover { background:var(--bg-elevated); }
.cal-month-other { opacity:.4; }
.cal-today .cal-day-num {
  background:var(--accent); color:#fff; border-radius:50%;
  width:22px; height:22px; display:inline-flex; align-items:center; justify-content:center;
  font-weight:700;
}
.cal-day-num { font-size:12px; color:var(--text-muted); font-weight:600; display:block; margin-bottom:2px; }
.cal-ev-chip {
  font-size:11px; color:#fff; border-radius:4px; padding:1px 6px;
  margin-bottom:2px; cursor:pointer; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; display:block;
  transition:filter .12s;
}
.cal-ev-chip:hover { filter:brightness(1.15); }
.cal-ev-more { font-size:10px; color:var(--text-muted); padding:1px 4px; }

/* Week view */
.cal-week-wrap { display:flex; flex-direction:column; min-height:100%; }
.cal-week-hdr {
  display:grid; grid-template-columns:52px repeat(7,1fr);
  border-bottom:1px solid var(--border); flex-shrink:0;
  background:var(--bg-secondary); position:sticky; top:0; z-index:2;
}
.cal-week-col-hdr {
  text-align:center; padding:6px 0; font-size:12px; color:var(--text-muted);
  border-left:1px solid var(--border);
}
.cal-week-col-hdr.today { color:var(--accent); font-weight:700; }
.cal-week-col-hdr strong { display:block; font-size:16px; color:var(--text-primary); }
.cal-week-allday-row {
  display:grid; grid-template-columns:52px repeat(7,1fr);
  border-bottom:2px solid var(--border); flex-shrink:0; min-height:28px;
}
.cal-week-allday-cell { border-left:1px solid var(--border); padding:2px 3px; }
.cal-allday-label { font-size:10px; color:var(--text-muted); padding:4px 4px; }
.cal-week-grid,.cal-day-grid {
  display:grid; grid-template-columns:52px 1fr; flex:1; position:relative;
}
.cal-day-grid { grid-template-columns:52px 1fr; }
.cal-week-grid { grid-template-columns:52px repeat(7,1fr); }
.cal-week-time-col { display:flex; flex-direction:column; }
.cal-time-lbl {
  height:48px; font-size:10px; color:var(--text-muted); text-align:right;
  padding-right:6px; padding-top:4px; flex-shrink:0;
}
.cal-week-col,.cal-day-col { position:relative; border-left:1px solid var(--border); }
.cal-hour-line {
  height:48px; border-bottom:1px solid var(--border)55; cursor:pointer;
  transition:background .1s;
}
.cal-hour-line:hover { background:var(--accent)11; }
.cal-week-ev {
  position:absolute; left:2px; right:2px; border-radius:5px;
  font-size:11px; color:#fff; padding:2px 5px; overflow:hidden;
  cursor:pointer; transition:filter .12s; z-index:1;
}
.cal-week-ev:hover { filter:brightness(1.15); }
.cal-week-time-gutter { width:52px; flex-shrink:0; }

/* Day view */
.cal-day-wrap { display:flex; flex-direction:column; min-height:100%; }
.cal-day-allday {
  display:flex; align-items:center; gap:6px; padding:4px 8px;
  border-bottom:1px solid var(--border); flex-shrink:0;
}
.cal-day-col { flex:1; }

/* Modal */
.cal-modal {
  position:absolute; inset:0; background:rgba(0,0,0,.45);
  display:flex; align-items:center; justify-content:center; z-index:100;
}
.cal-modal.hidden { display:none; }
.cal-modal-box {
  background:var(--bg-secondary); border-radius:14px; width:420px; max-width:95%;
  box-shadow:0 16px 48px rgba(0,0,0,.45); display:flex; flex-direction:column;
  overflow:hidden;
}
.cal-modal-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border-bottom:1px solid var(--border);
  font-size:15px; font-weight:700; color:var(--text-primary);
}
.cal-modal-close {
  background:none; border:none; cursor:pointer; color:var(--text-muted);
  font-size:18px; padding:2px 7px; border-radius:5px;
}
.cal-modal-close:hover { color:var(--text-primary); }
.cal-modal-body { padding:16px 18px; display:flex; flex-direction:column; gap:10px; }
.cal-input {
  background:var(--input-bg); border:1px solid var(--input-border);
  color:var(--text-primary); border-radius:8px; padding:8px 11px;
  font-size:13px; outline:none; width:100%; transition:border-color .15s;
}
.cal-input:focus { border-color:var(--accent); }
.cal-sm { width:auto; flex-shrink:0; }
.cal-form-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.cal-form-row label { font-size:12px; color:var(--text-muted); flex-shrink:0; }
.cal-check-lbl { display:flex; align-items:center; gap:4px; font-size:12px; color:var(--text-muted); cursor:pointer; }
.cal-notes { resize:vertical; min-height:64px; font-family:inherit; }
.cal-color-row { display:flex; gap:6px; flex-wrap:wrap; }
.cal-color-swatch {
  width:22px; height:22px; border-radius:50%; border:2px solid transparent;
  cursor:pointer; transition:border-color .15s, transform .15s;
}
.cal-color-swatch:hover  { transform:scale(1.15); }
.cal-color-swatch.active { border-color:var(--text-primary); transform:scale(1.15); }
.cal-modal-foot {
  display:flex; gap:8px; padding:12px 18px;
  border-top:1px solid var(--border);
}
.cal-btn {
  padding:8px 18px; border-radius:8px; border:none; cursor:pointer;
  font-size:13px; font-weight:600; transition:filter .13s;
  background:var(--bg-elevated); color:var(--text-primary);
}
.cal-btn.primary { background:var(--accent); color:#fff; }
.cal-btn.primary:hover,.cal-btn:hover { filter:brightness(1.12); }
.cal-danger { background:var(--danger,#e74c3c)!important; color:#fff!important; }

/* ── Calendar enhanced event form ── */
.cal-modal-wide { width: 580px !important; }
.cal-adv-body   { gap: 0 !important; padding: 0 !important; overflow-y: auto; max-height: calc(100vh - 220px); }

.cal-title-input {
  margin: 14px 18px 0; width: calc(100% - 36px);
  font-size: 16px; font-weight: 600;
  background: var(--input-bg); border: 1px solid var(--input-border);
  color: var(--text-primary); border-radius: 8px; padding: 9px 13px;
  outline: none; box-sizing: border-box; transition: border-color .15s;
}
.cal-title-input:focus { border-color: var(--accent); }

.cal-adv-section {
  padding: 10px 18px;
  border-bottom: 1px solid var(--border);
}
.cal-adv-section:last-child { border-bottom: none; }

.cal-adv-row {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.cal-adv-col       { flex: 1; min-width: 100px; display: flex; flex-direction: column; gap: 4px; }
.cal-adv-col2      { flex: 2; min-width: 180px; }
.cal-allday-col    { flex: 0 0 auto; justify-content: flex-end; }
.cal-color-col     { flex: 2; }

.cal-adv-lbl {
  font-size: 10.5px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-muted);
}

/* ICS import/export/subscribe buttons */
.cal-ics-btns {
  display: flex; gap: 4px; flex-wrap: wrap; padding: 6px 8px;
  border-bottom: 1px solid var(--border);
}
.cal-ics-btn {
  flex: 1; padding: 5px 4px; border-radius: 6px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-secondary);
  font-size: 11px; cursor: pointer; text-align: center; white-space: nowrap;
  transition: background .12s, color .12s;
}
.cal-ics-btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

/* Subscriptions sidebar list */
.cal-sub-list { padding: 0 6px 4px; }
.cal-sub-head {
  padding: 6px 6px 2px; font-size: 10.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .05em; color: var(--text-muted);
}
.cal-sub-item {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 6px; border-radius: 6px; font-size: 12px;
  color: var(--text-secondary);
}
.cal-sub-item:hover { background: var(--bg-tertiary); }
.cal-sub-dot  { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.cal-sub-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-sub-rm   {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; font-size: 14px; padding: 0 2px; line-height: 1;
}
.cal-sub-rm:hover { color: #e57373; }

/* Subscribe modal */
.cal-sub-status {
  font-size: 12px; color: var(--text-muted); margin-top: 6px; min-height: 16px;
}

/* Invitees */
.cal-invitee-wrap {
  position: relative; display: flex; flex-wrap: wrap; align-items: center;
  gap: 4px; padding: 5px 8px; border-radius: 8px;
  border: 1px solid var(--input-border); background: var(--input-bg);
  transition: border-color .15s;
}
.cal-invitee-wrap:focus-within { border-color: var(--accent); }
.cal-invitee-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.cal-chip {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 20px; font-size: 11.5px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
}
.cal-chip-rm {
  background: none; border: none; color: inherit; cursor: pointer;
  font-size: 13px; padding: 0 0 0 2px; opacity: .7; line-height: 1;
}
.cal-chip-rm:hover { opacity: 1; }
.cal-invitee-input {
  border: none; outline: none; background: transparent;
  color: var(--text-primary); font-size: 12.5px; min-width: 120px; flex: 1;
}

/* Invitee autocomplete */
.cal-invitee-ac {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 9999;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; box-shadow: 0 6px 20px rgba(0,0,0,.3);
  overflow: hidden; margin-top: 3px;
}
.cal-ac-item {
  padding: 7px 12px; font-size: 12.5px; cursor: pointer;
  color: var(--text-secondary); transition: background .1s, color .1s;
}
.cal-ac-item:hover { background: var(--accent); color: #fff; }

/* ══════════════════════════════════════════════════════════
   DRAW.IO INTEGRATION
   ══════════════════════════════════════════════════════════ */
.dio-wrap {
  height: 100%; display: flex; flex-direction: column;
  background: var(--bg-primary); overflow: hidden;
}
.dio-toolbar {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 8px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
}
.dio-btn {
  background: none; border: none; cursor: pointer;
  color: var(--text-secondary); padding: 5px 10px;
  border-radius: 6px; font-size: 13px; white-space: nowrap;
  transition: background .13s, color .13s;
}
.dio-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }
.dio-sep { width: 1px; height: 20px; background: var(--border); margin: 0 4px; flex-shrink: 0; }
.dio-path { font-size: 12px; color: var(--text-muted); margin-left: 6px; }
.dio-mod  { font-size: 12px; color: var(--warning, #f4a22d); margin-left: 4px; }

.dio-frame-wrap {
  flex: 1; position: relative; overflow: hidden;
  background: #1e1e2e;
}
.dio-frame {
  width: 100%; height: 100%; border: none; display: block;
}
.dio-loading {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 16px;
  background: #1e1e2e; color: rgba(255,255,255,.55); font-size: 14px;
}
.dio-loading-spinner {
  width: 36px; height: 36px; border-radius: 50%;
  border: 3px solid rgba(255,255,255,.15);
  border-top-color: var(--accent);
  animation: dio-spin .8s linear infinite;
}
@keyframes dio-spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════
   IMAGE VIEWER
   ══════════════════════════════════════════════════════════ */
.iv-wrap {
  height: 100%; display: flex; flex-direction: column;
  background: var(--bg-primary); overflow: hidden; position: relative;
}
.iv-toolbar {
  display: flex; align-items: center; gap: 2px;
  padding: 4px 8px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.iv-btn {
  background: none; border: none; cursor: pointer; color: var(--text-secondary);
  padding: 5px 9px; border-radius: 6px; font-size: 13px;
  transition: background .13s, color .13s; white-space: nowrap;
}
.iv-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }
.iv-btn.iv-icon { padding: 5px 7px; font-size: 15px; }
.iv-sep { width: 1px; height: 20px; background: var(--border); margin: 0 4px; flex-shrink: 0; }
.iv-info { font-size: 12px; color: var(--text-muted); min-width: 50px; text-align: center; }

.iv-stage {
  flex: 1; position: relative; overflow: hidden;
  background: var(--bg-tertiary);
  display: flex; align-items: center; justify-content: center;
}
.iv-canvas-wrap {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  cursor: grab; overflow: hidden;
}
.iv-canvas-wrap:active { cursor: grabbing; }
.iv-image {
  max-width: none; max-height: none;
  user-select: none; pointer-events: none;
  border-radius: 4px;
  box-shadow: 0 4px 24px rgba(0,0,0,.45);
  transition: box-shadow .2s;
  transform-origin: center center;
}

/* Empty state */
.iv-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; text-align: center; padding: 40px;
}
.iv-empty-icon { font-size: 56px; opacity: .4; }
.iv-empty-title { font-size: 18px; font-weight: 600; color: var(--text-secondary); }
.iv-empty-hint  { font-size: 13px; color: var(--text-muted); }
.iv-big-btn {
  margin-top: 6px; padding: 10px 24px; border-radius: 8px;
  background: var(--accent); color: #fff; border: none; cursor: pointer;
  font-size: 14px; font-weight: 600; transition: filter .13s;
}
.iv-big-btn:hover { filter: brightness(1.15); }

/* Filmstrip */
.iv-strip {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px; overflow-x: auto;
  background: var(--bg-secondary); border-top: 1px solid var(--border);
  flex-shrink: 0; max-height: 82px;
  scrollbar-width: thin;
}
.iv-thumb {
  flex-shrink: 0; width: 64px; height: 64px;
  border-radius: 6px; overflow: hidden; cursor: pointer;
  border: 2px solid transparent;
  background: var(--bg-elevated);
  transition: border-color .15s, transform .15s;
}
.iv-thumb:hover { transform: scale(1.07); }
.iv-thumb.active { border-color: var(--accent); }
.iv-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Info panel (slide-over) */
.iv-info-panel {
  position: absolute; top: 0; right: 0; bottom: 0; width: 260px;
  background: var(--bg-secondary); border-left: 1px solid var(--border);
  display: flex; flex-direction: column; z-index: 10;
  transition: transform .2s;
}
.iv-info-panel.hidden { display: none; }
.iv-info-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; font-weight: 600; font-size: 13px;
  border-bottom: 1px solid var(--border);
}
.iv-close-info {
  background: none; border: none; cursor: pointer; color: var(--text-muted);
  font-size: 16px; padding: 2px 6px; border-radius: 4px;
}
.iv-close-info:hover { color: var(--text-primary); }
.iv-info-body { flex: 1; overflow-y: auto; padding: 10px 14px; }
.iv-info-row {
  display: flex; justify-content: space-between; gap: 8px;
  padding: 7px 0; border-bottom: 1px solid var(--border)40;
  font-size: 12px;
}
.iv-info-row span:first-child { color: var(--text-muted); flex-shrink: 0; }
.iv-info-row span:last-child  { color: var(--text-primary); text-align: right; word-break: break-all; }

/* ══════════════════════════════════════════════════════════
   VIDEO PLAYER
   ══════════════════════════════════════════════════════════ */
.vp-wrap {
  height: 100%; display: flex; flex-direction: column;
  background: #0a0a0a; overflow: hidden; position: relative;
}
.vp-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px; text-align: center; padding: 40px;
}
.vp-empty-icon  { font-size: 56px; opacity: .4; }
.vp-empty-title { font-size: 18px; font-weight: 600; color: var(--text-secondary); }
.vp-empty-hint  { font-size: 13px; color: var(--text-muted); }
.vp-big-btn {
  margin-top: 6px; padding: 10px 24px; border-radius: 8px;
  background: var(--accent); color: #fff; border: none; cursor: pointer;
  font-size: 14px; font-weight: 600; transition: filter .13s;
}
.vp-big-btn:hover { filter: brightness(1.15); }

.vp-video-area {
  flex: 1; display: none; align-items: center; justify-content: center;
  position: relative; overflow: hidden; background: #000;
}
.vp-video {
  max-width: 100%; max-height: 100%;
  display: block; outline: none;
}
.vp-overlay {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  transition: opacity .25s;
}
.vp-overlay.vp-hidden { opacity: 0; pointer-events: none; }
.vp-center-btn {
  font-size: 40px; color: rgba(255,255,255,.85);
  background: rgba(0,0,0,.45); border-radius: 50%;
  width: 68px; height: 68px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: transform .15s, background .15s;
}
.vp-center-btn:hover { transform: scale(1.12); background: rgba(0,0,0,.7); }

/* Controls */
.vp-controls {
  background: linear-gradient(0deg, rgba(0,0,0,.95) 0%, rgba(0,0,0,.6) 100%);
  padding: 0 10px 6px;
  transition: opacity .3s;
  flex-shrink: 0;
}
.vp-controls.vp-hidden { opacity: 0; pointer-events: none; }

.vp-progress-wrap { padding: 8px 2px 4px; }
.vp-progress-bg {
  position: relative; height: 5px; border-radius: 3px;
  background: rgba(255,255,255,.2); cursor: pointer;
  transition: height .15s;
}
.vp-progress-bg:hover { height: 8px; }
.vp-progress-buf {
  position: absolute; left: 0; top: 0; height: 100%;
  background: rgba(255,255,255,.25); border-radius: 3px;
  pointer-events: none;
}
.vp-progress-fill {
  position: absolute; left: 0; top: 0; height: 100%;
  background: var(--accent); border-radius: 3px; pointer-events: none;
}
.vp-progress-thumb {
  position: absolute; top: 50%; transform: translate(-50%,-50%);
  width: 13px; height: 13px; border-radius: 50%;
  background: #fff; pointer-events: none;
  box-shadow: 0 0 4px rgba(0,0,0,.6);
  opacity: 0; transition: opacity .15s;
}
.vp-progress-bg:hover .vp-progress-thumb { opacity: 1; }
.vp-tooltip {
  position: absolute; bottom: 14px; transform: translateX(-50%);
  background: rgba(0,0,0,.8); color: #fff; font-size: 11px; padding: 2px 7px;
  border-radius: 4px; pointer-events: none; white-space: nowrap;
  opacity: 0; transition: opacity .15s;
}

.vp-bar {
  display: flex; align-items: center; gap: 4px; min-height: 36px;
}
.vp-btn {
  background: none; border: none; color: rgba(255,255,255,.8); cursor: pointer;
  font-size: 16px; padding: 5px 7px; border-radius: 6px;
  transition: background .13s, color .13s;
}
.vp-btn:hover { background: rgba(255,255,255,.12); color: #fff; }
.vp-play-btn { font-size: 20px; }
.vp-time { font-size: 12px; color: rgba(255,255,255,.7); white-space: nowrap; margin: 0 6px; }
.vp-slider {
  -webkit-appearance: none; appearance: none;
  width: 80px; height: 4px; border-radius: 2px;
  background: rgba(255,255,255,.3); outline: none; cursor: pointer;
}
.vp-slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 12px; height: 12px; border-radius: 50%; background: #fff;
}
.vp-select {
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.8); border-radius: 5px; font-size: 12px;
  padding: 3px 6px; cursor: pointer; outline: none;
}

/* Playlist sidebar */
.vp-playlist {
  position: absolute; top: 0; right: 0; bottom: 0; width: 240px;
  background: rgba(15,15,15,.96); border-left: 1px solid rgba(255,255,255,.1);
  display: flex; flex-direction: column; z-index: 10;
}
.vp-pl-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.85);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.vp-pl-close {
  background: none; border: none; color: rgba(255,255,255,.5); cursor: pointer; font-size: 15px;
  padding: 2px 5px; border-radius: 4px;
}
.vp-pl-close:hover { color: #fff; }
.vp-pl-list { flex: 1; overflow-y: auto; padding: 6px 0; }
.vp-pl-item {
  padding: 9px 14px; font-size: 12px; color: rgba(255,255,255,.65); cursor: pointer;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  border-radius: 6px; margin: 1px 6px; transition: background .12s;
}
.vp-pl-item:hover  { background: rgba(255,255,255,.08); color: #fff; }
.vp-pl-item.active { background: var(--accent)33; color: var(--accent); }

/* ══════════════════════════════════════════════════════════
   MUSIC PLAYER
   ══════════════════════════════════════════════════════════ */
.mp-wrap {
  height: 100%; display: flex;
  background: var(--bg-primary); overflow: hidden;
}

/* Now-playing panel */
.mp-now-playing {
  width: 300px; min-width: 260px; flex-shrink: 0;
  display: flex; flex-direction: column; align-items: center;
  gap: 14px; padding: 20px 18px;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
}

/* Album art + visualizer */
.mp-art {
  position: relative; width: 180px; height: 180px;
  border-radius: 50%; overflow: hidden;
  background: var(--bg-elevated);
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: box-shadow .3s;
}
.mp-art.mp-art-spin { animation: mp-spin 8s linear infinite; }
@keyframes mp-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.mp-art-default { font-size: 60px; opacity: .4; }
.mp-visualizer {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border-radius: 50%; transition: opacity .3s;
}

/* Track info */
.mp-track-info { text-align: center; width: 100%; }
.mp-title  { font-size: 15px; font-weight: 700; color: var(--text-primary);
             white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-artist { font-size: 12px; color: var(--text-muted); margin-top: 3px; }

/* Progress */
.mp-progress-wrap {
  display: flex; align-items: center; gap: 8px; width: 100%;
}
.mp-time-cur, .mp-time-dur {
  font-size: 11px; color: var(--text-muted); width: 30px; flex-shrink: 0;
}
.mp-time-dur { text-align: right; }
.mp-progress-bg {
  flex: 1; height: 5px; border-radius: 3px;
  background: var(--bg-elevated); cursor: pointer; position: relative;
  transition: height .15s;
}
.mp-progress-bg:hover { height: 8px; }
.mp-progress-fill {
  position: absolute; left: 0; top: 0; height: 100%;
  background: var(--accent); border-radius: 3px; pointer-events: none;
}
.mp-progress-thumb {
  position: absolute; top: 50%; transform: translate(-50%,-50%);
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--accent); pointer-events: none;
  opacity: 0; transition: opacity .15s;
}
.mp-progress-bg:hover .mp-progress-thumb { opacity: 1; }

/* Controls */
.mp-controls {
  display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%;
}
.mp-ctrl-btn {
  background: none; border: none; cursor: pointer;
  color: var(--text-secondary); font-size: 26px; padding: 6px;
  border-radius: 50%; width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  transition: background .13s, color .13s, transform .13s;
}
.mp-ctrl-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }
.mp-ctrl-btn.mp-small { font-size: 18px; width: 36px; height: 36px; }
.mp-ctrl-btn.mp-active { color: var(--accent); }
.mp-ctrl-btn.mp-play {
  background: var(--accent); color: #fff; font-size: 22px;
  box-shadow: 0 4px 14px rgba(0,0,0,.3);
}
.mp-ctrl-btn.mp-play:hover { filter: brightness(1.12); transform: scale(1.06); }

/* Extras row */
.mp-extras {
  display: flex; align-items: center; gap: 6px; width: 100%;
}
.mp-icon-btn {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); font-size: 16px; padding: 5px;
  border-radius: 6px; transition: background .13s, color .13s;
}
.mp-icon-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }
.mp-icon-btn.mp-active { color: var(--accent); }
.mp-vol {
  flex: 1; -webkit-appearance: none; appearance: none;
  height: 4px; border-radius: 2px;
  background: var(--bg-elevated); outline: none; cursor: pointer;
}
.mp-vol::-webkit-slider-thumb {
  -webkit-appearance: none; width: 12px; height: 12px; border-radius: 50%;
  background: var(--accent);
}

/* Queue panel */
.mp-queue {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
}
.mp-queue-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  font-size: 13px; font-weight: 600; color: var(--text-primary); flex-shrink: 0;
}
.mp-queue-count { font-size: 12px; color: var(--text-muted); font-weight: 400; }
.mp-queue-list { flex: 1; overflow-y: auto; padding: 6px 0; }
.mp-qi {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 16px; cursor: pointer; border-radius: 8px; margin: 1px 8px;
  transition: background .12s;
}
.mp-qi:hover  { background: var(--bg-elevated); }
.mp-qi.active { background: var(--accent)1a; }
.mp-qi-num   { font-size: 12px; color: var(--text-muted); width: 20px; text-align: center; flex-shrink: 0; }
.mp-qi.active .mp-qi-num { color: var(--accent); font-size: 16px; }
.mp-qi-title { flex: 1; font-size: 13px; color: var(--text-primary);
               white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-qi.active .mp-qi-title { color: var(--accent); font-weight: 600; }
.mp-qi-dur   { font-size: 11px; color: var(--text-muted); flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════
   PDF VIEWER
   ══════════════════════════════════════════════════════════ */
.pv-wrap {
  height: 100%; display: flex; flex-direction: column;
  background: var(--bg-primary);
}

.pv-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
}

.pv-sep { width: 1px; height: 20px; background: var(--border); margin: 0 2px; }

#pv-page-info, .pv-page-info { font-size: 12px; color: var(--text-secondary); min-width: 60px; text-align: center; }
#pv-zoom-level { font-size: 12px; color: var(--text-secondary); min-width: 40px; text-align: center; }

.pv-loading {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.4); color: #fff; font-size: 14px;
}

.pv-canvas-wrap {
  flex: 1; overflow: auto;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 16px; background: var(--bg-tertiary);
}

.pv-empty {
  color: var(--text-muted); align-self: center; font-size: 14px;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}

.pv-canvas {
  box-shadow: 0 4px 24px rgba(0,0,0,.5);
  max-width: 100%;
}

/* ══════════════════════════════════════════════════════════
   SETTINGS
   ══════════════════════════════════════════════════════════ */
.settings-wrap {
  height: 100%; display: flex; background: var(--bg-primary);
}

.settings-sidebar {
  width: 160px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  padding: 8px 0;
  overflow-y: auto;
}

.settings-nav-item {
  padding: 9px 16px; cursor: pointer;
  color: var(--text-secondary); font-size: 13px;
  transition: background .1s, color .1s;
}
.settings-nav-item:hover  { background: rgba(82,148,226,.12); color: var(--text-primary); }
.settings-nav-item.active { background: rgba(82,148,226,.25); color: var(--accent); border-left: 2px solid var(--accent); }

.settings-content {
  flex: 1; overflow-y: auto; padding: 24px;
}

.settings-section h2 {
  font-size: 18px; font-weight: 400;
  color: var(--text-primary); margin-bottom: 20px;
  border-bottom: 1px solid var(--border); padding-bottom: 10px;
}

.settings-group {
  margin-bottom: 24px;
}
.settings-group label {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--text-secondary); text-transform: uppercase;
  letter-spacing: .5px; margin-bottom: 10px;
}

/* ── Profile avatar editor ─────────────────────────────────── */
.prf-avatar-wrap {
  display: flex; gap: 20px; align-items: flex-start;
}
.prf-avatar-circle {
  flex-shrink: 0;
  width: 88px; height: 88px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--bg-elevated);
  border: 3px solid var(--accent)50;
  box-shadow: 0 4px 16px rgba(0,0,0,.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 44px;
  cursor: pointer;
  transition: border-color .2s;
}
.prf-avatar-circle:hover { border-color: var(--accent); }
.prf-avatar-img  { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.prf-avatar-emoji { line-height: 1; }
.prf-avatar-actions {
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.prf-avatar-hint {
  font-size: 11px; color: var(--text-muted);
}
.prf-emoji-row {
  position: relative; margin-top: 4px;
}

/* Trigger button */
.prf-ep-trigger {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 8px;
  background: var(--bg-elevated); border: 1px solid var(--border);
  cursor: pointer; color: var(--text); transition: border-color .15s, background .15s;
}
.prf-ep-trigger:hover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, var(--bg-elevated)); }
.prf-ep-current { font-size: 22px; line-height: 1; }
.prf-ep-label   { font-size: 12px; color: var(--text-muted); }

/* Popup panel */
.prf-ep-popup {
  position: absolute; left: 0; top: calc(100% + 6px); z-index: 9999;
  width: 320px;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.4);
  display: flex; flex-direction: column; overflow: hidden;
}
.prf-ep-popup.hidden { display: none; }

/* Search bar */
.pep-header { padding: 10px 10px 0; }
.pep-search {
  width: 100%; box-sizing: border-box;
  padding: 7px 12px; border-radius: 20px;
  background: var(--bg); border: 1px solid var(--border);
  color: var(--text); font-size: 13px; outline: none;
  transition: border-color .15s;
}
.pep-search:focus { border-color: var(--accent); }

/* Category tabs */
.pep-cats {
  display: flex; gap: 2px; padding: 8px 10px 4px;
  overflow-x: auto; scrollbar-width: none;
}
.pep-cats::-webkit-scrollbar { display: none; }
.pep-cat {
  flex-shrink: 0; font-size: 18px; padding: 4px 6px;
  border-radius: 6px; border: none; background: transparent;
  cursor: pointer; transition: background .15s; opacity: .6;
}
.pep-cat:hover { background: var(--bg); opacity: 1; }
.pep-cat.active { background: color-mix(in srgb, var(--accent) 18%, var(--bg-elevated)); opacity: 1; }

/* Emoji grid */
.pep-grid {
  padding: 6px 8px 10px;
  display: grid; grid-template-columns: repeat(8, 1fr);
  gap: 2px;
  max-height: 220px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
}
.pep-em {
  font-size: 20px; padding: 4px; border-radius: 6px;
  border: none; background: transparent; cursor: pointer;
  transition: background .1s, transform .1s; line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.pep-em:hover {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  transform: scale(1.25);
}
.pep-empty {
  grid-column: 1/-1; text-align: center;
  color: var(--text-muted); font-size: 12px; padding: 24px 0;
}

/* Theme Grid (scoped to .settings-wrap) */
.settings-wrap .theme-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
}

.settings-wrap .theme-card {
  border-radius: 10px; overflow: hidden; position: relative;
  border: 2px solid var(--border);
  cursor: pointer; transition: border-color .2s, transform .15s;
}
.settings-wrap .theme-card:hover  { border-color: var(--accent); transform: translateY(-2px); }
.settings-wrap .theme-card.active { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent); }
.settings-wrap .theme-preview {
  height: 64px; display: flex; flex-direction: column;
  position: relative; overflow: hidden;
}
.settings-wrap .theme-name {
  padding: 5px 8px; font-size: 11px; font-weight: 500;
  background: var(--bg-secondary); color: var(--text-primary);
  text-align: center;
}


/* ── Custom theme card (scoped) ─────────────────────────── */
.settings-wrap .tp-custom {
  background: conic-gradient(
    #5294e2 0deg 45deg, #88c0d0 45deg 90deg, #bd93f9 90deg 135deg,
    #00ff41 135deg 180deg, #f4a22d 180deg 225deg, #ed4e4e 225deg 270deg,
    #007aff 270deg 315deg, #5294e2 315deg 360deg);
  position: relative;
}
.settings-wrap .tc-custom-card .theme-name::after { content: ' ✎'; }

/* ── Installed (community) theme cards (scoped) ─────────── */
.settings-wrap .theme-card[data-installed] { position: relative; }
.settings-wrap .theme-uninstall-btn {
  position: absolute; top: 4px; right: 4px;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(0,0,0,.45); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .15s;
  padding: 0; color: #fff;
}
.settings-wrap .theme-uninstall-btn svg { width: 10px; height: 10px; stroke: #fff; }
.settings-wrap .theme-card[data-installed]:hover .theme-uninstall-btn { opacity: 1; }

/* ── Theme Install bar (admin) (scoped) ─────────────────── */
.settings-wrap .theme-install-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 10px 0 4px;
}
.settings-wrap .theme-install-hint {
  font-size: 11px; color: var(--text-muted);
}
.settings-wrap .theme-install-hint code {
  background: var(--bg-secondary); border-radius: 3px;
  padding: 1px 4px; font-size: 11px;
}

/* ── Theme Customizer Panel ─────────────────────────────── */
.settings-wrap #tc-panel {
  margin-top: 10px;
}
.settings-wrap .tc-toolbar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 10px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 10px 10px 0 0;
  border-bottom: none;
}
.settings-wrap .tc-toolbar-title {
  font-weight: 600; font-size: 13px; color: var(--text-primary);
  display: flex; align-items: center; gap: 6px; margin-right: auto;
}
.settings-wrap .tc-toolbar-title svg { width: 15px; height: 15px; stroke: var(--accent); flex-shrink: 0; }
.settings-wrap .tc-toolbar-right {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.settings-wrap .tc-base-label {
  font-size: 12px; color: var(--text-secondary); display: flex; align-items: center; gap: 4px;
}
.settings-wrap .tc-base-sel { padding: 4px 6px; font-size: 12px; height: 28px; }
.settings-wrap .tc-name-input { padding: 4px 8px; font-size: 12px; height: 28px; width: 160px; }

.settings-wrap .tc-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  background: var(--bg-secondary);
  padding: 0 12px;
  flex-shrink: 0;
}
.settings-wrap .tc-tab {
  padding: 8px 14px; font-size: 12px; font-weight: 500;
  background: none; border: none; cursor: pointer;
  color: var(--text-secondary);
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  margin-bottom: -1px;
}
.settings-wrap .tc-tab:hover  { color: var(--text-primary); }
.settings-wrap .tc-tab.active { color: var(--accent); border-bottom-color: var(--accent); }

.settings-wrap .tc-main {
  display: flex; gap: 0;
  border: 1px solid var(--border);
  border-radius: 0 0 10px 10px;
  overflow: hidden;
  background: var(--bg-primary);
  min-height: 340px;
}
.settings-wrap .tc-editor {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  border-right: 1px solid var(--border);
}
.settings-wrap .tc-tab-panel { flex: 1; overflow-y: auto; padding: 12px; }
.settings-wrap .tc-tab-panel.hidden { display: none; }

/* Variable groups */
.settings-wrap .tc-group { margin-bottom: 14px; }
.settings-wrap .tc-group-title {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-muted); margin-bottom: 6px;
  padding-bottom: 4px; border-bottom: 1px solid var(--border);
}
.settings-wrap .tc-row {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 0; min-height: 32px;
}
.settings-wrap .tc-row-label {
  flex: 0 0 130px; font-size: 12px; color: var(--text-secondary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.settings-wrap .tc-row-ctrl {
  display: flex; align-items: center; gap: 6px; flex: 1; min-width: 0;
}
.settings-wrap .tc-row-ctrl input[type="text"],
.settings-wrap .tc-row-ctrl input[type="range"] {
  flex: 1; min-width: 0;
}
.settings-wrap .tc-swatch-wrap { display: flex; align-items: center; cursor: pointer; flex-shrink: 0; }
.settings-wrap .tc-swatch {
  width: 22px; height: 22px; border-radius: 5px;
  border: 1px solid var(--border);
  flex-shrink: 0; display: block;
}
.settings-wrap .tc-swatch-complex { cursor: default; }
.settings-wrap .tc-color-pick {
  position: absolute; width: 0; height: 0; padding: 0; border: none; opacity: 0; pointer-events: none;
}
.settings-wrap .tc-row-ctrl-complex .tc-swatch { opacity: .5; cursor: default; }

/* CSS editor tab */
.settings-wrap .tc-css-hint {
  font-size: 11px; color: var(--text-muted); margin-bottom: 8px;
  padding: 6px 8px; background: var(--bg-secondary); border-radius: 6px;
  border: 1px solid var(--border);
}
.settings-wrap .tc-css-editor {
  width: 100%; box-sizing: border-box;
  min-height: 220px; resize: vertical;
  font-family: 'Cascadia Code', 'Fira Code', monospace; font-size: 12px;
  background: var(--bg-secondary); color: var(--text-primary);
  border: 1px solid var(--border); border-radius: 6px;
  padding: 10px 12px; line-height: 1.5;
  outline: none;
  transition: border-color .15s;
}
.settings-wrap .tc-css-editor:focus { border-color: var(--accent); }
.settings-wrap .tc-css-actions {
  margin-top: 8px; display: flex; gap: 6px;
}
.settings-wrap .tc-upload-lbl {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; cursor: pointer;
}
.settings-wrap .tc-upload-lbl svg { width: 13px; height: 13px; }

/* Preview pane */
.settings-wrap .tc-prev-wrap {
  width: 220px; flex-shrink: 0;
  padding: 12px;
  display: flex; flex-direction: column; gap: 8px;
  background: var(--bg-secondary);
}
.settings-wrap .tc-prev-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-muted);
}
.settings-wrap .tc-prev {
  width: 196px; height: 156px;
  border-radius: 8px; overflow: hidden;
  background: var(--desktop-bg);
  border: 1px solid var(--border);
  display: flex; flex-direction: column;
  flex-shrink: 0;
}
.settings-wrap .tc-prev-desktop {
  flex: 1; padding: 8px;
  display: flex; align-items: center; justify-content: center;
}
.settings-wrap .tc-prev-win {
  width: 170px; border-radius: var(--window-radius);
  overflow: hidden; border: 1px solid var(--border);
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.settings-wrap .tc-prev-bar {
  background: var(--titlebar-bg);
  padding: 4px 6px;
  display: flex; align-items: center; gap: 4px;
}
.settings-wrap .tc-prev-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.settings-wrap .tc-dot-close { background: var(--btn-close); }
.settings-wrap .tc-dot-min   { background: var(--btn-min); }
.settings-wrap .tc-dot-max   { background: var(--btn-max); }
.settings-wrap .tc-prev-title {
  flex: 1; font-size: 8px; color: var(--titlebar-text); text-align: center;
}
.settings-wrap .tc-prev-body {
  background: var(--bg-primary);
  padding: 6px; display: flex; flex-direction: column; gap: 3px;
}
.settings-wrap .tc-prev-primary   { font-size: 8px; color: var(--text-primary); }
.settings-wrap .tc-prev-secondary { font-size: 7px; color: var(--text-secondary); }
.settings-wrap .tc-prev-accent-btn {
  font-size: 8px; background: var(--accent); color: #fff;
  padding: 2px 5px; border-radius: 4px; text-align: center; align-self: flex-start;
}
.settings-wrap .tc-prev-input {
  height: 10px; background: var(--input-bg);
  border: 1px solid var(--input-border); border-radius: 3px;
}
.settings-wrap .tc-prev-taskbar {
  height: 20px; background: var(--taskbar-bg);
  display: flex; align-items: center; padding: 0 5px; gap: 4px; flex-shrink: 0;
}
.settings-wrap .tc-prev-launcher { font-size: 10px; color: var(--taskbar-text); }
.settings-wrap .tc-prev-te {
  font-size: 8px; color: var(--taskbar-text);
  background: rgba(128,128,128,.2); padding: 1px 4px; border-radius: 2px;
}

/* Buttons (reuse stock, size tweaks) */
.settings-btn-primary.small,
.settings-btn.small {
  padding: 4px 10px; font-size: 12px; height: 28px; display: inline-flex; align-items: center; gap: 4px;
}
.settings-btn-primary.small svg,
.settings-btn.small svg { width: 13px; height: 13px; }

/* ── Wallpaper Builder ─────────────────────────────────── */
.settings-wrap .wp-builder { display: flex; flex-direction: column; gap: 10px; }

/* ── Wallpaper builder ─────────────────────────────────── */

/* Preview row: thumbnail + remove button side by side */
.settings-wrap .wp-preview-row { display: flex; flex-direction: column; gap: 6px; }

/* Mini desktop preview */
.settings-wrap .wp-preview {
  width: 100%; height: 120px; border-radius: 10px;
  overflow: hidden; position: relative;
  border: 2px solid var(--border);
  background: var(--desktop-bg);
  background-size: cover; background-position: center;
  flex-shrink: 0;
  transition: background .4s;
}
.settings-wrap .wp-preview-icons {
  position: absolute; top: 12px; left: 12px;
  display: flex; flex-direction: column; gap: 6px;
}
.settings-wrap .wp-preview-icon {
  width: 30px; height: 30px; border-radius: 6px;
  background: rgba(255,255,255,.18); backdrop-filter: blur(4px);
}
.settings-wrap .wp-preview-taskbar {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 18px; background: rgba(0,0,0,.45); backdrop-filter: blur(4px);
}

/* Remove current wallpaper button */
.settings-wrap .wp-remove-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 6px;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-muted); font-size: 12px; cursor: pointer;
  align-self: flex-start;
  transition: color .12s, border-color .12s, background .12s;
}
.settings-wrap .wp-remove-btn:hover { color: var(--danger); border-color: var(--danger); background: rgba(237,78,78,.06); }
.settings-wrap .wp-remove-btn .wos-icon { width: 13px; height: 13px; }

/* Source type tabs */
.settings-wrap .wp-tabs {
  display: flex; gap: 2px;
  background: var(--bg-tertiary);
  border-radius: 10px; padding: 3px;
  margin-top: 2px;
}
.settings-wrap .wp-tab {
  flex: 1; padding: 7px 6px;
  border: none; border-radius: 8px;
  background: transparent;
  color: var(--text-muted); font-size: 12px; font-weight: 500;
  cursor: pointer; transition: background .15s, color .15s;
  white-space: nowrap;
}
.settings-wrap .wp-tab:hover:not(.active) { background: var(--hover); color: var(--text-primary); }
.settings-wrap .wp-tab.active {
  background: var(--bg-elevated); color: var(--text-primary);
  box-shadow: 0 1px 3px rgba(0,0,0,.18);
}

/* Tab panels */
.settings-wrap .wp-panel { padding-top: 10px; }
.settings-wrap .wp-panel.hidden { display: none !important; }

/* Panel hint text */
.settings-wrap .wp-panel-hint {
  font-size: 12px; color: var(--text-muted); margin: 0 0 10px;
  line-height: 1.4;
}

/* ── Presets panel ─────────────────────────── */
.settings-wrap .wp-presets {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 8px;
}
.settings-wrap .wp-preset {
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  background: none; border: 2px solid var(--border);
  border-radius: 9px; padding: 5px 5px 6px; cursor: pointer;
  transition: border-color .15s, transform .12s, box-shadow .15s;
}
.settings-wrap .wp-preset:hover  { border-color: var(--accent); transform: translateY(-2px); }
.settings-wrap .wp-preset.active { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.settings-wrap .wp-preset-swatch {
  width: 100%; aspect-ratio: 16/10; border-radius: 5px;
  border: 1px solid rgba(0,0,0,.1);
}
.settings-wrap .wp-preset span { font-size: 10px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }

/* ── Photo panel ─────────────────────────────── */
.settings-wrap .wp-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 8px;
}
.settings-wrap .wp-photo-btn {
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  padding: 14px 10px; border-radius: 10px;
  background: var(--bg-tertiary); border: 2px solid var(--border);
  color: var(--text-secondary); font-size: 12px; font-weight: 500;
  cursor: pointer; transition: border-color .15s, background .15s, transform .12s, color .15s;
}
.settings-wrap .wp-photo-btn:hover:not(:disabled) {
  border-color: var(--accent); background: var(--hover);
  color: var(--text-primary); transform: translateY(-2px);
}
.settings-wrap .wp-photo-btn:disabled { opacity: .5; cursor: wait; }
.settings-wrap .wp-photo-btn-icon { display: flex; }
.settings-wrap .wp-photo-btn-icon .wos-icon { width: 22px; height: 22px; }
.settings-wrap .wp-photo-status { font-size: 12px; padding: 8px 10px; border-radius: 7px; margin-top: 8px; }
.settings-wrap .wp-photo-status-info  { background: color-mix(in srgb, var(--accent) 12%, transparent); color: var(--accent); }
.settings-wrap .wp-photo-status-error { background: color-mix(in srgb, var(--danger) 12%, transparent); color: var(--danger); }

/* ── Gradient panel ──────────────────────────── */
.settings-wrap .wp-gradient-builder { display: flex; flex-direction: column; gap: 10px; }
.settings-wrap .wp-gradient-controls { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.settings-wrap .wp-grad-type-group { display: flex; border: 1px solid var(--border); border-radius: 7px; overflow: hidden; }
.settings-wrap .wp-type-btn {
  padding: 5px 16px; background: transparent; border: none;
  color: var(--text-muted); font-size: 12px; cursor: pointer;
  transition: background .12s, color .12s;
}
.settings-wrap .wp-type-btn:hover  { background: var(--bg-tertiary); }
.settings-wrap .wp-type-btn.active { background: var(--accent); color: #fff; }
.settings-wrap .wp-grad-angle-wrap {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text-secondary);
}
.settings-wrap .wp-grad-angle-wrap input[type=range] { width: 90px; }
.settings-wrap .wp-grad-angle-wrap span:last-child { min-width: 32px; font-size: 12px; color: var(--text-primary); }
.settings-wrap .wp-grad-bar-wrap { padding: 2px 0; }
.settings-wrap .wp-grad-bar {
  height: 40px; border-radius: 8px;
  border: 2px solid var(--border);
  cursor: pointer; transition: transform .12s, border-color .15s;
  position: relative;
}
.settings-wrap .wp-grad-bar:hover { transform: scaleY(1.05); border-color: var(--accent); }
.settings-wrap .wp-grad-bar::after {
  content: 'Click to apply'; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: rgba(255,255,255,.6); opacity: 0;
  transition: opacity .15s;
}
.settings-wrap .wp-grad-bar:hover::after { opacity: 1; }
.settings-wrap .wp-gradient-actions {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
}
/* Color stop rows */
.settings-wrap .wp-stop-row { display: flex; align-items: center; gap: 8px; padding: 3px 0; }
.settings-wrap .wp-stop-color {
  width: 34px; height: 28px; padding: 0 2px;
  border-radius: 5px; border: 2px solid var(--border);
  background: transparent; cursor: pointer; flex-shrink: 0;
}
.settings-wrap .wp-stop-pos { flex: 1; }
.settings-wrap .wp-stop-pos-val { min-width: 34px; font-size: 12px; color: var(--text-muted); text-align: right; }
.settings-wrap .wp-stop-remove {
  padding: 3px 8px; border-radius: 5px;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-muted); cursor: pointer; font-size: 11px;
  transition: color .1s, border-color .1s;
}
.settings-wrap .wp-stop-remove:hover:not(.disabled) { color: var(--danger); border-color: var(--danger); }
.settings-wrap .wp-stop-remove.disabled { opacity: .35; cursor: default; }

/* ── Upload panel ────────────────────────────── */
.settings-wrap .wp-upload-area {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; padding: 24px 16px;
  border: 2px dashed var(--border); border-radius: 12px;
  background: var(--bg-tertiary);
  cursor: pointer; transition: border-color .15s, background .15s;
}
.settings-wrap .wp-upload-area:hover { border-color: var(--accent); background: var(--hover); }
.settings-wrap .wp-upload-icon { color: var(--text-muted); }
.settings-wrap .wp-upload-icon .wos-icon { width: 32px; height: 32px; }
.settings-wrap .wp-upload-label { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.settings-wrap .wp-upload-hint  { font-size: 11px; color: var(--text-muted); margin-top: -2px; }
.settings-wrap .wp-img-hint     { font-size: 11px; color: var(--text-muted); }

.settings-btn {
  padding: 7px 16px; border-radius: 7px;
  background: var(--accent); border: none;
  color: #fff; font-size: 13px; cursor: pointer;
  transition: background .15s;
  display: inline-flex; align-items: center; gap: 5px;
}
.settings-btn:hover  { background: var(--accent-hover); }
.settings-btn.danger, .settings-btn-danger { background: #ed4e4e; border: none; color: #fff; }
.settings-btn.danger:hover, .settings-btn-danger:hover { background: #c0392b; }
.settings-btn.small  { padding: 3px 8px; font-size: 11px; }
.settings-btn.accent { background: var(--accent); color: #fff; }
.settings-btn.accent:hover { background: var(--accent-hover, var(--accent)); }
.settings-btn-primary { background: var(--accent); border: none; color: #fff; padding: 7px 16px; border-radius: 7px; cursor: pointer; font-size: 13px; display: inline-flex; align-items: center; gap: 5px; }
.settings-btn-primary:hover { background: var(--accent-hover); }
/* Within settings forms, add spacing between stacked buttons */
.settings-group .settings-btn,
.settings-group .settings-btn-primary { margin-top: 8px; }
.settings-input {
  padding: 7px 10px; border-radius: 7px; border: 1px solid var(--input-border);
  background: var(--input-bg); color: var(--text-primary); font-size: 13px;
  outline: none; width: 100%; box-sizing: border-box; font-family: inherit;
  transition: border-color .15s;
}
.settings-input::placeholder { color: var(--text-muted); }
.settings-input:focus { border-color: var(--accent); }
.settings-hint { font-size: 11px; color: var(--text-muted); margin: 2px 0 0; }
.settings-hint a { color: var(--accent); }

/* ── Settings toggle-row (used in Developer section) ─────── */
.settings-toggle-row {
  display: flex; align-items: flex-start; gap: 16px; justify-content: space-between;
}
.settings-toggle-info { flex: 1; min-width: 0; }
.settings-toggle-info strong { display: block; font-size: 13px; color: var(--text-primary); margin-bottom: 3px; }
.settings-toggle-info .settings-hint { margin: 0; }

/* ── Toggle switch (scoped to settings to avoid global leakage) ─ */
.settings-wrap .toggle-switch {
  position: relative; display: inline-block;
  width: 44px; height: 24px; flex-shrink: 0;
}
.settings-wrap .toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.settings-wrap .toggle-knob {
  position: absolute; inset: 0;
  background: var(--border); border-radius: 24px; cursor: pointer;
  transition: background .2s;
}
.settings-wrap .toggle-knob::before {
  content: ''; position: absolute;
  width: 18px; height: 18px; left: 3px; top: 3px;
  background: #fff; border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,.3);
  transition: transform .2s;
}
.settings-wrap .toggle-switch input:checked + .toggle-knob { background: var(--accent); }
.settings-wrap .toggle-switch input:checked + .toggle-knob::before { transform: translateX(20px); }
.settings-wrap .toggle-switch input:focus-visible + .toggle-knob { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ── Desktop icon color row ─────────────────────────────── */
.settings-wrap .ic-color-row {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 4px;
}
.settings-wrap .ic-color-swatches {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.settings-wrap .ic-swatch {
  width: 24px; height: 24px; border-radius: 50%; cursor: pointer;
  border: 2px solid transparent; flex-shrink: 0;
  transition: transform .12s, border-color .12s;
}
.settings-wrap .ic-swatch:hover  { transform: scale(1.18); }
.settings-wrap .ic-swatch.active { border-color: var(--accent); transform: scale(1.15); }
.settings-wrap .ic-custom-wrap {
  display: flex; align-items: center; gap: 5px; cursor: pointer;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 7px; padding: 3px 8px; font-size: 11px;
  color: var(--text-secondary); transition: border-color .15s;
}
.settings-wrap .ic-custom-wrap:hover { border-color: var(--accent); }
.settings-wrap .ic-custom-wrap input[type="color"] {
  width: 22px; height: 22px; border: none; background: none;
  cursor: pointer; padding: 0; border-radius: 3px; overflow: hidden;
}
.settings-wrap .ic-custom-lbl { white-space: nowrap; }

/* Users list */
.user-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  margin-bottom: 6px;
}
.ur-avatar { font-size: 22px; }
.ur-name   { flex: 1; font-size: 13px; color: var(--text-primary); }
.ur-name small { color: var(--text-muted); }
.ur-current{ color: var(--accent); font-size: 11px; }
.ur-admin  { font-size: 10px; padding: 2px 7px; border-radius: 10px; background: rgba(82,148,226,.2); color: var(--accent); }
.ur-cap-badge { font-size: 10px; padding: 2px 7px; border-radius: 10px; }
.ur-cap-badge.upload { background: rgba(76,175,80,.2); color: #81c784; }
.ur-usage-lbl { display: block; margin-top: 2px; }
/* Highlight capability buttons when the capability is active */
.settings-btn.active-cap { background: rgba(76,175,80,.2) !important; border-color: #4caf5060 !important; color: #81c784 !important; }

/* Terminal style settings panel */
.term-style-grid  { display: flex; flex-direction: column; gap: 10px; }
.term-style-row   { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.term-style-lbl   { font-size: 12px; color: var(--text-muted); min-width: 90px; }
.term-scheme-swatches { display: flex; gap: 6px; flex-wrap: wrap; }
.term-scheme-swatch {
  width: 30px; height: 26px; border-radius: 5px; cursor: pointer;
  border: 2px solid transparent; transition: transform .1s, border-color .15s;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
}
.term-scheme-swatch:hover  { transform: scale(1.15); }
.term-scheme-swatch.active { outline: 2px solid var(--accent); outline-offset: 2px; }

/* Storage quota usage bar */
.storage-usage-card {
  width: 100%; margin-top: 8px; padding: 12px 14px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; box-sizing: border-box;
}
.storage-usage-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 12px; color: var(--text-secondary); margin-bottom: 8px;
}
.storage-usage-text { font-weight: 500; color: var(--text-primary); }
.storage-bar-track {
  height: 8px; border-radius: 4px;
  background: var(--bg-tertiary, rgba(255,255,255,.08));
  overflow: hidden;
}
.storage-bar-fill {
  height: 100%; border-radius: 4px;
  background: var(--accent, #5294e2);
  transition: width .4s ease;
}
.storage-bar-fill.warning  { background: #f0a500; }
.storage-bar-fill.critical { background: #e05050; }
.storage-usage-sub {
  margin-top: 6px; font-size: 11px; color: var(--text-muted);
}

/* About */
.about-info {
  display: flex; flex-direction: column; align-items: flex-start; gap: 12px;
}
.about-logo { font-size: 48px; }
.about-info h3 { font-size: 20px; font-weight: 400; color: var(--text-primary); }
.about-info p  { color: var(--text-secondary); font-size: 13px; }
.about-table { border-collapse: collapse; font-size: 12px; }
.about-table td { padding: 5px 12px 5px 0; color: var(--text-secondary); vertical-align: top; }
.about-table td:first-child { color: var(--text-muted); font-weight: 500; min-width: 100px; }

/* ── Share Manager ──────────────────────────────────────────── */
/* ══════════════════════════════════════════════════════════
   ADMINISTRATION PORTAL
   ══════════════════════════════════════════════════════════ */
.ap-wrap { height: 100%; display: flex; flex-direction: column; overflow: hidden; position: relative; }

/* Header banner */
.ap-header {
  flex-shrink: 0;
  background: linear-gradient(125deg, #1a1f2e 0%, #1e3a5f 60%, #2a3550 100%);
  padding: 14px 20px;
  display: flex; align-items: center; gap: 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ap-header-icon { font-size: 30px; filter: drop-shadow(0 2px 6px rgba(82,148,226,.5)); }
.ap-header-info { flex: 1; }
.ap-header-title { font-size: 15px; font-weight: 700; color: #fff; line-height: 1.2; }
.ap-header-sub   { font-size: 11px; color: rgba(255,255,255,.45); margin-top: 2px; }
.ap-header-stats { display: flex; gap: 10px; flex-shrink: 0; }
.ap-hstat {
  text-align: center; min-width: 52px;
  background: rgba(255,255,255,.07); border-radius: 8px;
  padding: 6px 10px; border: 1px solid rgba(255,255,255,.08);
}
.ap-hstat-val { font-size: 17px; font-weight: 700; color: #5294e2; line-height: 1; }
.ap-hstat-lbl { font-size: 9px; color: rgba(255,255,255,.4); text-transform: uppercase; margin-top: 3px; letter-spacing: .5px; }

/* Body */
.ap-body    { flex: 1; display: flex; overflow: hidden; min-height: 0; }
.ap-content { flex: 1; overflow-y: auto; min-width: 0; }
.ap-section { padding: 20px 24px; }

/* Sidebar */
.ap-sidebar {
  width: 176px; flex-shrink: 0;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  overflow-y: auto; padding: 8px 0;
}
.ap-nav-group-label {
  font-size: 9.5px; font-weight: 700; text-transform: uppercase;
  color: var(--text-muted); padding: 14px 14px 4px;
  letter-spacing: .8px;
}
.ap-nav-item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 14px; cursor: pointer;
  font-size: 13px; color: var(--text-primary);
  border-radius: 7px; margin: 1px 6px;
  transition: background .12s, color .12s;
}
.ap-nav-item:hover  { background: rgba(82,148,226,.15); }
.ap-nav-item.active { background: rgba(82,148,226,.22); color: var(--accent); font-weight: 600; }
.ap-nav-icon   { font-size: 15px; min-width: 20px; text-align: center; }
.ap-nav-badge  {
  margin-left: auto; background: var(--accent); color: #fff;
  border-radius: 10px; padding: 1px 7px;
  font-size: 10px; font-weight: 700;
}

/* Section header */
.ap-section-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
}
.ap-section-title { font-size: 18px; font-weight: 700; color: var(--text-primary); margin: 0; }
.ap-section-desc  { font-size: 13px; color: var(--text-secondary); margin: -10px 0 18px; }
.ap-empty         { color: var(--text-muted); padding: 32px; text-align: center; font-size: 13px; }

/* Overview stat cards */
.ap-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px; margin-bottom: 24px;
}
.ap-stat-card {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px; border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--bg-secondary);
  cursor: pointer; transition: transform .12s, box-shadow .12s;
}
.ap-stat-card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.2); }
.ap-stat-icon { font-size: 30px; }
.ap-stat-val  { font-size: 24px; font-weight: 800; line-height: 1; }
.ap-stat-lbl  { font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-top: 2px; }
.ap-stat-sub  { font-size: 11px; color: var(--text-muted); margin-top: 3px; }
.ap-stat-accent { border-color: rgba(82,148,226,.35); }
.ap-stat-accent .ap-stat-val { color: #5294e2; }
.ap-stat-green  { border-color: rgba(80,250,123,.25); }
.ap-stat-green  .ap-stat-val { color: #50fa7b; }
.ap-stat-orange { border-color: rgba(255,184,108,.25); }
.ap-stat-orange .ap-stat-val { color: #ffb86c; }
.ap-stat-purple { border-color: rgba(189,147,249,.25); }
.ap-stat-purple .ap-stat-val { color: #bd93f9; }

/* Overview panels */
.ap-overview-panels { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .ap-overview-panels { grid-template-columns: 1fr; } }
.ap-panel {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden;
}
.ap-panel-title {
  padding: 11px 16px; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .6px;
  color: var(--text-muted); border-bottom: 1px solid var(--border);
  background: var(--bg-tertiary);
}
.ap-panel-body    { padding: 8px 0; }
.ap-panel-empty   { padding: 20px; text-align: center; color: var(--text-muted); font-size: 13px; }
.ap-panel-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px; transition: background .1s;
}
.ap-panel-row:hover { background: var(--bg-tertiary); }
.ap-panel-avatar { font-size: 22px; flex-shrink: 0; }
.ap-panel-info   { flex: 1; min-width: 0; }
.ap-panel-name   { font-size: 13px; font-weight: 600; color: var(--text-primary); display: block; }
.ap-panel-uname  { font-size: 11px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* User row: inline storage bar */
.ur-avatar-wrap { flex-shrink: 0; display: flex; align-items: center; }
.ur-avatar-img  { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
.ap-ur-storage  { display: flex; align-items: center; gap: 8px; margin-top: 4px; }
.ap-ur-storage-bar-track {
  flex: 1; height: 4px; border-radius: 2px;
  background: var(--bg-tertiary); max-width: 120px;
}
.ap-ur-storage-bar-fill {
  height: 100%; border-radius: 2px; background: var(--accent);
  transition: width .3s;
}
.ap-ur-storage-bar-fill.warning  { background: #f0a500; }
.ap-ur-storage-bar-fill.critical { background: #e05050; }
.ap-ur-storage-lbl { font-size: 11px; color: var(--text-muted); }

.sm-wrap {
  display: flex; height: 100%; overflow: hidden;
}
.sm-sidebar {
  width: 160px; flex-shrink: 0;
  border-right: 1px solid var(--border);
  padding: 8px 0;
  overflow-y: auto;
}
.sm-nav-item {
  padding: 9px 16px; font-size: 13px; cursor: pointer;
  color: var(--text-secondary); border-radius: 0;
  transition: background .12s, color .12s;
}
.sm-nav-item:hover  { background: rgba(255,255,255,.05); color: var(--text-primary); }
.sm-nav-item.active { background: var(--accent)20; color: var(--accent); font-weight: 600; }

.sm-content {
  flex: 1; overflow-y: auto; padding: 0;
}
.sm-section { padding: 16px 20px 24px; }
.sm-section.hidden { display: none; }

.sm-header-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
}
.sm-header-row h2 { margin: 0; font-size: 16px; font-weight: 600; }

.sm-empty {
  color: var(--text-muted); font-size: 13px; padding: 24px 0; text-align: center;
}

/* Share cards */
/* ── Shares keep old style ── */
.sm-share-list { display: flex; flex-direction: column; gap: 14px; }
.sm-share-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden;
}

/* ── Groups: identity/role cards ── */
.grp-list { display: flex; flex-direction: column; gap: 16px; }
.grp-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 12px; overflow: hidden;
}

/* Identity header */
.grp-card-head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, transparent 100%);
  border-bottom: 1px solid var(--border);
  border-left: 4px solid var(--grp-color, #5294e2);
  position: relative;
}
.grp-color-dot {
  width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(255,255,255,.1);
  transition: transform .15s, box-shadow .15s;
}
.grp-color-dot:hover { transform: scale(1.2); box-shadow: 0 0 0 4px rgba(255,255,255,.2); }
.grp-id-info { flex: 1; min-width: 0; }
.grp-name { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.grp-desc { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.grp-head-actions { display: flex; gap: 6px; flex-shrink: 0; }

/* Color picker popup */
.grp-color-popup {
  position: absolute; top: 48px; left: 14px; z-index: 200;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 10px; padding: 8px;
  display: flex; gap: 6px; flex-wrap: wrap; max-width: 220px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.grp-clr-swatch {
  width: 22px; height: 22px; border-radius: 50%; border: 2px solid transparent;
  cursor: pointer; transition: transform .12s, border-color .12s;
}
.grp-clr-swatch:hover { transform: scale(1.2); }
.grp-clr-swatch.active { border-color: #fff; transform: scale(1.15); }

/* Capabilities + quota row */
.grp-caps-row {
  display: flex; gap: 0; border-bottom: 1px solid var(--border);
}
.grp-caps-section,
.grp-quota-section {
  flex: 1; padding: 10px 16px;
}
.grp-caps-section { border-right: 1px solid var(--border); }
.grp-section-lbl {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  color: var(--text-muted); letter-spacing: .6px; margin-bottom: 6px;
  display: flex; align-items: center; gap: 6px;
}
.grp-member-count {
  background: var(--bg-tertiary); color: var(--text-muted);
  font-size: 10px; padding: 1px 6px; border-radius: 8px;
  font-weight: 600;
}
.grp-caps-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.grp-cap-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: 20px; font-size: 12px; cursor: pointer;
  border: 1px solid var(--border); background: var(--bg-tertiary);
  color: var(--text-secondary); transition: all .15s;
}
.grp-cap-pill:hover { border-color: var(--accent); }
.grp-cap-pill.on  { background: rgba(76,175,80,.15); border-color: rgba(76,175,80,.5); color: #81c784; }
.grp-cap-pill.off { opacity: .7; }
.grp-cap-state { font-size: 11px; font-weight: 700; }

.grp-quota-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: 20px; font-size: 12px; cursor: pointer;
  border: 1px solid var(--border); background: var(--bg-tertiary);
  color: var(--text-secondary); transition: all .15s;
}
.grp-quota-btn:hover { border-color: var(--accent); }

/* Members section */
.grp-members-section {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
}
.grp-member-list { margin-top: 4px; }
.grp-add-row { padding: 6px 0 2px; border-top: 1px solid rgba(255,255,255,.05); margin-top: 4px; }

/* Shared access section */
.grp-access-section {
  padding: 10px 16px 12px;
  background: rgba(255,255,255,.01);
}
.grp-access-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.grp-access-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12px; color: var(--text-secondary);
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 9px;
}
.grp-access-badge {
  font-size: 10px; padding: 1px 5px; border-radius: 8px; font-weight: 700;
}
.grp-access-badge.ro { background: rgba(82,148,226,.2); color: #7ab2f0; }
.grp-access-badge.rw { background: rgba(76,175,80,.2);  color: #81c784; }
.grp-access-none { font-size: 12px; color: var(--text-muted); font-style: italic; }

/* Group badges on user rows */
.ur-group-badges { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; }
.ur-group-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; padding: 2px 7px; border-radius: 10px;
  border: 1px solid; color: var(--grp-color, #5294e2);
  background: rgba(0,0,0,.15);
  white-space: nowrap;
}
.ur-group-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

/* section subtitle */
.ap-section-sub {
  font-size: 12px; color: var(--text-muted); margin: 2px 0 0;
  max-width: 540px; line-height: 1.5;
}
.sm-share-head {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.02);
}
.sm-share-icon { font-size: 22px; flex-shrink: 0; }
.sm-share-info { flex: 1; min-width: 0; }
.sm-share-name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.sm-share-path { font-size: 11px; color: var(--accent); font-family: var(--font-mono); }
.sm-share-desc { font-size: 12px; color: var(--text-muted); margin-top: 2px; }

/* Permissions */
.sm-perm-list { padding: 8px 14px; }
.sm-perm-empty { font-size: 12px; color: var(--text-muted); padding: 6px 0; }
.sm-perm-row {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 0; border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: 13px;
}
.sm-perm-row:last-child { border-bottom: none; }
.sm-perm-subject { flex: 1; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.sm-access-badge {
  font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 600; white-space: nowrap;
}
.sm-access-badge.ro { background: rgba(82,148,226,.2); color: #7ab2f0; }
.sm-access-badge.rw { background: rgba(76,175,80,.2);  color: #81c784; }

.sm-perm-toggle {
  font-size: 11px; padding: 2px 8px; border-radius: 6px;
  background: rgba(255,255,255,.06); border: 1px solid var(--border);
  color: var(--text-secondary); cursor: pointer; white-space: nowrap;
  transition: background .12s;
}
.sm-perm-toggle:hover { background: rgba(255,255,255,.12); }

.sm-perm-remove {
  background: none; border: none; color: var(--text-muted); cursor: pointer;
  font-size: 13px; padding: 2px 5px; border-radius: 4px;
  transition: color .12s, background .12s;
}
.sm-perm-remove:hover { color: var(--danger); background: rgba(237,78,78,.1); }

/* Add permission row */
.sm-add-perm-row {
  display: flex; gap: 8px; align-items: center;
  padding: 10px 14px; border-top: 1px solid var(--border);
  background: rgba(255,255,255,.01);
}
.sm-subject-sel, .sm-access-sel {
  padding: 5px 8px; border-radius: 6px;
  background: var(--input-bg); border: 1px solid var(--input-border);
  color: var(--text-primary); font-size: 12px; outline: none;
}
.sm-subject-sel { flex: 1; min-width: 0; }

/* Group members */
.sm-member-list { padding: 6px 14px 8px; }
.sm-member-row {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 0; font-size: 13px;
}
.sm-member-avatar { font-size: 18px; }
.sm-member-name { flex: 1; color: var(--text-primary); }
.sm-member-uname { font-size: 11px; color: var(--text-muted); }
.sm-remove-member {
  background: none; border: none; color: var(--text-muted); cursor: pointer;
  font-size: 12px; padding: 2px 5px; border-radius: 4px;
  transition: color .12s;
}
.sm-remove-member:hover { color: var(--danger); }


/* ══════════════════════════════════════════════════════════
   Custom Dialog (replaces browser prompt/confirm/alert)
   ══════════════════════════════════════════════════════════ */
.dlg-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
  animation: dlg-fade-in .12s ease;
}
@keyframes dlg-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.dlg-box {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 20px 60px rgba(0,0,0,.7);
  width: 380px; max-width: 92vw;
  overflow: hidden;
  animation: dlg-slide-in .14s ease;
}
@keyframes dlg-slide-in {
  from { transform: scale(.94) translateY(-8px); opacity: 0; }
  to   { transform: scale(1)   translateY(0);    opacity: 1; }
}
.dlg-header {
  display: flex; align-items: center; gap: 10px;
  background: var(--titlebar-bg);
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
}
.dlg-icon  { font-size: 18px; line-height: 1; }
.dlg-title { font-size: 13px; font-weight: 600; color: var(--titlebar-text); }
.dlg-body  { padding: 18px 16px 12px; display: flex; flex-direction: column; gap: 12px; }
.dlg-body-html { display: block; max-height: 70vh; overflow-y: auto; }
.dlg-message {
  font-size: 13px; color: var(--text-primary); line-height: 1.5;
  white-space: pre-wrap; word-break: break-word;
}
.dlg-input {
  width: 100%; background: var(--bg-tertiary);
  border: 1px solid var(--border); border-radius: 5px;
  padding: 7px 10px; font-size: 13px; color: var(--text-primary);
  outline: none; font-family: inherit;
}
.dlg-input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(82,148,226,.2); }
.dlg-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 10px 16px 14px;
  background: var(--bg-primary);
  border-top: 1px solid var(--border);
}
.dlg-btn {
  padding: 7px 20px; border-radius: 5px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-primary);
  font-size: 12px; font-weight: 500; cursor: pointer;
  transition: background .12s, box-shadow .12s;
}
.dlg-btn:hover    { background: var(--bg-elevated); }
.dlg-btn:focus    { outline: none; box-shadow: 0 0 0 2px rgba(82,148,226,.35); }
.dlg-primary      { background: var(--accent); border-color: var(--accent); color: #fff; }
.dlg-primary:hover{ background: var(--accent-hover); }
.dlg-danger       { background: #c0392b; border-color: #c0392b; color: #fff; }
.dlg-danger:hover { background: #e74c3c; }

/* ══════════════════════════════════════════════════════════
   File Picker Modal
   ══════════════════════════════════════════════════════════ */
.fp-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(3px);
}
.fp-dialog {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 24px 64px rgba(0,0,0,.7);
  display: flex; flex-direction: column;
  width: 720px; height: 480px;
  max-width: 96vw; max-height: 90vh;
  overflow: hidden;
}
.fp-header {
  display: flex; align-items: center;
  background: var(--titlebar-bg);
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  gap: 8px;
}
.fp-title  { flex: 1; font-size: 13px; font-weight: 600; color: var(--titlebar-text); }
.fp-close  { background: var(--btn-close); border: none; border-radius: 50%; width: 16px; height: 16px; cursor: pointer; font-size: 10px; color: transparent; transition: color .15s; }
.fp-close:hover { color: #fff; }

.fp-body {
  display: flex; flex: 1; overflow: hidden;
}
.fp-sidebar {
  width: 180px; min-width: 160px;
  background: var(--bg-primary);
  border-right: 1px solid var(--border);
  overflow-y: auto; padding: 8px 0;
  display: flex; flex-direction: column;
}
.fp-section-label {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  color: var(--text-muted); padding: 8px 12px 4px; letter-spacing: .06em;
}
.fp-place {
  padding: 6px 12px; font-size: 12px; cursor: pointer;
  color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  border-radius: 4px; margin: 1px 6px; transition: background .12s, color .12s;
}
.fp-place:hover { background: var(--bg-tertiary); color: var(--text-primary); }

.fp-recent-list {
  display: flex; flex-direction: column; gap: 1px; padding: 0 6px;
}
.fp-recent-item {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 6px; border-radius: 4px; cursor: pointer;
  font-size: 11px; color: var(--text-secondary);
  white-space: nowrap; overflow: hidden;
  transition: background .12s, color .12s;
}
.fp-recent-item:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.fp-recent-icon { font-size: 13px; flex-shrink: 0; }
.fp-recent-name { overflow: hidden; text-overflow: ellipsis; }
.fp-recent-empty { font-size: 11px; color: var(--text-muted); padding: 4px 6px; }

.fp-main {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
}
.fp-path-row {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-primary);
}
.fp-up-btn {
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 4px; padding: 4px 8px; cursor: pointer;
  color: var(--text-primary); font-size: 11px;
}
.fp-up-btn:hover { background: var(--bg-elevated); }
.fp-breadcrumb {
  flex: 1; display: flex; align-items: center; flex-wrap: wrap; gap: 2px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 4px; padding: 4px 8px; font-size: 12px; min-height: 28px;
  color: var(--text-primary); overflow: hidden;
}
.fp-bc-seg {
  cursor: pointer; color: var(--accent); border-radius: 3px; padding: 0 2px;
  white-space: nowrap; max-width: 120px; overflow: hidden; text-overflow: ellipsis;
}
.fp-bc-seg:hover { text-decoration: underline; }
.fp-bc-cur { cursor: default; color: var(--text-primary); font-weight: 600; }
.fp-bc-cur:hover { text-decoration: none; }
.fp-bc-sep { color: var(--text-muted); font-size: 10px; margin: 0 1px; }
.fp-newfolder-btn {
  flex-shrink: 0; background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 4px; padding: 4px 8px; cursor: pointer;
  color: var(--text-secondary); font-size: 11px; white-space: nowrap;
}
.fp-newfolder-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }

.fp-files {
  flex: 1; overflow-y: auto; padding: 8px;
  display: flex; flex-wrap: wrap; align-content: flex-start; gap: 4px;
}
.fp-empty { font-size: 12px; color: var(--text-muted); padding: 16px; width: 100%; text-align: center; }

.fp-item {
  display: flex; flex-direction: column; align-items: center;
  width: 80px; padding: 8px 4px; border-radius: 6px; cursor: pointer;
  transition: background .12s; border: 1px solid transparent;
  gap: 4px;
}
.fp-item:hover   { background: var(--bg-tertiary); }
.fp-item.selected{ background: rgba(82,148,226,.22); border-color: var(--accent); }
.fp-item.fp-dir  { opacity: .95; }
.fp-item.fp-dir:hover { background: rgba(82,148,226,.12); }
.fp-item.fp-dir .fp-item-name { color: var(--accent); font-weight: 500; }
.fp-item-icon { font-size: 22px; line-height: 1; }
.fp-item-name {
  font-size: 11px; color: var(--text-primary); text-align: center;
  word-break: break-all; display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden; line-height: 1.3;
}

.fp-footer {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: var(--bg-primary);
  border-top: 1px solid var(--border);
}
.fp-sel-display {
  flex: 1; font-size: 11px; color: var(--text-secondary);
  font-family: var(--font-mono); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.fp-filename {
  flex: 1; background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 4px; padding: 5px 8px; font-size: 12px; color: var(--text-primary); outline: none;
}
.fp-filename:focus { border-color: var(--accent); }
.fp-footer-btns { display: flex; gap: 8px; }
.fp-btn {
  padding: 6px 16px; border-radius: 5px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-primary);
  font-size: 12px; cursor: pointer; transition: background .12s;
}
.fp-btn:hover        { background: var(--bg-elevated); }
.fp-btn-primary      { background: var(--accent); border-color: var(--accent); color: #fff; }
.fp-btn-primary:hover{ background: var(--accent-hover); }

/* ══════════════════════════════════════════════════════════
   Files app — sidebar labels + Recent section
   ══════════════════════════════════════════════════════════ */
.fm-sidebar-label {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  color: var(--text-muted); padding: 8px 12px 2px; letter-spacing: .06em;
}
.fm-sidebar-recent-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-right: 6px;
}
.fm-sidebar-recent-head .fm-sidebar-label { flex: 1; padding-right: 0; }
.fm-recent-clear {
  background: none; border: none; color: var(--text-muted);
  font-size: 11px; line-height: 1; cursor: pointer;
  width: 20px; height: 20px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s; flex-shrink: 0;
}
.fm-recent-clear:hover { background: rgba(255,255,255,.08); color: var(--text-primary); }
.fm-recent-clear.hidden { display: none; }
.fm-recents { display: flex; flex-direction: column; }
.fm-recent-empty {
  font-size: 11px; color: var(--text-muted); padding: 4px 12px;
}
.fm-recent-item {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px; border-radius: 4px; cursor: pointer; font-size: 11px;
  color: var(--text-secondary); white-space: nowrap; overflow: hidden;
  transition: background .12s, color .12s; margin: 1px 4px;
}
.fm-recent-item:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.fm-recent-item-icon { font-size: 13px; flex-shrink: 0; }
.fm-recent-item-name { overflow: hidden; text-overflow: ellipsis; }

/* ═══════════════════════════════════════════════════════════
   Journal App
   ═══════════════════════════════════════════════════════════ */
.jn-root {
  display: flex; height: 100%; overflow: hidden;
  font-size: 13px; color: var(--text-primary);
  background: var(--bg-primary);
}

/* ── Sidebar ── */
.jn-sidebar {
  width: 230px; min-width: 180px; max-width: 300px;
  display: flex; flex-direction: column;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  flex-shrink: 0;
}

.jn-sidebar-top {
  padding: 10px 8px 6px; border-bottom: 1px solid var(--border);
}

.jn-search {
  width: 100%; padding: 5px 9px; border-radius: 6px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 12px;
  outline: none; box-sizing: border-box;
  transition: border-color .15s;
}
.jn-search:focus { border-color: var(--accent); }
.jn-search::placeholder { color: var(--text-muted); }

/* Tag bar */
.jn-tag-bar {
  display: flex; flex-wrap: wrap; gap: 4px;
  padding: 6px 8px; border-bottom: 1px solid var(--border);
  min-height: 30px;
}
.jn-no-tags { font-size: 11px; color: var(--text-muted); padding: 1px 2px; }

/* Tag chips */
.jn-tag-chip {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 7px 1px 8px; border-radius: 20px;
  font-size: 11px; font-weight: 500; cursor: pointer;
  background: color-mix(in srgb, var(--tc, #888) 18%, transparent);
  color: var(--tc, #888);
  border: 1px solid color-mix(in srgb, var(--tc, #888) 40%, transparent);
  transition: background .12s, opacity .12s;
  user-select: none;
}
.jn-tag-chip:hover  { background: color-mix(in srgb, var(--tc, #888) 28%, transparent); }
.jn-chip-active     { background: color-mix(in srgb, var(--tc, #888) 35%, transparent) !important; }

.jn-tag-rm {
  background: none; border: none; color: inherit; cursor: pointer;
  font-size: 13px; line-height: 1; padding: 0 0 0 2px; opacity: .7;
}
.jn-tag-rm:hover { opacity: 1; }

/* Entry tags (in editor header) */
.jn-etag { font-size: 11px; }

/* Tree */
.jn-tree {
  flex: 1; overflow-y: auto; padding: 4px 0;
  outline: none;
}
.jn-tree:empty::after {
  content: 'No entries yet'; display: block;
  padding: 16px 14px; color: var(--text-muted); font-size: 12px;
}

.jn-tree-item {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 8px 4px 6px; border-radius: 5px; margin: 1px 4px;
  cursor: pointer; user-select: none; white-space: nowrap;
  transition: background .1s, color .1s;
}
.jn-tree-item:hover   { background: var(--bg-tertiary); }
.jn-tree-item.active  { background: var(--accent); color: #fff; }

.jn-arrow {
  width: 14px; font-size: 10px; color: var(--text-muted);
  flex-shrink: 0; text-align: center;
  transition: transform .1s;
}
.jn-tree-item.active .jn-arrow { color: rgba(255,255,255,.7); }
.jn-item-icon  { font-size: 14px; flex-shrink: 0; }
.jn-item-label { flex: 1; overflow: hidden; text-overflow: ellipsis; font-size: 12.5px; }

/* Subtree indentation */
.jn-subtree { padding-left: 14px; }

/* Tag dots on tree items */
.jn-tdots { display: flex; gap: 3px; align-items: center; }
.jn-tdot  { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }

/* Sidebar footer */
.jn-sidebar-foot {
  display: flex; gap: 6px; padding: 8px;
  border-top: 1px solid var(--border);
}
.jn-foot-btn {
  flex: 1; padding: 5px 0; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-secondary);
  cursor: pointer; transition: background .12s, color .12s;
  display: flex; align-items: center; justify-content: center; gap: 3px;
}
.jn-foot-btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.jn-foot-plus { font-size: 14px; font-weight: 700; line-height: 1; margin-top: -1px; }

/* ── Main ── */
.jn-main {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
  background: var(--bg-primary);
}

/* Empty state */
.jn-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  color: var(--text-muted);
}
.jn-empty-icon  { font-size: 48px; opacity: .5; }
.jn-empty-label { font-size: 13px; }

/* Editor wrapper */
.jn-editor-wrap {
  flex: 1; display: flex; flex-direction: column; min-height: 0;
}

/* Editor header */
.jn-editor-head {
  padding: 10px 14px 8px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-secondary);
  flex-shrink: 0;
}

.jn-title-input {
  width: 100%; padding: 4px 0; font-size: 18px; font-weight: 600;
  background: transparent; border: none; outline: none;
  color: var(--text-primary); box-sizing: border-box;
  border-bottom: 2px solid transparent; transition: border-color .15s;
}
.jn-title-input:focus { border-bottom-color: var(--accent); }
.jn-title-input::placeholder { color: var(--text-muted); font-weight: 400; }

.jn-head-row2 {
  display: flex; align-items: center; gap: 8px; margin-top: 6px;
  flex-wrap: wrap;
}

.jn-entry-tags { display: flex; flex-wrap: wrap; gap: 4px; flex: 1; }

.jn-editor-actions {
  display: flex; gap: 6px; flex-shrink: 0;
}

.jn-btn {
  padding: 4px 11px; border-radius: 6px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-secondary);
  font-size: 12px; cursor: pointer; transition: background .12s, color .12s;
  white-space: nowrap;
}
.jn-btn:hover { background: var(--bg-hover, var(--bg-tertiary)); color: var(--text-primary); }
.jn-save-btn  { background: var(--accent); color: #fff; border-color: var(--accent); }
.jn-save-btn:hover { opacity: .88; }

/* ── Markdown Toolbar (shared by Journal + Editor) ── */
.mdt-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1px;
  padding: 3px 8px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  min-height: 32px;
}
.mdt-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 24px;
  padding: 0 5px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: 4px;
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
  transition: background .1s, color .1s;
  line-height: 1;
  white-space: nowrap;
}
.mdt-btn:hover { background: var(--hover); color: var(--text); }
.mdt-btn:active { background: color-mix(in srgb, var(--accent) 20%, var(--hover)); }
/* Style specific buttons */
.mdt-btn[data-fmt="h1"] { font-weight: 800; font-size: 11px; }
.mdt-btn[data-fmt="h2"] { font-weight: 700; font-size: 11px; }
.mdt-btn[data-fmt="h3"] { font-weight: 600; font-size: 11px; }
.mdt-btn[data-fmt="bold"]   { font-weight: 800; }
.mdt-btn[data-fmt="italic"] { font-style: italic; font-weight: 600; }
.mdt-btn[data-fmt="strike"] { text-decoration: line-through; }
.mdt-btn[data-fmt="code"],
.mdt-btn[data-fmt="codeblock"] { font-family: monospace; font-size: 11px; }
.mdt-sep {
  width: 1px;
  height: 16px;
  background: var(--border);
  margin: 0 3px;
  flex-shrink: 0;
}

/* Journal markdown toolbar wrapper */
.jn-md-toolbar-wrap { flex-shrink: 0; }
.jn-md-toolbar-wrap .mdt-bar { border-top: 1px solid var(--border); }

/* ── Content area — split pane modes ── */
.jn-content-area {
  flex: 1; min-height: 0; display: flex; position: relative;
}

/* Split: textarea left, preview right */
.jn-mode-split .jn-editor-side,
.jn-mode-split .jn-preview-side {
  flex: 1; min-width: 0; display: flex; flex-direction: column;
}
.jn-mode-split .jn-editor-side {
  border-right: 1px solid var(--border);
}
/* Edit-only */
.jn-mode-edit .jn-editor-side  { flex: 1; min-width: 0; }
.jn-mode-edit .jn-preview-side { display: none; }
/* Preview-only */
.jn-mode-preview .jn-editor-side  { display: none; }
.jn-mode-preview .jn-preview-side { flex: 1; min-width: 0; }

/* Ensure textarea fills its side */
.jn-editor-side .jn-textarea {
  flex: 1; min-height: 0; resize: none; border: none; outline: none;
}
.jn-preview-side { overflow: hidden; }
.jn-preview-side .jn-preview { height: 100%; }

.jn-textarea {
  flex: 1; resize: none; border: none; outline: none;
  padding: 16px 20px; font-size: 13.5px; line-height: 1.65;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  background: var(--bg-primary); color: var(--text-primary);
  box-sizing: border-box; width: 100%;
}
.jn-textarea::placeholder { color: var(--text-muted); }

.jn-preview {
  flex: 1; overflow-y: auto; padding: 20px 28px;
  background: var(--bg-primary); color: var(--text-primary);
  font-size: 14px; line-height: 1.7;
  box-sizing: border-box; width: 100%;
}

/* ── Shared Markdown preview typography (.md-preview) ──
   Applied to: .jn-preview, .ed-md-preview, and DevIDE preview
   ─────────────────────────────────────────────────────── */
.md-preview h1, .md-preview h2, .md-preview h3,
.md-preview h4, .md-preview h5, .md-preview h6 {
  color: var(--text-primary); margin: 1.1em 0 .4em;
  font-weight: 600; line-height: 1.3;
}
.md-preview h1 { font-size: 1.6em; border-bottom: 1px solid var(--border); padding-bottom: .3em; }
.md-preview h2 { font-size: 1.3em; border-bottom: 1px solid var(--border); padding-bottom: .2em; }
.md-preview h3 { font-size: 1.1em; }
.md-preview p  { margin: .5em 0; }
.md-preview a  { color: var(--accent); text-decoration: none; }
.md-preview a:hover { text-decoration: underline; }
.md-preview blockquote {
  border-left: 3px solid var(--accent); margin: .8em 0;
  padding: .4em .8em; background: var(--bg-secondary); border-radius: 0 4px 4px 0;
  color: var(--text-secondary); font-style: italic;
}
.md-preview code {
  background: var(--bg-tertiary); color: var(--accent);
  padding: 1px 5px; border-radius: 4px; font-size: .9em;
  font-family: var(--font-mono, monospace);
}
.md-preview pre {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; overflow-x: auto; padding: 12px 16px; margin: .8em 0;
}
.md-preview pre code { background: none; color: inherit; padding: 0; font-size: 12.5px; }
.md-preview table { border-collapse: collapse; width: 100%; margin: .8em 0; font-size: 13px; }
.md-preview th, .md-preview td {
  border: 1px solid var(--border); padding: 6px 12px; text-align: left;
}
.md-preview th { background: var(--bg-secondary); font-weight: 600; }
.md-preview tr:nth-child(even) td { background: color-mix(in srgb, var(--bg-secondary) 40%, transparent); }
.md-preview ul, .md-preview ol { padding-left: 1.5em; margin: .5em 0; }
.md-preview li { margin: .2em 0; }
.md-preview li input[type=checkbox] { margin-right: 5px; accent-color: var(--accent); }
.md-preview hr { border: none; border-top: 1px solid var(--border); margin: 1.2em 0; }
.md-preview img { max-width: 100%; border-radius: 6px; }
.md-preview strong { font-weight: 700; }
.md-preview em     { font-style: italic; }
.md-preview del    { text-decoration: line-through; opacity: .7; }

/* Keep legacy .jn-preview selectors working via the shared class */
.jn-preview { /* inherits from .md-preview */ }

/* Status bar */
.jn-statusbar {
  display: flex; align-items: center; gap: 10px;
  padding: 4px 14px; border-top: 1px solid var(--border);
  font-size: 11px; color: var(--text-muted);
  background: var(--bg-secondary); flex-shrink: 0;
}
.jn-stat-spacer { flex: 1; }
.jn-stat-sep    { opacity: .4; }

/* Tag input popover */
.jn-tag-popover {
  position: absolute; z-index: 9999;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px; min-width: 180px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.jn-tag-input {
  width: 100%; padding: 5px 9px; border-radius: 6px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 12px; outline: none;
  box-sizing: border-box;
}
.jn-tag-input:focus { border-color: var(--accent); }
.jn-tag-suggestions { margin-top: 6px; display: flex; flex-direction: column; gap: 2px; }
.jn-sug-item {
  padding: 4px 8px; border-radius: 5px; cursor: pointer; font-size: 12px;
  color: var(--text-secondary); transition: background .1s, color .1s;
}
.jn-sug-item:hover { background: var(--accent); color: #fff; }

/* ── Journal: toolbar separator & today button ────── */
.jn-action-sep {
  width: 1px; height: 18px; align-self: center;
  background: var(--border); margin: 0 2px; flex-shrink: 0;
}
.jn-sidebar-foot .jn-today-btn {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
  color: var(--accent); font-weight: 600;
}
.jn-sidebar-foot .jn-today-btn:hover {
  background: color-mix(in srgb, var(--accent) 28%, transparent);
}
.jn-empty-today {
  margin-top: 12px; padding: 8px 20px;
  font-size: 13px; border-radius: 8px;
  background: var(--accent); color: #fff; border: none;
  cursor: pointer; transition: opacity .15s;
}
.jn-empty-today:hover { opacity: .85; }

/* ── Journal: modal overlays ────────────────────────── */
.jn-modal-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  z-index: 200;
}
.jn-modal-overlay.hidden { display: none; }
.jn-modal-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 48px rgba(0,0,0,.55);
  width: 420px; max-width: 94%;
  display: flex; flex-direction: column;
  animation: jn-modal-in .14s ease;
  overflow: hidden;
}
.jn-extract-card { width: 500px; }
@keyframes jn-modal-in {
  from { opacity: 0; transform: scale(.95) translateY(8px); }
  to   { opacity: 1; transform: scale(1)  translateY(0);    }
}
.jn-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elevated);
}
.jn-modal-title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.jn-modal-close {
  background: none; border: none; font-size: 18px; line-height: 1;
  color: var(--text-muted); cursor: pointer; padding: 0 2px;
  border-radius: 4px; transition: background .12s, color .12s;
}
.jn-modal-close:hover { background: rgba(255,255,255,.08); color: var(--text-primary); }
.jn-modal-body {
  padding: 16px; display: flex; flex-direction: column; gap: 10px;
  overflow-y: auto; max-height: 62vh;
}
.jn-modal-lbl {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .5px; color: var(--text-muted); margin-bottom: 2px;
  display: block;
}
.jn-modal-opt { font-weight: 400; text-transform: none; letter-spacing: 0; opacity: .7; }
.jn-modal-hint {
  font-size: 12px; color: var(--text-secondary);
  background: rgba(255,255,255,.04); border-radius: 6px;
  padding: 8px 10px; margin: 0;
}
.jn-modal-hint code { font-size: 11px; background: rgba(255,255,255,.08); padding: 1px 4px; border-radius: 3px; }
.jn-modal-input {
  width: 100%; padding: 7px 10px; font-size: 13px;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 7px; color: var(--text-primary); box-sizing: border-box;
  transition: border-color .12s;
}
.jn-modal-input:focus { outline: none; border-color: var(--accent); }
.jn-ev-color-input { padding: 2px 4px; height: 34px; cursor: pointer; }
.jn-modal-select {
  width: 100%; padding: 7px 10px; font-size: 13px;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 7px; color: var(--text-primary); cursor: pointer;
  box-sizing: border-box;
}
.jn-modal-textarea {
  width: 100%; padding: 7px 10px; font-size: 12px; font-family: inherit;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 7px; color: var(--text-primary); box-sizing: border-box;
  resize: vertical; transition: border-color .12s;
}
.jn-modal-textarea:focus { outline: none; border-color: var(--accent); }
.jn-modal-row2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.jn-modal-foot {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  background: var(--bg-elevated);
}
.jn-modal-primary {
  background: var(--accent); color: #fff; border: none;
  padding: 7px 18px; font-weight: 600; border-radius: 7px;
  cursor: pointer; transition: opacity .15s;
}
.jn-modal-primary:hover { opacity: .85; }

/* Extract-tasks modal */
.jn-ext-task-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 260px; overflow-y: auto;
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px;
}
.jn-ext-item {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 6px 8px; border-radius: 6px; cursor: pointer;
  font-size: 13px; color: var(--text-primary);
  transition: background .12s;
}
.jn-ext-item:hover { background: rgba(255,255,255,.06); }
.jn-ext-check { margin-top: 1px; accent-color: var(--accent); flex-shrink: 0; }

/* ═══════════════════════════════════════════════════════════
   Mail App
   ═══════════════════════════════════════════════════════════ */
.ml-root {
  display: flex; height: 100%; overflow: hidden;
  font-size: 13px; color: var(--text-primary);
  background: var(--bg-primary);
}

/* ── Sidebar ── */
.ml-sidebar {
  width: 190px; min-width: 160px; flex-shrink: 0;
  display: flex; flex-direction: column;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
}

.ml-compose-btn {
  margin: 10px 10px 6px; padding: 7px 0; border-radius: 8px;
  background: var(--accent); color: #fff; border: none;
  font-size: 13px; font-weight: 600; cursor: pointer;
  transition: opacity .15s;
}
.ml-compose-btn:hover { opacity: .85; }

.ml-nav { padding: 4px 6px; }
.ml-nav-item {
  display: flex; align-items: center; gap: 7px;
  padding: 6px 9px; border-radius: 7px; cursor: pointer;
  font-size: 12.5px; color: var(--text-secondary);
  transition: background .12s, color .12s;
  user-select: none; position: relative;
}
.ml-nav-item:hover   { background: var(--bg-tertiary); color: var(--text-primary); }
.ml-nav-item.active  { background: var(--accent); color: #fff; }
.ml-nav-icon         { font-size: 14px; }
.ml-nav-label        { flex: 1; }

.ml-unread-badge {
  background: #e53935; color: #fff;
  font-size: 10px; font-weight: 700; border-radius: 20px;
  padding: 1px 5px; min-width: 16px; text-align: center;
}
.ml-unread-badge.hidden { display: none; }

.ml-contacts-head {
  padding: 10px 12px 4px; font-size: 10.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-muted); border-top: 1px solid var(--border);
  margin-top: 4px;
}
.ml-contacts { padding: 2px 6px; overflow-y: auto; flex: 1; }
.ml-contact {
  display: flex; align-items: center; gap: 7px;
  padding: 5px 6px; border-radius: 6px; cursor: pointer;
  font-size: 12px; color: var(--text-secondary);
  transition: background .12s, color .12s;
}
.ml-contact:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.ml-contact-av {
  width: 24px; height: 24px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
}
.ml-contact-initials {
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700;
  line-height: 1; overflow: hidden;
}
.ml-contact-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Message list panel ── */
.ml-list-panel {
  width: 260px; min-width: 200px; flex-shrink: 0;
  display: flex; flex-direction: column;
  border-right: 1px solid var(--border);
  background: var(--bg-primary);
}
.ml-list-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 8px 6px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.ml-search {
  flex: 1; padding: 5px 9px; border-radius: 6px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 12px; outline: none;
  transition: border-color .15s;
}
.ml-search:focus { border-color: var(--accent); }
.ml-search::placeholder { color: var(--text-muted); }
.ml-select-all, .ml-delete-sel {
  padding: 4px 7px; border-radius: 5px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-secondary);
  font-size: 12px; cursor: pointer;
}

.ml-list { flex: 1; overflow-y: auto; }
.ml-list-empty { padding: 20px 14px; color: var(--text-muted); font-size: 12px; text-align: center; }

.ml-list-item {
  display: flex; gap: 8px; padding: 9px 10px 8px;
  border-bottom: 1px solid var(--border); cursor: pointer;
  transition: background .1s;
}
.ml-list-item:hover  { background: var(--bg-secondary); }
.ml-list-item.active { background: color-mix(in srgb, var(--accent) 15%, transparent); }

.ml-item-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
  margin-top: 5px; flex-shrink: 0; opacity: 0; transition: opacity .15s;
}
.ml-item-dot.visible { opacity: 1; }

.ml-item-body { flex: 1; min-width: 0; }
.ml-item-row1 { display: flex; justify-content: space-between; align-items: baseline; gap: 4px; }
.ml-item-from { font-size: 12.5px; font-weight: 500; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.ml-item-date { font-size: 10.5px; color: var(--text-muted); white-space: nowrap; flex-shrink: 0; }
.ml-item-subject { font-size: 12px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin: 2px 0 1px; }
.ml-list-item.unread .ml-item-from,
.ml-list-item.unread .ml-item-subject { color: var(--text-primary); font-weight: 600; }
.ml-item-preview { font-size: 11px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── View panel ── */
.ml-view-panel {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
  background: var(--bg-primary);
}

.ml-view-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  color: var(--text-muted);
}
.ml-view-empty-icon { font-size: 48px; opacity: .4; }
.ml-view-empty p    { font-size: 13px; }

/* Read view */
.ml-read-view { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.ml-read-header {
  padding: 14px 18px 10px; border-bottom: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.ml-read-subject {
  font-size: 17px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px;
}
.ml-read-meta {
  font-size: 11.5px; color: var(--text-muted); margin-bottom: 10px;
  display: flex; flex-wrap: wrap; gap: 4px;
}
.ml-read-actions { display: flex; gap: 8px; }
.ml-btn {
  padding: 5px 13px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-secondary);
  font-size: 12px; cursor: pointer; white-space: nowrap;
  transition: background .12s, color .12s;
}
.ml-btn:hover       { background: var(--bg-hover, var(--bg-secondary)); color: var(--text-primary); }
.ml-btn-danger      { color: #e57373; border-color: rgba(229,115,115,.4); }
.ml-btn-danger:hover{ background: rgba(229,115,115,.15); color: #e57373; }
.ml-btn-ghost       { background: transparent; border-color: transparent; }
.ml-btn-ghost:hover { background: var(--bg-tertiary); }

.ml-read-body {
  flex: 1; overflow-y: auto; padding: 20px 24px;
  font-size: 14px; line-height: 1.7;
}
/* Markdown in read body — same as journal */
.ml-read-body h1, .ml-read-body h2, .ml-read-body h3 { color: var(--text-primary); margin: 1em 0 .4em; font-weight: 600; }
.ml-read-body h1 { font-size: 1.5em; border-bottom: 1px solid var(--border); padding-bottom: .25em; }
.ml-read-body h2 { font-size: 1.25em; }
.ml-read-body p  { margin: .5em 0; }
.ml-read-body a  { color: var(--accent); }
.ml-read-body blockquote {
  border-left: 3px solid var(--accent); margin: .7em 0;
  padding: .3em .8em; background: var(--bg-secondary); border-radius: 0 4px 4px 0;
}
.ml-read-body code {
  background: var(--bg-tertiary); color: var(--accent);
  padding: 1px 5px; border-radius: 4px; font-size: .9em;
}
.ml-read-body pre {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; overflow-x: auto; padding: 12px 16px; margin: .8em 0;
}
.ml-read-body pre code { background: none; color: inherit; padding: 0; }
.ml-read-body table    { border-collapse: collapse; width: 100%; margin: .8em 0; }
.ml-read-body th, .ml-read-body td { border: 1px solid var(--border); padding: 5px 10px; }
.ml-read-body th       { background: var(--bg-secondary); font-weight: 600; }
.ml-read-body ul, .ml-read-body ol { padding-left: 1.4em; margin: .4em 0; }
.ml-read-body img      { max-width: 100%; border-radius: 6px; }
.ml-read-body hr       { border: none; border-top: 1px solid var(--border); margin: 1em 0; }

.ml-read-attachments {
  border-top: 1px solid var(--border); padding: 10px 18px;
  background: var(--bg-secondary); flex-shrink: 0;
  display: flex; flex-wrap: wrap; gap: 8px;
}
.ml-read-att {
  display: flex; align-items: center; gap: 6px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 7px; padding: 5px 10px; font-size: 12px;
}
.ml-att-icon { font-size: 15px; }
.ml-att-name { font-weight: 500; color: var(--text-primary); }
.ml-att-size { color: var(--text-muted); font-size: 11px; }
.ml-att-dl   { background: none; border: none; color: var(--accent); cursor: pointer; font-size: 11.5px; }
.ml-att-dl:hover { text-decoration: underline; }

/* ── Compose view ── */
.ml-compose-view { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.ml-compose-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px 8px; border-bottom: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.ml-compose-title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.ml-compose-close {
  background: none; border: none; font-size: 15px; color: var(--text-muted);
  cursor: pointer; padding: 2px 6px; border-radius: 4px;
}
.ml-compose-close:hover { background: var(--bg-tertiary); color: var(--text-primary); }

.ml-compose-fields { padding: 8px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.ml-field-row {
  display: flex; align-items: flex-start; gap: 8px; padding: 3px 0;
  border-bottom: 1px solid var(--border); position: relative;
}
.ml-field-row:last-child { border-bottom: none; }
.ml-field-label { font-size: 11.5px; color: var(--text-muted); padding: 6px 0 0; min-width: 40px; flex-shrink: 0; }

/* Chips wrap (To / CC) */
.ml-chips-wrap {
  flex: 1; display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
  padding: 4px 0; min-height: 28px;
}
.ml-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.ml-chip {
  display: inline-flex; align-items: center; gap: 3px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  border-radius: 20px; padding: 1px 7px; font-size: 11.5px;
}
.ml-chip-rm {
  background: none; border: none; color: inherit; cursor: pointer;
  font-size: 13px; padding: 0 0 0 2px; opacity: .7; line-height: 1;
}
.ml-chip-rm:hover { opacity: 1; }
.ml-recipient-input {
  border: none; outline: none; background: transparent;
  color: var(--text-primary); font-size: 12.5px;
  min-width: 140px; flex: 1;
}

.ml-subject-input {
  flex: 1; border: none; outline: none; background: transparent;
  color: var(--text-primary); font-size: 13px; padding: 5px 0;
}

/* Autocomplete dropdown */
.ml-autocomplete {
  position: absolute; top: 100%; left: 48px; z-index: 9999;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 7px; box-shadow: 0 6px 20px rgba(0,0,0,.3);
  min-width: 200px; overflow: hidden;
}
.ml-ac-item {
  padding: 7px 12px; font-size: 12.5px; cursor: pointer;
  color: var(--text-secondary); transition: background .1s, color .1s;
}
.ml-ac-item:hover { background: var(--accent); color: #fff; }

/* Format toolbar */
.ml-compose-toolbar {
  display: flex; align-items: center; gap: 3px; flex-wrap: wrap;
  padding: 5px 10px; border-bottom: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.ml-fmt-btn {
  padding: 4px 9px; border-radius: 5px; border: 1px solid transparent;
  background: transparent; color: var(--text-secondary); font-size: 12px; cursor: pointer;
  transition: background .1s, color .1s;
}
.ml-fmt-btn:hover  { background: var(--bg-tertiary); color: var(--text-primary); border-color: var(--border); }
.ml-fmt-sep { width: 1px; background: var(--border); height: 16px; margin: 0 3px; }

/* Compose body area */
.ml-compose-body-wrap {
  flex: 1; min-height: 0; display: flex; flex-direction: column;
}
.ml-compose-body {
  flex: 1; resize: none; border: none; outline: none;
  padding: 14px 18px; font-size: 13.5px; line-height: 1.65;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  background: var(--bg-primary); color: var(--text-primary);
  box-sizing: border-box;
}
.ml-compose-body::placeholder { color: var(--text-muted); }
.ml-compose-preview {
  flex: 1; overflow-y: auto; padding: 16px 22px;
  font-size: 14px; line-height: 1.7;
  background: var(--bg-primary); color: var(--text-primary);
}
/* Inherit read-body markdown styles for preview */
.ml-compose-preview h1,.ml-compose-preview h2,.ml-compose-preview h3 { color: var(--text-primary); margin: .8em 0 .3em; font-weight: 600; }
.ml-compose-preview code { background: var(--bg-tertiary); padding: 1px 5px; border-radius: 4px; font-size: .9em; }
.ml-compose-preview pre  { background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 8px; padding: 10px 14px; overflow-x: auto; margin: .6em 0; }
.ml-compose-preview pre code { background: none; padding: 0; }
.ml-compose-preview img  { max-width: 100%; border-radius: 6px; }
.ml-compose-preview a    { color: var(--accent); }
.ml-compose-preview blockquote { border-left: 3px solid var(--accent); padding: .2em .7em; margin: .5em 0; background: var(--bg-secondary); border-radius: 0 4px 4px 0; }

/* Compose attachments */
.ml-compose-attachments {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 6px 12px; border-top: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.ml-compose-att {
  display: flex; align-items: center; gap: 5px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 8px; font-size: 11.5px;
}
.ml-att-rm {
  background: none; border: none; color: var(--text-muted); cursor: pointer;
  font-size: 14px; padding: 0 0 0 3px;
}
.ml-att-rm:hover { color: #e57373; }

/* Compose footer */
.ml-compose-footer {
  display: flex; gap: 8px; padding: 8px 12px;
  border-top: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.ml-send-btn { background: var(--accent); color: #fff; border-color: var(--accent); }
.ml-send-btn:hover { opacity: .85; }

/* ═══════════════════════════════════════════════════════════
   Password Manager
   ═══════════════════════════════════════════════════════════ */
.pm-root {
  display: flex; height: 100%; overflow: hidden;
  font-size: 13px; color: var(--text-primary);
  background: var(--bg-primary);
}

/* ── Lock screen ── */
.pm-lock-screen {
  flex: 1; display: flex; align-items: center; justify-content: center;
  background: var(--bg-primary);
}
.pm-lock-card {
  display: flex; flex-direction: column; align-items: center;
  width: 340px; padding: 36px 32px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 16px; box-shadow: 0 8px 32px rgba(0,0,0,.25);
  gap: 10px;
}
.pm-lock-icon  { font-size: 48px; line-height: 1; }
.pm-lock-title { font-size: 22px; font-weight: 700; color: var(--text-primary); }
.pm-lock-sub   { font-size: 12.5px; color: var(--text-muted); text-align: center; }
.pm-lock-form  { display: flex; flex-direction: column; gap: 10px; width: 100%; margin-top: 6px; }
.pm-master-input, .pm-master-confirm {
  width: 100%; padding: 9px 13px; border-radius: 8px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 13px; outline: none;
  box-sizing: border-box; transition: border-color .15s;
}
.pm-master-input:focus, .pm-master-confirm:focus { border-color: var(--accent); }
.pm-lock-error {
  font-size: 12px; color: #e57373; text-align: center; padding: 2px 0;
}
.pm-lock-btn {
  width: 100%; padding: 9px 0; border-radius: 8px;
  background: var(--accent); color: #fff; border: none;
  font-size: 14px; font-weight: 600; cursor: pointer;
  transition: opacity .15s;
}
.pm-lock-btn:hover { opacity: .85; }
.pm-lock-hint { font-size: 11px; color: var(--text-muted); text-align: center; }

/* ── Vault layout ── */
.pm-vault {
  display: flex; height: 100%; width: 100%;
}

/* Sidebar */
.pm-sidebar {
  width: 190px; min-width: 160px; flex-shrink: 0;
  display: flex; flex-direction: column;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
}
.pm-sidebar-top {
  padding: 10px 10px 6px;
  border-bottom: 1px solid var(--border);
}
.pm-lock-vault-btn {
  width: 100%; padding: 6px 0; border-radius: 7px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-secondary); font-size: 12.5px; cursor: pointer;
  transition: background .12s, color .12s;
}
.pm-lock-vault-btn:hover { background: rgba(229,115,115,.15); color: #e57373; border-color: rgba(229,115,115,.4); }

.pm-nav { padding: 6px 6px; overflow-y: auto; flex: 1; }
.pm-nav-item {
  display: flex; align-items: center; gap: 7px;
  padding: 6px 9px; border-radius: 7px; cursor: pointer;
  font-size: 12.5px; color: var(--text-secondary);
  transition: background .12s, color .12s; user-select: none;
}
.pm-nav-item:hover  { background: var(--bg-tertiary); color: var(--text-primary); }
.pm-nav-item.active { background: var(--accent); color: #fff; }
.pm-nav-sep   { height: 1px; background: var(--border); margin: 4px 6px; }
.pm-nav-label { padding: 6px 9px 2px; font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); }

.pm-folders { padding: 0; }

/* Entry list */
.pm-list-panel {
  width: 240px; min-width: 200px; flex-shrink: 0;
  display: flex; flex-direction: column;
  border-right: 1px solid var(--border);
  background: var(--bg-primary);
}
.pm-list-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 8px 6px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.pm-search {
  flex: 1; padding: 5px 9px; border-radius: 6px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 12px; outline: none;
  transition: border-color .15s;
}
.pm-search:focus { border-color: var(--accent); }
.pm-search::placeholder { color: var(--text-muted); }
.pm-add-btn {
  flex-shrink: 0; padding: 4px 10px; border-radius: 7px;
  background: var(--accent); color: #fff; border: none;
  font-size: 16px; font-weight: 300; cursor: pointer; line-height: 1.2;
  transition: opacity .15s;
}
.pm-add-btn:hover { opacity: .85; }

.pm-list { flex: 1; overflow-y: auto; }
.pm-list-empty { padding: 20px 12px; color: var(--text-muted); font-size: 12px; text-align: center; }

.pm-list-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background .1s;
}
.pm-list-item:hover  { background: var(--bg-secondary); }
.pm-list-item.active { background: color-mix(in srgb, var(--accent) 15%, transparent); }
.pm-item-icon {
  width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0;
  background: var(--bg-tertiary); display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.pm-item-favicon { width: 16px; height: 16px; }
.pm-item-letter  { font-size: 14px; font-weight: 700; color: var(--text-secondary); }
.pm-item-body { flex: 1; min-width: 0; }
.pm-item-title { font-size: 12.5px; font-weight: 500; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pm-item-sub   { font-size: 11px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Detail panel */
.pm-detail-panel {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
  background: var(--bg-primary); position: relative;
}
.pm-detail-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px; color: var(--text-muted);
}
.pm-detail-empty-icon { font-size: 48px; opacity: .4; }
.pm-detail-empty p    { font-size: 13px; }

/* Entry view */
.pm-entry-view { display: flex; flex-direction: column; flex: 1; min-height: 0; overflow-y: auto; }
.pm-entry-view-head {
  padding: 16px 20px 12px; border-bottom: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.pm-entry-view-icon { font-size: 28px; margin-bottom: 4px; }
.pm-entry-view-title  { font-size: 20px; font-weight: 700; color: var(--text-primary); }
.pm-entry-view-folder { font-size: 12px; color: var(--text-muted); }
.pm-entry-view-actions { display: flex; gap: 8px; margin-top: 8px; }

.pm-btn {
  padding: 5px 13px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-tertiary); color: var(--text-secondary);
  font-size: 12px; cursor: pointer; white-space: nowrap;
  transition: background .12s, color .12s;
}
.pm-btn:hover       { background: var(--bg-hover, var(--bg-secondary)); color: var(--text-primary); }
.pm-btn-danger      { color: #e57373; border-color: rgba(229,115,115,.3); }
.pm-btn-danger:hover{ background: rgba(229,115,115,.15); color: #e57373; }
.pm-btn-ghost       { background: transparent; border-color: transparent; }
.pm-btn-ghost:hover { background: var(--bg-tertiary); }

/* Fields in view */
.pm-entry-fields { padding: 14px 20px; display: flex; flex-direction: column; gap: 12px; }
.pm-field-row {
  display: flex; align-items: center; gap: 10px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 9px; padding: 10px 12px;
}
.pm-field-icon    { font-size: 17px; flex-shrink: 0; }
.pm-field-content { flex: 1; min-width: 0; }
.pm-field-label   { display: block; font-size: 10.5px; color: var(--text-muted); margin-bottom: 2px; }
.pm-field-value   { font-size: 13.5px; color: var(--text-primary); font-family: 'JetBrains Mono', monospace; word-break: break-all; }
.pm-masked        { font-family: monospace; letter-spacing: 2px; }
.pm-field-btns    { display: flex; gap: 5px; flex-shrink: 0; }

/* Tags + notes in view */
.pm-entry-tags-view  { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 20px 10px; }
.pm-tag-chip {
  padding: 2px 10px; border-radius: 20px; font-size: 11.5px;
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
}
.pm-entry-notes-view {
  margin: 0 20px 16px; padding: 12px 14px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 9px; font-size: 12.5px; color: var(--text-secondary);
  white-space: pre-wrap; line-height: 1.6;
}

/* Edit form */
.pm-entry-edit { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.pm-edit-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px 10px; border-bottom: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.pm-edit-title-label { font-size: 14px; font-weight: 600; }
.pm-edit-actions { display: flex; gap: 8px; }
.pm-save-btn { background: var(--accent); color: #fff; border-color: var(--accent); }
.pm-save-btn:hover { opacity: .85; }

.pm-edit-form {
  flex: 1; overflow-y: auto; padding: 14px 18px;
  display: flex; flex-direction: column; gap: 4px;
}
.pm-edit-form label {
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .05em; margin-top: 8px;
}
.pm-edit-form label:first-child { margin-top: 0; }
.pm-edit-form input, .pm-edit-form select, .pm-edit-form textarea {
  padding: 7px 11px; border-radius: 7px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 13px; outline: none;
  transition: border-color .15s; box-sizing: border-box; width: 100%;
}
.pm-edit-form input:focus, .pm-edit-form select:focus, .pm-edit-form textarea:focus {
  border-color: var(--accent);
}
.pm-edit-form textarea { resize: vertical; font-family: inherit; }
.pm-edit-form select { cursor: pointer; }

/* Password row */
.pm-pw-row {
  display: flex; gap: 6px;
}
.pm-pw-row input { flex: 1; font-family: 'JetBrains Mono', monospace; }

/* Strength bar */
.pm-strength-bar-wrap {
  display: flex; align-items: center; gap: 10px; margin: 2px 0 4px;
}
.pm-strength-bar {
  height: 4px; border-radius: 4px; background: var(--accent);
  transition: width .3s, background .3s; min-width: 0;
  flex: 0 0 auto; /* width set inline */
}
.pm-strength-label { font-size: 11px; font-weight: 600; }

/* Generator panel */
.pm-gen-panel {
  flex: 1; display: flex; flex-direction: column; padding: 20px 22px; gap: 14px;
  overflow-y: auto;
}
.pm-gen-head { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.pm-gen-output-wrap {
  display: flex; align-items: center; gap: 10px;
}
.pm-gen-output {
  flex: 1; padding: 10px 14px; border-radius: 9px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  font-family: 'JetBrains Mono', monospace; font-size: 14px; font-weight: 500;
  color: var(--text-primary); letter-spacing: .5px; word-break: break-all;
  cursor: pointer; transition: background .12s;
}
.pm-gen-output:hover { background: var(--bg-tertiary); }
.pm-gen-refresh { padding: 8px 12px; font-size: 16px; }
.pm-gen-strength { margin: -6px 0 0; }
.pm-gen-controls { display: flex; flex-direction: column; gap: 10px; }
.pm-gen-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.pm-gen-row input[type=range] { flex: 1; accent-color: var(--accent); }
.pm-gen-check { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--text-secondary); cursor: pointer; }
.pm-gen-check input[type=checkbox] { accent-color: var(--accent); width: 14px; height: 14px; }
.pm-gen-copy { padding: 8px 18px; background: var(--accent); color: #fff; border-color: var(--accent); margin-top: 4px; }
.pm-gen-copy:hover { opacity: .85; }

/* Health panel */
.pm-health-panel { flex: 1; display: flex; flex-direction: column; overflow-y: auto; }
.pm-health-head {
  padding: 14px 20px 10px; font-size: 16px; font-weight: 700;
  border-bottom: 1px solid var(--border); background: var(--bg-secondary); flex-shrink: 0;
}
.pm-health-body { padding: 14px 20px; display: flex; flex-direction: column; gap: 14px; }
.pm-health-ok   { color: var(--text-secondary); font-size: 13px; }
.pm-health-section { background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 9px; overflow: hidden; }
.pm-health-sec-title {
  padding: 9px 14px; background: var(--bg-tertiary);
  font-size: 12px; font-weight: 600; color: var(--text-primary);
  border-bottom: 1px solid var(--border);
}
.pm-health-item {
  padding: 7px 14px; font-size: 12.5px; color: var(--text-secondary);
  border-bottom: 1px solid var(--border); transition: background .1s;
}
.pm-health-item:last-child  { border-bottom: none; }
.pm-health-item[data-id]:hover { background: color-mix(in srgb, var(--accent) 10%, transparent); color: var(--text-primary); }

/* ═══════════════════════════════════════════════════════════
   Shared SVG icons
   ═══════════════════════════════════════════════════════════ */
.wos-icon { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; line-height: 0; }
.wos-icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }
.wos-icon-app { width: 20px; height: 20px; }
.wos-icon-theme { width: 28px; height: 28px; }
.wos-icon-label { display: inline-flex; align-items: center; gap: 6px; }
.wos-icon-label .wos-icon { width: 14px; height: 14px; flex-shrink: 0; }
.di-icon .wos-icon-app { width: 28px; height: 28px; }
.window-icon .wos-icon,
.window-icon .wos-icon-app { width: 14px; height: 14px; vertical-align: -2px; }
.dlg-icon .wos-icon { width: 20px; height: 20px; vertical-align: -4px; }

/* ═══════════════════════════════════════════════════════════
   Blog Manager
   ═══════════════════════════════════════════════════════════ */
.bg-root { display: flex; height: 100%; overflow: hidden; background: var(--bg-primary); }
.bg-sidebar {
  width: 230px; flex-shrink: 0; display: flex; flex-direction: column;
  border-right: 1px solid var(--border); background: var(--bg-secondary);
}
.bg-sidebar-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 10px 8px; border-bottom: 1px solid var(--border);
}
.bg-sidebar-title { font-size: 12px; font-weight: 700; text-transform: uppercase; color: var(--text-muted); letter-spacing: .05em; }
.bg-icon-btn {
  width: 28px; height: 28px; border: none; border-radius: 6px; cursor: pointer;
  background: var(--accent); color: #fff; line-height: 0;
  display: flex; align-items: center; justify-content: center;
}
.bg-icon-btn .wos-icon { width: 14px; height: 14px; }
.bg-icon-btn:hover { opacity: .85; }
.bg-site-list { flex: 1; overflow-y: auto; padding: 6px; }
.bg-site-item {
  display: flex; align-items: center; gap: 8px; width: 100%; padding: 8px 10px;
  border: 1px solid transparent; border-radius: 8px; background: none;
  cursor: pointer; text-align: left; color: var(--text-primary); margin-bottom: 2px;
  transition: background .12s, border-color .12s;
}
.bg-site-item:hover { background: rgba(255,255,255,.06); }
.bg-site-item.active { background: color-mix(in srgb, var(--accent) 18%, transparent); border-color: color-mix(in srgb, var(--accent) 40%, transparent); }
.bg-site-icon { flex-shrink: 0; display: flex; align-items: center; color: var(--text-secondary); }
.bg-site-icon .wos-icon { width: 18px; height: 18px; }
.bg-indexed-badge { display: flex; align-items: center; opacity: .7; color: var(--text-muted); }
.bg-indexed-badge .wos-icon { width: 12px; height: 12px; }
.bg-site-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.bg-site-name { font-size: 13px; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bg-site-domain { font-size: 10px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; }
.bg-empty-sites { font-size: 12px; color: var(--text-muted); padding: 12px 8px; text-align: center; }
.bg-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; position: relative; }
.bg-welcome {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; color: var(--text-secondary);
}
.bg-welcome-icon { display: flex; color: var(--accent); opacity: .55; }
.bg-welcome-icon .wos-icon-app { width: 48px; height: 48px; }
.bg-welcome h2 { color: var(--text-primary); font-size: 1.4rem; }
.bg-panel { flex: 1; overflow-y: auto; padding: 16px 20px; }
.bg-panel-head {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 16px; flex-wrap: wrap;
}
.bg-panel-head h2 { font-size: 1.25rem; color: var(--text-primary); }
.bg-panel-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.bg-btn {
  padding: 6px 12px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-primary); font-size: 12px;
  cursor: pointer; transition: background .12s;
  display: inline-flex; align-items: center; justify-content: center;
}
.bg-btn:hover { background: rgba(255,255,255,.08); }
.bg-btn-primary { background: var(--accent); border-color: transparent; color: #fff; }
.bg-btn-primary:hover { opacity: .9; }
.bg-btn-danger { color: #ef5350; border-color: rgba(239,83,80,.35); }
.bg-tabs { display: flex; gap: 4px; margin-bottom: 14px; border-bottom: 1px solid var(--border); }
.bg-tab {
  padding: 8px 14px; background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-muted); cursor: pointer; font-size: 13px; margin-bottom: -1px;
}
.bg-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.bg-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.bg-form-grid label { display: flex; flex-direction: column; gap: 4px; font-size: 11px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; }
.bg-full { grid-column: 1 / -1; }
.bg-input, .bg-textarea {
  padding: 8px 10px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-secondary); color: var(--text); font-size: 13px; font-family: inherit;
}
.bg-textarea { resize: vertical; min-height: 60px; }
.bg-hint { font-weight: 400; text-transform: none; opacity: .7; }
.bg-check-label { flex-direction: row !important; align-items: center; gap: 8px !important; text-transform: none !important; font-size: 13px !important; color: var(--text) !important; }
.bg-color-row { display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 14px; }
.bg-color-row label { font-size: 11px; color: var(--text-muted); display: flex; flex-direction: column; gap: 4px; }
.bg-color-row input[type=color] { width: 48px; height: 32px; padding: 2px; cursor: pointer; border: 1px solid var(--border); border-radius: 6px; }
.bg-logo-row { margin-bottom: 14px; display: flex; flex-wrap: wrap; align-items: flex-end; gap: 10px; }
.bg-logo-preview { max-height: 48px; max-width: 120px; border-radius: 6px; border: 1px solid var(--border); }
.bg-form-actions { display: flex; justify-content: space-between; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border); }
.bg-theme-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 14px; padding: 16px 0; }
.bg-theme-card {
  display: flex; flex-direction: column; align-items: stretch; gap: 8px; padding: 0 0 12px;
  border: 2px solid var(--border); border-radius: 12px; background: var(--bg-secondary);
  cursor: pointer; text-align: left; transition: border-color .15s, box-shadow .15s; overflow: hidden;
}
.bg-theme-card:hover { border-color: var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent); }
.bg-theme-card.active { border-color: var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent); }
.bg-theme-name { font-weight: 600; color: var(--text); font-size: 13px; padding: 0 12px; }
.bg-theme-desc { font-size: 11px; color: var(--text-muted); padding: 0 12px; line-height: 1.4; }
/* Live preview thumbnail */
.bg-theme-preview-wrap {
  position: relative; width: 100%; height: 128px;
  overflow: hidden; background: #f0f0f0; flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}
.bg-theme-preview-frame {
  width: 860px; height: 600px; border: none;
  transform: scale(0.221); transform-origin: top left;
  pointer-events: none; display: block;
}
.bg-theme-active-badge {
  position: absolute; top: 6px; right: 6px;
  background: var(--accent); color: #fff;
  font-size: 10px; font-weight: 700; letter-spacing: .04em;
  padding: 2px 7px; border-radius: 20px;
  pointer-events: none;
}
/* Admin theme toolbar */
.bg-theme-toolbar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0 4px; border-bottom: 1px solid var(--border); margin-bottom: 4px;
}
.bg-theme-toolbar-hint { flex: 1; font-size: 12px; color: var(--text-muted); }
.bg-theme-install-btn { font-size: 12px; gap: 5px; }
/* Uninstall (trash) button on installed theme cards */
.bg-theme-uninstall-btn {
  position: absolute; bottom: 6px; right: 6px;
  background: rgba(0,0,0,.55); color: #fff; border: none; border-radius: 6px;
  width: 24px; height: 24px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; opacity: 0; transition: opacity .15s; padding: 0;
}
.bg-theme-uninstall-btn svg { width: 13px; height: 13px; }
.bg-theme-preview-wrap:hover .bg-theme-uninstall-btn,
.bg-theme-card:hover .bg-theme-uninstall-btn { opacity: 1; }
.bg-theme-uninstall-btn:hover { background: var(--danger, #e55); }
/* Post list */
.bg-post-list { display: flex; flex-direction: column; gap: 6px; padding-bottom: 16px; }
.bg-post-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--bg-secondary); transition: border-color .12s;
}
.bg-post-row:hover { border-color: color-mix(in srgb, var(--accent) 40%, transparent); }
.bg-post-row.active { border-color: var(--accent); }
.bg-post-thumb { width: 60px; height: 42px; border-radius: 6px; flex-shrink: 0; background-size: cover; background-position: center; }
.bg-post-thumb-ph { width: 60px; height: 42px; border-radius: 6px; flex-shrink: 0; background: var(--bg-tertiary); border: 1px solid var(--border); }
.bg-post-row-body { flex: 1; min-width: 0; }
.bg-post-title { font-weight: 600; font-size: 13.5px; color: var(--text); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bg-post-row-meta { display: flex; align-items: center; gap: 6px; margin-top: 3px; flex-wrap: wrap; }
.bg-status-pill { padding: 1px 7px; border-radius: 20px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; }
.bg-status-pill.pub   { background: color-mix(in srgb, #4caf50 15%, transparent); color: #4caf50; }
.bg-status-pill.draft { background: color-mix(in srgb, var(--text-muted) 15%, transparent); color: var(--text-muted); }
.bg-post-date { font-size: 11px; color: var(--text-muted); }
.bg-post-tag-chip { padding: 1px 7px; border-radius: 20px; font-size: 10px; background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--accent); }
.bg-empty-posts { text-align: center; padding: 52px 20px; color: var(--text-muted); }
.bg-empty-posts p { margin-bottom: 6px; }
.bg-empty-hint { font-size: 12px; opacity: .7; }
.bg-count-lbl { font-size: 12px; color: var(--text-muted); }
/* Editor */
.bg-editor-root { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
.bg-editor-head { flex-shrink: 0; padding: 10px 16px; border-bottom: 1px solid var(--border); margin-bottom: 0; }
.bg-editor-meta { display: flex; flex-direction: column; gap: 8px; padding: 12px 16px 10px; flex-shrink: 0; }
.bg-editor-meta-row { display: flex; gap: 8px; }
.bg-editor-meta-row .bg-input { flex: 1; min-width: 0; }
.bg-cover-row { display: flex; align-items: center; gap: 10px; padding: 0 16px 10px; flex-shrink: 0; flex-wrap: wrap; }
.bg-cover-preview { height: 48px; border-radius: 8px; border: 1px solid var(--border); object-fit: cover; max-width: 160px; }
.bg-cover-btns { display: flex; gap: 6px; align-items: center; }
.bg-md-area { flex: 1; display: flex; flex-direction: column; min-height: 0; border-top: 1px solid var(--border); }
.bg-md-toolbar {
  display: flex; align-items: center; gap: 2px; padding: 5px 10px;
  border-bottom: 1px solid var(--border); background: var(--bg-secondary); flex-shrink: 0; flex-wrap: wrap;
}
.bg-md-t {
  padding: 3px 8px; border-radius: 5px; border: none; background: none; color: var(--text-muted);
  font-size: 12px; cursor: pointer; transition: background .1s, color .1s; white-space: nowrap;
}
.bg-md-t:hover { background: var(--hover); color: var(--text); }
.bg-md-t.active { background: color-mix(in srgb, var(--accent) 18%, transparent); color: var(--accent); }
.bg-md-sep { width: 1px; height: 16px; background: var(--border); margin: 0 4px; flex-shrink: 0; }
.bg-md-spacer { flex: 1; }
.bg-md-body { flex: 1; display: flex; min-height: 0; position: relative; }
.bg-md-body .bg-textarea {
  flex: 1; resize: none; border: none; border-radius: 0; font-family: 'Consolas','Courier New',monospace;
  font-size: 13px; line-height: 1.65; padding: 14px 18px; background: var(--bg); min-height: 0;
}
.bg-md-body .bg-textarea:focus { outline: none; }
.bg-md-preview {
  flex: 1; overflow-y: auto; padding: 18px 24px; font-size: 14px; line-height: 1.7;
  background: var(--bg); color: var(--text); min-height: 0;
}
.bg-md-preview p { margin-bottom: 1em; }
.bg-md-preview h1,.bg-md-preview h2,.bg-md-preview h3 { margin: 1.4em 0 .5em; color: var(--accent); }
.bg-md-preview ul,.bg-md-preview ol { margin: 0 0 1em 1.5em; }
.bg-md-preview code { background: var(--bg-secondary); padding: 1px 5px; border-radius: 4px; font-family: monospace; font-size: .88em; }
.bg-md-preview pre { background: var(--bg-secondary); padding: 14px 16px; border-radius: 8px; overflow-x: auto; margin: 1em 0; }
.bg-md-preview blockquote { border-left: 3px solid var(--accent); padding: 8px 14px; background: color-mix(in srgb,var(--accent) 8%,transparent); margin: 1em 0; }
.bg-md-preview img { max-width: 100%; border-radius: 6px; }
.bg-md-preview strong { font-weight: 700; }
.bg-md-preview em { font-style: italic; }
/* Site info */
.bg-panel-title { font-size: 1.2rem; font-weight: 700; color: var(--text); }
.bg-panel-sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
/* Misc */
.bg-dirty { position: relative; }
.bg-dirty::after { content: '●'; font-size: 8px; vertical-align: super; margin-left: 4px; color: #ff9800; }
.bg-count { display: inline-flex; align-items: center; justify-content: center; min-width: 18px; height: 18px; border-radius: 9px; padding: 0 5px; background: var(--bg-elevated); border: 1px solid var(--border); font-size: 10px; color: var(--text-muted); }
.bg-site-badges { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.bg-preview-frame { width: 100%; height: 100%; border: none; background: #fff; }

/* ── Blog share dialog ── */
.bg-share-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); display: flex; align-items: center; justify-content: center; z-index: 200; border-radius: inherit; }
.bg-share-dialog { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 12px; width: 360px; max-width: 90%; display: flex; flex-direction: column; gap: 0; box-shadow: 0 20px 60px rgba(0,0,0,.4); }
.bg-share-header { display: flex; align-items: center; gap: 8px; padding: 16px 16px 12px; font-weight: 700; font-size: .95rem; color: var(--text-primary); border-bottom: 1px solid var(--border); }
.bg-share-header .wos-icon { flex-shrink: 0; color: var(--accent); }
.bg-share-header span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bg-share-close { background: none; border: none; cursor: pointer; color: var(--text-muted); padding: 2px; display: flex; border-radius: 4px; }
.bg-share-close:hover { background: rgba(255,255,255,.08); color: var(--text-primary); }
.bg-share-hint { font-size: .8rem; color: var(--text-muted); padding: 10px 16px 4px; line-height: 1.5; }
.bg-share-user-list { display: flex; flex-direction: column; max-height: 260px; overflow-y: auto; padding: 6px 0; }
.bg-share-user-row { display: flex; align-items: center; gap: 10px; padding: 9px 16px; cursor: pointer; transition: background .1s; }
.bg-share-user-row:hover { background: rgba(255,255,255,.05); }
.bg-share-chk { width: 15px; height: 15px; flex-shrink: 0; accent-color: var(--accent); cursor: pointer; }
.bg-share-avatar { font-size: 1.2rem; flex-shrink: 0; }
.bg-share-uname { flex: 1; font-size: .9rem; color: var(--text-primary); }
.bg-share-tag { font-size: .72rem; font-weight: 600; color: transparent; }
.bg-share-tag-on { color: var(--accent); }
.bg-share-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border); }

/* ── Post attachments (editor) ── */
.bg-attach-row { border-top: 1px solid var(--border); padding: 14px 16px 16px; flex-shrink: 0; }
.bg-attach-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; font-size: .82rem; font-weight: 600; color: var(--text-muted); }
.bg-attach-head .wos-icon-label { display: flex; align-items: center; gap: 6px; }
.bg-attach-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.bg-attach-empty { font-size: .8rem; color: var(--text-muted); padding: 4px 0; }
.bg-attach-item { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border: 1px solid var(--border); border-radius: 7px; background: var(--bg-elevated); font-size: .84rem; }
.bg-attach-icon { flex-shrink: 0; color: var(--accent); display: flex; align-items: center; }
.bg-attach-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; color: var(--text-primary); }
.bg-attach-size { flex-shrink: 0; font-size: .76rem; color: var(--text-muted); white-space: nowrap; }
.bg-attach-rm { margin-left: 4px; flex-shrink: 0; background: none; border: none; cursor: pointer; padding: 3px; border-radius: 4px; color: var(--text-muted); display: flex; align-items: center; }
.bg-attach-rm:hover { background: var(--danger-bg, rgba(239,68,68,.12)); color: var(--danger, #ef4444); }

/* ═══════════════════════════════════════════════════════════
   Internal Browser
   ═══════════════════════════════════════════════════════════ */
.wb-root { display: flex; flex-direction: column; height: 100%; background: var(--bg-primary); overflow: hidden; }

/* ── Tab bar ── */
.wb-tabbar {
  display: flex; align-items: flex-end; gap: 2px;
  padding: 6px 8px 0; overflow-x: auto; overflow-y: hidden;
  scrollbar-width: none;
  background: color-mix(in srgb, var(--bg-secondary) 90%, var(--bg-primary));
}
.wb-tabbar::-webkit-scrollbar { display: none; }
.wb-tab {
  display: flex; align-items: center; gap: 5px;
  min-width: 90px; max-width: 190px; flex-shrink: 0;
  padding: 5px 6px 5px 10px;
  border-radius: 7px 7px 0 0;
  border: 1px solid transparent; border-bottom: none;
  background: color-mix(in srgb, var(--bg-elevated) 60%, transparent);
  color: var(--text-muted); cursor: pointer; font-size: 12px;
  transition: background .12s, color .12s;
  position: relative; user-select: none;
}
.wb-tab:not(.wb-tab-active):hover {
  background: color-mix(in srgb, var(--bg-primary) 50%, var(--bg-elevated));
  color: var(--text-secondary);
}
.wb-tab.wb-tab-active {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--border);
  border-bottom: 1px solid var(--bg-secondary);
  margin-bottom: -1px; z-index: 1;
}
.wb-tab-title {
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  font-size: 12px; line-height: 1.4;
}
.wb-tab-close {
  background: none; border: none; cursor: pointer; color: var(--text-muted);
  width: 17px; height: 17px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; flex-shrink: 0; line-height: 1;
  opacity: 0; transition: opacity .12s, background .1s;
}
.wb-tab:hover .wb-tab-close,
.wb-tab.wb-tab-active .wb-tab-close { opacity: .6; }
.wb-tab-close:hover { opacity: 1 !important; background: color-mix(in srgb, #ef5350 14%, transparent); color: #ef5350; }
.wb-newtab-btn {
  background: none; border: none; cursor: pointer; color: var(--text-muted);
  width: 28px; height: 26px; border-radius: 6px; align-self: center;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; line-height: 1; flex-shrink: 0; margin-left: 2px;
  transition: background .12s, color .12s;
}
.wb-newtab-btn:hover { background: rgba(255,255,255,.1); color: var(--text-primary); }

/* Chrome bar */
.wb-chrome { flex-shrink: 0; background: var(--bg-secondary); border-bottom: 1px solid var(--border); position: relative; }
.wb-toolbar {
  display: flex; align-items: center; gap: 4px; padding: 8px 10px 6px;
}
.wb-nav {
  width: 32px; height: 32px; border: none; border-radius: 8px; background: none;
  color: var(--text-secondary); cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s;
}
.wb-nav .wos-icon { width: 16px; height: 16px; }
.wb-nav:hover:not(:disabled) { background: rgba(255,255,255,.1); color: var(--text-primary); }
.wb-nav:disabled,.wb-nav.wb-nav-dim { opacity: .32; cursor: default; }
/* Omnibar */
.wb-omni {
  flex: 1; display: flex; align-items: center; height: 34px;
  background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 10px;
  padding: 0 8px 0 10px; gap: 4px; min-width: 0; transition: border-color .15s, box-shadow .15s;
  position: relative; flex-wrap: wrap; align-content: flex-start;
}
.wb-suggest {
  position: absolute; left: 0; right: 0; top: calc(100% + 4px); z-index: 120;
  background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,.35); max-height: 280px; overflow-y: auto;
}
.wb-suggest.hidden { display: none; }
.wb-sug-item {
  display: flex; align-items: center; gap: 10px; width: 100%; padding: 9px 12px;
  border: none; background: transparent; color: var(--text-primary); text-align: left; cursor: pointer;
}
.wb-sug-item:hover, .wb-sug-item.active { background: var(--hover); }
.wb-sug-ic { font-size: 1.1rem; flex-shrink: 0; width: 22px; text-align: center; }
.wb-sug-body { min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.wb-sug-title { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wb-sug-sub { font-size: 11px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wb-omni:focus-within { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 20%, transparent); }
.wb-scheme { font-size: 12px; color: var(--text-muted); flex-shrink: 0; user-select: none; }
.wb-url-form { flex: 1; min-width: 0; display: flex; }
.wb-url { flex: 1; border: none; outline: none; background: transparent; color: var(--text-primary); font-size: 13px; min-width: 0; }
.wb-url::placeholder { color: var(--text-muted); }
.wb-omni-btn {
  width: 26px; height: 26px; flex-shrink: 0; border: none; background: none;
  color: var(--text-muted); cursor: pointer; border-radius: 6px; display: flex; align-items: center; justify-content: center;
  transition: color .12s, background .12s;
}
.wb-omni-btn .wos-icon { width: 15px; height: 15px; }
.wb-omni-btn:hover { background: rgba(255,255,255,.1); color: var(--text-primary); }
.wb-omni-btn.wb-starred { color: #f9a825; }
/* Loading bar */
.wb-progress { height: 2px; background: transparent; overflow: hidden; }
.wb-progress-fill { height: 100%; width: 0; background: var(--accent); transition: width .3s ease; border-radius: 1px; }
.wb-progress-fill.wb-loading { animation: wb-progress-anim 1.6s ease-in-out infinite; }
@keyframes wb-progress-anim { 0%{width:35%;margin-left:0} 50%{width:50%;margin-left:25%} 100%{width:35%;margin-left:65%} }
/* Bookmarks dropdown */
.wb-bk-dropdown {
  position: absolute; top: 52px; right: 50px; z-index: 100; min-width: 260px; max-width: 340px;
  background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,.35); overflow: hidden;
}
.wb-bk-dropdown.hidden { display: none; }
.wb-bkd-head { padding: 10px 14px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); border-bottom: 1px solid var(--border); }
.wb-bkd-item { display: flex; align-items: center; border-bottom: 1px solid var(--border); }
.wb-bkd-item:last-child { border-bottom: none; }
.wb-bkd-link { flex: 1; padding: 9px 14px; border: none; background: none; color: var(--text-primary); font-size: 13px; cursor: pointer; text-align: left; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wb-bkd-link:hover { background: rgba(255,255,255,.06); }
.wb-bkd-del { padding: 9px 10px; border: none; background: none; color: var(--text-muted); font-size: 12px; cursor: pointer; flex-shrink: 0; }
.wb-bkd-del:hover { color: #ef5350; background: rgba(239,83,80,.08); }
.wb-bkd-empty { padding: 20px 14px; font-size: 12px; color: var(--text-muted); line-height: 1.6; }
/* Content */
.wb-content { flex: 1; position: relative; overflow: hidden; }
.wb-frame { position: absolute; inset: 0; width: 100%; height: 100%; border: none; background: #fff; }
/* Status bar */
.wb-statusbar {
  display: flex; align-items: center; gap: 8px; padding: 3px 12px;
  font-size: 11px; color: var(--text-muted); border-top: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0; min-height: 22px;
}
.wb-status-domain { color: var(--accent); font-weight: 600; }
/* Bookmark btn in toolbar */
.wb-bk-btn { position: relative; }

/* Full-screen toggle button */
.wb-fs-btn { margin-left: 2px; }
.wb-fs-btn.wb-fs-active { color: var(--accent); }
.wb-fs-btn.wb-fs-active .wos-icon { stroke: var(--accent); }

/* ═══════════════════════════════════════════════════════════
   Admin Portal — application access
   ═══════════════════════════════════════════════════════════ */
.ap-section-sub { font-size: 12px; color: var(--text-muted); margin: 4px 0 0; }
.ap-apps-policy {
  background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px 16px; margin-bottom: 18px; font-size: 12.5px; color: var(--text-secondary);
}
.ap-apps-policy-list { margin: 8px 0 0 18px; line-height: 1.6; }
.ap-apps-table { border: 1px solid var(--border); border-radius: 10px; overflow: hidden; margin-bottom: 20px; }
.ap-apps-head, .ap-apps-row {
  display: grid; grid-template-columns: 1fr 140px; gap: 12px; align-items: center;
  padding: 10px 14px; border-bottom: 1px solid var(--border);
}
.ap-apps-head { background: var(--bg-tertiary); font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--text-muted); }
.ap-apps-row:last-child { border-bottom: none; }
.ap-apps-app { display: flex; align-items: center; gap: 10px; min-width: 0; }
.ap-apps-icon { display: flex; align-items: center; flex-shrink: 0; }
.ap-apps-name { font-weight: 600; color: var(--text-primary); font-size: 13px; }
.ap-apps-id { font-size: 11px; color: var(--text-muted); }
.ap-apps-meta { font-size: 12px; color: var(--text-secondary); }
.ap-apps-quick { margin-top: 8px; }
.ap-apps-quick-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.ap-section-lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--text-muted); letter-spacing: .04em; }

.ap-app-modal {
  position: absolute; inset: 0; z-index: 50; background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.ap-app-panel {
  width: min(640px, 100%); max-height: min(82vh, 560px); display: flex; flex-direction: column;
  background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
}
.ap-app-panel-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  padding: 16px 18px 12px; border-bottom: 1px solid var(--border);
}
.ap-app-panel-title { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.ap-app-panel-sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.ap-app-close {
  width: 32px; height: 32px; border: none; border-radius: 8px; background: var(--bg-tertiary);
  color: var(--text-secondary); font-size: 20px; cursor: pointer; line-height: 1;
}
.ap-app-close:hover { color: var(--text-primary); }
.ap-app-list { flex: 1; overflow-y: auto; padding: 8px 12px; }
.ap-app-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 10px 8px; border-bottom: 1px solid var(--border);
}
.ap-app-row:last-child { border-bottom: none; }
.ap-app-row.locked { opacity: .55; }
.ap-app-row-main { display: flex; align-items: center; gap: 10px; min-width: 0; flex: 1; }
.ap-app-row-icon { display: flex; flex-shrink: 0; }
.ap-app-row-text { min-width: 0; }
.ap-app-row-name { display: block; font-size: 13px; font-weight: 600; color: var(--text-primary); }
.ap-app-eff { display: block; font-size: 11px; margin-top: 2px; color: var(--text-muted); }
.ap-app-eff.allowed { color: #81c784; }
.ap-app-eff.denied { color: #e57373; }
.ap-app-rules { display: flex; gap: 4px; flex-shrink: 0; }
.ap-app-rule-btn {
  padding: 4px 8px; border-radius: 6px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-secondary); font-size: 11px; cursor: pointer;
}
.ap-app-rule-btn:hover { color: var(--text-primary); }
.ap-app-rule-btn.active { background: color-mix(in srgb, var(--accent) 20%, transparent); border-color: var(--accent); color: var(--accent); font-weight: 600; }
.ap-app-rule-btn.allow.active { border-color: #66bb6a; color: #81c784; background: rgba(102,187,106,.12); }
.ap-app-rule-btn.deny.active { border-color: #ef5350; color: #e57373; background: rgba(239,83,80,.12); }
.ap-app-rule-btn:disabled { cursor: not-allowed; opacity: .45; }
.ap-app-foot { padding: 12px 18px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; }
.grp-apps-section { padding: 12px 16px 16px; border-top: 1px solid var(--border); }

/* ═══════════════════════════════════════════════════════════
   AI Assistant (LLM Chat)
   ═══════════════════════════════════════════════════════════ */
.llm-root {
  display: flex; height: 100%; overflow: hidden;
  background: var(--bg-primary); color: var(--text-primary);
}

/* ── Sidebar ── */
.llm-sidebar {
  width: 230px; flex-shrink: 0;
  display: flex; flex-direction: column;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
}
.llm-sidebar-head { padding: 12px 10px 8px; }
.llm-new-chat-btn {
  width: 100%; display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 8px; border: 1px solid var(--border);
  background: transparent; color: var(--text-primary);
  cursor: pointer; font-size: 13px; font-weight: 500;
  transition: background .15s;
}
.llm-new-chat-btn:hover { background: var(--bg-elevated); }
.llm-new-chat-btn .wos-icon { width: 16px; height: 16px; }

.llm-conv-list {
  flex: 1; overflow-y: auto; padding: 0 6px 8px;
  display: flex; flex-direction: column; gap: 1px;
}
.llm-conv-group-hdr {
  font-size: 10px; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; color: var(--text-muted);
  padding: 10px 8px 3px;
}
.llm-conv-item {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 8px; border-radius: 7px; cursor: pointer;
  transition: background .12s; position: relative;
}
.llm-conv-item:hover { background: var(--bg-elevated); }
.llm-conv-item.active { background: color-mix(in srgb, var(--accent) 15%, transparent); }
.llm-conv-item-title {
  flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-size: 12.5px;
}
.llm-conv-del {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; padding: 2px; border-radius: 4px; opacity: 0;
  transition: opacity .15s; display: flex; align-items: center;
}
.llm-conv-del .wos-icon { width: 13px; height: 13px; }
.llm-conv-item:hover .llm-conv-del { opacity: 1; }
.llm-conv-del:hover { color: var(--color-danger, #e05f3d); }
.llm-conv-empty { font-size: 12px; color: var(--text-muted); padding: 12px 8px; text-align: center; }

.llm-sidebar-foot { padding: 8px 10px 12px; border-top: 1px solid var(--border); }
.llm-foot-btn {
  width: 100%; display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 7px; border: none;
  background: transparent; color: var(--text-secondary); cursor: pointer;
  font-size: 12px; transition: background .15s;
}
.llm-foot-btn:hover { background: var(--bg-elevated); color: var(--text-primary); }
.llm-foot-btn .wos-icon { width: 14px; height: 14px; }

/* ── Main area ── */
.llm-main {
  flex: 1; display: flex; flex-direction: column; overflow: hidden; min-width: 0;
}

/* Top bar */
.llm-topbar {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px; border-bottom: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.llm-conv-title {
  flex: 1; font-size: 13px; font-weight: 600;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.llm-topbar-right { display: flex; align-items: center; gap: 8px; }
.llm-model-select {
  padding: 4px 8px; border-radius: 6px; border: 1px solid var(--border);
  background: var(--bg-primary); color: var(--text-primary); font-size: 12px;
  cursor: pointer;
}
.llm-tools-toggle {
  display: flex; align-items: center; gap: 5px; font-size: 12px;
  color: var(--text-secondary); cursor: pointer; user-select: none;
}
.llm-tools-toggle input { accent-color: var(--accent); }
.llm-tools-toggle .wos-icon { width: 13px; height: 13px; }

/* Message feed */
.llm-feed {
  flex: 1; overflow-y: auto; padding: 20px 0;
  display: flex; flex-direction: column; gap: 4px;
}

/* Welcome screen */
.llm-welcome {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 40px 24px; gap: 10px;
  text-align: center; height: 100%;
}
.llm-welcome-icon .wos-icon-app { width: 52px; height: 52px; color: var(--accent); }
.llm-welcome h2 { font-size: 20px; font-weight: 600; margin: 0; }
.llm-welcome p  { color: var(--text-secondary); font-size: 13px; margin: 0; }
.llm-suggestions { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-top: 8px; max-width: 520px; }
.llm-suggestion {
  padding: 8px 14px; border-radius: 20px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-primary);
  cursor: pointer; font-size: 12px; transition: background .15s, border-color .15s;
}
.llm-suggestion:hover { background: var(--bg-secondary); border-color: var(--accent); }

/* Messages */
.llm-msg {
  display: flex; gap: 12px; padding: 12px 24px;
  align-items: flex-start;
}
.llm-msg:hover { background: rgba(128,128,128,.04); }
.llm-msg-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 18px; overflow: hidden;
}
.llm-av-user { background: var(--accent); color: #fff; }
.llm-av-user img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.llm-av-user .tray-avatar { font-size: 16px; line-height: 1; }
.llm-av-ai { background: color-mix(in srgb, var(--accent) 20%, var(--bg-elevated)); }
.llm-av-ai .wos-icon-app { width: 18px; height: 18px; color: var(--accent); }

.llm-msg-body { flex: 1; min-width: 0; }
.llm-msg-content {
  font-size: 13.5px; line-height: 1.65;
  color: var(--text-primary); word-break: break-word;
}
.llm-msg-user .llm-msg-content { }
.llm-msg-assistant .llm-msg-content { }
.llm-msg-content h1, .llm-msg-content h2, .llm-msg-content h3 {
  margin: .8em 0 .3em; font-weight: 600;
}
.llm-msg-content h1 { font-size: 17px; }
.llm-msg-content h2 { font-size: 15px; }
.llm-msg-content h3 { font-size: 13.5px; }
.llm-msg-content p  { margin: .4em 0; }
.llm-msg-content ul, .llm-msg-content ol { padding-left: 20px; margin: .4em 0; }
.llm-msg-content li { margin: .2em 0; }
.llm-msg-content blockquote {
  border-left: 3px solid var(--accent); padding-left: 12px; margin: .5em 0;
  color: var(--text-secondary); font-style: italic;
}
.llm-msg-content hr { border: none; border-top: 1px solid var(--border); margin: 1em 0; }
.llm-msg-content a { color: var(--accent); text-decoration: none; }
.llm-msg-content a:hover { text-decoration: underline; }
.llm-msg-content table { border-collapse: collapse; width: 100%; margin: .6em 0; font-size: 12.5px; }
.llm-msg-content th, .llm-msg-content td {
  padding: 5px 10px; border: 1px solid var(--border); text-align: left;
}
.llm-msg-content th { background: var(--bg-elevated); font-weight: 600; }

/* Code */
.llm-code-block {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; padding: 12px 16px; margin: .6em 0;
  overflow-x: auto; font-size: 12px; line-height: 1.55;
  font-family: 'Cascadia Code', 'Fira Code', 'JetBrains Mono', monospace;
}
.llm-inline-code {
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: 4px; padding: 1px 5px; font-family: monospace; font-size: .88em;
}

/* Blinking cursor */
@keyframes llm-blink { 0%,100% { opacity: 1; } 50% { opacity: 0; } }
.llm-cursor {
  display: inline-block; width: 2px; height: 14px;
  background: var(--text-primary); margin-left: 2px;
  vertical-align: middle; border-radius: 1px;
  animation: llm-blink 1s step-start infinite;
}

/* Message actions */
.llm-msg-actions {
  display: flex; gap: 6px; margin-top: 6px; opacity: 0;
  transition: opacity .15s;
}
.llm-msg:hover .llm-msg-actions { opacity: 1; }
.llm-act-btn {
  display: flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 5px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-secondary);
  cursor: pointer; font-size: 11px; transition: background .12s;
}
.llm-act-btn:hover { background: var(--bg-secondary); color: var(--text-primary); }
.llm-act-btn .wos-icon { width: 12px; height: 12px; }

/* Tool call indicator */
.llm-tool-call {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 24px; font-size: 11.5px; color: var(--text-muted);
}
.llm-tool-icon .wos-icon { width: 13px; height: 13px; }
.llm-tool-name { font-weight: 600; color: var(--text-secondary); font-family: monospace; }
.llm-tool-preview { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 300px; }
.llm-tool-running .llm-tool-spinner .wos-icon {
  width: 13px; height: 13px; color: var(--accent);
  animation: spin 1s linear infinite;
}
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* Error message */
.llm-error {
  display: flex; align-items: center; gap: 6px;
  color: var(--color-danger, #e05f3d); font-size: 13px;
  padding: 8px 12px; background: rgba(224,95,61,.08);
  border: 1px solid rgba(224,95,61,.25); border-radius: 8px;
}
.llm-error .wos-icon { width: 14px; height: 14px; }

/* ── Input area ── */
.llm-input-wrap {
  padding: 10px 20px 14px; border-top: 1px solid var(--border);
  background: var(--bg-secondary); flex-shrink: 0;
}
.llm-input-box {
  display: flex; align-items: flex-end; gap: 8px;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: 12px; padding: 6px 8px 6px 14px;
  transition: border-color .15s;
}
.llm-input-box:focus-within { border-color: var(--accent); }
.llm-input {
  flex: 1; resize: none; border: none; background: transparent;
  color: var(--text-primary); font-size: 13.5px; line-height: 1.5;
  outline: none; max-height: 180px; overflow-y: auto; padding: 4px 0;
  font-family: inherit;
}
.llm-input::placeholder { color: var(--text-muted); }
.llm-input-actions { display: flex; gap: 4px; align-items: flex-end; padding-bottom: 2px; }
.llm-send-btn, .llm-stop-btn {
  width: 32px; height: 32px; border-radius: 8px; border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .15s;
}
.llm-send-btn { background: var(--accent); color: #fff; }
.llm-send-btn:hover { background: color-mix(in srgb, var(--accent) 80%, #000); }
.llm-send-btn .wos-icon { width: 16px; height: 16px; }
.llm-stop-btn { background: var(--bg-elevated); color: var(--text-primary); border: 1px solid var(--border); }
.llm-stop-btn:hover { background: var(--bg-secondary); }
.llm-stop-btn .wos-icon { width: 14px; height: 14px; }
.llm-input-footer {
  display: flex; align-items: center; gap: 10px; margin-top: 6px;
  font-size: 11px;
}
.llm-model-badge {
  padding: 2px 7px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-muted); font-size: 10.5px;
}
.llm-key-status { display: flex; align-items: center; gap: 4px; font-size: 11px; }
.llm-key-status .wos-icon { width: 12px; height: 12px; }
.llm-key-ok  { color: #66bb6a; }
.llm-key-warn { color: #ffa726; }
.llm-key-link { color: var(--accent); cursor: pointer; text-decoration: underline; }

/* No-key setup card */
.llm-nokey-banner {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 40px 32px; max-width: 400px; margin: 24px auto;
  background: var(--bg-elevated); border: 1.5px dashed var(--border);
  border-radius: 16px; text-align: center;
}
.llm-nokey-icon { color: var(--accent); }
.llm-nokey-icon .wos-icon { width: 40px; height: 40px; stroke-width: 1.5; }
.llm-nokey-banner h3 { margin: 0; font-size: 17px; font-weight: 700; }
.llm-nokey-banner p { margin: 0; font-size: 13px; color: var(--text-secondary); line-height: 1.55; }
.llm-nokey-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 22px; border-radius: 10px; border: none; cursor: pointer;
  background: var(--accent); color: #fff; font-size: 13.5px; font-weight: 600;
}
.llm-nokey-btn .wos-icon { width: 15px; height: 15px; }
.llm-nokey-btn:hover { filter: brightness(1.08); }
.llm-nokey-link { font-size: 12px; color: var(--text-muted); text-decoration: none; }
.llm-nokey-link:hover { color: var(--accent); text-decoration: underline; }

/* ── Settings form (inside dialog) ── */
.llm-settings-form { display: flex; flex-direction: column; gap: 16px; padding: 4px 0; }
.llm-sf-group { display: flex; flex-direction: column; gap: 6px; }
.llm-sf-label { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.llm-sf-row { display: flex; gap: 6px; }
.llm-sf-input {
  flex: 1; padding: 7px 10px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-primary); font-size: 13px; outline: none;
}
.llm-sf-input:focus { border-color: var(--accent); }
.llm-sf-eyebtn {
  padding: 7px 10px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-secondary); cursor: pointer;
  display: flex; align-items: center;
}
.llm-sf-hint { font-size: 11px; color: var(--text-muted); margin: 0; }
.llm-sf-hint a { color: var(--accent); }
.llm-sf-syskey-note {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: #66bb6a; background: rgba(102,187,106,.08);
  border: 1px solid rgba(102,187,106,.25); border-radius: 7px; padding: 8px 12px;
}
.llm-sf-syskey-note .wos-icon { width: 14px; height: 14px; }

/* Admin portal AI section */
.ap-ai-form { display: flex; flex-direction: column; gap: 18px; max-width: 560px; }
.ap-ai-key-row { display: flex; gap: 6px; }
.ap-ai-status {
  display: flex; align-items: center; gap: 6px; font-size: 12.5px;
  padding: 8px 12px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-elevated);
}
.ap-ai-status .wos-icon { width: 14px; height: 14px; }
.ap-ai-actions { display: flex; gap: 8px; }

/* Admin AI enable/disable toggle row */
.ap-toggle-row {
  display: inline-flex; align-items: center; gap: 10px; cursor: pointer;
  padding: 6px 10px 6px 0; user-select: none;
}
.ap-toggle {
  width: 40px; height: 22px; border-radius: 11px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  position: relative; flex-shrink: 0; cursor: pointer;
  transition: background .2s, border-color .2s;
}
.ap-toggle::after {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--text-muted);
  transition: left .2s, background .2s;
}
.ap-toggle.on { background: var(--accent); border-color: var(--accent); }
.ap-toggle.on::after { left: 20px; background: #fff; }

/* ── In-app AI sparkle button (shared across Tasks / Calendar / Journal / Mail) */
.wos-ai-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 6px; border: none; cursor: pointer;
  font-size: 12px; font-weight: 500;
  background: linear-gradient(135deg, rgba(108,79,240,.18) 0%, rgba(0,122,255,.18) 100%);
  color: var(--accent);
  border: 1px solid rgba(108,79,240,.22);
  transition: background .15s, transform .1s;
  white-space: nowrap;
}
.wos-ai-btn:hover {
  background: linear-gradient(135deg, rgba(108,79,240,.28) 0%, rgba(0,122,255,.28) 100%);
  transform: translateY(-1px);
}
.wos-ai-btn:active { transform: translateY(0); }
.wos-ai-btn .wos-ai-spark { font-size: 13px; }
/* Disabled state when AI is not ready */
.wos-ai-btn:disabled { opacity: .35; cursor: default; transform: none; }

/* Settings AI section */
.ai-sf-block { display: flex; flex-direction: column; gap: 6px; margin-bottom: 4px; }
.ai-sf-block label { font-size: 12px; font-weight: 600; }
.ai-sys-note {
  display: flex; align-items: center; gap: 6px; font-size: 12px; color: #66bb6a;
  background: rgba(102,187,106,.08); border: 1px solid rgba(102,187,106,.25);
  border-radius: 6px; padding: 7px 10px;
}
.ai-sys-note .wos-icon { width: 13px; height: 13px; }

/* ── Admin Portal: System Logs ─────────────────────────────────────── */
.syslog-section-title {
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  color: var(--text-secondary); margin-bottom: 8px;
  display: flex; align-items: center; gap: 6px;
}
.syslog-section-title .wos-icon { width: 14px; height: 14px; }

.syslog-current-errors {
  background: rgba(224,82,82,.08); border: 1px solid rgba(224,82,82,.3);
  border-radius: 8px; padding: 12px 16px; margin-bottom: 16px;
}
.syslog-ok-banner {
  display: flex; align-items: center; gap: 8px;
  background: rgba(102,187,106,.08); border: 1px solid rgba(102,187,106,.3);
  border-radius: 8px; padding: 10px 16px; font-size: 13px;
  color: #66bb6a; margin-bottom: 16px;
}
.syslog-ok-banner .wos-icon { width: 15px; height: 15px; }

.syslog-error-list {
  margin: 8px 0 0 0; padding-left: 18px;
  font-size: 12.5px; line-height: 1.6; color: var(--text-primary);
}
.syslog-error-list li { margin-bottom: 6px; }
.syslog-stack {
  font-size: 10.5px; color: var(--text-muted); background: var(--bg-base);
  border-radius: 4px; padding: 4px 8px; margin: 4px 0 0; overflow-x: auto;
  white-space: pre-wrap; word-break: break-all;
}

.syslog-entry {
  border-radius: 7px; border: 1px solid var(--border);
  padding: 10px 14px; margin-bottom: 8px;
}
.syslog-entry-error { border-color: rgba(224,82,82,.4); background: rgba(224,82,82,.04); }
.syslog-entry-ok    { background: var(--bg-elevated); }
.syslog-entry-header {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-size: 12.5px;
}
.syslog-entry-date { color: var(--text-primary); font-weight: 500; }
.syslog-entry-meta { color: var(--text-muted); font-size: 11.5px; margin-left: auto; }

.syslog-badge {
  display: inline-block; padding: 1px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 700;
}
.syslog-badge-ok    { background: rgba(102,187,106,.15); color: #66bb6a; }
.syslog-badge-error { background: rgba(224,82,82,.15); color: #e05252; }

.syslog-vfs-log {
  font-size: 11px; line-height: 1.55; background: var(--bg-base);
  border: 1px solid var(--border); border-radius: 6px; padding: 12px;
  overflow-x: auto; white-space: pre-wrap; word-break: break-all;
  max-height: 300px; overflow-y: auto; color: var(--text-secondary);
}

/* ═══════════════════════════════════════════════════════
   Runtime Log (Admin Portal — System Logs section)
   ═══════════════════════════════════════════════════════ */
.rl-count {
  font-size: 11px; font-weight: 400; color: var(--text-muted);
  text-transform: none; letter-spacing: 0; margin-left: 8px;
}

.rl-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px; gap: 8px; flex-wrap: wrap;
}
.rl-filter-btns { display: flex; gap: 4px; }
.rl-filter {
  padding: 3px 11px; border-radius: 99px; font-size: 11.5px; font-weight: 500;
  border: 1px solid var(--border); background: transparent; color: var(--text-muted);
  cursor: pointer; transition: background .12s, color .12s;
}
.rl-filter.active, .rl-filter:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.rl-filter-error.active  { background: #e05252; border-color: #e05252; }
.rl-filter-error:not(.active):hover { background: rgba(224,82,82,.15); color: #e05252; }
.rl-filter-warn.active   { background: #f4a22d; border-color: #f4a22d; }
.rl-filter-warn:not(.active):hover  { background: rgba(244,162,45,.15); color: #f4a22d; }
.rl-filter-info.active   { background: #5294e2; border-color: #5294e2; }
.rl-filter-info:not(.active):hover  { background: rgba(82,148,226,.15); color: #5294e2; }
.rl-live-label {
  display: flex; align-items: center; gap: 5px;
  font-size: 11.5px; color: var(--text-muted); cursor: pointer;
  user-select: none;
}
.rl-live-label input { cursor: pointer; }

/* User filter dropdown */
.rl-user-filter-wrap {
  display: flex; align-items: center; gap: 5px;
}
.rl-user-filter-label { font-size: 11.5px; color: var(--text-muted); }
.rl-user-select {
  font-size: 11.5px; padding: 3px 7px;
  border: 1px solid var(--border); border-radius: 6px;
  background: var(--bg-secondary); color: var(--text);
  cursor: pointer;
}

.rl-table-wrap {
  border: 1px solid var(--border); border-radius: 8px;
  overflow: hidden; max-height: 380px; overflow-y: auto;
}
.rl-table {
  width: 100%; border-collapse: collapse;
  font-family: 'Consolas','Cascadia Code','Fira Code','Courier New',monospace;
  font-size: 11.5px;
}
.rl-th {
  padding: 7px 10px; background: var(--surface);
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-muted);
  border-bottom: 1px solid var(--border); text-align: left;
  position: sticky; top: 0; z-index: 1;
}
.rl-row { border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent); }
.rl-row:last-child { border-bottom: none; }
.rl-row:hover { background: var(--hover); }
.rl-row-error { background: rgba(224,82,82,.04); }
.rl-row-warn  { background: rgba(244,162,45,.04); }

.rl-td { padding: 5px 10px; vertical-align: top; }
.rl-td-time   { color: var(--text-muted); white-space: nowrap; font-size: 11px; }
.rl-td-level  { white-space: nowrap; }
.rl-td-user   { font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 90px; font-weight: 500; }
.rl-user-system { color: var(--text-muted); font-style: italic; }
.rl-td-app    { white-space: nowrap; }
.rl-td-source { white-space: nowrap; }
.rl-td-msg    { color: var(--text); word-break: break-word; }
.rl-td-copy   { width: 36px; text-align: center; padding: 0 4px; }
.rl-copy-btn  {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); padding: 3px 5px; border-radius: 5px;
  display: inline-flex; align-items: center; opacity: 0;
  transition: opacity .15s, color .15s, background .15s;
}
.rl-row:hover .rl-copy-btn { opacity: 1; }
.rl-copy-btn:hover { color: var(--accent); background: color-mix(in srgb, var(--accent) 12%, transparent); }

.rl-badge {
  display: inline-block; padding: 1px 6px; border-radius: 4px;
  font-size: 10px; font-weight: 700; letter-spacing: .04em;
}
.rl-badge-error { background: rgba(224,82,82,.18); color: #e05252; }
.rl-badge-warn  { background: rgba(244,162,45,.18); color: #f4a22d; }
.rl-badge-info  { background: rgba(82,148,226,.18); color: #5294e2; }
.rl-badge-debug { background: rgba(100,100,100,.18); color: var(--text-muted); }

.rl-source {
  display: inline-block; padding: 1px 6px; border-radius: 4px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent); font-size: 10.5px;
}
.rl-empty {
  text-align: center; padding: 24px; color: var(--text-muted); font-family: var(--font-ui);
}

/* ── Admin Portal: Add User Modal ───────────────────────────────────────── */
.ap-modal-backdrop {
  position: fixed; inset: 0; z-index: 9500;
  background: rgba(0,0,0,.55); backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center;
  animation: ap-backdrop-in .18s ease;
}
@keyframes ap-backdrop-in { from { opacity: 0; } to { opacity: 1; } }

.ap-modal {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  width: 560px; max-width: 96vw;
  max-height: 88vh; overflow-y: auto;
  display: flex; flex-direction: column;
  animation: ap-modal-in .22s cubic-bezier(.25,.8,.25,1);
}
@keyframes ap-modal-in {
  from { opacity: 0; transform: translateY(16px) scale(.97); }
  to   { opacity: 1; transform: none; }
}

.ap-modal-hdr {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 20px 16px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.ap-modal-icon-wrap {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(82,148,226,.12);
  border: 2px solid rgba(82,148,226,.3);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: border-color .2s;
}
.ap-nu-avatar-preview { font-size: 28px; line-height: 1; }
.ap-modal-title { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.ap-modal-sub   { font-size: 12px; color: var(--text-muted); margin-top: 1px; }
.ap-modal-close {
  margin-left: auto; background: none; border: none;
  color: var(--text-muted); font-size: 20px; line-height: 1;
  cursor: pointer; padding: 4px 8px; border-radius: 6px;
  transition: color .15s, background .15s;
}
.ap-modal-close:hover { color: var(--text-primary); background: var(--bg-tertiary); }

.ap-modal-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 18px; }
.ap-modal-footer {
  padding: 14px 20px; border-top: 1px solid var(--border);
  display: flex; gap: 8px; justify-content: flex-end; flex-shrink: 0;
}

/* Sections inside the modal */
.ap-nu-section { display: flex; flex-direction: column; gap: 8px; }
.ap-nu-section-lbl {
  font-size: 10.5px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--text-muted);
  border-bottom: 1px solid var(--border); padding-bottom: 5px;
}
.ap-nu-optional { font-weight: 400; text-transform: none; font-size: 10px; }
.ap-nu-required { color: var(--accent); }

.ap-nu-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.ap-nu-field { display: flex; flex-direction: column; gap: 4px; }
.ap-nu-label { font-size: 11px; font-weight: 600; color: var(--text-secondary); }
.ap-nu-hint  { font-size: 10px; color: var(--text-muted); }

/* Avatar grid */
.ap-nu-avatar-grid { display: flex; flex-wrap: wrap; gap: 5px; }
.ap-nu-avatar-btn {
  width: 34px; height: 34px; font-size: 18px;
  background: var(--bg); border: 1.5px solid transparent;
  border-radius: 8px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: border-color .12s, background .12s, transform .1s;
  padding: 0;
}
.ap-nu-avatar-btn:hover { background: rgba(82,148,226,.15); }
.ap-nu-avatar-btn.selected {
  border-color: var(--accent); background: rgba(82,148,226,.2);
  transform: scale(1.15);
}

/* Password field with show/hide */
.ap-nu-pwd-wrap { position: relative; display: flex; align-items: center; }
.ap-nu-pwd-wrap .ap-field-input { padding-right: 36px; }
.ap-nu-pwd-eye {
  position: absolute; right: 8px;
  background: none; border: none; cursor: pointer;
  font-size: 15px; padding: 0; color: var(--text-muted);
  transition: color .15s;
}
.ap-nu-pwd-eye:hover { color: var(--text-primary); }

/* Permission toggles */
.ap-nu-toggles { display: flex; flex-direction: column; gap: 6px; }
.ap-nu-toggle-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 8px;
  background: var(--bg); border: 1px solid var(--border);
  cursor: pointer; transition: background .15s;
}
.ap-nu-toggle-row:hover { background: var(--bg-tertiary); }
.ap-nu-checkbox { display: none; }
.ap-nu-toggle-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.ap-nu-toggle-title { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.ap-nu-toggle-desc  { font-size: 11px; color: var(--text-muted); }

/* Error */
.ap-nu-error {
  padding: 8px 12px; border-radius: 7px;
  background: rgba(224,82,82,.1); color: #e05252;
  border: 1px solid rgba(224,82,82,.25); font-size: 12px;
}

/* Responsive: single column on narrow modal */
@media (max-width: 480px) { .ap-nu-2col { grid-template-columns: 1fr; } }

/* Admin Portal shared field + button classes */
.ap-field-group { display: flex; flex-direction: column; gap: 5px; }
.ap-brand-logo-preview {
  width: 72px; height: 72px; object-fit: contain; border-radius: 12px;
  border: 1px solid var(--border, rgba(255,255,255,.12)); background: rgba(0,0,0,.15);
  flex-shrink: 0;
}
.ap-brand-logo-ph {
  display: flex; align-items: center; justify-content: center;
  color: var(--accent, #5294e2);
}
.ap-field-label { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.ap-field-hint  { font-size: 11.5px; color: var(--text-muted); margin: 0; line-height: 1.5; }
.ap-field-input {
  padding: 7px 10px; border-radius: 7px; border: 1px solid var(--input-border);
  background: var(--input-bg); color: var(--text-primary); font-size: 13px;
  outline: none; width: 100%; box-sizing: border-box; font-family: inherit;
  transition: border-color .15s;
}
.ap-field-input:focus { border-color: var(--accent); }

.ap-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 7px; border: 1px solid var(--border);
  background: var(--bg-elevated); color: var(--text-primary);
  font-size: 12.5px; font-weight: 500; cursor: pointer; white-space: nowrap;
}
.ap-btn:hover { background: var(--bg-tertiary); }
.ap-btn .wos-icon { width: 14px; height: 14px; }

.ap-btn-primary {
  background: var(--accent); border-color: var(--accent); color: #fff;
}
.ap-btn-primary:hover { filter: brightness(1.08); }

.ap-btn-danger {
  background: rgba(224,82,82,.1); color: #e05252;
  border-color: rgba(224,82,82,.3);
}
.ap-btn-danger:hover { background: rgba(224,82,82,.2); }

/* ── App Store ──────────────────────────────────────────────────────────── */
.as-summary-chips {
  display: flex; gap: 8px; align-items: center; flex-shrink: 0;
}
.as-summary-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 11px; border-radius: 12px; font-size: 11.5px; font-weight: 500;
  background: var(--bg-tertiary); color: var(--text-secondary);
  border: 1px solid var(--border);
}
.as-chip-installed { background: rgba(72,199,142,.1); color: #48c78e; border-color: rgba(72,199,142,.25); }
.as-summary-chip .wos-icon { width: 13px; height: 13px; }

/* Tab bar */
.as-tabs {
  display: flex; gap: 2px;
  border-bottom: 2px solid var(--border);
  margin-bottom: 18px; margin-top: 12px;
}
.as-tab-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; border: none; background: none;
  color: var(--text-secondary); font-size: 12.5px; font-weight: 500;
  cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px;
  border-radius: 6px 6px 0 0; transition: color .15s, background .15s;
}
.as-tab-btn:hover  { background: var(--bg-tertiary); color: var(--text-primary); }
.as-tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); background: rgba(var(--accent-rgb,.5,.5,1),.06); }
.as-tab-btn .wos-icon { width: 14px; height: 14px; }

/* App list cards */
.as-group-label {
  display: flex; align-items: center; gap: 7px;
  font-size: 11.5px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .06em;
  margin: 4px 0 10px;
}
.as-group-label .wos-icon { width: 13px; height: 13px; }

.as-app-list {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px;
}

.as-app-card {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 12px 14px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--bg-elevated); transition: border-color .15s;
}
.as-app-card:hover { border-color: var(--accent); }
.as-app-card-builtin { opacity: .78; }
.as-app-card-builtin:hover { border-color: var(--border); opacity: .85; }

.as-card-icon {
  width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-tertiary); overflow: hidden;
}
.as-card-icon .wos-icon, .as-card-icon svg { width: 22px; height: 22px; }
.as-card-icon-default .wos-icon { color: var(--text-muted); }
.as-card-icon-builtin { background: rgba(var(--accent-rgb,100,150,255),.1); }
.as-card-icon-builtin .wos-icon { color: var(--accent); }

.as-card-body { flex: 1; min-width: 0; }
.as-card-name { font-size: 13.5px; font-weight: 600; color: var(--text-primary); margin-bottom: 3px; }
.as-card-meta {
  display: flex; flex-wrap: wrap; gap: 6px 12px;
  font-size: 11.5px; color: var(--text-muted); margin-bottom: 4px;
}
.as-card-desc   { font-size: 12px; color: var(--text-secondary); line-height: 1.45; margin-top: 2px; }
.as-card-source { font-size: 11px; color: var(--text-muted); margin-top: 4px; }

.as-card-actions {
  display: flex; align-items: center; gap: 7px; flex-shrink: 0; padding-top: 2px;
}

.as-installed-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 12px; font-size: 11px; font-weight: 600;
  background: rgba(72,199,142,.15); color: #48c78e;
  border: 1px solid rgba(72,199,142,.3);
}
.as-installed-badge .wos-icon { width: 12px; height: 12px; }

.as-builtin-lock {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11.5px; color: var(--text-muted); padding: 4px 8px;
}
.as-builtin-lock .wos-icon { width: 13px; height: 13px; }

.as-admin-badge {
  padding: 1px 7px; border-radius: 8px; font-size: 10.5px; font-weight: 600;
  background: rgba(224,82,82,.12); color: #e05252;
}

/* Empty state */
.as-empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 32px 20px; gap: 10px; text-align: center;
  border: 2px dashed var(--border); border-radius: 12px;
  background: var(--bg-tertiary); margin-bottom: 10px;
}
.as-empty-state .wos-icon { width: 36px; height: 36px; color: var(--text-muted); opacity: .5; }
.as-empty-title { font-size: 14px; font-weight: 600; color: var(--text-secondary); }
.as-empty-sub   { font-size: 12.5px; color: var(--text-muted); }

/* Install panel */
.as-panel {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
  margin-bottom: 14px;
}
.as-panel-title {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  margin-bottom: 8px;
}
.as-panel-title .wos-icon { color: var(--accent); width: 15px; height: 15px; }

.as-install-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }

.as-file-label {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 7px; border: 1.5px dashed var(--border);
  background: var(--bg-tertiary); color: var(--text-primary);
  font-size: 12.5px; font-weight: 500; cursor: pointer; white-space: nowrap;
}
.as-file-label:hover { border-color: var(--accent); color: var(--accent); }
.as-file-label .wos-icon { width: 14px; height: 14px; }

.as-zip-filename { font-size: 12px; color: var(--text-muted); font-style: italic; }

.as-status {
  margin-top: 10px; padding: 8px 12px; border-radius: 7px;
  display: flex; align-items: center; gap: 6px; font-size: 12.5px;
}
.as-status.hidden { display: none; }
.as-status-ok  { background: rgba(72,199,142,.12); color: #48c78e; border: 1px solid rgba(72,199,142,.25); }
.as-status-err { background: rgba(224,82,82,.1);   color: #e05252; border: 1px solid rgba(224,82,82,.25); }
.as-status-info{ background: rgba(100,150,255,.1); color: var(--accent); border: 1px solid rgba(100,150,255,.2); }
.as-status .wos-icon { width: 14px; height: 14px; }

.as-catalog-loading {
  font-size: 12px; color: var(--text-muted); padding: 16px;
  text-align: center; font-style: italic;
}

/* Developer code blocks */
.as-code-block {
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 8px; padding: 12px 14px; margin: 8px 0 0;
  font-size: 11.5px; line-height: 1.7; overflow-x: auto;
  color: var(--text-secondary); font-family: 'Courier New', monospace;
  white-space: pre;
}

.ap-empty {
  font-size: 12.5px; color: var(--text-muted); text-align: center;
  padding: 20px 0; font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════
   GRAPHCALC
═══════════════════════════════════════════════════════════════ */
.gc-root { display:flex; height:100%; overflow:hidden; font-size:13px; background:var(--surface); outline:none; }

/* ── Sidebar ── */
.gc-sidebar {
  display:flex; flex-direction:column;
  width:270px; min-width:270px;
  border-right:1px solid var(--border);
  background:var(--surface-raised);
}

.gc-display {
  padding:10px 14px 8px;
  border-bottom:1px solid var(--border);
  min-height:68px;
}
.gc-display-expr {
  font-size:11px; color:var(--text-muted);
  min-height:18px; text-align:right;
  word-break:break-all; line-height:1.4;
}
.gc-display-result {
  font-size:24px; font-weight:600; color:var(--text);
  text-align:right; min-height:32px;
  word-break:break-all; line-height:1.2;
  transition: color .15s;
}
.gc-display-result.error { font-size:14px; color:var(--danger, #e25252); }

.gc-history { flex:1; overflow-y:auto; padding:4px 0; }

.gc-mode-selector {
  display: flex; justify-content: space-around;
  padding: 8px 5px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-raised);
}

.gc-mode-btn {
  padding: 5px 8px;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--surface);
  color: var(--text-muted);
  font-size: 11px;
  cursor: pointer;
  flex-grow: 1; /* Distribute space evenly */
  margin: 0 2px;
  text-align: center;
}

.gc-mode-btn:hover { background: var(--hover); color: var(--text); }
.gc-mode-btn.active { background: var(--theme-a-90); color: var(--text-inverted); border-color: var(--theme-a-90); }

.gc-mode-btn:first-child { margin-left: 0; }
.gc-mode-btn:last-child { margin-right: 0; }

.gc-hist-empty {
  padding:12px 14px; font-size:12px;
  color:var(--text-muted); font-style:italic;
}
.gc-hist-item {
  display:flex; justify-content:space-between; align-items:center;
  padding:3px 14px; cursor:pointer; gap:8px;
}
.gc-hist-item:hover { background:var(--hover); }
.gc-hist-expr {
  font-size:11px; color:var(--text-muted);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.gc-hist-val { font-size:13px; color:var(--text); font-weight:500; white-space:nowrap; }

/* ── Keypad ── */
.gc-keypad {
  padding:6px 6px 8px;
  display:grid; grid-template-columns:repeat(5,1fr); gap:4px;
  border-top:1px solid var(--border);
}
.gc-key {
  padding:7px 2px; border:1px solid var(--border); border-radius:6px;
  background:var(--surface); color:var(--text); font-size:12px;
  cursor:pointer; text-align:center; user-select:none;
  transition:background .1s, transform .08s;
  line-height:1;
}
.gc-key:hover  { background:var(--hover); }
.gc-key:active { transform:scale(.92); background:rgba(82,148,226,.18); }
.gc-key.fn     { font-size:11px; color:var(--accent); background:rgba(82,148,226,.07); }
.gc-key.op     { color:var(--accent); font-weight:600; font-size:14px; }
.gc-key.del    { background:rgba(226,82,82,.08); color:#e25252; }
.gc-key.ac     { background:rgba(226,82,82,.14); color:#e25252; font-weight:700; }
.gc-key.eq     {
  background:var(--accent); color:#fff; font-weight:700;
  font-size:18px; border-color:transparent;
}
.gc-key.eq:hover { filter:brightness(1.1); background:var(--accent); }

/* ── Main area ── */
.gc-main { flex:1; display:flex; flex-direction:column; min-width:0; }

.gc-tab-bar {
  display:flex; border-bottom:1px solid var(--border);
  padding:0 10px; gap:0; background:var(--surface-raised); flex-shrink:0;
}
.gc-tab {
  padding:9px 18px; font-size:12.5px; font-weight:500;
  color:var(--text-muted); cursor:pointer;
  border-bottom:2px solid transparent; transition:color .15s;
  white-space:nowrap;
}
.gc-tab:hover  { color:var(--text); }
.gc-tab.active { color:var(--accent); border-bottom-color:var(--accent); }

.gc-panels { flex:1; overflow:hidden; position:relative; }
.gc-panel  { position:absolute; inset:0; display:none; }
.gc-panel.active { display:flex; flex-direction:column; }

/* ── Graph panel ── */
.gc-graph-toolbar {
  display:flex; align-items:center; gap:5px;
  padding:5px 8px; border-bottom:1px solid var(--border);
  background:var(--surface-raised); flex-shrink:0;
}
.gc-graph-btn {
  padding:4px 10px; border:1px solid var(--border); border-radius:5px;
  background:var(--surface); color:var(--text-muted); font-size:11.5px;
  cursor:pointer; white-space:nowrap;
}
.gc-graph-btn:hover { background:var(--hover); color:var(--text); }

.gc-angle-mode,
.gc-base-mode {
  margin-left: 8px;
  padding: 4px 8px;
  min-width: 40px;
  text-align: center;
}

.gc-graph-wrap { flex:1; position:relative; overflow:hidden; }
.gc-canvas { display:block; width:100%; height:100%; cursor:crosshair; }
.gc-graph-info {
  position:absolute; bottom:8px; right:10px; font-size:11px;
  color:var(--text-muted); background:var(--surface);
  border:1px solid var(--border); border-radius:5px;
  padding:3px 10px; pointer-events:none;
  max-width:80%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}

/* ── Y= editor ── */
.gc-yedit { flex:1; overflow-y:auto; padding:14px; display:flex; flex-direction:column; gap:10px; }
.gc-fn-row { display:flex; align-items:center; gap:8px; }
.gc-fn-swatch {
  width:14px; height:14px; border-radius:50%; border:2px solid transparent;
  cursor:pointer; flex-shrink:0; transition:opacity .15s, filter .15s;
}
.gc-fn-swatch.off { opacity:.25; filter:grayscale(1); }
.gc-fn-label { font-size:12.5px; color:var(--text-muted); white-space:nowrap; font-style:italic; }
.gc-fn-input {
  flex:1; border:1px solid var(--border); border-radius:6px;
  padding:5px 9px; background:var(--surface); color:var(--text);
  font-size:12.5px; font-family:'Consolas','Courier New',monospace;
}
.gc-fn-input:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 2px rgba(82,148,226,.15); }
.gc-fn-clear { padding:4px; background:none; border:none; cursor:pointer; color:var(--text-muted); opacity:.5; line-height:0; }
.gc-fn-clear:hover { color:#e25252; opacity:1; }
.gc-fn-clear .wos-icon { width:14px; height:14px; }

/* ── Table panel ── */
.gc-table-wrap { flex:1; overflow:auto; }
.gc-table-wrap table { width:100%; border-collapse:collapse; font-size:12px; }
.gc-table-wrap th {
  position:sticky; top:0; background:var(--surface-raised);
  border-bottom:2px solid var(--border);
  padding:6px 14px; text-align:right; font-weight:600; color:var(--text-muted);
  white-space:nowrap;
}
.gc-table-wrap th:first-child { text-align:center; }
.gc-table-wrap td {
  padding:3px 14px; border-bottom:1px solid var(--border);
  text-align:right; font-family:'Consolas','Courier New',monospace; font-size:11.5px;
}
.gc-table-wrap td:first-child { text-align:center; color:var(--text-muted); }
.gc-table-wrap tr:hover td { background:var(--hover); }
.gc-table-toolbar {
  padding:8px 12px; border-top:1px solid var(--border);
  display:flex; gap:8px; flex-shrink:0;
}
.gc-table-btn {
  padding:5px 14px; border:1px solid var(--border); border-radius:6px;
  background:var(--surface); color:var(--text); font-size:12px;
  cursor:pointer; display:flex; align-items:center; gap:6px;
}
.gc-table-btn:hover { background:var(--hover); }
.gc-table-btn .wos-icon { width:14px; height:14px; }

/* ════════════════════════════════════════════════════════
   APP STUDIO  (DevIDE)
   ════════════════════════════════════════════════════════ */

.di-root {
  display:flex; flex-direction:column; height:100%; overflow:hidden;
  background:var(--bg-primary); color:var(--text);
  font-family: system-ui, sans-serif;
}

/* ── Toolbar ── */
.di-toolbar {
  display:flex; align-items:center; gap:6px;
  padding:0 10px; height:42px; flex-shrink:0;
  background:var(--surface-raised);
  border-bottom:2px solid var(--border);
}
.di-project-name {
  font-size:13px; font-weight:600; color:var(--text);
  margin-right:4px; max-width:200px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.di-toolbar-gap { flex:1; }
.di-toolbar-sep { width:1px; height:20px; background:var(--border); margin:0 4px; }

.di-btn {
  display:flex; align-items:center; gap:5px;
  padding:5px 10px; font-size:12px; border-radius:6px;
  border:1px solid var(--border); background:var(--surface-raised);
  color:var(--text); cursor:pointer; white-space:nowrap;
}
.di-btn:hover:not(:disabled) { background:var(--hover); }
.di-btn:disabled { opacity:0.4; cursor:default; }
.di-btn .wos-icon { width:14px; height:14px; }

.di-btn-run {
  background:var(--accent); border-color:var(--accent);
  color:#fff; font-weight:600;
}
.di-btn-run:hover:not(:disabled) { filter:brightness(1.1); background:var(--accent); }
.di-btn-ai {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  border-color: var(--accent); color: var(--accent); font-weight:600;
}
.di-btn-ai:hover:not(:disabled) { background: color-mix(in srgb, var(--accent) 25%, transparent); }

/* ── Body split ── */
.di-body {
  display:flex; flex:1; overflow:hidden;
}

/* ── Editor pane — grows to fill all available space ── */
.di-editor-pane {
  display:flex; flex-direction:column;
  flex:1; min-width:320px;
  border-right:2px solid var(--border);
  overflow:hidden;
}

.di-file-tabs {
  display:flex; flex-shrink:0; overflow-x:auto;
  background:var(--surface-raised); border-bottom:1px solid var(--border);
}
.di-file-tabs::-webkit-scrollbar { height:3px; }
.di-file-tabs::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }

.di-tab {
  display:flex; align-items:center; gap:5px;
  padding:0 14px; height:34px; font-size:12px;
  color:var(--text-muted); cursor:pointer; white-space:nowrap;
  border-right:1px solid var(--border); border-bottom:2px solid transparent;
  transition:color .15s, background .15s;
}
.di-tab:hover { color:var(--text); background:var(--hover); }
.di-tab.active {
  color:var(--text); border-bottom-color:var(--accent);
  background:var(--bg-primary);
}
.di-dot {
  display:inline-block; width:6px; height:6px;
  border-radius:50%; background:var(--accent); margin-left:2px;
}
/* Design tab — distinctive accent */
.di-tab-design { color:var(--accent) !important; font-weight:600; letter-spacing:.02em; }
.di-tab-design:hover { color:var(--text) !important; }
.di-tab-design.active { background:color-mix(in srgb, var(--accent) 10%, transparent); }

/* Design pane — fills the editor area, hosts AppStudio canvas */
.di-design-pane {
  display:flex; flex-direction:column; flex:1; overflow:hidden;
  background:var(--bg-primary);
}

/* ── Editor itself ── */
.di-editor-wrap {
  display:flex; flex:1; overflow:hidden;
  background:var(--bg-primary);
}
.di-line-nums {
  width:44px; flex-shrink:0; overflow:hidden;
  padding:12px 0; text-align:right;
  background:var(--surface); border-right:1px solid var(--border);
  font-family:'Consolas','Cascadia Code','Fira Code','Courier New',monospace;
  font-size:12.5px; line-height:1.6; color:var(--text-muted);
  user-select:none;
}
.di-line-nums div { padding-right:10px; }

/* Container holding the overlay <pre> and the transparent <textarea> */
.di-editor-area {
  position:relative; flex:1; overflow:hidden;
}

/* Syntax-highlight overlay — sits below the transparent textarea */
.di-hl-pre {
  position:absolute; inset:0;
  margin:0; padding:12px 14px;
  overflow:hidden; pointer-events:none;
  font-family:'Consolas','Cascadia Code','Fira Code','Courier New',monospace;
  font-size:12.5px; line-height:1.6;
  tab-size:2; -moz-tab-size:2;
  white-space:pre-wrap; word-break:break-all;
  background:transparent; border:none; outline:none;
  box-sizing:border-box; z-index:0;
}
.di-hl-code {
  display:block; font:inherit; background:transparent; padding:0; border-radius:0;
  white-space:pre-wrap; word-break:break-all;
}

.di-editor {
  position:relative; z-index:1;
  flex:1; width:100%; height:100%;
  border:none; outline:none; resize:none;
  padding:12px 14px;
  background:transparent;
  color:transparent;
  -webkit-text-fill-color:transparent;
  caret-color:var(--text);
  font-family:'Consolas','Cascadia Code','Fira Code','Courier New',monospace;
  font-size:12.5px; line-height:1.6;
  tab-size:2; -moz-tab-size:2;
  overflow:auto; box-sizing:border-box;
}
.di-editor::placeholder { -webkit-text-fill-color:var(--text-muted); font-style:italic; }
.di-editor::-webkit-scrollbar { width:8px; height:8px; }
.di-editor::-webkit-scrollbar-track { background:transparent; }
.di-editor::-webkit-scrollbar-thumb { background:var(--border); border-radius:4px; }

/* ── Syntax token colours (IDE dark palette) ── */
.di-hl-pre .hljs-keyword,
.di-hl-pre .hljs-operator  { color:#c792ea; }
.di-hl-pre .hljs-string,
.di-hl-pre .hljs-regexp    { color:#c3e88d; }
.di-hl-pre .hljs-number,
.di-hl-pre .hljs-literal   { color:#f78c6c; }
.di-hl-pre .hljs-comment   { color:#546e7a; font-style:italic; }
.di-hl-pre .hljs-title,
.di-hl-pre .hljs-function,
.di-hl-pre .hljs-name      { color:#82aaff; }
.di-hl-pre .hljs-built_in,
.di-hl-pre .hljs-type      { color:#89ddff; }
.di-hl-pre .hljs-attr,
.di-hl-pre .hljs-attribute,
.di-hl-pre .hljs-property  { color:#ffcb6b; }
.di-hl-pre .hljs-params,
.di-hl-pre .hljs-variable  { color:#d4d4d4; }
.di-hl-pre .hljs-selector-tag,
.di-hl-pre .hljs-selector-class,
.di-hl-pre .hljs-selector-id { color:#ff5370; }
.di-hl-pre .hljs-tag        { color:#f07178; }
.di-hl-pre .hljs-punctuation,
.di-hl-pre .hljs-meta       { color:#89ddff; }
/* JSON keys look great as accent */
.di-hl-pre .hljs-string.hljs-attr { color:#82aaff; }

/* ── Preview pane — fixed 45% proportion, disappears cleanly ── */
.di-preview-pane {
  display:flex; flex-direction:column;
  flex: 0 0 45%; min-width:260px; overflow:hidden;
  transition: flex 0.2s ease, min-width 0.2s ease;
}
.di-preview-pane.di-preview-hidden {
  flex: 0 0 30px; min-width: 30px; overflow: hidden;
}
/* Only the toggle strip shows when collapsed */
.di-preview-pane.di-preview-hidden .di-preview-wrap,
.di-preview-pane.di-preview-hidden .di-console { display: none; }
.di-preview-pane.di-preview-hidden .di-preview-header {
  flex-direction: column; height: 100%; width: 30px;
  padding: 6px 0; gap: 4px; border-bottom: none;
  border-left: 2px solid var(--border);
  justify-content: flex-start; align-items: center;
}
.di-preview-pane.di-preview-hidden .di-preview-label,
.di-preview-pane.di-preview-hidden #di-refresh,
.di-preview-pane.di-preview-hidden #di-preview-pop { display: none; }
/* Force-hidden: used by Design tab — no strip at all, full width for designer */
.di-preview-pane.di-preview-force-hidden {
  display: none !important;
}
/* Active state — icon tinted when preview is hidden */
.di-preview-toggle.active { color: var(--accent) !important; }
.di-preview-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 10px; height:34px; flex-shrink:0;
  background:var(--surface-raised); border-bottom:2px solid var(--border);
  font-size:12px; color:var(--text-muted);
}
.di-preview-label {
  display:flex; align-items:center; gap:5px;
}
.di-preview-label .wos-icon { width:13px; height:13px; }
.di-preview-header-actions { display:flex; align-items:center; gap:2px; }

.di-icon-btn {
  display:flex; align-items:center; justify-content:center;
  width:26px; height:26px; border-radius:4px; border:none;
  background:transparent; color:var(--text-muted); cursor:pointer;
}
.di-icon-btn:hover { background:var(--hover); color:var(--text); }
.di-icon-btn .wos-icon { width:14px; height:14px; }

.di-preview-wrap {
  flex:1; overflow:hidden; background:var(--bg-primary);
  position:relative;
}
.di-frame {
  width:100%; height:100%;
  border:none; display:block;
  background:var(--bg-primary);
}

/* Preview-popped-out placeholder */
.di-preview-ph {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg-primary);
}
.di-preview-ph-inner {
  display:flex; flex-direction:column; align-items:center; gap:12px;
  color:var(--text-muted); font-size:13px; text-align:center;
  padding:24px;
}
.di-preview-ph-inner .wos-icon { width:28px; height:28px; opacity:.4; }
.di-btn-sm { height:28px; padding:0 12px; font-size:12px; }
.di-btn-ghost {
  background:transparent;
  border-color: var(--border);
  color:var(--text-muted);
}
.di-btn-ghost:hover:not(:disabled) { background:var(--hover); color:var(--text); }

/* ── Console ── */
.di-console {
  height:120px; flex-shrink:0;
  border-top:2px solid var(--border);
  display:flex; flex-direction:column; overflow:hidden;
}
.di-console-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 10px; height:28px; flex-shrink:0;
  background:var(--surface-raised); border-bottom:1px solid var(--border);
  font-size:11px; color:var(--text-muted); font-weight:600; letter-spacing:.04em;
}
.di-console-body {
  flex:1; overflow-y:auto; padding:4px 10px;
  font-family:'Consolas','Courier New',monospace; font-size:11.5px; line-height:1.5;
}
.di-console-body::-webkit-scrollbar { width:6px; }
.di-console-body::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }
.di-console-line { padding:1px 0; border-bottom:1px solid color-mix(in srgb, var(--border) 40%, transparent); }
.di-console-error { color:#f38ba8; }
.di-console-warn  { color:#fab387; }
.di-console-log   { color:var(--text); }

/* ── New Project Modal ── */
.di-modal-overlay {
  position:absolute; inset:0; z-index:100;
  background:rgba(0,0,0,.55);
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(2px);
}
.di-modal-overlay[hidden] { display:none; }

.di-modal {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  width:min(720px, 94%);
  max-height:90%;
  display:flex; flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  overflow:hidden;
}
.di-modal-header {
  display:flex; align-items:center; gap:8px;
  padding:14px 18px;
  font-size:14px; font-weight:700;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.di-modal-header .wos-icon { width:15px; height:15px; color:var(--accent); }
.di-modal-close { margin-left:auto; }

.di-modal-body {
  padding:20px 20px 8px;
  overflow-y:auto; flex:1;
}
.di-modal-body::-webkit-scrollbar { width:6px; }
.di-modal-body::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }

.di-modal-label {
  display:block; font-size:11px; font-weight:700;
  color:var(--text-muted); letter-spacing:.05em;
  margin-bottom:6px;
}
.di-modal-input {
  width:100%; box-sizing:border-box;
  padding:9px 12px; font-size:13px;
  background:var(--surface-raised); border:1px solid var(--border);
  border-radius:6px; color:var(--text); font-family:monospace;
}
.di-modal-input:focus { outline:none; border-color:var(--accent); }
.di-modal-name-hint { font-size:11px; min-height:16px; margin-top:4px; }

.di-modal-section-label {
  font-size:11px; font-weight:700; color:var(--text-muted);
  letter-spacing:.05em; margin:18px 0 10px;
  text-transform:uppercase;
}

/* ── Template cards grid ── */
.di-tpl-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(130px, 1fr));
  gap:10px;
}
.di-tpl-card {
  display:flex; flex-direction:column; gap:6px;
  padding:14px 12px;
  background:var(--bg-primary);
  border:2px solid var(--border);
  border-radius:8px;
  cursor:pointer;
  transition:border-color .15s, background .15s;
}
.di-tpl-card:hover { border-color:color-mix(in srgb,var(--accent) 60%,transparent); background:var(--hover); }
.di-tpl-card.selected {
  border-color:var(--accent);
  background:color-mix(in srgb, var(--accent) 10%, var(--bg-primary));
}
.di-tpl-icon {
  width:36px; height:36px; border-radius:8px;
  background:color-mix(in srgb,var(--accent) 15%, transparent);
  display:flex; align-items:center; justify-content:center;
  color:var(--accent);
}
.di-tpl-icon svg { display:block; }
.di-tpl-name { font-size:13px; font-weight:700; color:var(--text); }
.di-tpl-desc { font-size:11px; color:var(--text-muted); line-height:1.4; }

/* ── Modal footer ── */
.di-modal-footer {
  display:flex; justify-content:flex-end; gap:8px;
  padding:14px 18px;
  border-top:1px solid var(--border);
  flex-shrink:0;
}

/* ── Download icon (if not yet in icons.js) ── */
.di-btn .wos-icon { width:14px; height:14px; }

/* ═══════════════════════════════════════════════════════
   Open Project Modal
   ═══════════════════════════════════════════════════════ */
.di-open-modal {
  width: min(860px, 94vw);
  max-height: 80vh;
  display: flex;
  flex-direction: column;
}
.di-open-search-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px 0;
}
.di-open-search-icon .wos-icon { width:16px; height:16px; color:var(--text-muted); }
.di-open-search-input {
  flex: 1;
  height: 36px;
  padding: 0 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
  font-size: 13px;
  outline: none;
  transition: border-color .15s;
}
.di-open-search-input:focus { border-color: var(--accent); }

.di-open-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 18px 10px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.di-op-section-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}

.di-op-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}

.di-op-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  color: var(--text);
  transition: border-color .15s, background .15s, transform .1s;
  width: 100%;
}
.di-op-card:hover, .di-op-card:focus {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
  outline: none;
  transform: translateY(-1px);
}
.di-op-card:active { transform: translateY(0); }

.di-op-card-icon .wos-icon {
  width: 28px;
  height: 28px;
  color: var(--accent);
  flex-shrink: 0;
  margin-top: 2px;
}

.di-op-card-info { flex: 1; min-width: 0; }
.di-op-card-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.di-op-card-desc {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.di-op-card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}
.di-op-cat-badge {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 99px;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
  font-weight: 500;
  text-transform: lowercase;
}
.di-op-time {
  font-size: 10px;
  color: var(--text-muted);
}

.di-op-section-hint {
  font-size: 10px;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-muted);
  margin-left: 4px;
}

.di-op-sys-badge {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 99px;
  background: color-mix(in srgb, var(--text-muted) 16%, transparent);
  color: var(--text-muted);
  font-weight: 500;
  text-transform: lowercase;
}

.di-op-card-system {
  border-style: dashed;
  opacity: .88;
}
.di-op-card-system:hover,
.di-op-card-system:focus {
  border-style: solid;
  opacity: 1;
}
.di-op-card-icon svg {
  width: 28px;
  height: 28px;
  color: var(--accent);
}

.di-op-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 40px 20px;
  color: var(--text-muted);
  text-align: center;
}
.di-op-empty-icon .wos-icon { width:36px; height:36px; opacity:.35; }
.di-op-empty p { font-size:13px; margin:0; }
.di-op-empty strong { color:var(--text); }

/* ════════════════════════════════════════════════════════
   APP STUDIO — Visual Form Editors (manifest.json / i18n.js)
   ════════════════════════════════════════════════════════ */

/* Form editor container */
.di-form-editor {
  flex:1; overflow-y:auto; background:var(--bg-primary);
  display:flex; flex-direction:column;
}

/* Shared form header */
.di-ff-header {
  padding:12px 20px 11px;
  border-bottom:2px solid var(--border);
  background:var(--surface-raised);
  flex-shrink:0;
}
.di-ff-title {
  display:flex; align-items:center; gap:7px;
  font-size:13px; font-weight:700; color:var(--text);
}
.di-ff-title .wos-icon { width:14px; height:14px; color:var(--accent); }
.di-ff-subtitle {
  display:block; margin-top:3px;
  font-size:11px; color:var(--text-muted);
}

/* ── Manifest form ── */
.di-ff-wrap {
  display:flex; flex-direction:column; height:100%;
}
.di-ff-form {
  padding:16px 20px;
  display:flex; flex-direction:column; gap:12px;
}
.di-ff-row {
  display:grid; grid-template-columns:130px 1fr;
  gap:10px; align-items:start;
}
.di-ff-label {
  font-size:12px; font-weight:700; color:var(--text-muted);
  letter-spacing:.03em; padding-top:9px;
}
.di-ff-req { color:#f38ba8; }
.di-ff-value { display:flex; flex-direction:column; gap:4px; }
.di-ff-input {
  width:100%; box-sizing:border-box;
  padding:7px 10px; font-size:13px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:6px; color:var(--text); font-family:inherit;
}
.di-ff-input:focus { outline:none; border-color:var(--accent); }
.di-ff-textarea { resize:vertical; min-height:70px; font-family:inherit; }
.di-ff-hint { font-size:11px; color:var(--text-muted); line-height:1.4; }

/* Checkbox row */
.di-ff-check-label {
  display:flex; align-items:center; gap:8px;
  cursor:pointer; padding:6px 0;
}
.di-ff-check { width:15px; height:15px; accent-color:var(--accent); cursor:pointer; }
.di-ff-check-on  { display:none; font-size:12px; color:var(--accent); font-weight:600; }
.di-ff-check-off { font-size:12px; color:var(--text-muted); }
.di-ff-check:checked ~ .di-ff-check-on  { display:inline; }
.di-ff-check:checked ~ .di-ff-check-off { display:none; }

/* Validation error */
.di-ff-invalid .di-ff-input { border-color:#f38ba8; }
.di-ff-invalid .di-ff-hint::before {
  content:'⚠ '; color:#f38ba8;
}

/* ── manual.js form ── */
.di-mn-meta {
  padding: 12px 20px 8px;
  display: flex; flex-direction: column; gap: 8px;
  border-bottom: 1px solid var(--border);
}
.di-mn-row {
  display: flex; flex-direction: column; gap: 4px;
}
.di-mn-row label {
  font-size: 11px; font-weight: 700; color: var(--text-muted);
  letter-spacing: .03em; text-transform: uppercase;
}
.di-mn-row .di-ff-input { width: 100%; box-sizing: border-box; }
.di-mn-row textarea.di-ff-input { min-height: 72px; resize: vertical; font-family: var(--font-mono, monospace); font-size: 12px; }
.di-mn-sections { flex: 1; overflow-y: auto; padding: 10px 20px; display: flex; flex-direction: column; gap: 8px; }
.di-mn-section {
  border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-secondary); overflow: hidden;
}
.di-mn-sec-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; cursor: pointer; user-select: none;
  background: var(--bg-tertiary); list-style: none;
}
.di-mn-sec-hdr::-webkit-details-marker { display: none; }
.di-mn-sec-label { font-size: 12px; font-weight: 600; color: var(--text); flex: 1; }
.di-mn-sec-del {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); font-size: 13px; padding: 2px 6px;
  border-radius: 4px; line-height: 1;
}
.di-mn-sec-del:hover { background: color-mix(in srgb, var(--danger) 15%, transparent); color: var(--danger); }
.di-mn-sec-body { padding: 12px; display: flex; flex-direction: column; gap: 8px; }
.di-mn-add-btn {
  margin: 0 20px 10px; padding: 8px 14px;
  background: none; border: 1px dashed var(--border);
  border-radius: 7px; color: var(--accent); font-size: 13px;
  cursor: pointer; transition: background .12s;
}
.di-mn-add-btn:hover { background: color-mix(in srgb, var(--accent) 10%, transparent); }
.di-mn-hint {
  margin: 0 20px 16px; padding: 8px 12px;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  border-radius: 6px; font-size: 11px; color: var(--text-muted); line-height: 1.5;
}
.di-mn-hint code { color: var(--accent); }

/* ── i18n table ── */
.di-i18n-wrap {
  display:flex; flex-direction:column; height:100%;
}
.di-i18n-controls {
  display:flex; align-items:center; gap:10px;
  padding:8px 16px;
  background:var(--surface); border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.di-i18n-ns-label { font-size:12px; color:var(--text-muted); }
.di-i18n-ns-label code { color:var(--accent); font-size:12px; }
.di-i18n-controls-gap { flex:1; }

.di-i18n-table-wrap {
  flex:1; overflow:auto;
  min-height:0;
}
.di-i18n-table {
  width:100%; border-collapse:collapse;
  font-size:12.5px;
  table-layout:fixed;
}
.di-i18n-table th {
  position:sticky; top:0; z-index:2;
  background:var(--surface);
  border-bottom:2px solid var(--border);
  padding:7px 10px;
  font-size:11px; font-weight:700; color:var(--text-muted);
  letter-spacing:.05em; text-align:left;
  white-space:nowrap;
}
.di-i18n-key-th   { width:160px; }
.di-i18n-lang-th  {
  min-width:140px;
  display:table-cell; /* needed for sticky */
}
.di-i18n-lang-th { padding-right:6px; }
.di-i18n-lang-th span { margin-right:4px; }
.di-i18n-del-th   { width:36px; }

.di-i18n-table td {
  padding:4px 6px;
  border-bottom:1px solid color-mix(in srgb, var(--border) 60%, transparent);
  vertical-align:middle;
}
.di-i18n-table tr:hover td { background:var(--hover); }
.di-i18n-table tr:last-child td { border-bottom:none; }

.di-i18n-key-cell { background:color-mix(in srgb, var(--surface) 50%, transparent); }

/* Inputs inside the table */
.di-i18n-key, .di-i18n-val {
  width:100%; box-sizing:border-box;
  padding:5px 8px; font-size:12.5px;
  background:transparent; border:1px solid transparent;
  border-radius:4px; color:var(--text); font-family:inherit;
}
.di-i18n-key {
  font-family:var(--font-mono, monospace);
  color:var(--accent);
  font-weight:600;
}
.di-i18n-key[data-required] { color:var(--text-muted); pointer-events:none; opacity:.7; }
.di-i18n-key:focus, .di-i18n-val:focus {
  outline:none;
  border-color:var(--accent);
  background:var(--surface);
}
.di-i18n-del-cell { text-align:center; }

.di-i18n-footer {
  padding:10px 14px;
  border-top:1px solid var(--border);
  background:var(--surface);
  flex-shrink:0;
}

/* tab badge for form-capable files */
.di-tab-form-badge {
  font-size:9px; opacity:.55;
  margin-left:2px; vertical-align:middle;
}

/* Hover + selected lang delete button in header */
.di-i18n-del-lang {
  opacity:0; transition:opacity .15s;
  width:18px; height:18px;
}
.di-i18n-lang-th:hover .di-i18n-del-lang { opacity:.7; }
.di-i18n-del-lang:hover { opacity:1 !important; }
.di-i18n-del-lang .wos-icon { width:10px; height:10px; }

/* ══════════════════════════════════════════════════════════════════
   POPOUT MODE  —  webos/popout.html
   ══════════════════════════════════════════════════════════════════ */
body.popout-mode {
  margin: 0; padding: 0;
  display: flex; flex-direction: column;
  height: 100vh; overflow: hidden;
  background: var(--bg-primary);
  color: var(--text);
}

/* Thin native-style titlebar */
.popout-bar {
  display: flex; align-items: center; gap: 6px;
  height: 36px; min-height: 36px;
  padding: 0 6px 0 10px;
  background: var(--titlebar-bg);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  -webkit-app-region: drag; /* allows drag in Electron/PWA contexts */
  user-select: none;
}
.popout-bar-icon {
  display: flex; align-items: center;
  flex-shrink: 0;
}
.popout-bar-icon svg { width: 14px; height: 14px; }
.popout-bar-title {
  font-size: 13px; font-weight: 500;
  color: var(--titlebar-text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.popout-bar-gap { flex: 1; }

.popout-bar-btn {
  -webkit-app-region: no-drag;
  display: flex; align-items: center; gap: 4px;
  height: 24px; padding: 0 8px;
  border-radius: 4px; border: 1px solid transparent;
  background: transparent; color: var(--titlebar-text);
  font-size: 11px; cursor: pointer;
  transition: background .15s, border-color .15s;
  flex-shrink: 0;
}
.popout-bar-btn svg { width: 12px; height: 12px; }
.popout-bar-btn:hover { background: var(--hover); border-color: var(--border); }
.popout-bar-btn span { white-space: nowrap; }

.popout-bar-close {
  width: 28px; height: 28px; padding: 0;
  justify-content: center;
  font-size: 16px; font-weight: 400;
  border-radius: 50%;
}
.popout-bar-close:hover { background: var(--btn-close); color: #fff; border-color: transparent; }

/* The app fills the remaining space */
.popout-container {
  flex: 1; overflow: hidden;
  display: flex; flex-direction: column;
  position: relative;
  /* mirror .window-body */
  background: var(--bg-primary);
}

/* In popout mode, window-body children should flex-fill */
.popout-mode .window-body,
.popout-container > * { height: 100%; }

/* Error state */
.popout-error {
  flex: 1; display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--text-muted);
  padding: 32px; text-align: center;
}

/* ── Dev Console Panel ─────────────────────────────────────────────── */
.dev-console {
  position: fixed; bottom: 40px; left: 0; right: 0;
  height: 260px; z-index: 9500;
  background: #12121e;
  border-top: 2px solid var(--accent);
  display: flex; flex-direction: column;
  font-family: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
  font-size: 12px; color: #d4d4d4;
  box-shadow: 0 -4px 24px rgba(0,0,0,.5);
  transition: height .1s;
}
.dev-console.hidden { display: none; }
.dev-console.dc-minimized { height: 34px !important; overflow: hidden; }

/* Resize handle */
.dc-resize-handle {
  height: 4px; cursor: n-resize; flex-shrink: 0;
  background: transparent;
  transition: background .15s;
}
.dc-resize-handle:hover { background: var(--accent); }

/* Toolbar */
.dc-toolbar {
  display: flex; align-items: center; gap: 6px; flex-shrink: 0;
  padding: 4px 8px; height: 30px;
  background: #1a1a2e; border-bottom: 1px solid #2a2a42;
}
.dc-title {
  display: flex; align-items: center; gap: 5px;
  font-weight: 600; font-size: 11px; text-transform: uppercase;
  letter-spacing: .06em; color: var(--accent); white-space: nowrap;
}
.dc-title svg { flex-shrink: 0; stroke: var(--accent); }
.dc-filter {
  background: #0d0d1a; color: #d4d4d4;
  border: 1px solid #333; border-radius: 4px;
  padding: 2px 6px; font-size: 11px; cursor: pointer;
}
.dc-autoscroll-label {
  display: flex; align-items: center; gap: 4px;
  font-size: 11px; color: #888; cursor: pointer; user-select: none;
}
.dc-autoscroll-label input { cursor: pointer; }
.dc-toolbar-spacer { flex: 1; }
.dc-btn {
  background: none; border: 1px solid #333; border-radius: 4px;
  color: #aaa; font-size: 11px; padding: 2px 8px; cursor: pointer;
  transition: color .15s, border-color .15s, background .15s;
}
.dc-btn:hover { color: #fff; border-color: #555; background: rgba(255,255,255,.06); }
.dc-btn-close:hover { color: #ff5f57; border-color: #ff5f57; }
.dc-run-btn { color: var(--accent); border-color: var(--accent); }
.dc-run-btn:hover { background: var(--accent); color: #fff; }

/* Log area */
.dc-log {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 4px 0;
  scrollbar-width: thin;
  scrollbar-color: #333 transparent;
}
.dc-entry {
  display: flex; align-items: baseline; gap: 6px;
  padding: 1px 10px; line-height: 1.55;
  border-bottom: 1px solid rgba(255,255,255,.03);
  white-space: pre-wrap; word-break: break-all;
}
.dc-entry:hover { background: rgba(255,255,255,.04); }
.dc-ts   { color: #555; font-size: 11px; flex-shrink: 0; }
.dc-badge {
  flex-shrink: 0; font-size: 10px; padding: 0 4px;
  border-radius: 3px; font-weight: 700; letter-spacing: .04em;
}
.dc-badge-log    { background: #1e3a5f; color: #7eb8f7; }
.dc-badge-info   { background: #1a3a2a; color: #5fb87e; }
.dc-badge-warn   { background: #3a2a00; color: #f0c060; }
.dc-badge-error  { background: #3a1010; color: #f07070; }
.dc-badge-result { background: #2a1a3a; color: #c080f0; }
.dc-src  { color: #666; font-size: 11px; flex-shrink: 0; }
.dc-msg  { flex: 1; min-width: 0; }
.dc-lvl-warn  .dc-msg { color: #f0c060; }
.dc-lvl-error .dc-msg { color: #f07070; }
.dc-lvl-info  .dc-msg { color: #5fb87e; }
.dc-lvl-result .dc-msg { color: #c080f0; }

/* Eval bar */
.dc-eval-bar {
  display: flex; align-items: center; gap: 6px; flex-shrink: 0;
  padding: 4px 8px; border-top: 1px solid #2a2a42;
  background: #0d0d1a;
}
.dc-eval-prompt { color: var(--accent); font-size: 14px; font-weight: 700; flex-shrink: 0; }
.dc-eval-input {
  flex: 1; background: transparent; border: none; outline: none;
  color: #d4d4d4; font-family: inherit; font-size: 12px;
  caret-color: var(--accent);
}
.dc-eval-input::placeholder { color: #444; }


/* ── macOS Menu Bar (structural — shared with Ubuntu theme) ─────────────── */
.macos-menubar {
  display: none; /* shown only under macOS theme */
  position: absolute; top: 0; left: 0; right: 0;
  height: 28px; z-index: 5100;
  align-items: center; justify-content: space-between;
  padding: 0 12px;
  backdrop-filter: blur(40px) saturate(1.8);
  -webkit-backdrop-filter: blur(40px) saturate(1.8);
  background: rgba(255,255,255,0.68);
  border-bottom: 1px solid rgba(0,0,0,0.1);
  user-select: none;
  font-family: -apple-system, 'SF Pro Text', system-ui, sans-serif;
  font-size: 13px;
}

.mmb-left  { display: flex; align-items: center; gap: 16px; }
.mmb-right { display: flex; align-items: center; gap: 10px; }

.mmb-apple {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 22px; border-radius: 4px;
  background: none; border: none; cursor: default;
  color: #1d1d1f; padding: 0;
  transition: background 0.1s;
}
.mmb-apple:hover { background: rgba(0,0,0,0.07); }

.mmb-appname {
  font-weight: 600; color: #1d1d1f; font-size: 13px;
  letter-spacing: -0.01em;
}

.mmb-sep {
  width: 1px; height: 14px;
  background: rgba(0,0,0,0.15);
  display: inline-block;
}

.mmb-tray-btn {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 22px; border-radius: 4px;
  background: none; border: none; cursor: default;
  color: #1d1d1f; padding: 0; position: relative;
  transition: background 0.1s;
}
.mmb-tray-btn:hover { background: rgba(0,0,0,0.07); }
.mmb-tray-btn svg { width: 14px; height: 14px; }
.mmb-tray-btn.mmb-has-notif::after {
  content: '';
  position: absolute; top: 3px; right: 3px;
  width: 6px; height: 6px; border-radius: 50%;
  background: #ff3b30;
}

.mmb-clock-wrap {
  display: flex; align-items: center; gap: 6px;
  cursor: default;
}
.mmb-date  { color: rgba(29,29,31,0.75); font-size: 12px; }
.mmb-clock { color: #1d1d1f; font-weight: 500; font-size: 13px; }

  ·  .sidebar-collapsed on the app wrapper
   Smooth max-width slide animation. Works for: Mail, Files, Journal,
   Tasks, Settings, Password Manager, Admin Portal.
   ══════════════════════════════════════════════════════════════════════ */

/* ── Collapse bar — sits at the top of every sidebar ───────────────── */
/* ══════════════════════════════════════════════════════════════════════
   SIDEBAR TOGGLE  ·  .sidebar-collapsed on the app wrapper
   Smooth max-width slide animation. Works for: Mail, Files, Journal,
   Tasks, Settings, Password Manager, Admin Portal.
   ══════════════════════════════════════════════════════════════════════ */

.sb-bar {
  display: flex;
  align-items: center;
  padding: 6px 8px 6px 12px;
  gap: 6px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  min-height: 36px;
}
.sb-bar-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .7px; color: var(--text-muted);
  flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sb-close-btn {
  display: flex; align-items: center; gap: 4px;
  background: none; border: none;
  color: var(--text-muted); font-size: 11px; font-weight: 500;
  padding: 4px 8px; border-radius: 6px; cursor: pointer;
  transition: background .15s, color .15s;
  flex-shrink: 0; white-space: nowrap;
}
.sb-close-btn:hover { background: var(--hover); color: var(--text); }
.sb-close-btn svg   { flex-shrink: 0; }

/* ── Open button — inline in the adjacent toolbar / content header ── */
.sb-open-btn {
  display: none;                        /* invisible when sidebar is visible */
  align-items: center; justify-content: center;
  background: none; border: none;
  color: var(--text-muted);
  padding: 5px 8px; border-radius: 6px; cursor: pointer;
  transition: background .15s, color .15s;
  flex-shrink: 0;
}
.sb-open-btn:hover { background: var(--hover); color: var(--text); }
.sidebar-collapsed .sb-open-btn { display: flex; }

/* ── Smooth slide animation on all sidebars ─────────────────────────── */
/* Transition on the sidebar element itself                               */
.ml-sidebar,
.fm-sidebar,
.jn-sidebar,
.tk-sidebar,
.settings-sidebar,
.pm-sidebar,
.ap-sidebar,
.bg-sidebar,
.ch-sidebar {
  transition: max-width .22s ease, opacity .18s ease, padding .2s ease,
              border-color .1s ease;
  overflow-x: hidden;
}

/* ── Collapsed state ────────────────────────────────────────────────── */
.sidebar-collapsed .ml-sidebar,
.sidebar-collapsed .fm-sidebar,
.sidebar-collapsed .jn-sidebar,
.sidebar-collapsed .tk-sidebar,
.sidebar-collapsed .settings-sidebar,
.sidebar-collapsed .pm-sidebar,
.sidebar-collapsed .ap-sidebar,
.sidebar-collapsed .bg-sidebar,
.sidebar-collapsed .ch-sidebar {
  max-width:   0      !important;
  min-width:   0      !important;
  opacity:     0;
  padding-left:  0   !important;
  padding-right: 0   !important;
  border-right-color: transparent !important;
  pointer-events: none;
}
/* Ensure main content fills the freed space */
.ml-root.sidebar-collapsed        .ml-list-panel,
.fm-wrap.sidebar-collapsed        .fm-main,
.jn-root.sidebar-collapsed        .jn-main,
.tk-wrap.sidebar-collapsed        .tk-main,
.settings-wrap.sidebar-collapsed  .settings-content,
.pm-root.sidebar-collapsed        .pm-list-panel,
.ap-root.sidebar-collapsed        .ap-content,
.bg-root.sidebar-collapsed        .bg-main,
.ch-wrap.sidebar-collapsed        .ch-main          { flex: 1 !important; }

/* ══════════════════════════════════════════════════════════════════════
   MOBILE MODE  ·  Android-inspired UI
   Status bar (top 28 px) + 3-button nav bar (bottom 52 px).
   Apps fill the space between. No desktop taskbar shown.
   ══════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════
   MOBILE — CSS custom properties & base overrides
   ════════════════════════════════════════════════════════════════════ */
:root {
  --msb-h: 32px;
  --mnb-h: 56px;
  --mobile-radius: 16px;
  --mobile-glass: rgba(10,10,20,.72);
  --mobile-glass-light: rgba(255,255,255,.10);
  --mobile-icon-size: 60px;
  --mobile-icon-radius: 18px;
}

/* ── Login screen ───────────────────────────────────────────────────── */
[data-mobile="true"] .login-center  { padding: 24px 20px; }
[data-mobile="true"] .login-os-name { font-size: 22px; }

/* ════════════════════════════════════════════════════════════════════
   STATUS BAR
   ════════════════════════════════════════════════════════════════════ */
.mobile-status-bar {
  display: none;
  position: absolute;
  top: 0; left: 0; right: 0;
  height: var(--msb-h);
  background: var(--mobile-glass);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid rgba(255,255,255,.06);
  color: rgba(255,255,255,.95);
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  z-index: 10001;
  user-select: none;
}
[data-mobile="true"] .mobile-status-bar { display: flex; }

.msb-right { display: flex; align-items: center; gap: 5px; width: 44px; }
.msb-time  { font-size: 12px; font-weight: 700; letter-spacing: .3px; }

.msb-drawer-btn {
  background: none; border: none;
  color: rgba(255,255,255,.82);
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; border-radius: 10px;
  transition: background .15s, transform .1s;
  -webkit-tap-highlight-color: transparent;
  flex-shrink: 0;
}
.msb-drawer-btn:hover  { background: rgba(255,255,255,.10); }
.msb-drawer-btn:active { background: rgba(255,255,255,.20); transform: scale(.92); }

/* ════════════════════════════════════════════════════════════════════
   HOME SCREEN WIDGET (clock when no apps are open)
   ════════════════════════════════════════════════════════════════════ */
.mobile-home-widget {
  display: none;
  position: absolute;
  top: var(--msb-h); left: 0; right: 0; bottom: var(--mnb-h);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 1;
  gap: 4px;
  transition: opacity .35s ease;
}
[data-mobile="true"] .mobile-home-widget { display: flex; }
.mobile-home-widget.mhw-hidden { opacity: 0; }

.mhw-time {
  font-size: 76px;
  font-weight: 200;
  line-height: 1;
  letter-spacing: -3px;
  color: #fff;
  text-shadow: 0 2px 24px rgba(0,0,0,.45);
}
.mhw-date {
  font-size: 15px;
  font-weight: 400;
  color: rgba(255,255,255,.82);
  text-shadow: 0 1px 8px rgba(0,0,0,.4);
  letter-spacing: .2px;
}
.mhw-hint {
  position: absolute;
  bottom: 28px;
  font-size: 12px;
  color: rgba(255,255,255,.42);
  letter-spacing: .4px;
}

/* ════════════════════════════════════════════════════════════════════
   NAVIGATION BAR
   ════════════════════════════════════════════════════════════════════ */
.mobile-nav-bar {
  display: none;
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: var(--mnb-h);
  background: var(--mobile-glass);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-top: 1px solid rgba(255,255,255,.07);
  align-items: center;
  justify-content: space-around;
  z-index: 10001;
  user-select: none;
  padding-bottom: 4px;
}
[data-mobile="true"] .mobile-nav-bar { display: flex; }

.mnb-btn {
  background: none; border: none;
  color: rgba(255,255,255,.70);
  width: 54px; height: 44px;
  cursor: pointer; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s, transform .12s;
  -webkit-tap-highlight-color: transparent;
}
.mnb-btn:hover  { background: rgba(255,255,255,.08); color: rgba(255,255,255,.95); }
.mnb-btn:active { background: rgba(255,255,255,.16); transform: scale(.88); }
.mnb-btn svg    { width: 20px; height: 20px; }

/* Home pill (gesture-style indicator) */
.mnb-home-pill {
  width: 36px; height: 5px;
  background: rgba(255,255,255,.80);
  border-radius: 3px;
  transition: width .15s, background .15s;
}
.mnb-home:hover .mnb-home-pill { width: 28px; background: #fff; }
.mnb-home:active .mnb-home-pill { width: 22px; }

/* ════════════════════════════════════════════════════════════════════
   WM CONTAINER — fill between the two bars
   ════════════════════════════════════════════════════════════════════ */
[data-mobile="true"] .wm-container {
  top:    var(--msb-h) !important;
  bottom: var(--mnb-h) !important;
}
[data-mobile="true"] .desktop-icons {
  top:    var(--msb-h) !important;
  bottom: var(--mnb-h) !important;
}

/* ════════════════════════════════════════════════════════════════════
   WINDOWS — always full-screen, slide-in animation
   ════════════════════════════════════════════════════════════════════ */
[data-mobile="true"] .window {
  left: 0 !important; top: 0 !important;
  width: 100% !important; height: 100% !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transform: none !important;
  max-width: none !important; min-width: 0 !important; min-height: 0 !important;
  animation: mob-win-in .22s cubic-bezier(.25,.8,.25,1) both;
}
@keyframes mob-win-in {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: none; }
}
[data-mobile="true"] .resize-handle,
[data-mobile="true"] .snap-preview { display: none !important; }
[data-mobile="true"] .wbtn-min,
[data-mobile="true"] .wbtn-max,
[data-mobile="true"] .wbtn-popout  { display: none !important; }

/* Android action-bar titlebar */
[data-mobile="true"] .window-titlebar {
  height: 52px;
  padding: 0 8px 0 4px;
  background: var(--titlebar-bg) !important;
  border-bottom: 1px solid rgba(128,128,128,.15);
}
[data-mobile="true"] .window-controls { order: -1; margin-right: 4px; }
[data-mobile="true"] .window-title {
  font-size: 16px; font-weight: 600;
  letter-spacing: -.1px;
  flex: 1;
}
[data-mobile="true"] .window-icon svg   { width: 20px; height: 20px; }
[data-mobile="true"] .wbtn-close {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(128,128,128,.12);
  color: var(--titlebar-text, #fff);
  font-size: 20px;
  line-height: 1;
}
[data-mobile="true"] .wbtn-close:hover  { background: rgba(255,80,80,.25); }
[data-mobile="true"] .wbtn-close:active { transform: scale(.85); }
[data-mobile="true"] .window-body {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* ════════════════════════════════════════════════════════════════════
   APP LAUNCHER — full-screen, frosted-glass, slide-up animation
   ════════════════════════════════════════════════════════════════════ */
[data-mobile="true"] .app-launcher {
  border-radius: 0 !important;
  left: 0 !important; right: 0 !important;
  top: var(--msb-h) !important;
  bottom: var(--mnb-h) !important;
  max-height: none !important; height: auto !important;
  background: rgba(10,10,22,.75) !important;
  backdrop-filter: saturate(160%) blur(28px) !important;
  -webkit-backdrop-filter: saturate(160%) blur(28px) !important;
}
[data-mobile="true"] .app-launcher:not(.hidden) {
  animation: launcher-in .28s cubic-bezier(.25,.8,.25,1) both;
}
@keyframes launcher-in {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: none; }
}
[data-mobile="true"] .launcher-apps {
  grid-template-columns: repeat(4, 1fr);
  gap: 20px 4px;
  padding: 6px 4px 16px;
}
[data-mobile="true"] .launcher-app-btn .app-icon,
[data-mobile="true"] .launcher-app .la-icon {
  width: var(--mobile-icon-size); height: var(--mobile-icon-size);
  border-radius: var(--mobile-icon-radius);
  box-shadow: 0 4px 14px rgba(0,0,0,.35);
}
[data-mobile="true"] .launcher-app-btn .app-icon svg,
[data-mobile="true"] .launcher-app .la-icon svg { width: 30px; height: 30px; }
[data-mobile="true"] .launcher-app-btn .app-label,
[data-mobile="true"] .launcher-app .la-name {
  font-size: 10px; margin-top: 5px;
  color: rgba(255,255,255,.88);
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
}
[data-mobile="true"] .launcher-app-btn:active .app-icon,
[data-mobile="true"] .launcher-app:active .la-icon {
  transform: scale(.88);
  transition: transform .1s;
}
[data-mobile="true"] .launcher-search {
  font-size: 15px;
  padding: 10px 18px;
  border-radius: 24px;
  margin: 10px 12px 4px;
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  color: #fff !important;
  backdrop-filter: blur(4px);
}
[data-mobile="true"] .launcher-search::placeholder { color: rgba(255,255,255,.45); }
[data-mobile="true"] #launcher-user-hero {
  padding: 10px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* ════════════════════════════════════════════════════════════════════
   NOTIFICATION PANEL
   ════════════════════════════════════════════════════════════════════ */
[data-mobile="true"] .notif-panel {
  left: 0 !important; right: 0 !important;
  border-radius: 0 0 20px 20px;
  top: var(--msb-h) !important;
  bottom: auto !important;
  max-height: 65vh;
  animation: notif-slide-in .25s cubic-bezier(.25,.8,.25,1) both;
}
[data-mobile="true"] .notif-panel::after {
  content: '';
  display: block;
  width: 36px; height: 4px;
  background: rgba(128,128,128,.4);
  border-radius: 2px;
  margin: 8px auto 0;
}
@keyframes notif-slide-in {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: none; }
}

/* ── Dev console ────────────────────────────────────────────────────── */
[data-mobile="true"] .dev-console {
  top: var(--msb-h); bottom: var(--mnb-h);
}

/* ── Desktop icons: hidden on home (use launcher) ───────────────────── */
[data-mobile="true"] .desktop-icon { display: none; }

/* ── Taskbar: completely hidden in mobile ──────────────────────────── */
[data-mobile="true"] .taskbar { display: none !important; }

/* ── All sidebar apps (except Mail): overlay slide-in from left ──────
   The same overlay model as Mail. Sidebar is position:absolute and
   slides in from the left; main content always fills full width.     */
[data-mobile="true"] .fm-wrap,
[data-mobile="true"] .jn-root,
[data-mobile="true"] .tk-wrap,
[data-mobile="true"] .settings-wrap,
[data-mobile="true"] .pm-root,
[data-mobile="true"] .ap-root,
[data-mobile="true"] .bg-root,
[data-mobile="true"] .ch-wrap,
[data-mobile="true"] .fl-root {
  position: relative !important;
  overflow: hidden !important;
  flex-direction: row !important;
}

[data-mobile="true"] .fm-sidebar,
[data-mobile="true"] .jn-sidebar,
[data-mobile="true"] .tk-sidebar,
[data-mobile="true"] .settings-sidebar,
[data-mobile="true"] .pm-sidebar,
[data-mobile="true"] .ap-sidebar,
[data-mobile="true"] .bg-sidebar,
[data-mobile="true"] .ch-sidebar,
[data-mobile="true"] .fl-sidebar {
  position: absolute !important;
  top: 0 !important; left: 0 !important; bottom: 0 !important;
  z-index: 20 !important;
  width: 80% !important; max-width: 280px !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  overflow-y: auto !important; overflow-x: hidden !important;
  border-right: 1px solid var(--border) !important;
  border-bottom: none !important;
  box-shadow: 6px 0 24px rgba(0,0,0,.32) !important;
  transform: translateX(-110%) !important;
  transition: transform .28s cubic-bezier(.25,.8,.25,1) !important;
  /* Override sidebar-collapsed's max-width:0 / opacity:0 */
  opacity: 1 !important;
  padding-left: unset !important; padding-right: unset !important;
  max-height: none !important;
}

/* Slide in when NOT collapsed */
[data-mobile="true"] .fm-wrap:not(.sidebar-collapsed)         .fm-sidebar,
[data-mobile="true"] .jn-root:not(.sidebar-collapsed)         .jn-sidebar,
[data-mobile="true"] .tk-wrap:not(.sidebar-collapsed)         .tk-sidebar,
[data-mobile="true"] .settings-wrap:not(.sidebar-collapsed)   .settings-sidebar,
[data-mobile="true"] .pm-root:not(.sidebar-collapsed)         .pm-sidebar,
[data-mobile="true"] .ap-root:not(.sidebar-collapsed)         .ap-sidebar,
[data-mobile="true"] .bg-root:not(.sidebar-collapsed)         .bg-sidebar,
[data-mobile="true"] .ch-wrap:not(.sidebar-collapsed)         .ch-sidebar,
[data-mobile="true"] .fl-root:not(.sidebar-collapsed)         .fl-sidebar {
  transform: translateX(0) !important;
}

/* Scrim behind open sidebar */
[data-mobile="true"] .fm-wrap:not(.sidebar-collapsed)::before,
[data-mobile="true"] .jn-root:not(.sidebar-collapsed)::before,
[data-mobile="true"] .tk-wrap:not(.sidebar-collapsed)::before,
[data-mobile="true"] .settings-wrap:not(.sidebar-collapsed)::before,
[data-mobile="true"] .pm-root:not(.sidebar-collapsed)::before,
[data-mobile="true"] .ap-root:not(.sidebar-collapsed)::before,
[data-mobile="true"] .bg-root:not(.sidebar-collapsed)::before,
[data-mobile="true"] .ch-wrap:not(.sidebar-collapsed)::before,
[data-mobile="true"] .fl-root:not(.sidebar-collapsed)::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 15; background: rgba(0,0,0,.38);
}

/* Main content: always fills full width */
[data-mobile="true"] .fm-main,
[data-mobile="true"] .jn-main,
[data-mobile="true"] .tk-main,
[data-mobile="true"] .settings-content,
[data-mobile="true"] .ap-content,
[data-mobile="true"] .bg-main,
[data-mobile="true"] .ch-main {
  flex: 1 !important; min-width: 0 !important;
  overflow-y: auto;
}

/* ════════════════════════════════════════════════════════════════════
   RECENTS OVERLAY
   ════════════════════════════════════════════════════════════════════ */
.mobile-recents {
  position: absolute;
  top: var(--msb-h); left: 0; right: 0; bottom: var(--mnb-h);
  background: rgba(8,8,18,.85);
  backdrop-filter: saturate(160%) blur(24px);
  -webkit-backdrop-filter: saturate(160%) blur(24px);
  z-index: 9999;
  display: flex; flex-direction: column;
  padding: 20px 16px 12px;
  overflow-y: auto;
  animation: mr-in .22s cubic-bezier(.25,.8,.25,1) both;
}
.mobile-recents.hidden { display: none !important; }
@keyframes mr-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: none; }
}

.mr-header {
  display: flex; justify-content: space-between; align-items: center;
  color: #fff; padding: 0 4px 16px; flex-shrink: 0;
}
.mr-title {
  font-size: 11px; font-weight: 700; opacity: .45;
  text-transform: uppercase; letter-spacing: 1.2px;
}
.mr-clear-btn {
  background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.75);
  padding: 5px 16px; border-radius: 20px; font-size: 12px; cursor: pointer;
  transition: background .15s;
}
.mr-clear-btn:hover { background: rgba(255,255,255,.18); }

.mr-cards { display: flex; flex-direction: column; gap: 14px; }

.mr-card {
  background: var(--surface, #1a1a2e);
  border-radius: 18px; overflow: hidden;
  position: relative; cursor: pointer;
  box-shadow: 0 8px 32px rgba(0,0,0,.60);
  transition: transform .14s, box-shadow .14s;
}
.mr-card:hover  { transform: scale(1.015); box-shadow: 0 12px 36px rgba(0,0,0,.65); }
.mr-card:active { transform: scale(.97); }

.mr-card-header {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  background: var(--titlebar-bg, #252540);
  color: var(--titlebar-text, #fff);
  font-size: 14px; font-weight: 600;
  letter-spacing: -.1px;
}
.mr-card-icon { display: flex; align-items: center; opacity: .9; }
.mr-card-icon svg { width: 18px; height: 18px; }

.mr-card-preview { height: 72px; background: var(--surface-2, #252537); }

.mr-card-close {
  position: absolute; top: 10px; right: 10px;
  background: rgba(0,0,0,.55); border: none; color: rgba(255,255,255,.85);
  border-radius: 50%; width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .15s; z-index: 2;
}
.mr-card-close:hover { background: rgba(200,40,40,.8); }
.mr-card-close svg   { width: 13px; height: 13px; }

.mr-empty {
  color: rgba(255,255,255,.35); text-align: center;
  padding: 60px 20px; font-size: 15px;
}

/* ════════════════════════════════════════════════════════════════════
   MOBILE APP-SPECIFIC TWEAKS
   ════════════════════════════════════════════════════════════════════ */

/* ── Mail / Chat: three-panel → overlay slides ───────────────────────
   Default: list panel fills full width.
   Sidebar: slides in from left as a translucent overlay.
   View panel: slides in from right when message/compose is open.     */
[data-mobile="true"] .ml-root {
  position: relative !important;
  overflow: hidden !important;
}

/* Sidebar: detach from flow, overlay from the left */
[data-mobile="true"] .ml-sidebar {
  position: absolute !important;
  top: 0 !important; left: 0 !important; bottom: 0 !important;
  z-index: 20 !important;
  width: 82% !important;
  max-width: 300px !important;
  box-shadow: 6px 0 24px rgba(0,0,0,.35) !important;
  transform: translateX(-110%) !important;
  transition: transform .28s cubic-bezier(.25,.8,.25,1) !important;
  /* Override sidebar-collapsed's max-width:0 / opacity:0 */
  opacity: 1 !important;
  padding-left: unset !important;
  padding-right: unset !important;
  border-right: 1px solid var(--border) !important;
}
/* When sidebar is NOT collapsed, slide it in */
[data-mobile="true"] .ml-root:not(.sidebar-collapsed) .ml-sidebar {
  transform: translateX(0) !important;
}
/* Scrim behind open sidebar: tap anywhere outside to close */
[data-mobile="true"] .ml-root:not(.sidebar-collapsed)::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 15;
  background: rgba(0,0,0,.38);
}

/* List panel: always fills full width on mobile */
[data-mobile="true"] .ml-list-panel {
  width: auto !important;
  min-width: 0 !important;
  flex: 1 !important;
  border-right: none !important;
}

/* View panel: slides in from the right */
[data-mobile="true"] .ml-view-panel {
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
  z-index: 10 !important;
  background: var(--bg-primary) !important;
  transform: translateX(105%) !important;
  transition: transform .28s cubic-bezier(.25,.8,.25,1) !important;
}
/* Slide in when a message is being read OR compose panel is open */
[data-mobile="true"] .ml-root:has(.ml-read-view:not(.hidden)) .ml-view-panel,
[data-mobile="true"] .ml-root:has(.ml-compose-view:not(.hidden)) .ml-view-panel {
  transform: translateX(0) !important;
}

/* ── Terminal ───────────────────────────────────────────────────────── */
.term-shortcut-bar {
  display: none;
  flex-wrap: wrap; gap: 4px; padding: 4px 6px;
  background: var(--surface-2); border-top: 1px solid var(--border);
  flex-shrink: 0;
}
[data-mobile="true"] .term-shortcut-bar { display: flex; }
.term-sc {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text); border-radius: 6px;
  padding: 6px 10px; font-size: 12px; cursor: pointer;
  min-width: 44px; min-height: 36px;
  display: flex; align-items: center; justify-content: center;
}
.term-sc:active { background: var(--hover); }
[data-mobile="true"] .terminal-wrap { display: flex; flex-direction: column; height: 100%; }
[data-mobile="true"] .terminal-output { flex: 1; overflow-y: auto; min-height: 0; }

/* ── Music Player ───────────────────────────────────────────────────── */
[data-mobile="true"] .mp-wrap           { flex-direction: column; }
[data-mobile="true"] .mp-now-playing    { width: 100% !important; min-width: 0 !important; max-width: none !important; flex-shrink: 0; }
[data-mobile="true"] .mp-queue         { flex: 1; min-height: 0; overflow-y: auto; }
[data-mobile="true"] .mp-progress-wrap { width: 100%; }

/* ── Video Player ───────────────────────────────────────────────────── */
[data-mobile="true"] .vp-controls {
  flex-wrap: wrap; gap: 4px; padding: 6px 8px;
}
[data-mobile="true"] .vp-progress-wrap {
  order: -1; width: 100%; margin-bottom: 4px;
}
[data-mobile="true"] .vp-time-display { font-size: 11px; }
[data-mobile="true"] .vp-volume       { width: 60px !important; }

/* ── PDF Viewer ─────────────────────────────────────────────────────── */
[data-mobile="true"] .pv-toolbar {
  flex-wrap: wrap; gap: 2px; padding: 4px;
  max-height: none;
}
[data-mobile="true"] .pv-canvas-wrap { overflow-x: auto; }

/* ── Image Viewer ───────────────────────────────────────────────────── */
[data-mobile="true"] .iv-toolbar {
  flex-wrap: wrap; gap: 2px; padding: 4px 6px;
  max-height: none;
}
[data-mobile="true"] .iv-info-panel {
  position: absolute; left: 0; right: 0; bottom: 0;
  width: 100% !important; max-width: none !important;
  border-left: none; border-top: 1px solid var(--border);
  max-height: 40%;
}

/* ── Text Editor (markdown split) ───────────────────────────────────── */
[data-mobile="true"] .editor-container.ed-md-split {
  flex-direction: column;
}
[data-mobile="true"] .editor-container.ed-md-split textarea { flex: 1; min-height: 40%; }
[data-mobile="true"] .editor-container.ed-md-split .ed-md-preview { flex: 1; min-height: 40%; }

/* ── Doc Editor ─────────────────────────────────────────────────────── */
[data-mobile="true"] .de-main { flex-direction: column; }
[data-mobile="true"] .de-main > * { flex: none; height: 50% !important; min-height: 0; }
[data-mobile="true"] .de-toolbar.de-md-bar { flex-wrap: wrap; }
[data-mobile="true"] .de-toolbar.de-file-bar { flex-wrap: wrap; gap: 2px; }

/* ── Calendar ───────────────────────────────────────────────────────── */
[data-mobile="true"] .cal-root      { flex-direction: column; }
/* Sidebar: compact strip at top for the New Event button */
[data-mobile="true"] .cal-sidebar   {
  width: 100% !important; flex-shrink: 0;
  max-height: 52px; overflow: hidden;
  border-right: none; border-bottom: 1px solid var(--border);
  flex-direction: row; align-items: center; padding: 6px 10px;
}
/* Hide the mini-calendar and subscription list on mobile; keep New Event */
[data-mobile="true"] .cal-mini-calendar,
[data-mobile="true"] .cal-sidebar > *:not(.cal-new-btn) { display: none !important; }
[data-mobile="true"] .cal-new-btn  { width: 100%; }
[data-mobile="true"] .cal-main     { flex: 1; min-height: 0; }
[data-mobile="true"] .cal-toolbar  { flex-wrap: wrap; gap: 4px; }
[data-mobile="true"] .cal-view-area { -webkit-overflow-scrolling: touch; }
/* Fix: let month grid grow to its natural height so rows aren't compressed */
[data-mobile="true"] .cal-month-grid { height: auto !important; min-height: 0 !important; }
[data-mobile="true"] .cal-month-cell { min-height: 72px !important; }
[data-mobile="true"] .cal-week-grid  { min-width: 0 !important; overflow-x: auto; }
[data-mobile="true"] .cal-modal-box.cal-modal-wide {
  width: 100% !important; max-width: none !important;
  margin: 0; border-radius: 0; height: 100%; max-height: none;
}
[data-mobile="true"] .cal-adv-row   { flex-direction: column; }
[data-mobile="true"] .cal-adv-col   { min-width: 0 !important; width: 100% !important; }
[data-mobile="true"] .cal-modal     { align-items: flex-start; padding: 0; }
[data-mobile="true"] .cal-color-btn { width: 32px !important; height: 32px !important; }

/* ── Password Manager: list+detail stack vertically ────────────────── */
[data-mobile="true"] .pm-list-panel  { width: 100% !important; min-width: 0 !important; max-width: none !important; max-height: 45%; flex-shrink: 0; border-right: none; border-bottom: 1px solid var(--border); overflow-y: auto; }
[data-mobile="true"] .pm-detail-panel { flex: 1; min-height: 0; overflow-y: auto; }
[data-mobile="true"] .pm-main-panel  { flex: 1 !important; min-width: 0 !important; display: flex; flex-direction: column; }

/* ── Admin Portal ───────────────────────────────────────────────────── */
[data-mobile="true"] .ap-log-wrap,
[data-mobile="true"] .ap-runtime-log { overflow-x: auto !important; }
[data-mobile="true"] .ap-log-table   { min-width: 560px; }
[data-mobile="true"] .ap-user-row    { flex-wrap: wrap; }
[data-mobile="true"] .ap-overview-panels { grid-template-columns: 1fr !important; }

/* ── Browser ────────────────────────────────────────────────────────── */
[data-mobile="true"] .wb-toolbar     { flex-wrap: wrap; gap: 2px; padding: 4px; }
[data-mobile="true"] .wb-omni        { min-width: 0; flex: 1; }
[data-mobile="true"] .wb-nav         { min-width: 36px; min-height: 36px; }
[data-mobile="true"] .wb-tabbar      { overflow-x: auto; flex-wrap: nowrap; }
[data-mobile="true"] .wb-statusbar   { display: none; }

/* ── Calculator ─────────────────────────────────────────────────────── */
/* Column layout: keypad on top fills height, graph below when visible  */
[data-mobile="true"] .gc-root {
  flex-direction: column !important;
}
[data-mobile="true"] .gc-sidebar {
  width: 100% !important; min-width: 0 !important;
  flex: 1 !important;
  border-right: none !important;
  border-bottom: 1px solid var(--border);
}
[data-mobile="true"] .gc-history {
  flex: 1 !important; min-height: 48px !important;
  overflow-y: auto !important;
}
/* Graph panel: fixed height strip below the keypad */
[data-mobile="true"] .gc-main {
  width: 100% !important; min-width: 0 !important;
  height: 240px !important; flex-shrink: 0 !important;
  border-left: none !important;
  border-top: 1px solid var(--border);
}
[data-mobile="true"] .gc-graph-wrap { height: 100% !important; }
[data-mobile="true"] .gc-canvas     { width: 100% !important; }
[data-mobile="true"] .gc-graph-toolbar { flex-wrap: wrap; gap: 2px; padding: 4px; }
[data-mobile="true"] .gc-graph-btn     { font-size: 11px; padding: 3px 6px; }

/* ── App Studio ─────────────────────────────────────────────────────── */
[data-mobile="true"] .di-body         { flex-direction: column !important; }
[data-mobile="true"] .di-editor-pane  {
  width: 100% !important; min-width: 0 !important;
  height: 55% !important; flex: none !important;
  border-right: none !important; border-bottom: 2px solid var(--border);
}
[data-mobile="true"] .di-preview-pane {
  height: 45% !important; min-width: 0 !important; flex: none !important;
  border-left: none !important; border-top: 1px solid var(--border);
}
[data-mobile="true"] .di-toolbar      { flex-wrap: wrap; gap: 2px; padding: 4px 6px; }
[data-mobile="true"] .di-preview-header { flex-wrap: wrap; }

/* ── Spreadsheet / Draw.io — desktop-only warning ──────────────────── */
.ss-mobile-warn, .drawio-mobile-warn {
  display: none;
  position: absolute; inset: 0; z-index: 100;
  background: var(--surface);
  flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 24px; text-align: center;
}
/* Shown on mobile unless the user dismissed it (.mob-warn-dismissed) */
[data-mobile="true"] .ss-mobile-warn:not(.mob-warn-dismissed),
[data-mobile="true"] .drawio-mobile-warn:not(.mob-warn-dismissed) {
  display: flex;
}
.ss-mobile-warn svg, .drawio-mobile-warn svg { opacity: .4; }
.ss-mobile-warn p, .drawio-mobile-warn p { color: var(--text-muted); font-size: 14px; line-height: 1.5; }


/* ║                      DESKTOP WIDGETS                                   ║ */
/* ╚══════════════════════════════════════════════════════════════════════════╝ */

/* ── Layer ─────────────────────────────────────────────────────────────────── */
/* ╔══════════════════════════════════════════════════════════════════════════╗ */
/* ║                      DESKTOP WIDGETS                                   ║ */
/* ╚══════════════════════════════════════════════════════════════════════════╝ */

#widget-layer {
  position: absolute;
  inset: 0;
  z-index: 2;           /* above desktop-icons (1), below wm-container (10+) */
  pointer-events: none; /* transparent to clicks unless a widget is hit */
}

/* ── Card ──────────────────────────────────────────────────────────────────── */
.wos-widget {
  position: absolute;
  pointer-events: all;
  /* Theme-aware: uses surface color + backdrop blur */
  background: color-mix(in srgb, var(--surface, #1e2030) 88%, transparent);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28);
  width: 280px;  /* default unified width */
  min-width: 180px;
  max-width: 600px;
  overflow: visible;  /* allow resize handles to poke out */
  opacity: 0;
  transform: scale(0.94) translateY(8px);
  transition: opacity 0.24s ease, transform 0.24s ease, box-shadow 0.2s;
  will-change: transform, opacity;
}
/* Inner clip for content only */
.wos-widget > :not(.wos-widget-resize-e):not(.wos-widget-resize-w):not(.wos-widget-resize-handle) {
  overflow: hidden;
}
.wos-widget.wos-widget-visible { opacity: 1; transform: none; }
.wos-widget.wos-widget-exit    { opacity: 0; transform: scale(0.94) translateY(8px); transition: opacity .22s, transform .22s; }
.wos-widget.wos-widget-dragging {
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
  transition: box-shadow 0.2s;
  cursor: grabbing;
}

/* ── Light-theme adjustments ──────────────────────────────────────────────── */
[data-theme="light"] .wos-widget,
[data-theme="solarized-light"] .wos-widget {
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow: 0 4px 20px rgba(0,0,0,.14), 0 1px 4px rgba(0,0,0,.08);
  border-color: var(--border);
}

/* ── Header / drag handle ──────────────────────────────────────────────────── */
.wos-widget-hd {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 10px 8px;
  cursor: grab;
  user-select: none;
  border-bottom: 1px solid var(--border);
  min-height: 36px;
  border-radius: 14px 14px 0 0;
  overflow: hidden;
}
.wos-widget-hd:active { cursor: grabbing; }

.wos-widget-icon { display: flex; align-items: center; opacity: 0.65; flex-shrink: 0; }
.wos-widget-icon svg { width: 14px; height: 14px; }

.wos-widget-title {
  flex: 1;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-primary);
  opacity: 0.7;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wos-widget-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: transparent;
  border: none;
  color: var(--text-primary);
  opacity: 0;
  cursor: pointer;
  transition: background 0.12s, opacity 0.15s;
  flex-shrink: 0;
  padding: 0;
}
.wos-widget-btn svg { width: 12px; height: 12px; }
.wos-widget:hover .wos-widget-btn { opacity: 0.45; }
.wos-widget-btn:hover  { background: var(--hover); opacity: 1 !important; }
.wos-widget-close-btn:hover { background: rgba(237, 78, 78, 0.22); color: #ed4e4e; opacity: 1 !important; }

@keyframes wdg-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.wos-widget-refresh-btn.spinning svg { animation: wdg-spin 0.6s linear; }

/* ── Resize handles ────────────────────────────────────────────────────────── */
/* Bottom handle — height resize */
.wos-widget-resize-handle {
  height: 8px;
  cursor: ns-resize;
  border-radius: 0 0 14px 14px;
  background: transparent;
  transition: background 0.15s;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}
.wos-widget-resize-handle::after {
  content: '';
  position: absolute;
  left: 50%; transform: translateX(-50%);
  bottom: 2px;
  width: 28px; height: 3px;
  border-radius: 2px;
  background: var(--border);
  transition: background 0.15s, width 0.15s;
}
.wos-widget:hover .wos-widget-resize-handle::after { width: 40px; }
.wos-widget-resize-handle:hover::after,
.wos-widget-resize-handle.wos-widget-resizing::after { background: var(--accent); width: 48px; }

/* Right edge handle — width resize */
.wos-widget-resize-e {
  position: absolute;
  top: 8px; right: -5px; bottom: 8px;
  width: 10px;
  cursor: ew-resize;
  z-index: 10;
  border-radius: 0 8px 8px 0;
  display: flex; align-items: center; justify-content: center;
}
.wos-widget-resize-e::after {
  content: '';
  width: 3px; height: 24px;
  border-radius: 2px;
  background: var(--border);
  transition: background 0.15s, height 0.15s;
  opacity: 0;
  transition: opacity 0.15s;
}
.wos-widget:hover .wos-widget-resize-e::after { opacity: 1; }
.wos-widget-resize-e:hover::after,
.wos-widget-resize-e.wos-widget-resizing-ew::after { background: var(--accent); height: 36px; opacity: 1; }

/* Left edge handle — width resize (west) */
.wos-widget-resize-w {
  position: absolute;
  top: 8px; left: -5px; bottom: 8px;
  width: 10px;
  cursor: ew-resize;
  border-radius: 8px 0 0 8px;
  display: flex; align-items: center; justify-content: center;
}
.wos-widget-resize-w::after {
  content: '';
  width: 3px; height: 24px;
  border-radius: 2px;
  background: var(--border);
  opacity: 0;
  transition: opacity 0.15s;
}
.wos-widget:hover .wos-widget-resize-w::after { opacity: 1; }
.wos-widget-resize-w:hover::after,
.wos-widget-resize-w.wos-widget-resizing-ew::after { background: var(--accent); height: 36px; opacity: 1; }

/* Width snap guide badge */
.wos-widget-width-guide {
  position: absolute;
  height: 22px;
  padding: 0 8px;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 10001;
  opacity: 0.92;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}

/* ── Snap guide line ───────────────────────────────────────────────────────── */
.wos-widget-snap-line {
  position: absolute;
  background: var(--accent);
  opacity: 0.55;
  pointer-events: none;
  z-index: 1;
  border-radius: 2px;
  box-shadow: 0 0 8px var(--accent);
}

/* ── Body ──────────────────────────────────────────────────────────────────── */
.wos-widget-bd {
  padding: 10px 12px 8px;
  overflow-y: auto;
  /* No fixed max-height — user sets it via resize handle or right-click presets */
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
  color: var(--text-primary);
  font-size: 13px;
  line-height: 1.45;
  border-radius: 0 0 14px 14px;
}

/* ─────────────── Widget content styles ────────────────────────────────────── */

.wdg-empty {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--text-primary);
  opacity: 0.45;
  font-size: 12.5px;
  padding: 4px 0;
}
.wdg-empty svg { width: 15px; height: 15px; flex-shrink: 0; }

.wdg-error {
  font-size: 12px;
  color: #ed4e4e;
  opacity: 0.8;
  padding: 4px 0;
}

/* Section label */
.wdg-section-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-primary);
  opacity: 0.45;
  margin: 8px 0 3px;
}
.wdg-section-lbl:first-child { margin-top: 2px; }
.wdg-section-lbl.overdue { color: #f07878; opacity: 0.85; }

/* Task items */
.wdg-task-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 4px 4px 2px;
  border-radius: 7px;
  transition: background 0.12s;
}
.wdg-task-item:hover { background: var(--hover); }
.wdg-task-item.overdue .wdg-task-name { color: #f07878; }

/* Checkbox-style complete button */
.wdg-task-check {
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 2px solid currentColor;
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  transition: background .15s, transform .15s;
  color: var(--text-muted);
}
.wdg-task-check:hover {
  background: color-mix(in srgb, currentColor 18%, transparent);
  transform: scale(1.15);
}

.wdg-task-name {
  flex: 1;
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex; flex-direction: column; gap: 1px;
}
.wdg-task-logged {
  font-size: 9.5px;
  color: var(--accent);
  font-weight: 600;
  opacity: 0.8;
}

/* Timer button */
.wdg-task-timer-btn {
  width: 24px; height: 24px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: opacity .15s, background .12s, color .12s;
}
.wdg-task-timer-btn svg { width: 13px; height: 13px; }
.wdg-task-item:hover .wdg-task-timer-btn { opacity: 0.6; }
.wdg-task-timer-btn:hover { background: var(--hover); opacity: 1 !important; color: var(--text-primary); }
.wdg-task-timer-btn.running {
  opacity: 1 !important;
  color: #e85252;
  background: rgba(232, 82, 82, 0.12);
  animation: wdg-timer-pulse 1.5s ease-in-out infinite;
}
@keyframes wdg-timer-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(232,82,82,.3); }
  50%       { box-shadow: 0 0 0 4px rgba(232,82,82,0); }
}

.wdg-task-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.wdg-task-due {
  font-size: 11px;
  opacity: 0.45;
  flex-shrink: 0;
}

/* Calendar events */
.wdg-event-item {
  display: flex;
  align-items: stretch;
  gap: 10px;
  padding: 6px 6px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.12s;
  margin-bottom: 2px;
}
.wdg-event-item:hover { background: rgba(255,255,255,0.07); }
.wdg-event-color {
  width: 3px;
  border-radius: 2px;
  flex-shrink: 0;
}
.wdg-event-info { flex: 1; min-width: 0; }
.wdg-event-title {
  font-size: 12.5px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wdg-event-time {
  font-size: 11px;
  opacity: 0.55;
  margin-top: 2px;
}
.wdg-event-loc {
  font-size: 11px;
  opacity: 0.45;
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Clock widget */
.wdg-clock {
  text-align: center;
  padding: 6px 0 4px;
}
.wdg-clock-time {
  font-size: 34px;
  font-weight: 200;
  letter-spacing: -1px;
  color: var(--text-primary);
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.wdg-clock-date {
  font-size: 12px;
  opacity: 0.5;
  margin-top: 6px;
  letter-spacing: 0.3px;
}

/* Sticky note */
.wdg-sticky textarea {
  width: 100%;
  min-height: 120px;
  background: transparent;
  border: none;
  color: var(--text-primary);
  font-size: 13px;
  font-family: inherit;
  line-height: 1.55;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
  caret-color: var(--accent);
}
.wdg-sticky textarea::placeholder { opacity: 0.35; }

/* Footer link row */
.wdg-footer {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  gap: 8px;
}
.wdg-link-btn {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  opacity: 0.75;
  transition: opacity 0.12s;
}
.wdg-link-btn:hover { opacity: 1; text-decoration: underline; }


/* ╔═══════════════════════════════════════╗ */
/* ║        WIDGET PICKER MODAL           ║ */
/* ╚═══════════════════════════════════════╝ */

.wos-widget-picker-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.52);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.22s ease;
}
.wos-widget-picker-overlay.wos-widget-picker-visible { opacity: 1; }
.wos-widget-picker-overlay.wos-widget-picker-exit   { opacity: 0; transition: opacity 0.18s; }

.wos-widget-picker {
  background: var(--bg-secondary, #383c4a);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 18px;
  box-shadow: 0 32px 96px rgba(0,0,0,0.65);
  width: 560px;
  max-width: 92vw;
  max-height: 78vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: scale(0.96) translateY(10px);
  transition: transform 0.22s ease;
}
.wos-widget-picker-overlay.wos-widget-picker-visible .wos-widget-picker {
  transform: none;
}

.wos-widget-picker-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  flex-shrink: 0;
}
.wos-widget-picker-hd > span {
  display: flex;
  align-items: center;
  gap: 10px;
}
.wos-widget-picker-hd svg { width: 18px; height: 18px; color: var(--accent); }

.wos-widget-picker-close {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border: none;
  border-radius: 8px;
  color: var(--text-primary);
  opacity: 0.6;
  cursor: pointer;
  transition: background 0.12s, opacity 0.12s;
  padding: 0;
}
.wos-widget-picker-close:hover { opacity: 1; background: rgba(255,255,255,0.12); }
.wos-widget-picker-close svg { width: 15px; height: 15px; }

.wos-widget-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 12px;
  padding: 18px;
  overflow-y: auto;
  scrollbar-width: thin;
}

.wos-widget-picker-card {
  background: var(--bg-tertiary, #404552);
  border: 1.5px solid transparent;
  border-radius: 14px;
  padding: 18px 14px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  cursor: default;
  transition: border-color 0.15s, background 0.15s;
}
.wos-widget-picker-card:hover {
  border-color: var(--accent);
  background: rgba(82, 148, 226, 0.07);
}

.wos-widget-picker-icon {
  width: 46px;
  height: 46px;
  background: rgba(82, 148, 226, 0.12);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  margin-bottom: 4px;
}
.wos-widget-picker-icon svg { width: 24px; height: 24px; }

.wos-widget-picker-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}
.wos-widget-picker-desc {
  font-size: 11px;
  color: var(--text-primary);
  opacity: 0.5;
  line-height: 1.4;
}
.wos-widget-picker-add {
  margin-top: 8px;
  padding: 6px 16px;
  background: var(--accent, #5294e2);
  color: #fff;
  border: none;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.12s, transform 0.1s;
}
.wos-widget-picker-add:hover  { opacity: 0.88; }
.wos-widget-picker-add:active { transform: scale(0.96); }

/* ════════════════════════════════════════════════════════════════════════════
   MOBILE — macOS menubar, widgets, Finance app
   ════════════════════════════════════════════════════════════════════════════ */

/* Hide macOS menu bar on mobile — it would overlap the mobile status bar */
[data-mobile="true"] .macos-menubar { display: none !important; }

/* Widgets: hide the desktop widget layer on mobile (home screen has its own
   clock widget; freeform widget positioning makes no sense on a phone) */
[data-mobile="true"] #widget-layer { display: none !important; }

/* Launcher grid on mobile — real classes used by the DOM */
[data-mobile="true"] .la-app-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 18px 4px !important;
  padding: 6px 4px 16px !important;
}
[data-mobile="true"] .launcher-app .la-icon .wos-icon-app { width: 30px; height: 30px; }

/* ── Finance / Ledger app ────────────────────────────────────────────── */

/* Toolbar: allow buttons to wrap so they don't overflow on narrow screens */
[data-mobile="true"] .fl-toolbar { flex-wrap: wrap; gap: 4px; padding: 6px 8px; }
[data-mobile="true"] .fl-tbtn { font-size: 11px; padding: 5px 8px; }

/* Tables: allow horizontal scroll rather than clipping */
[data-mobile="true"] .fl-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
[data-mobile="true"] .fl-table { min-width: 480px; }

/* Two-column forms → single column on mobile */
[data-mobile="true"] .fl-form-2col { grid-template-columns: 1fr !important; }

/* KPI row: 2-up on small screens */
[data-mobile="true"] .fl-kpi-row { grid-template-columns: repeat(2, 1fr); gap: 8px; }
[data-mobile="true"] .fl-kpi { padding: 12px; }
[data-mobile="true"] .fl-kpi-value { font-size: 17px; }

/* Account grid: 1-up on mobile */
[data-mobile="true"] .fl-acc-grid { grid-template-columns: 1fr; }

/* Content area: ensure it scrolls and fills the window body */
[data-mobile="true"] .fl-body { flex-direction: column; }
[data-mobile="true"] .fl-content { padding: 12px; }

/* Modal: full-width, scroll from near top */
[data-mobile="true"] .fl-modal {
  width: 98vw !important;
  max-width: 98vw !important;
  max-height: 92vh !important;
  border-radius: 14px 14px 0 0;
  padding: 16px;
}
[data-mobile="true"] .fl-modal-backdrop { align-items: flex-end; }

/* D3 chart cards: let them scroll horizontally */
[data-mobile="true"] .fl-chart-card { overflow-x: auto; padding: 10px; }
[data-mobile="true"] .fl-chart-card svg { min-width: 340px; }

/* Tabs: scroll horizontally on narrow screens */
[data-mobile="true"] .fl-tabs {
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 4px;
}
[data-mobile="true"] .fl-tab { white-space: nowrap; flex-shrink: 0; }
