/* styles/tokens.css — Base resets, :root CSS custom properties, theme variants */
/* ═══════════════════════════════════════════════════════════════════════
   Base CSS Resets
   ═══════════════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; width: 100%; overflow: hidden; margin: 0; padding: 0; font-family: var(--font, 'Inter', sans-serif); font-size: 14px; line-height: 1.5; color: var(--text-primary); background: var(--bg-primary); -webkit-font-smoothing: antialiased; }
#app { height: 100%; width: 100%; overflow: hidden; }
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb, rgba(255,255,255,0.15)); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover, rgba(255,255,255,0.25)); }

/* ═══════════════════════════════════════════════════════════════════════
   SVG Icon Safety Net
   ═══════════════════════════════════════════════════════════════════════ */
.bean-desktop-root svg { max-width: 100%; max-height: 100%; }
.bean-desktop-root button svg, .bean-desktop-root [role="button"] svg { width: 16px; height: 16px; flex-shrink: 0; }
.bean-desktop-root span svg { width: 1em; height: 1em; flex-shrink: 0; vertical-align: middle; }

/* ═══════════════════════════════════════════════════════════════════════
   :root CSS Variables + Theme Overrides
   ═══════════════════════════════════════════════════════════════════════ */
:root {
  /* Component sizing (set by apply-appearance.ts, these are fallback defaults) */
  --taskbar-height: 36px;
  --statusbar-height: 28px;
  --chrome-height: 32px;
  --font-scale: 1;
  --base-font-size: 14px;

  --bg-primary: #1c1410; --bg-secondary: #261e18; --bg-tertiary: #3d2e22;
  --bg-input: #16100c; --bg-hover: #342820; --bg-message-hover: rgba(255,255,255,0.02);
  --text-primary: #f0e6dc; --text-secondary: #b8a898; --text-muted: #7a6b5c;
  --accent: #c47a3a; --accent-hover: #d9944e; --accent-dim: rgba(196,122,58,0.15);
  --green: #7cb66a; --yellow: #d4a04a; --red: #c45a4a;
  --border: rgba(255,255,255,0.05); --border-strong: rgba(255,255,255,0.10);
  --shadow: 0 2px 10px rgba(0,0,0,0.4); --radius: 8px; --radius-sm: 4px; --radius-md: 8px; --radius-lg: 12px;
  --font: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
  --bg-hover-strong: #4d3c2e; --bg-splash: #241a12; --bg-media: #0d0a07;
  --overlay-bg: rgba(0,0,0,0.7); --text-on-accent: #ffffff; --text-danger: #e74c3c;
  --accent-active: #8b5e3c; --green-bright: #4ade80; --green-dim: rgba(74,222,128,0.1);
  --red-dim: rgba(255,107,107,0.1); --yellow-dim: rgba(234,179,8,0.1);
  --status-online: #4ade80; --status-idle: #eab308; --status-dnd: #e74c3c;
  --status-watching: #9B59B6; --status-playing: #3498DB;
  --scrollbar-thumb: #4a3528; --scrollbar-thumb-hover: #5a4538;
  --control-bg: #2a1e14; --shadow-md: 0 4px 12px rgba(0,0,0,0.4); --shadow-lg: 0 8px 32px rgba(0,0,0,0.6);
  --chat-font-size: 14px;
  --bean-brown: #8B5E3C; --bean-dark: #5A3420; --bean-light: #A97B5A; --bean-cream: #F5E6D3;

  /* ── Typography Scale ── */
  --text-2xs: 9px;
  --text-xs: 10px;
  --text-sm: 11px;
  --text-base: 13px;
  --text-md: 14px;
  --text-lg: 16px;
  --text-xl: 18px;
  --text-2xl: 24px;
  --text-3xl: 32px;

  --weight-normal: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;

  --leading-tight: 1.2;
  --leading-normal: 1.4;
  --leading-relaxed: 1.6;

  /* ── Spacing Scale ── */
  --space-1: 2px;
  --space-2: 4px;
  --space-3: 6px;
  --space-4: 8px;
  --space-5: 10px;
  --space-6: 12px;
  --space-7: 14px;
  --space-8: 16px;
  --space-10: 20px;
  --space-12: 24px;
  --space-16: 32px;
  --space-20: 40px;

  /* ── Transition Timing ── */
  --duration-fast: 0.08s;
  --duration-base: 0.12s;
  --duration-slow: 0.15s;
  --duration-smooth: 0.25s;

  /* ── Shadow Scale (extend existing --shadow, --shadow-md, --shadow-lg) ── */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.15);
  --shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.2);
  --shadow-xl: 0 12px 48px rgba(0, 0, 0, 0.5);
}

/* ── Theme: Midnight (GitHub-like deep blue) ── */
[data-theme="midnight"] {
  --bg-primary: #0d1117;
  --bg-secondary: #161b22;
  --bg-tertiary: #21262d;
  --bg-input: #090c10;
  --bg-hover: #1c2128;
  --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #2d333b;
  --bg-splash: #0a0e14;
  --bg-media: #060809;
  --control-bg: #12171e;
  --text-primary: #e6edf3;
  --text-secondary: #8b949e;
  --text-muted: #484f58;
  --text-on-accent: #ffffff;
  --text-danger: #f85149;
  --accent: #58a6ff;
  --accent-hover: #79c0ff;
  --accent-dim: rgba(88, 166, 255, 0.15);
  --accent-active: #1f6feb;
  --green: #3fb950;
  --yellow: #d29922;
  --red: #f85149;
  --green-bright: #56d364;
  --green-dim: rgba(63, 185, 80, 0.1);
  --red-dim: rgba(248, 81, 73, 0.1);
  --yellow-dim: rgba(210, 153, 34, 0.1);
  --border: rgba(240,246,252,0.1);
  --border-strong: rgba(240,246,252,0.15);
  --shadow: 0 2px 10px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.7);
  --bean-brown: #58a6ff;
  --bean-dark: #1f6feb;
  --bean-light: #79c0ff;
  --bean-cream: #e6edf3;
  --bean-brown-dim: rgba(88, 166, 255, 0.15);
  --overlay-bg: rgba(0, 0, 0, 0.7);
  --scrollbar-thumb: #30363d;
  --scrollbar-thumb-hover: #484f58;
  --status-online: #3fb950;
  --status-idle: #d29922;
  --status-dnd: #f85149;
  --status-watching: #a371f7;
  --status-playing: #58a6ff;
  --avatar-1: #58a6ff;
  --avatar-2: #3fb950;
  --avatar-3: #d29922;
  --avatar-4: #bc8cff;
  --avatar-5: #1f6feb;
  --avatar-6: #79c0ff;
  --avatar-7: #f778ba;
  --avatar-8: #f85149;
}

/* ── Theme: Dark (Pure monochrome dark) ── */
[data-theme="dark"] {
  --bg-primary: #111111;
  --bg-secondary: #1a1a1a;
  --bg-tertiary: #2a2a2a;
  --bg-input: #0a0a0a;
  --bg-hover: #222222;
  --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #333333;
  --bg-splash: #0e0e0e;
  --bg-media: #080808;
  --control-bg: #161616;
  --text-primary: #e8e8e8;
  --text-secondary: #a0a0a0;
  --text-muted: #5a5a5a;
  --text-on-accent: #ffffff;
  --text-danger: #ff5555;
  --accent: #888888;
  --accent-hover: #aaaaaa;
  --accent-dim: rgba(136, 136, 136, 0.15);
  --accent-active: #666666;
  --green: #6abf69;
  --yellow: #d4aa4a;
  --red: #e05050;
  --green-bright: #7dd87d;
  --green-dim: rgba(106, 191, 105, 0.1);
  --red-dim: rgba(224, 80, 80, 0.1);
  --yellow-dim: rgba(212, 170, 74, 0.1);
  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.12);
  --shadow: 0 2px 10px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.7);
  --bean-brown: #888888;
  --bean-dark: #555555;
  --bean-light: #aaaaaa;
  --bean-cream: #e0e0e0;
  --bean-brown-dim: rgba(136, 136, 136, 0.15);
  --overlay-bg: rgba(0, 0, 0, 0.75);
  --scrollbar-thumb: #333333;
  --scrollbar-thumb-hover: #444444;
  --status-online: #6abf69;
  --status-idle: #d4aa4a;
  --status-dnd: #d46a6a;
  --status-watching: #9a7abf;
  --status-playing: #5a9abf;
  --avatar-1: #888888;
  --avatar-2: #6abf69;
  --avatar-3: #d4aa4a;
  --avatar-4: #b088cc;
  --avatar-5: #666666;
  --avatar-6: #aaaaaa;
  --avatar-7: #cc88aa;
  --avatar-8: #e05050;
}

/* ── Theme: Forest (Deep green tones) ── */
[data-theme="forest"] {
  --bg-primary: #0c1a0f;
  --bg-secondary: #142618;
  --bg-tertiary: #1e3322;
  --bg-input: #081208;
  --bg-hover: #1a2e1c;
  --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #2a4430;
  --bg-splash: #0a150c;
  --bg-media: #060d07;
  --control-bg: #102016;
  --text-primary: #d8ecd8;
  --text-secondary: #8bab8b;
  --text-muted: #4d6b4d;
  --text-on-accent: #ffffff;
  --text-danger: #e05050;
  --accent: #4a9c5a;
  --accent-hover: #5cb86c;
  --accent-dim: rgba(74, 156, 90, 0.15);
  --accent-active: #3a7a48;
  --green: #5cb86c;
  --yellow: #c8a84a;
  --red: #c45a4a;
  --green-bright: #7dd87d;
  --green-dim: rgba(92, 184, 108, 0.1);
  --red-dim: rgba(196, 90, 74, 0.1);
  --yellow-dim: rgba(200, 168, 74, 0.1);
  --border: rgba(200,230,200,0.08);
  --border-strong: rgba(200,230,200,0.12);
  --shadow: 0 2px 10px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.7);
  --bean-brown: #4a9c5a;
  --bean-dark: #2a6a35;
  --bean-light: #6ab87a;
  --bean-cream: #d8ecd8;
  --bean-brown-dim: rgba(74, 156, 90, 0.15);
  --overlay-bg: rgba(0, 0, 0, 0.7);
  --scrollbar-thumb: #2a4430;
  --scrollbar-thumb-hover: #3a5a40;
  --status-online: #5cb86c;
  --status-idle: #c8a84a;
  --status-dnd: #c85a5a;
  --status-watching: #8b6aaa;
  --status-playing: #5a8aaa;
  --avatar-1: #4a9c5a;
  --avatar-2: #5cb86c;
  --avatar-3: #c8a84a;
  --avatar-4: #6ab87a;
  --avatar-5: #3a7a48;
  --avatar-6: #8bcb8b;
  --avatar-7: #3d8b5a;
  --avatar-8: #c45a4a;
}

/* ── Theme: Slate (Nord-inspired blue-grey) ── */
[data-theme="slate"] {
  --bg-primary: #2e3440;
  --bg-secondary: #3b4252;
  --bg-tertiary: #434c5e;
  --bg-input: #272d38;
  --bg-hover: #3e4759;
  --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #4c566a;
  --bg-splash: #282e3a;
  --bg-media: #21262f;
  --control-bg: #333a47;
  --text-primary: #eceff4;
  --text-secondary: #d8dee9;
  --text-muted: #6b7994;
  --text-on-accent: #2e3440;
  --text-danger: #bf616a;
  --accent: #88c0d0;
  --accent-hover: #8fbcbb;
  --accent-dim: rgba(136, 192, 208, 0.15);
  --accent-active: #5e81ac;
  --green: #a3be8c;
  --yellow: #ebcb8b;
  --red: #bf616a;
  --green-bright: #a3be8c;
  --green-dim: rgba(163, 190, 140, 0.1);
  --red-dim: rgba(191, 97, 106, 0.1);
  --yellow-dim: rgba(235, 203, 139, 0.1);
  --border: rgba(236,239,244,0.08);
  --border-strong: rgba(236,239,244,0.12);
  --shadow: 0 2px 10px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.3);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.5);
  --bean-brown: #88c0d0;
  --bean-dark: #5e81ac;
  --bean-light: #8fbcbb;
  --bean-cream: #eceff4;
  --bean-brown-dim: rgba(136, 192, 208, 0.15);
  --overlay-bg: rgba(0, 0, 0, 0.6);
  --scrollbar-thumb: #4c566a;
  --scrollbar-thumb-hover: #5a657a;
  --status-online: #a3be8c;
  --status-idle: #ebcb8b;
  --status-dnd: #bf616a;
  --status-watching: #b48ead;
  --status-playing: #88c0d0;
  --avatar-1: #88c0d0;
  --avatar-2: #a3be8c;
  --avatar-3: #ebcb8b;
  --avatar-4: #b48ead;
  --avatar-5: #5e81ac;
  --avatar-6: #8fbcbb;
  --avatar-7: #81a1c1;
  --avatar-8: #bf616a;
}

/* ── Theme: Light ── */
[data-theme="light"] {
  --bg-primary: #f5f5f5;
  --bg-secondary: #e8e8e8;
  --bg-tertiary: #d8d8d8;
  --bg-input: #ffffff;
  --bg-hover: #e0e0e0;
  --bg-message-hover: rgba(0,0,0,0.03);
  --bg-hover-strong: #d0d0d0;
  --bg-splash: #f0f0f0;
  --bg-media: #fafafa;
  --control-bg: #eeeeee;
  --text-primary: #1a1a1a;
  --text-secondary: #4a4a4a;
  --text-muted: #8a8a8a;
  --text-on-accent: #ffffff;
  --text-danger: #d32f2f;
  --accent: #1976d2;
  --accent-hover: #1565c0;
  --accent-dim: rgba(25, 118, 210, 0.1);
  --accent-active: #0d47a1;
  --green: #388e3c;
  --yellow: #f9a825;
  --red: #d32f2f;
  --green-bright: #4caf50;
  --green-dim: rgba(56, 142, 60, 0.1);
  --red-dim: rgba(211, 47, 47, 0.1);
  --yellow-dim: rgba(249, 168, 37, 0.1);
  --border: rgba(0,0,0,0.1);
  --border-strong: rgba(0,0,0,0.18);
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.08);
  --shadow: 0 2px 10px rgba(0,0,0,0.1);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.12);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.15);
  --shadow-xl: 0 12px 48px rgba(0, 0, 0, 0.2);
  --bean-brown: #1976d2;
  --bean-dark: #0d47a1;
  --bean-light: #42a5f5;
  --bean-cream: #f5f5f5;
  --bean-brown-dim: rgba(25, 118, 210, 0.1);
  --overlay-bg: rgba(0, 0, 0, 0.4);
  --scrollbar-thumb: #bdbdbd;
  --scrollbar-thumb-hover: #9e9e9e;
  --status-online: #4caf50;
  --status-idle: #ff9800;
  --status-dnd: #f44336;
  --status-watching: #ab47bc;
  --status-playing: #42a5f5;
  --avatar-1: #1976d2;
  --avatar-2: #388e3c;
  --avatar-3: #f9a825;
  --avatar-4: #7b1fa2;
  --avatar-5: #0d47a1;
  --avatar-6: #0097a7;
  --avatar-7: #c2185b;
  --avatar-8: #d32f2f;
}

/* ── Theme: Ocean (Deep navy, bright cyan accent) ── */
[data-theme="ocean"] {
  --bg-primary: #0a1628; --bg-secondary: #0f2035; --bg-tertiary: #152a45;
  --bg-input: #071020; --bg-hover: #1a3550; --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #204060; --bg-splash: #0c1830; --bg-media: #050e1c;
  --text-primary: #e0f0ff; --text-secondary: #8ab4d8; --text-muted: #4a7a9c;
  --accent: #4da8da; --accent-hover: #6bc0ee; --accent-dim: rgba(77,168,218,0.15);
  --accent-active: #3090c0;
  --green: #4ade80; --yellow: #eab308; --red: #ef4444;
  --green-bright: #4ade80; --green-dim: rgba(74,222,128,0.1);
  --red-dim: rgba(239,68,68,0.1); --yellow-dim: rgba(234,179,8,0.1);
  --border: rgba(255,255,255,0.06); --border-strong: rgba(255,255,255,0.12);
  --shadow: 0 2px 10px rgba(0,0,0,0.5); --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.7);
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.2); --shadow-sm: 0 1px 4px rgba(0,0,0,0.25);
  --shadow-xl: 0 12px 48px rgba(0,0,0,0.6);
  --text-on-accent: #ffffff; --text-danger: #ef4444;
  --overlay-bg: rgba(0,0,0,0.7);
  --status-online: #4ade80; --status-idle: #eab308; --status-dnd: #ef4444;
  --status-watching: #9B59B6; --status-playing: #3498DB;
  --scrollbar-thumb: #1a3550; --scrollbar-thumb-hover: #2a4a68;
  --control-bg: #0d1e35;
  --font: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
  --bean-brown: #4da8da; --bean-dark: #2a6090; --bean-light: #6bc0ee; --bean-cream: #e0f0ff;
}

/* ── Theme: Ember (Dark warm reds, orange-red accent) ── */
[data-theme="ember"] {
  --bg-primary: #1a0a0a; --bg-secondary: #2d1212; --bg-tertiary: #3d1a1a;
  --bg-input: #140808; --bg-hover: #4a2020; --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #5a2828; --bg-splash: #1e0c0c; --bg-media: #100606;
  --text-primary: #ffecd2; --text-secondary: #d4a898; --text-muted: #8a5a4a;
  --accent: #e8553a; --accent-hover: #f07050; --accent-dim: rgba(232,85,58,0.15);
  --accent-active: #c84030;
  --green: #4ade80; --yellow: #eab308; --red: #ef4444;
  --green-bright: #4ade80; --green-dim: rgba(74,222,128,0.1);
  --red-dim: rgba(239,68,68,0.1); --yellow-dim: rgba(234,179,8,0.1);
  --border: rgba(255,255,255,0.06); --border-strong: rgba(255,255,255,0.12);
  --shadow: 0 2px 10px rgba(0,0,0,0.5); --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.7);
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.2); --shadow-sm: 0 1px 4px rgba(0,0,0,0.25);
  --shadow-xl: 0 12px 48px rgba(0,0,0,0.6);
  --text-on-accent: #ffffff; --text-danger: #ef4444;
  --overlay-bg: rgba(0,0,0,0.7);
  --status-online: #4ade80; --status-idle: #eab308; --status-dnd: #ef4444;
  --status-watching: #9B59B6; --status-playing: #3498DB;
  --scrollbar-thumb: #4a2020; --scrollbar-thumb-hover: #5a3030;
  --control-bg: #2a1010;
  --font: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
  --bean-brown: #e8553a; --bean-dark: #a03020; --bean-light: #f07050; --bean-cream: #ffecd2;
}

/* ── Theme: Lavender (Dark purple-gray, soft purple accent) ── */
[data-theme="lavender"] {
  --bg-primary: #1a1525; --bg-secondary: #231e30; --bg-tertiary: #2e2840;
  --bg-input: #14101e; --bg-hover: #3a3250; --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #443c58; --bg-splash: #1e1828; --bg-media: #100d18;
  --text-primary: #e8e0f0; --text-secondary: #b0a0c8; --text-muted: #706088;
  --accent: #9b7dd4; --accent-hover: #b090e0; --accent-dim: rgba(155,125,212,0.15);
  --accent-active: #7a60b0;
  --green: #4ade80; --yellow: #eab308; --red: #ef4444;
  --green-bright: #4ade80; --green-dim: rgba(74,222,128,0.1);
  --red-dim: rgba(239,68,68,0.1); --yellow-dim: rgba(234,179,8,0.1);
  --border: rgba(255,255,255,0.06); --border-strong: rgba(255,255,255,0.12);
  --shadow: 0 2px 10px rgba(0,0,0,0.5); --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.7);
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.2); --shadow-sm: 0 1px 4px rgba(0,0,0,0.25);
  --shadow-xl: 0 12px 48px rgba(0,0,0,0.6);
  --text-on-accent: #ffffff; --text-danger: #ef4444;
  --overlay-bg: rgba(0,0,0,0.7);
  --status-online: #4ade80; --status-idle: #eab308; --status-dnd: #ef4444;
  --status-watching: #9B59B6; --status-playing: #3498DB;
  --scrollbar-thumb: #3a3250; --scrollbar-thumb-hover: #4a4060;
  --control-bg: #201a2e;
  --font: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
  --bean-brown: #9b7dd4; --bean-dark: #6a50a0; --bean-light: #b090e0; --bean-cream: #e8e0f0;
}

/* ── Theme: Mocha (Darker warmer Coffee variant) ── */
[data-theme="mocha"] {
  --bg-primary: #1e1510; --bg-secondary: #2a1f16; --bg-tertiary: #3a2e22;
  --bg-input: #160f0a; --bg-hover: #4a3828; --bg-message-hover: rgba(255,255,255,0.02);
  --bg-hover-strong: #5a4838; --bg-splash: #221810; --bg-media: #0e0a06;
  --text-primary: #f0e4d8; --text-secondary: #c0a890; --text-muted: #7a6550;
  --accent: #b8835a; --accent-hover: #d0a070; --accent-dim: rgba(184,131,90,0.15);
  --accent-active: #906840;
  --green: #4ade80; --yellow: #eab308; --red: #ef4444;
  --green-bright: #4ade80; --green-dim: rgba(74,222,128,0.1);
  --red-dim: rgba(239,68,68,0.1); --yellow-dim: rgba(234,179,8,0.1);
  --border: rgba(255,255,255,0.05); --border-strong: rgba(255,255,255,0.10);
  --shadow: 0 2px 10px rgba(0,0,0,0.4); --shadow-md: 0 4px 12px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.6);
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.15); --shadow-sm: 0 1px 4px rgba(0,0,0,0.25);
  --shadow-xl: 0 12px 48px rgba(0,0,0,0.5);
  --text-on-accent: #ffffff; --text-danger: #e74c3c;
  --overlay-bg: rgba(0,0,0,0.7);
  --status-online: #4ade80; --status-idle: #eab308; --status-dnd: #e74c3c;
  --status-watching: #9B59B6; --status-playing: #3498DB;
  --scrollbar-thumb: #4a3828; --scrollbar-thumb-hover: #5a4838;
  --control-bg: #2a1e14;
  --font: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
  --bean-brown: #b8835a; --bean-dark: #705030; --bean-light: #d0a070; --bean-cream: #f0e4d8;
}

/* styles/core.css — Login flow: splash, username modal, PIN input, dialog manager, auto-connect, discovery */
/* ══════════════════════════════════════════════════════════════

/* ══════════════════════════════════════════════════════════════
   Login Flow — Splash, Username Modal, PIN Modal, Auto-Connect
   (ported from styles.css — runs before desktop shell)
   ══════════════════════════════════════════════════════════════ */

/* ── Splash Screen ── */
.splash-screen {
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse at center, var(--control-bg) 0%, #1c1410 70%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  animation: splash-fade-out 0.5s ease 2.2s forwards;
  pointer-events: none;
}

.splash-logo {
  width: 120px;
  height: 120px;
  animation: splash-bean-bounce 0.6s ease-out 0.2s both;
  filter: drop-shadow(0 8px 24px rgba(139, 94, 60, 0.4));
}

.splash-title {
  font-size: 36px;
  font-weight: 800;
  color: var(--bean-cream);
  margin-top: 20px;
  letter-spacing: 1px;
  animation: splash-text-up 0.5s ease-out 0.5s both;
  text-shadow: 0 2px 12px rgba(139, 94, 60, 0.3);
}

.splash-subtitle {
  font-size: 14px;
  color: var(--bean-light);
  margin-top: 8px;
  animation: splash-text-up 0.5s ease-out 0.7s both;
  opacity: 0;
}

.splash-dots {
  display: flex;
  gap: 6px;
  margin-top: 32px;
  animation: splash-text-up 0.4s ease-out 1s both;
  opacity: 0;
}

.splash-dots span {
  width: 8px;
  height: 8px;
  background: var(--bean-brown);
  border-radius: 50%;
  animation: splash-dot-pulse 1s ease-in-out infinite;
}

.splash-dots span:nth-child(2) { animation-delay: 0.15s; }
.splash-dots span:nth-child(3) { animation-delay: 0.3s; }

@keyframes splash-bean-bounce {
  0% { opacity: 0; transform: scale(0.3) translateY(30px); }
  60% { transform: scale(1.08) translateY(-4px); }
  100% { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes splash-text-up {
  0% { opacity: 0; transform: translateY(12px); }
  100% { opacity: 1; transform: translateY(0); }
}

@keyframes splash-dot-pulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.3); }
}

@keyframes splash-fade-out {
  0% { opacity: 1; }
  100% { opacity: 0; visibility: hidden; }
}


/* ── Username Modal ── */
/* ── Username Modal ── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(12, 8, 5, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  backdrop-filter: blur(6px);
  animation: modalOverlayIn 0.2s ease;
}

@keyframes modalOverlayIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.modal {
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: 16px;
  padding: 40px;
  width: 420px;
  max-width: 90vw;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
  animation: modalIn 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes modalIn {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(8px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.modal-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}

.modal-logo img {
  width: 72px;
  height: 72px;
  filter: drop-shadow(0 4px 12px rgba(139, 94, 60, 0.3));
}

.modal h1 {
  font-size: 26px;
  font-weight: 800;
  margin-bottom: 6px;
  color: var(--bean-cream);
  text-align: center;
  letter-spacing: 0.5px;
}

.modal p {
  color: var(--text-secondary);
  margin-bottom: 24px;
  font-size: 14px;
  text-align: center;
}

.modal label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 8px;
  letter-spacing: 0.5px;
}

.modal input[type="text"] {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  color: var(--text-primary);
  font-size: 16px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.15s;
  margin-bottom: 20px;
}

.modal input[type="text"]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.modal input[type="text"]::placeholder {
  color: var(--text-muted);
}

/* ── PIN Input ── */
.modal input[type="password"].pin-input {
  width: 100%;
  padding: 12px 16px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  color: var(--text-primary);
  font-size: 24px;
  font-family: var(--font-mono);
  letter-spacing: 12px;
  text-align: center;
  outline: none;
  transition: border-color 0.15s;
  margin-bottom: 16px;
}

.modal input[type="password"].pin-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.modal input[type="password"].pin-input::placeholder {
  color: var(--text-muted);
  letter-spacing: 8px;
}

.pin-error {
  color: var(--red);
  font-size: 13px;
  text-align: center;
  min-height: 20px;
  min-height: 20px;
  margin-bottom: 12px;
}

.modal-buttons {
  display: flex;
  gap: 12px;
}

/* ── Login Modal (password auth) ── */
.login-modal {
  max-width: 380px;
}

.login-subtitle {
  line-height: 1.5;
}

.login-field {
  margin-bottom: 16px;
}

.login-field label {
  margin-bottom: 6px;
}

.login-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.login-input {
  width: 100%;
  padding: 10px 40px 10px 12px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  color: var(--text-primary);
  font-size: 15px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.15s;
}

.login-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.login-input::placeholder {
  color: var(--text-muted);
}

.login-eye-btn {
  position: absolute;
  right: 8px;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: color 0.15s;
}

.login-eye-btn:hover {
  color: var(--text-primary);
}

.login-error {
  color: var(--red);
  font-size: 13px;
  text-align: center;
  min-height: 20px;
  margin-bottom: 12px;
}

.btn {
  padding: var(--space-5) var(--space-10);
  border: none;
  border-radius: var(--radius);
  font-size: var(--text-md);
  font-weight: var(--weight-semibold);
  font-family: var(--font);
  cursor: pointer;
  transition: all var(--duration-slow);
  flex: 1;
  transform: translateY(0);
}

.btn:hover {
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.btn:active {
  transform: translateY(0) scale(0.97);
  box-shadow: none;
  transition-duration: 0.05s;
}

.btn-primary {
  background: var(--accent);
  color: var(--text-on-accent);
}

.btn-primary:hover {
  background: var(--accent-hover);
}

.btn-secondary {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

.btn-secondary:hover {
  background: var(--bg-hover-strong);
}

.btn-danger {
  background: var(--red);
  color: #fff;
}

.btn-danger:hover {
  filter: brightness(0.9);
}

/* ── Dialog Manager ── */

.dialog-overlay {
  z-index: 10001;
}

.dialog-modal {
  width: 380px;
  padding: 28px 32px;
  text-align: left;
}

.dialog-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 8px;
}

.dialog-message {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 20px;
  text-align: left;
}

.dialog-input {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  color: var(--text-primary);
  font-size: 15px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.15s;
  margin-bottom: 20px;
  box-sizing: border-box;
}

.dialog-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.dialog-input::placeholder {
  color: var(--text-muted);
}

@keyframes dialogOverlayOut {
  to { opacity: 0; }
}

@keyframes dialogModalOut {
  to { opacity: 0; transform: scale(0.95) translateY(4px); }
}

.modal .join-section {
  margin-top: 16px;
}

.modal .divider {
  text-align: center;
  color: var(--text-muted);
  margin: 16px 0;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ── Modal Checkboxes ── */
.modal-checkboxes {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.modal-checkbox-label {
  display: flex !important;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px !important;
  font-weight: 400 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--text-secondary) !important;
  margin-bottom: 0 !important;
  user-select: none;
}

.modal-checkbox-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}


/* ── Auto-Connect Splash ── */
/* ── Auto-Connect Splash ── */
.auto-connect-splash {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-primary);
  z-index: 1000;
}

.auto-connect-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.auto-connect-logo {
  width: 64px;
  height: 64px;
  filter: drop-shadow(0 4px 12px rgba(139, 94, 60, 0.3));
}

.auto-connect-text {
  font-size: 16px;
  color: var(--text-secondary);
}

.auto-connect-text strong {
  color: var(--text-primary);
}

.auto-connect-dots {
  display: flex;
  gap: 6px;
}

.auto-connect-dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  animation: splash-dot 1.4s infinite ease-in-out both;
}

.auto-connect-dots span:nth-child(2) {
  animation-delay: 0.16s;
}

.auto-connect-dots span:nth-child(3) {
  animation-delay: 0.32s;
}

.auto-connect-cancel {
  background: none;
  border: 1px solid var(--border-strong);
  color: var(--text-secondary);
  padding: 6px 20px;
  border-radius: var(--radius);
  font-size: 13px;
  cursor: pointer;
  font-family: var(--font);
  transition: all 0.15s;
}

.auto-connect-cancel:hover {
  color: var(--text-primary);
  border-color: var(--accent);
}

/* ── Discovery Server Cards ── */
.discovery-server-card {
  padding: 8px 12px;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s;
}

.discovery-server-card:hover {
  border-color: var(--accent);
  background: var(--accent-dim, rgba(196, 122, 58, 0.08));
}

.discovery-server-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}

.discovery-server-info {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}


/* styles/taskbar.css — Taskbar, badges, groups, snap picker, shortcuts overlay, status bar */
/* ── Bean Chat Desktop Environment — Structural Styles ────────────────
 *
 * Scoped under .bean-desktop-root to avoid collisions with existing CSS.
 * --wm-* variables reference standard :root tokens so that when
 * applyAppearance sets data-theme on :root, the desktop chrome
 * cascades automatically.
 */

/* ── Variables (derived from :root theme tokens) ── */
.bean-desktop-root {
  --wm-chrome-bg: var(--bg-secondary);
  --wm-chrome-bg-focused: var(--bg-tertiary);
  --wm-chrome-text: var(--text-muted);
  --wm-chrome-text-focused: var(--text-secondary);
  --wm-chrome-border: var(--bg-tertiary);
  --wm-dot-close: var(--red);
  --wm-dot-minimize: var(--yellow);
  --wm-dot-maximize: var(--green);
  --wm-badge-green: var(--green);
  --wm-badge-blue: var(--status-playing);
  --wm-badge-red: var(--red);
  --wm-badge-amber: var(--yellow);
  --wm-window-bg: var(--bg-primary);
  --wm-window-border: var(--bg-tertiary);
  --wm-window-radius: var(--radius);
}

/* ── Root layout ── */
.bean-desktop-root {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background: var(--bg-media, #0f0b08);
}

/* ── Taskbar ── */
/* ── Taskbar (WO-A1a) ── */

.bean-taskbar {
  display: flex;
  align-items: center;
  height: var(--taskbar-height);
  padding: 0 8px;
  gap: 2px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  user-select: none;
}

/* Brand / Bean logo */
.bean-taskbar .tb-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  cursor: pointer;
  flex-shrink: 0;
  border-radius: var(--radius-sm);
  transition: background 0.12s;
}

.bean-taskbar .tb-brand:hover {
  background: var(--bg-hover);
}

.bean-taskbar .tb-brand:active {
  background: var(--bg-hover-strong);
}

.bean-taskbar .tb-bean-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Separator */
.bean-taskbar .tb-separator {
  width: 1px;
  height: 16px;
  background: var(--border);
  margin: 0 4px;
  flex-shrink: 0;
}

/* Pinned launchers container */
.bean-taskbar .tb-launchers {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
}

/* Open-but-unpinned windows container */
.bean-taskbar .tb-open-windows {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 1;
  min-width: 0;
}

/* Pinned launcher */
.bean-taskbar .tb-launcher {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.12s;
  font-size: 12px;
  color: var(--text-secondary);
  user-select: none;
  white-space: nowrap;
}

.bean-taskbar .tb-launcher:hover {
  background: var(--bg-hover);
}

.bean-taskbar .tb-launcher.active {
  color: var(--text-primary);
}

.bean-taskbar .tb-launcher.focused {
  background: var(--bg-hover-strong);
  color: var(--text-primary);
}

.bean-taskbar .tb-launcher.minimized {
  opacity: 0.5;
}

.bean-taskbar .tb-launcher.minimized .tb-dot {
  background: transparent !important;
  border: 1.5px solid currentColor;
}

/* Type-color dot */
.bean-taskbar .tb-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Launcher label */
.bean-taskbar .tb-launcher-name {
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Unpinned indicator — dimmer, hollow dot */
.bean-taskbar .tb-unpinned-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.12s;
  font-size: 12px;
  color: var(--text-secondary);
  user-select: none;
  white-space: nowrap;
  opacity: 0.7;
}

.bean-taskbar .tb-unpinned-item:hover {
  background: var(--bg-hover);
  opacity: 1;
}

.bean-taskbar .tb-unpinned-item.focused {
  background: var(--bg-hover-strong);
  color: var(--text-primary);
  opacity: 1;
}

.bean-taskbar .tb-unpinned-item.minimized {
  opacity: 0.4;
}

.bean-taskbar .tb-unpinned-item .tb-dot {
  background: transparent;
  border: 1.5px solid;
}

/* Spacer pushes utils to the right */
.bean-taskbar .tb-spacer {
  flex: 1;
  min-width: 8px;
}

/* Right-side utility buttons */
.bean-taskbar .tb-utils {
  display: flex;
  align-items: center;
  gap: 2px;
}

.bean-taskbar .tb-util-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 6px;
  border-radius: var(--radius-sm);
  transition: color 0.12s, background 0.12s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bean-taskbar .tb-util-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

/* ── Taskbar Badges (WO-A1b) ── */
.tb-launcher {
  position: relative;
}

.tb-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
  z-index: 1;
}

.tb-badge-count {
  min-width: 14px;
  height: 14px;
  padding: 0 4px;
  border-radius: 7px;
  background: var(--text-muted);
  color: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tb-badge-count.mention {
  background: var(--red);
  color: #fff;
}

.tb-badge-live {
  padding: 1px 4px;
  border-radius: 3px;
  background: var(--green);
  color: #fff;
  font-size: 8px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.tb-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.tb-badge-status {
  display: flex;
  align-items: center;
  justify-content: center;
}

.tb-badge-status svg {
  width: 10px;
  height: 10px;
}

/* ── Taskbar Groups (WO-A1c) ── */
.tb-group {
  display: flex;
  align-items: center;
  gap: 0;
}

.tb-group-label {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: background 0.12s;
  user-select: none;
  white-space: nowrap;
}

.tb-group-label:hover {
  background: var(--bg-hover);
}

.tb-group-label-chevron {
  font-size: 8px;
  transition: transform 0.15s;
}

.tb-group.collapsed .tb-group-label-chevron {
  transform: rotate(-90deg);
}

.tb-group.collapsed .tb-group-items {
  display: none;
}

.tb-group-items {
  display: flex;
  align-items: center;
  gap: 2px;
}

.tb-group-color-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── Spacer Divider ── */
.tb-spacer-divider {
  width: 1px;
  height: 16px;
  background: var(--border-strong);
  margin: 0 6px;
  flex-shrink: 0;
}

/* ── Drag Feedback ── */
.tb-launcher.dragging,
.tb-unpinned-item.dragging {
  opacity: 0.4;
}

.tb-drop-indicator {
  width: 2px;
  height: 20px;
  background: var(--accent);
  border-radius: 1px;
  flex-shrink: 0;
  pointer-events: none;
}

/* ── Taskbar Profile Items (WO-B3) ── */
.tb-profiles {
  display: flex;
  align-items: center;
  gap: 2px;
}

.tb-profile {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.12s;
  user-select: none;
  font-size: 14px;
}

.tb-profile:hover {
  background: var(--bg-hover);
}

.tb-profile:active {
  background: var(--bg-hover-strong);
}

.tb-profile-icon {
  line-height: 1;
}

/* ── Snap Picker (WO-B4) ── */
.snap-picker-trigger {
  position: absolute;
  top: 40px;
  right: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  transition: color 0.12s, background 0.12s, border-color 0.12s;
}

.snap-picker-trigger:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
  border-color: var(--border-strong);
}

.snap-picker-panel {
  position: absolute;
  top: 64px;
  right: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 12px;
  z-index: 10001;
  box-shadow: var(--shadow-lg);
  min-width: 220px;
}

.snap-picker-section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 8px;
}

.snap-picker-section-title:not(:first-child) {
  margin-top: 12px;
}

.snap-picker-zones-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}

.snap-picker-zone-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}

.snap-picker-zone-btn:hover {
  border-color: var(--accent);
  background: var(--bg-hover);
}

.snap-picker-composite-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}

.snap-picker-composite-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 6px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}

.snap-picker-composite-btn:hover {
  border-color: var(--accent);
  background: var(--bg-hover);
}

.snap-picker-composite-name {
  font-size: 9px;
  color: var(--text-muted);
  white-space: nowrap;
}

/* ── Sequential Assignment Prompt (WO-D5) ── */
.snap-assign-prompt {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 12px 24px;
  background: var(--bg-secondary);
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  font-size: 14px;
  color: var(--text-primary);
  z-index: 10005;
  pointer-events: none;
  text-align: center;
}

/* ── Shortcut Cheat Sheet Overlay (WO-A2) ── */
.shortcut-sheet-overlay {
  position: fixed;
  inset: 0;
  background: var(--overlay-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  transition: opacity 0.2s ease;
  backdrop-filter: blur(4px);
}

.shortcut-sheet-overlay.visible {
  opacity: 1;
}

.shortcut-sheet {
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 24px 32px;
  max-width: 480px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: var(--shadow-lg);
  transform: scale(0.95);
  transition: transform 0.2s ease;
}

.shortcut-sheet-overlay.visible .shortcut-sheet {
  transform: scale(1);
}

.shortcut-sheet-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 20px 0;
}

.shortcut-sheet-section {
  margin-bottom: 16px;
}

.shortcut-sheet-section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 8px;
}

.shortcut-sheet-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
}

.shortcut-sheet-keys {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-primary);
  background: var(--bg-tertiary);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  white-space: nowrap;
}

.shortcut-sheet-action {
  font-size: 13px;
  color: var(--text-secondary);
  text-align: right;
}

.shortcut-sheet-hint {
  text-align: center;
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}

/* ── Status Bar (WO-A4) ── */
.bean-statusbar {
  display: flex;
  align-items: center;
  height: var(--statusbar-height);
  padding: 0 10px;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--text-secondary);
  flex-shrink: 0;
  user-select: none;
  gap: 4px;
}

.sb-voice {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sb-voice-users {
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--text-muted);
  font-size: 11px;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sb-voice-quality {
  display: flex;
  align-items: center;
  cursor: pointer;
}

.sb-quality-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  transition: background 0.3s;
}

.sb-voice-controls {
  display: flex;
  align-items: center;
  gap: 2px;
}

.sb-ctrl-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: var(--radius-sm);
  background: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  transition: color 0.12s, background 0.12s;
}

.sb-ctrl-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.sb-ctrl-btn.active {
  color: var(--red);
}

.sb-ctrl-btn.active-green {
  color: var(--green);
}

.sb-ctrl-btn[data-action="disconnect"] {
  color: var(--text-muted);
}

.sb-ctrl-btn[data-action="disconnect"]:hover {
  color: var(--red);
  background: var(--red-dim);
}

.sb-ctrl-btn svg {
  width: 14px;
  height: 14px;
}

.sb-spacer {
  flex: 1;
}

.sb-telemetry {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sb-telemetry-item {
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--text-muted);
  font-size: 11px;
  font-family: var(--font-mono);
  cursor: default;
}

.sb-telemetry-item svg {
  width: 12px;
  height: 12px;
}

/* ── Update Available Pill ── */
.sb-update-pill {
  display: flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: 10px;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: filter 0.15s;
}
.sb-update-pill:hover { filter: brightness(1.15); }

.sb-update-popover {
  width: 260px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
  z-index: 9999;
  font-size: 13px;
  color: var(--text-primary);
}
.sb-update-header {
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 4px;
}
.sb-update-versions {
  color: var(--text-muted);
  font-size: 12px;
  margin-bottom: 12px;
}
.sb-update-section {
  margin-bottom: 10px;
}
.sb-update-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}
.sb-update-link {
  display: block;
  padding: 4px 8px;
  border-radius: 4px;
  color: var(--accent);
  text-decoration: none;
  font-size: 12px;
  transition: background 0.12s;
}
.sb-update-link:hover {
  background: var(--bg-hover);
}
.sb-update-btn {
  display: block;
  width: 100%;
  background: var(--accent);
  color: #fff;
  border: none;
  font-size: 13px;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  margin-top: 8px;
  transition: filter 0.15s;
}
.sb-update-btn:hover { filter: brightness(1.15); }
.sb-update-hint {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 8px;
  line-height: 1.4;
  text-align: center;
}
.sb-update-dismiss {
  position: absolute;
  top: 8px;
  right: 8px;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 14px;
  padding: 2px 4px;
  border-radius: 4px;
}
.sb-update-dismiss:hover { background: var(--bg-hover); color: var(--text-primary); }

/* ── BeanBot Status Bar Toggle (WO-D10) ── */
.sb-bot-toggle { display: flex; align-items: center; gap: 4px; padding: 2px 6px; border-radius: var(--radius-sm); cursor: pointer; transition: background 0.12s; user-select: none; }
.sb-bot-toggle:hover { background: var(--bg-hover); }
.sb-bot-icon { font-size: 14px; line-height: 1; filter: grayscale(0.8); transition: filter 0.2s; }
.sb-bot-toggle.active .sb-bot-icon { filter: grayscale(0); }
.sb-bot-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--text-muted); transition: background 0.2s; }
.sb-bot-dot.active { background: var(--green); }

/* ── Voice Channel Picker (WO-D13) ── */
.sb-channel-picker {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.12s;
  user-select: none;
}
.sb-channel-picker:hover {
  background: var(--bg-hover);
}
.sb-channel-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sb-channel-arrow {
  font-size: 10px;
  color: var(--text-muted);
  line-height: 1;
}

.sb-voice-avatars {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 0 2px;
}
.sb-voice-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  color: var(--text-secondary);
  overflow: hidden;
  flex-shrink: 0;
  border: 1.5px solid var(--bg-secondary);
}
.sb-voice-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.sb-channel-dropdown {
  position: fixed;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: 4px;
  min-width: 180px;
  max-width: 260px;
  box-shadow: var(--shadow-lg);
  z-index: 10003;
}
.sb-channel-dropdown-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 12px;
  color: var(--text-secondary);
  transition: background 0.1s, color 0.1s;
}
.sb-channel-dropdown-item:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}
.sb-channel-dropdown-item.active {
  background: var(--accent-dim);
  color: var(--accent);
}
.sb-channel-dropdown-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sb-channel-dropdown-count {
  font-size: 10px;
  font-weight: 600;
  background: var(--bg-tertiary);
  color: var(--text-muted);
  border-radius: 8px;
  padding: 1px 6px;
  min-width: 16px;
  text-align: center;
  flex-shrink: 0;
  margin-left: 8px;
}

/* styles/window-chrome.css — Toast notifications, window frames, title bars, resize handles, modes, groups, dock strips, context menu, snap preview, empty states */
/* ── Toast Notification System (WO-C3) ── */
.toast-container {
  position: absolute;
  bottom: calc(var(--statusbar-height) + 4px);
  right: 12px;
  display: flex;
  flex-direction: column-reverse;
  gap: 6px;
  z-index: 10002;
  pointer-events: none;
  max-width: 360px;
}

.toast {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  font-size: 13px;
  color: var(--text-primary);
  pointer-events: auto;
  position: relative;
  overflow: hidden;
  transform: translateX(100%);
  opacity: 0;
  transition: transform 0.2s ease-out, opacity 0.2s ease-out;
}

.toast.visible {
  transform: translateX(0);
  opacity: 1;
}

.toast.dismissing {
  transform: translateX(100%);
  opacity: 0;
  transition: transform 0.15s ease-in, opacity 0.15s ease-in;
}

.toast.clickable { cursor: pointer; }
.toast.clickable:hover { background: var(--bg-hover); }

.toast-critical { border-left: 3px solid var(--red); }
.toast-social { border-left: 3px solid var(--accent); }
.toast-informational { border-left: 3px solid var(--text-muted); }

.toast-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--text-muted);
}

.toast-critical .toast-icon { color: var(--red); }
.toast-social .toast-icon { color: var(--accent); }

.toast-message { flex: 1; min-width: 0; line-height: 1.4; }

.toast-dismiss {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  padding: 0 2px;
  flex-shrink: 0;
  transition: color 0.1s;
}

.toast-dismiss:hover { color: var(--text-primary); }

.toast-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--border);
}

.toast-progress-bar {
  height: 100%;
  background: var(--accent);
  width: 100%;
  animation: toast-progress-shrink linear forwards;
}

@keyframes toast-progress-shrink {
  from { width: 100%; }
  to { width: 0%; }
}

@media (prefers-reduced-motion: reduce) {
  .toast { transition: none; transform: none; }
  .toast.visible { transform: none; }
  .toast.dismissing { transform: none; }
  .toast-progress-bar { animation: none; width: 0%; }
}

/* ── Window Empty/Loading/Error States (WO-C4) ── */
.ws-state-container {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ws-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 24px;
  text-align: center;
  max-width: 300px;
}

.ws-state-icon { font-size: 36px; line-height: 1; opacity: 0.7; }
.ws-error-icon { color: var(--yellow); }
.ws-state-text { font-size: 14px; color: var(--text-secondary); line-height: 1.5; }

.ws-state-action-btn {
  margin-top: 4px;
  padding: 8px 20px;
  background: var(--accent);
  color: var(--text-on-accent);
  border: none;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: filter 0.12s;
}

.ws-state-action-btn:hover { filter: brightness(1.1); }

.ws-spinner {
  width: 24px;
  height: 24px;
  border: 2.5px solid var(--border-strong);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: ws-spin 0.8s linear infinite;
}

@keyframes ws-spin { to { transform: rotate(360deg); } }

@media (prefers-reduced-motion: reduce) {
  .ws-spinner { animation: none; opacity: 0.6; }
}

/* ── Settings Auto-Revert Banner (WO-C5) ── */
.settings-revert-banner {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 18px;
  background: var(--yellow);
  color: #1a1a1a;
  font-weight: 600;
  font-size: 13px;
  gap: 12px;
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.3);
}

.settings-revert-text {
  font-size: 13px;
  color: #1a1a1a;
}

.settings-revert-keep-btn {
  padding: 6px 16px;
  background: #1a1a1a;
  color: var(--yellow);
  border: none;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: filter 0.08s;
}

.settings-revert-keep-btn:hover { filter: brightness(1.2); }

/* ── Settings Danger Button ── */
.settings-btn-danger {
  padding: 8px 20px;
  background: var(--red-dim);
  color: var(--red);
  border: 1px solid var(--red);
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: filter 0.12s;
}

.settings-btn-danger:hover { filter: brightness(1.1); }

/* ── Settings Section Cards (WO-D6) ── */
.sw-section-card {
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 16px;
  overflow: hidden;
}

.sw-section-card-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
}

.sw-section-card-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  display: block;
}

.sw-section-card-desc {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
  display: block;
}

.sw-section-card-body {
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sw-setting-note {
  font-size: 12px;
  color: var(--text-muted);
  padding: 8px 12px;
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  line-height: 1.5;
}

.sw-setting-note kbd {
  display: inline-block;
  padding: 1px 6px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-strong);
  border-radius: 3px;
  font-family: var(--font-mono);
  font-size: 11px;
}

.sw-btn-secondary {
  padding: 8px 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}

.sw-btn-secondary:hover {
  background: var(--bg-hover);
  border-color: var(--accent);
}

.sw-btn-danger {
  padding: 8px 16px;
  background: var(--red-dim);
  border: 1px solid var(--red);
  border-radius: var(--radius-sm);
  color: var(--red);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.12s;
}

.sw-btn-danger:hover {
  background: var(--red);
  color: #fff;
}

/* ── About Tab ── */
.sw-about-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: 13px;
}

.sw-about-label { color: var(--text-muted); }
.sw-about-value { color: var(--text-primary); font-family: var(--font-mono); }

/* ── Emulator Stream Controls (WO-D7) ── */
.emu-stream-controls {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
  opacity: 0;
  transition: opacity 0.2s ease;
}

.vw-video-cell:hover .emu-stream-controls {
  opacity: 1;
}

.emu-stream-volume-slider {
  flex: 1;
  max-width: 120px;
  accent-color: var(--accent);
  height: 4px;
}

.emu-stream-volume-label {
  color: #fff;
  font-size: 11px;
  font-family: var(--font-mono);
  min-width: 32px;
  text-align: right;
}

.sw-about-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}

/* ── Accessibility: Focus Visible Rings (WO-C9) ── */
.bean-desktop-root :focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.bean-desktop-root .ctx-menu-item:focus-visible,
.bean-desktop-root .tb-launcher:focus-visible,
.bean-desktop-root .tb-util-btn:focus-visible,
.bean-desktop-root .tb-profile:focus-visible,
.bean-desktop-root .sb-ctrl-btn:focus-visible,
.bean-desktop-root .window-ctrl-btn:focus-visible,
.bean-desktop-root .snap-picker-zone-btn:focus-visible,
.bean-desktop-root .snap-picker-composite-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -1px;
}

.bean-desktop-root :focus:not(:focus-visible) {
  outline: none;
}

@media (prefers-reduced-motion: reduce) {
  .bean-desktop-root :focus-visible {
    transition: none;
  }
}

/* ── Cross-Window Drag Feedback (WO-C6) ── */
.fw-item.dragging,
.aw-card.dragging,
.mw-track-row.dragging {
  opacity: 0.5;
}

/* ── Connection Stats Popover (WO-C7) ── */
.sb-stats-popover {
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: 12px;
  min-width: 200px;
  box-shadow: var(--shadow-lg);
  z-index: 10003;
  position: fixed;
}

.sb-stats-header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

.sb-stats-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 12px;
}

.sb-stats-label { font-size: 12px; color: var(--text-muted); }
.sb-stats-value { font-size: 12px; color: var(--text-primary); font-family: var(--font-mono); text-align: right; }

.drop-target-active,
.cw-input-dragover {
  outline: 2px dashed var(--accent) !important;
  outline-offset: -2px;
  background: var(--accent-dim) !important;
}


/* ── Desktop area ── */
.bean-desktop {
  position: relative;
  flex: 1;
  overflow: hidden;
  outline: none; /* Remove focus outline — keyboard shortcuts need focus */
}

/* ── Window Mode Classes (WO-B0/B1) ── */

/* Compact toggle button now uses .window-ctrl-compact (see window chrome CSS below) */

/* ── Compact Mode: Chat ── */
/* sidebar-col removed (WO-D29) */
.cw-compact .chat-tab-strip {
  display: none;
}

/* ── Compact Mode: Music ── */
.mw-compact .mw-tabs { display: none !important; }
.mw-compact .mw-toolbar { display: none !important; }
.mw-compact .mw-yt-form { display: none !important; }
.mw-compact .mw-content { display: none !important; }
.mw-compact .mw-playlist-area { display: none !important; }
.mw-compact .mw-queue-area { display: none !important; }

/* ── Compact Mode: Voice ── */
.vw-compact .vw-channel-list {
  display: none !important;
}

/* ── Compact Mode: Arcade ── */
.aw-compact .aw-tab-bar {
  display: none !important;
}

.aw-compact .aw-toolbar {
  display: none !important;
}

.aw-compact .aw-filters {
  display: none !important;
}

.aw-compact .aw-search-bar {
  display: none !important;
}

/* ── Window ── */
.bean-desktop .window {
  position: absolute;
  display: flex;
  flex-direction: column;
  background: var(--wm-window-bg);
  border: 1px solid var(--wm-window-border);
  border-radius: var(--wm-window-radius);
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
  transition: left 0.2s ease, top 0.2s ease, width 0.2s ease, height 0.2s ease, box-shadow 0.15s ease;
  animation: window-open 0.15s ease-out;
}

/* Disable position/size transitions during drag & resize for immediate feedback */
.bean-desktop .window.dragging,
.bean-desktop .window.resizing {
  transition: none;
}

/* ── Window open animation ── */
@keyframes window-open {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* ── Window close animation ── */
@keyframes window-close {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.95);
  }
}

.bean-desktop .window.closing {
  animation: window-close 0.15s ease-in forwards;
  pointer-events: none;
}

/* ── Window minimize animation ── */
@keyframes window-minimize {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
  to {
    opacity: 0;
    transform: scale(0.5) translateY(100%);
  }
}

/* Minimize animation now handled via inline styles in desktop-shell.ts (WO-B2) */

.bean-desktop .window.focused {
  border-color: var(--wm-chrome-bg-focused);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

/* Elevated shadow during drag */
.bean-desktop .window.dragging {
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.6);
}

.bean-desktop .window.minimized {
  display: none;
}

.bean-desktop .window.detached {
  display: none;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .bean-desktop .window {
    transition: none !important;
  }
}

.bean-desktop .window.maximized {
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border-radius: 0;
}

/* ── Title bar (WO-C0) ── */
.bean-desktop .window-titlebar {
  display: flex;
  align-items: center;
  height: var(--chrome-height);
  padding: 0 4px 0 12px;
  gap: 4px;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border);
  cursor: grab;
  flex-shrink: 0;
  user-select: none;
}

.bean-desktop .window.focused .window-titlebar {
  background: var(--wm-chrome-bg-focused);
}

.bean-desktop .window-titlebar:active {
  cursor: grabbing;
}

.bean-desktop .window-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.bean-desktop .window.focused .window-title {
  color: var(--wm-chrome-text-focused);
}

/* ── Resize handles — 8 zones around window edges ── */
.bean-desktop .window .resize-handle {
  position: absolute;
  z-index: 10;
}

.bean-desktop .window .resize-handle.n {
  top: -3px; left: 8px; right: 8px; height: 6px;
  cursor: n-resize;
}
.bean-desktop .window .resize-handle.s {
  bottom: -3px; left: 8px; right: 8px; height: 6px;
  cursor: s-resize;
}
.bean-desktop .window .resize-handle.e {
  right: -3px; top: 8px; bottom: 8px; width: 6px;
  cursor: e-resize;
}
.bean-desktop .window .resize-handle.w {
  left: -3px; top: 8px; bottom: 8px; width: 6px;
  cursor: w-resize;
}
.bean-desktop .window .resize-handle.nw {
  top: -3px; left: -3px; width: 12px; height: 12px;
  cursor: nw-resize;
}
.bean-desktop .window .resize-handle.ne {
  top: -3px; right: -3px; width: 12px; height: 12px;
  cursor: ne-resize;
}
.bean-desktop .window .resize-handle.sw {
  bottom: -3px; left: -3px; width: 12px; height: 12px;
  cursor: sw-resize;
}
.bean-desktop .window .resize-handle.se {
  bottom: -3px; right: -3px; width: 12px; height: 12px;
  cursor: se-resize;
}

/* Maximize hides resize handles */
.bean-desktop .window.maximized .resize-handle {
  display: none;
}

/* ── Window chrome (WO-C0) ── */

.bean-desktop .window-chrome {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.window-title-spacer {
  flex: 1;
}

/* Control buttons (right-aligned) */
.bean-desktop .window-controls {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
}

.bean-desktop .window-ctrl-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 24px;
  border: none;
  background: none;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: color 0.1s, background 0.1s;
  padding: 0;
}

.bean-desktop .window-ctrl-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.bean-desktop .window-ctrl-btn svg {
  width: 12px;
  height: 12px;
}

/* Close button: red hover */
.bean-desktop .window-ctrl-close:hover {
  color: #fff;
  background: var(--red);
}

/* Compact toggle active state */
.bean-desktop .window-ctrl-compact.active {
  color: var(--accent);
}

/* ── Window Focus States (WO-C0) ── */
.bean-desktop .window {
  transition: box-shadow 0.2s ease;
}

.bean-desktop .window.unfocused .window-chrome {
  opacity: 0.85;
  transition: opacity 0.2s ease;
}

.bean-desktop .window.unfocused .window-titlebar {
  filter: saturate(0.7);
}

.bean-desktop .window.unfocused .window-body {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .bean-desktop .window,
  .bean-desktop .window.unfocused .window-chrome {
    transition: none;
  }
}

/* Badge */
.bean-desktop .window-badge {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 8px;
  font-weight: 600;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  flex-shrink: 0;
}

.bean-desktop .window-badge--green { background: var(--wm-badge-green); color: #000; }
.bean-desktop .window-badge--blue { background: var(--wm-badge-blue); color: #fff; }
.bean-desktop .window-badge--red { background: var(--wm-badge-red); color: #fff; }
.bean-desktop .window-badge--amber { background: var(--wm-badge-amber); color: #000; }

/* Tabs in title bar */
.bean-desktop .window-tabs {
  display: flex;
  gap: 2px;
  margin-left: 4px;
  flex-shrink: 1;
  overflow: hidden;
}

.bean-desktop .window-tab {
  background: transparent;
  border: none;
  color: var(--wm-chrome-text);
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.1s, color 0.1s;
}

.bean-desktop .window-tab:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--wm-chrome-text-focused);
}

.bean-desktop .window-tab.active {
  background: rgba(255, 255, 255, 0.1);
  color: var(--wm-chrome-text-focused);
}

/* Window body */
.bean-desktop .window-body { flex: 1; min-height: 0; min-width: 0; overflow: hidden; display: flex; flex-direction: column; }
.bean-desktop .window-body > * { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; }

/* Window lock button (title bar) */
.bean-desktop .window-lock-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  margin-right: 2px;
  flex-shrink: 0;
  padding: 0;
  transition: color 0.1s;
}
.bean-desktop .window-lock-btn svg { width: 12px; height: 12px; }
.bean-desktop .window-lock-btn.visible { display: flex; }
.bean-desktop .window-lock-btn:hover { color: var(--text-primary); }
.bean-desktop .window-lock-btn.persistent { color: var(--accent); }
.bean-desktop .window-lock-btn.persistent:hover { color: var(--accent); opacity: 0.8; }

/* Locked / persistent window indicators */
.bean-desktop .window.locked .resize-handle { pointer-events: none; cursor: default; }
.bean-desktop .window.locked .window-titlebar { cursor: default; }

/* ── Window Group Tabs ── */
.bean-desktop .window-group-tabs {
  display: flex;
  gap: 1px;
  margin-left: 6px;
  flex-shrink: 1;
  overflow: hidden;
  align-items: center;
}

.bean-desktop .window-group-tab {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0 8px;
  height: calc(var(--chrome-height, 32px) - 8px);
  border-radius: var(--radius-sm, 4px) var(--radius-sm, 4px) 0 0;
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 11px;
  cursor: pointer;
  max-width: 140px;
  transition: background 0.1s, color 0.1s;
  flex-shrink: 1;
  min-width: 0;
}

.bean-desktop .window-group-tab:hover { background: rgba(255, 255, 255, 0.06); color: var(--text-secondary); }
.bean-desktop .window-group-tab.active { background: rgba(255, 255, 255, 0.1); color: var(--text-primary); }

.bean-desktop .window-group-tab-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}

.bean-desktop .window-group-tab-close {
  width: 14px;
  height: 14px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 12px;
  line-height: 1;
  opacity: 0;
  padding: 0;
  transition: opacity 0.1s;
}

.bean-desktop .window-group-tab:hover .window-group-tab-close { opacity: 1; }
.bean-desktop .window-group-tab-close:hover { color: var(--red); background: rgba(255, 80, 80, 0.15); }

/* ── Edge Dock Strips ── */
.bean-desktop .dock-strip {
  position: absolute;
  z-index: 999990;
  cursor: pointer;
}
.bean-desktop .dock-strip[data-dock-edge="left"] { left: 0; top: 0; bottom: 0; width: 6px; }
.bean-desktop .dock-strip[data-dock-edge="right"] { right: 0; top: 0; bottom: 0; width: 6px; }
.bean-desktop .dock-strip[data-dock-edge="top"] { left: 0; right: 0; top: 0; height: 6px; }
.bean-desktop .dock-strip[data-dock-edge="bottom"] { left: 0; right: 0; bottom: 0; height: 6px; }

.bean-desktop .dock-strip-indicator {
  width: 100%;
  height: 100%;
  background: var(--accent, #7c5cbf);
  opacity: 0.35;
  border-radius: 2px;
  transition: opacity 0.15s;
}
.bean-desktop .dock-strip:hover .dock-strip-indicator { opacity: 0.8; }

.bean-desktop .dock-reveal-panel {
  position: absolute;
  z-index: 999991;
  pointer-events: none;
  overflow: hidden;
}

.bean-desktop .dock-reveal-panel[data-dock-edge="left"] {
  left: 0; top: 0; bottom: 0;
  transform: translateX(-100%);
  transition: transform 150ms ease-out;
}
.bean-desktop .dock-reveal-panel[data-dock-edge="right"] {
  right: 0; top: 0; bottom: 0;
  transform: translateX(100%);
  transition: transform 150ms ease-out;
}
.bean-desktop .dock-reveal-panel[data-dock-edge="top"] {
  left: 0; right: 0; top: 0;
  transform: translateY(-100%);
  transition: transform 150ms ease-out;
}
.bean-desktop .dock-reveal-panel[data-dock-edge="bottom"] {
  left: 0; right: 0; bottom: 0;
  transform: translateY(100%);
  transition: transform 150ms ease-out;
}

.bean-desktop .dock-reveal-panel.revealed {
  transform: translate(0, 0);
  pointer-events: auto;
}

/* Group merge preview (drag onto title bar) */
.bean-desktop .group-merge-preview {
  position: absolute;
  background: var(--accent, #7c5cbf);
  opacity: 0.25;
  border: 2px dashed var(--accent, #7c5cbf);
  pointer-events: none;
  border-radius: var(--radius-sm, 4px);
  z-index: 999998;
  transition: all 100ms ease;
}

/* Snap guide lines (edge magnetism) */
.bean-desktop .snap-guide-line {
  position: absolute;
  background: var(--accent, #7c5cbf);
  opacity: 0.5;
  pointer-events: none;
  z-index: 999997;
}

/* Lazy window loading placeholder */
.bean-desktop .window-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--text-muted);
  font-size: var(--text-sm);
  opacity: 0.6;
}

/* ── Context Menu Engine (WO-C2a) ── */
.ctx-menu {
  position: fixed;
  z-index: 99999;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: 4px;
  min-width: 160px;
  max-width: 280px;
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(8px);
  outline: none;
}

.ctx-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 13px;
  color: var(--text-primary);
  transition: background 0.08s;
  position: relative;
  user-select: none;
}

.ctx-menu-item:hover,
.ctx-menu-item.focused {
  background: var(--bg-hover);
}

.ctx-menu-item.disabled {
  color: var(--text-muted);
  cursor: default;
  pointer-events: none;
}

.ctx-menu-item.danger {
  color: var(--red);
}

.ctx-menu-item.danger:hover,
.ctx-menu-item.danger.focused {
  background: var(--red-dim);
}

.ctx-menu-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.ctx-menu-icon svg {
  width: 14px;
  height: 14px;
}

.ctx-menu-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ctx-menu-shortcut {
  font-size: 11px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  margin-left: auto;
  padding-left: 16px;
  flex-shrink: 0;
}

.ctx-menu-arrow {
  font-size: 10px;
  color: var(--text-muted);
  margin-left: auto;
  flex-shrink: 0;
}

.ctx-menu-separator {
  height: 1px;
  background: var(--border);
  margin: 4px 8px;
}

.ctx-menu-item .ctx-menu {
  position: absolute;
  top: 0;
  left: 100%;
}

.ctx-menu-item.ctx-submenu-open {
  background: var(--bg-hover);
}

@media (prefers-reduced-motion: reduce) {
  .ctx-menu {
    backdrop-filter: none;
  }
}

/* ── Snap preview (WO-2C) ── */
.bean-desktop .snap-preview {
  position: absolute;
  background: var(--wm-chrome-bg-focused);
  opacity: 0.3;
  border-radius: var(--wm-window-radius);
  border: 2px solid var(--wm-dot-maximize);
  pointer-events: none;
  transition: all 150ms ease;
  z-index: 999999;
  animation: snap-pulse 2s ease infinite;
}

@keyframes snap-pulse {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 0.45; }
}

/* ── Modern empty state (shared) ── */
.modern-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  text-align: center;
}

.modern-section-header {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  padding: 12px 16px 6px;
}

/* styles/hub.css — Hub/welcome window */
/* ══════════════════════════════════════════════════════════════════════
   WO-D30: Hub Window (rewrite)
   ══════════════════════════════════════════════════════════════════════ */

.hub-root {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 24px;
  height: 100%;
  overflow-y: auto;
}

/* ── Hero ── */
.hub-hero {
  padding: 4px 0;
}

.hub-greeting {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 4px;
}

.hub-summary {
  font-size: 13px;
  color: var(--text-secondary);
  margin: 0;
}

/* ── Activity cards (horizontal scroll) ── */
.hub-activity-cards {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: thin;
}

.hub-activity-cards::-webkit-scrollbar {
  height: 4px;
}

.hub-activity-cards::-webkit-scrollbar-thumb {
  background: var(--bg-tertiary);
  border-radius: 2px;
}

.hub-activity-card {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 180px;
  max-width: 240px;
  flex-shrink: 0;
  padding: 10px 14px;
  background: var(--bg-secondary);
  border-radius: 10px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: background 0.15s, transform 0.1s;
}

.hub-activity-card:hover {
  background: var(--bg-tertiary);
  transform: translateY(-1px);
}

.hub-activity-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  border-radius: 3px 0 0 3px;
  background: var(--accent);
}

.hub-activity-card[data-type="game"]::before { background: var(--green); }
.hub-activity-card[data-type="music"]::before { background: var(--accent); }
.hub-activity-card[data-type="voice"]::before { background: var(--yellow); }
.hub-activity-card[data-type="bot"]::before { background: #c47a3a; }

.hub-activity-card-icon {
  font-size: 20px;
  flex-shrink: 0;
}

.hub-activity-card-body {
  min-width: 0;
  flex: 1;
}

.hub-activity-card-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hub-activity-card-sub {
  font-size: 11px;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Stats strip ── */
.hub-stats-strip {
  display: flex;
  gap: 8px;
}

.hub-stat-pill {
  flex: 1;
  background: var(--bg-secondary);
  border-radius: 8px;
  padding: 10px 8px;
  text-align: center;
  min-width: 0;
}

.hub-stat-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
}

.hub-stat-label {
  font-size: 10px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-top: 2px;
}

/* ── Two-column layout ── */
.hub-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.hub-col {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.hub-col-header {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--text-muted);
  padding-bottom: 4px;
}

/* ── Events list ── */
.hub-events-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.hub-events-empty {
  font-size: 13px;
  color: var(--text-muted);
  font-style: italic;
  padding: 8px 0;
}

.hub-event-item {
  display: flex;
  gap: 12px;
  padding: 8px 12px;
  background: var(--bg-secondary);
  border-radius: 6px;
}

.hub-event-date {
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  white-space: nowrap;
  min-width: 80px;
}

.hub-event-info {
  flex: 1;
  min-width: 0;
}

.hub-event-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hub-event-meta {
  font-size: 12px;
  color: var(--text-muted);
}

/* ── System health gauges ── */
.hub-system-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.hub-gauge {
  padding: 0;
}

.hub-gauge-label {
  font-size: 11px;
  color: var(--text-muted);
}

.hub-gauge-value {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
}

.hub-gauge-bar {
  height: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}

.hub-gauge-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.4s ease, background 0.3s ease;
  position: relative;
}

.hub-gauge-bar-fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.1) 50%,
    rgba(255, 255, 255, 0) 100%
  );
  animation: hub-gauge-shimmer 2s ease-in-out infinite;
}

@keyframes hub-gauge-shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* ── Activity feed ── */
.hub-feed {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.hub-feed-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.hub-feed-empty {
  font-size: 13px;
  color: var(--text-muted);
  font-style: italic;
  padding: 8px 0;
}

.hub-feed-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: var(--bg-secondary);
  border-radius: 6px;
  font-size: 13px;
}

.hub-feed-item-icon {
  font-size: 14px;
  flex-shrink: 0;
}

.hub-feed-item-text {
  flex: 1;
  color: var(--text-secondary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hub-feed-item-time {
  font-size: 11px;
  color: var(--text-muted);
  flex-shrink: 0;
}

/* styles/social.css — Bookmarks, lists, feedback, events windows */
/* ══════════════════════════════════════════════════════════════════════
   WO-5C: Bookmarks Window
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root ── */
.bkm-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.bkm-search-bar {
  padding: var(--space-5, 12px) var(--space-6, 16px) var(--space-3, 8px);
  flex-shrink: 0;
}

.bkm-search-input {
  width: 100%;
  padding: 8px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s;
  box-sizing: border-box;
}

.bkm-search-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-dim, rgba(196,122,58,0.15));
}

.bkm-search-input::placeholder {
  color: var(--text-muted);
}

/* ── Tag filter chips ── */
.bkm-tag-bar {
  display: flex;
  gap: 6px;
  padding: 0 var(--space-6, 16px) var(--space-4, 10px);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.bkm-tag-chip {
  padding: 3px 10px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-pill, 12px);
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}

.bkm-tag-chip:hover {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

.bkm-tag-chip.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--text-on-accent, #fff);
}

/* ── Cards grid ── */
.bkm-cards {
  flex: 1;
  overflow-y: auto;
  padding: 0 var(--space-6, 16px) var(--space-6, 16px);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4, 10px);
  align-content: start;
}

.bkm-card {
  background: var(--bg-secondary);
  border-radius: var(--radius-md, 8px);
  overflow: hidden;
  border: 1px solid var(--bg-tertiary);
  transition: border-color 0.15s, transform 0.12s, box-shadow 0.2s;
}

.bkm-card:hover {
  border-color: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* ── Card image (140px cover) ── */
.bkm-card-image {
  width: 100%;
  height: 140px;
  object-fit: cover;
  display: block;
}

.bkm-card-content {
  padding: var(--space-5, 12px) var(--space-5, 14px);
}

.bkm-card-site {
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  margin-bottom: 4px;
}

.bkm-card-title {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bkm-card-title:hover {
  text-decoration: underline;
}

/* ── 2-line description clamp ── */
.bkm-card-desc {
  font-size: 12px;
  color: var(--text-secondary);
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.5;
}

.bkm-card-url {
  font-size: 11px;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-bottom: var(--space-3, 8px);
}

.bkm-jump-link {
  color: var(--accent);
  text-decoration: none;
  cursor: pointer;
  font-weight: 500;
  display: inline-block;
}

.bkm-jump-link:hover {
  text-decoration: underline;
  color: var(--accent-hover, var(--accent));
}

/* ── Tag pills (accent-colored) ── */
.bkm-card-tags {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: var(--space-3, 8px);
}

.bkm-card-tag {
  padding: 2px 8px;
  background: var(--accent-dim, rgba(196,122,58,0.15));
  border-radius: var(--radius-pill, 10px);
  font-size: 11px;
  color: var(--accent);
  font-weight: 500;
}

.bkm-add-tag-btn {
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
  border: none;
  border-radius: 50%;
  color: var(--text-muted);
  font-size: 14px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}

.bkm-add-tag-btn:hover {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
}

.bkm-tag-input {
  padding: 2px 8px;
  background: var(--bg-primary);
  border: 1px solid var(--accent);
  border-radius: var(--radius-pill, 10px);
  font-size: 11px;
  color: var(--text-primary);
  outline: none;
  width: 80px;
}

/* ── Footer ── */
.bkm-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.bkm-card-meta {
  font-size: 11px;
  color: var(--text-muted);
}

.bkm-delete-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  border-radius: var(--radius-sm, 4px);
  display: flex;
  align-items: center;
  transition: color 0.12s, background 0.12s;
}

.bkm-delete-btn:hover {
  color: var(--red, #e74c3c);
  background: rgba(231, 76, 60, 0.1);
}

.bkm-delete-btn svg {
  width: 14px;
  height: 14px;
}

/* ══════════════════════════════════════════════════════════════════════
   WO-5D: Lists Window
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root ── */
.lst-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.lst-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-5, 14px) var(--space-6, 16px) var(--space-4, 10px);
  flex-shrink: 0;
}

.lst-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
}

.lst-create-btn {
  padding: 6px 14px;
  background: var(--accent);
  border: none;
  border-radius: var(--radius-sm, 6px);
  color: var(--text-on-accent, #fff);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: filter 0.12s, transform 0.08s;
}

.lst-create-btn:hover { filter: brightness(1.1); }
.lst-create-btn:active { transform: scale(0.97); }

/* ── Create form ── */
.lst-create-form {
  padding: 0 var(--space-6, 16px) var(--space-5, 12px);
  flex-shrink: 0;
}

.lst-create-input {
  width: 100%;
  padding: 8px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  margin-bottom: var(--space-3, 8px);
  box-sizing: border-box;
  transition: border-color 0.15s;
}

.lst-create-input:focus { border-color: var(--accent); }
.lst-create-input::placeholder { color: var(--text-muted); }

.lst-create-btn-row {
  display: flex;
  gap: var(--space-3, 8px);
}

.lst-create-submit {
  padding: 6px 14px;
  background: var(--accent);
  border: none;
  border-radius: var(--radius-sm, 6px);
  color: var(--text-on-accent, #fff);
  font-size: 13px;
  cursor: pointer;
  transition: filter 0.12s;
}

.lst-create-submit:hover { filter: brightness(1.1); }

.lst-create-cancel {
  padding: 6px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.12s;
}

.lst-create-cancel:hover { background: var(--bg-tertiary); }

/* ── List cards ── */
.lst-cards {
  flex: 1;
  overflow-y: auto;
  padding: 0 var(--space-6, 16px) var(--space-6, 16px);
}

.lst-card {
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-md, 8px);
  margin-bottom: var(--space-3, 8px);
  overflow: hidden;
  transition: border-color 0.15s;
}

.lst-card:hover { border-color: rgba(255, 255, 255, 0.12); }
.lst-card.expanded { border-color: var(--accent); }

.lst-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-5, 12px) var(--space-5, 14px);
  cursor: pointer;
  transition: background 0.12s;
}

.lst-card-header:hover { background: rgba(255, 255, 255, 0.03); }

/* ── Bold card title ── */
.lst-card-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}

.lst-card-right {
  display: flex;
  align-items: center;
  gap: var(--space-3, 8px);
}

.lst-card-stats {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 500;
}

.lst-delete-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  border-radius: var(--radius-sm, 4px);
  display: flex;
  align-items: center;
  transition: color 0.12s, background 0.12s;
}

.lst-delete-btn:hover {
  color: var(--red, #e74c3c);
  background: rgba(231, 76, 60, 0.1);
}

.lst-delete-btn svg { width: 14px; height: 14px; }

/* ── Item rows ── */
.lst-items {
  padding: 0 var(--space-5, 14px) var(--space-5, 12px);
}

.lst-item {
  display: flex;
  align-items: center;
  gap: var(--space-3, 8px);
  padding: 6px 0;
  border-bottom: 1px solid var(--bg-tertiary);
  transition: background 0.08s;
}

.lst-item:last-of-type { border-bottom: none; }

/* ── Checked strikethrough + muted ── */
.lst-item.checked .lst-item-text {
  text-decoration: line-through;
  color: var(--text-muted);
  opacity: 0.6;
}

/* ── Checkbox accent color ── */
.lst-item-checkbox {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  flex-shrink: 0;
  cursor: pointer;
}

.lst-item-text {
  flex: 1;
  font-size: 13px;
  color: var(--text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color 0.12s, opacity 0.12s;
}

.lst-item-delete-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  border-radius: var(--radius-sm, 4px);
  display: flex;
  align-items: center;
  opacity: 0;
  transition: opacity 0.12s, color 0.12s;
}

.lst-item:hover .lst-item-delete-btn { opacity: 1; }
.lst-item-delete-btn:hover { color: var(--red, #e74c3c); }
.lst-item-delete-btn svg { width: 12px; height: 12px; }

.lst-add-input {
  width: 100%;
  padding: 8px 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--bg-tertiary);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.15s;
}

.lst-add-input:focus { border-bottom-color: var(--accent); }
.lst-add-input::placeholder { color: var(--text-muted); }

.lst-card-footer {
  padding: var(--space-3, 8px) var(--space-5, 14px);
  font-size: 11px;
  color: var(--text-muted);
  border-top: 1px solid var(--bg-tertiary);
}

/* ══════════════════════════════════════════════════════════════════════
   WO-5E: Feedback Window
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root ── */
.fb-root {
  padding: var(--space-8, 20px);
  height: 100%;
  box-sizing: border-box;
  overflow-y: auto;
}

.fb-header {
  margin-bottom: var(--space-6, 16px);
}

.fb-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.fb-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4, 10px);
  max-width: 520px;
}

.fb-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.fb-cat-group {
  display: flex;
  gap: 6px;
}

.fb-cat-btn {
  flex: 1;
  padding: 8px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}

.fb-cat-btn:hover {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

.fb-cat-btn.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--text-on-accent, #fff);
}

/* ── bc-input style for feedback form inputs ── */
.fb-input {
  padding: 8px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.fb-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-dim, rgba(196,122,58,0.15));
}
.fb-input::placeholder { color: var(--text-muted); }

.fb-textarea {
  padding: 8px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  resize: vertical;
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.fb-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-dim, rgba(196,122,58,0.15));
}
.fb-textarea::placeholder { color: var(--text-muted); }

.fb-file-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.fb-file-btn {
  padding: 6px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
  flex-shrink: 0;
}

.fb-file-btn:hover {
  background: var(--bg-tertiary);
  border-color: var(--accent);
}

.fb-file-name {
  font-size: 12px;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fb-status {
  font-size: 13px;
  min-height: 20px;
  transition: color 0.15s;
}

.fb-status.error { color: var(--red, #e74c3c); }
.fb-status.success { color: var(--green); }

/* ── Submit button (bc-btn bc-btn-primary style) ── */
.fb-submit-btn {
  padding: 10px 20px;
  background: var(--accent);
  border: none;
  border-radius: var(--radius-sm, 6px);
  color: var(--text-on-accent, #fff);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: filter 0.12s, transform 0.08s;
}

.fb-submit-btn:hover { filter: brightness(1.1); }
.fb-submit-btn:active { transform: scale(0.97); }
.fb-submit-btn:disabled { opacity: 0.5; cursor: not-allowed; filter: none; }

/* ══════════════════════════════════════════════════════════════════════
   WO-D31: Events Window
   ══════════════════════════════════════════════════════════════════════ */

.evt-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

/* Header */
.evt-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px 10px;
  flex-shrink: 0;
}

.evt-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}

.evt-create-btn {
  padding: 6px 14px;
  background: var(--accent);
  border: none;
  border-radius: 6px;
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}

.evt-create-btn:hover { opacity: 0.85; }
.evt-create-btn:active { transform: scale(0.97); }

/* Create form — card surface */
.evt-create-form {
  margin: 0 16px 12px;
  padding: 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex-shrink: 0;
}

.evt-create-btn-row {
  display: flex;
  gap: 8px;
  padding-top: 4px;
}

.evt-create-submit {
  padding: 7px 16px;
  background: var(--accent);
  border: none;
  border-radius: 6px;
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}

.evt-create-submit:hover { opacity: 0.85; }
.evt-create-submit:active { transform: scale(0.97); }

.evt-create-cancel {
  padding: 7px 16px;
  background: transparent;
  border: 1px solid var(--bg-tertiary);
  border-radius: 6px;
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}

.evt-create-cancel:hover {
  background: var(--bg-tertiary);
  border-color: rgba(255, 255, 255, 0.1);
}

/* Calendar — card surface */
.evt-calendar {
  margin: 0 16px 12px;
  padding: 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: 10px;
  flex-shrink: 0;
}

.evt-calendar-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.evt-calendar-nav-btn {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  transition: background 0.12s, color 0.12s;
}

.evt-calendar-nav-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
}

.evt-calendar-nav-btn svg { width: 16px; height: 16px; }

.evt-calendar-month-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0.2px;
}

/* Calendar grid — 7 column */
.evt-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}

.evt-calendar-dow {
  font-size: 11px;
  color: var(--text-muted);
  text-align: center;
  padding: 4px 0 6px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.evt-calendar-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 4px 2px;
  border-radius: 6px;
  min-height: 36px;
  font-size: 12px;
  color: var(--text-secondary);
  transition: background 0.12s;
}

.evt-calendar-day.other-month {
  color: var(--text-muted);
  opacity: 0.35;
}

.evt-calendar-day.today .evt-calendar-day-num {
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  box-shadow: 0 0 8px rgba(88, 101, 242, 0.35);
}

.evt-calendar-day.has-events {
  cursor: pointer;
}

.evt-calendar-day.has-events:hover {
  background: rgba(255, 255, 255, 0.06);
}

.evt-calendar-day-num {
  font-size: 12px;
  line-height: 1;
}

.evt-calendar-dots {
  display: flex;
  gap: 3px;
  margin-top: 3px;
}

.evt-calendar-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  transition: transform 0.12s;
}

.evt-calendar-dot.past {
  background: var(--text-muted);
}

.evt-calendar-dot.going {
  background: var(--green);
  box-shadow: 0 0 4px rgba(46, 204, 113, 0.4);
}

.evt-calendar-dot.pending {
  background: var(--accent);
  box-shadow: 0 0 4px rgba(88, 101, 242, 0.4);
}

/* Cards container */
.evt-cards {
  flex: 1;
  overflow-y: auto;
  padding: 0 16px 16px;
}

.evt-section-header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  padding: 14px 0 8px;
}

.evt-past-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 12px 0;
  font-size: 13px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.12s;
  user-select: none;
}

.evt-past-toggle:hover { color: var(--text-primary); }
.evt-past-toggle svg { width: 14px; height: 14px; }

/* Event card */
.evt-card {
  background: var(--bg-secondary);
  border: 1px solid var(--bg-tertiary);
  border-radius: 10px;
  margin-bottom: 10px;
  overflow: hidden;
  transition: border-color 0.15s, box-shadow 0.2s;
}

.evt-card:hover {
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.evt-card.past {
  opacity: 0.55;
  filter: saturate(0.6);
}

.evt-card-header {
  padding: 14px 14px 8px;
}

.evt-card-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 3px;
}

.evt-card-datetime {
  font-size: 12px;
  color: var(--accent);
  font-weight: 500;
}

.evt-card-body {
  padding: 0 14px 10px;
}

.evt-card-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.45;
}

/* RSVP segmented control */
.evt-rsvp-bar {
  display: flex;
  margin: 0 14px;
  border: 1px solid var(--bg-tertiary);
  border-radius: 8px;
  overflow: hidden;
}

.evt-rsvp-btn {
  flex: 1;
  padding: 7px 8px;
  background: transparent;
  border: none;
  border-right: 1px solid var(--bg-tertiary);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}

.evt-rsvp-btn:last-child { border-right: none; }

.evt-rsvp-btn:hover { background: rgba(255, 255, 255, 0.06); }

.evt-rsvp-btn.going.selected {
  background: rgba(46, 204, 113, 0.15);
  color: var(--green);
}

.evt-rsvp-btn.maybe.selected {
  background: rgba(241, 196, 15, 0.15);
  color: var(--yellow);
}

.evt-rsvp-btn.not-going.selected {
  background: rgba(231, 76, 60, 0.12);
  color: var(--red, #e74c3c);
}

/* Attendees — avatar circles */
.evt-attendees {
  padding: 10px 14px 6px;
}

.evt-attendee-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.evt-attendee-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  flex-shrink: 0;
}

.evt-attendee-label.going { color: var(--green); }
.evt-attendee-label.maybe { color: var(--yellow); }
.evt-attendee-label.not-going { color: var(--red, #e74c3c); }

.evt-attendee-avatars {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.evt-attendee-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  flex-shrink: 0;
  cursor: default;
}

/* Footer */
.evt-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 14px;
  border-top: 1px solid var(--bg-tertiary);
  font-size: 11px;
  color: var(--text-muted);
}

.evt-delete-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  transition: color 0.12s, background 0.12s;
}

.evt-delete-btn:hover {
  color: var(--red, #e74c3c);
  background: rgba(231, 76, 60, 0.1);
}

.evt-delete-btn svg { width: 14px; height: 14px; }

/* styles/settings.css — Settings window, legacy inner component styles */
/* ── Settings Window ── */

.sw-root {
  display: flex;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--bg-primary);
  container-type: inline-size;
}

.sw-nav {
  width: 200px;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border, var(--bg-tertiary));
  padding: 8px 0;
  overflow-y: auto;
  gap: 2px;
}

.sw-nav-group-label {
  font-size: var(--text-2xs, 9px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  padding: 10px 16px 4px;
  margin-top: 4px;
  user-select: none;
}

.sw-nav-group-label:first-child {
  margin-top: 0;
  padding-top: 6px;
}

.sw-nav-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  margin: 0 6px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  text-align: left;
  white-space: nowrap;
}

.sw-nav-btn:hover {
  background: var(--bg-hover, rgba(255,255,255,0.05));
  color: var(--text-primary);
}

.sw-nav-btn.active {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
}

.sw-nav-icon {
  font-size: 14px;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
  line-height: 1;
}

.sw-nav-icon svg {
  width: 14px;
  height: 14px;
}

.sw-nav-admin {
  opacity: 0.7;
}
.sw-nav-admin:hover {
  opacity: 1;
}

.sw-nav-divider {
  height: 1px;
  background: var(--border, var(--bg-tertiary));
  margin: 6px 12px;
}

.sw-nav-save-btn {
  display: block;
  width: calc(100% - 12px);
  margin: 0 6px;
  padding: 8px;
  border: none;
  border-radius: 4px;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
}

.sw-nav-save-btn:hover {
  background: var(--accent-hover, var(--accent));
}

.sw-nav-save-btn:active {
  transform: scale(0.97);
}

.sw-nav-save-btn.saved {
  background: var(--green, #27ae60);
}

.sw-nav-profile-btn {
  display: block;
  width: calc(100% - 12px);
  margin: 4px 6px 0;
  padding: 6px 8px;
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 4px;
  background: transparent;
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.12s;
}

.sw-nav-profile-btn:hover {
  background: var(--bg-hover, rgba(255,255,255,0.05));
}

.sw-profile-input-row {
  display: flex;
  gap: 4px;
  padding: 4px 6px;
  align-items: center;
}

.sw-profile-input {
  flex: 1;
  padding: 4px 8px;
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 4px;
  background: var(--bg-input, var(--bg-primary));
  color: var(--text-primary);
  font-size: 12px;
  outline: none;
}

.sw-profile-confirm-btn,
.sw-profile-cancel-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
}
.sw-profile-confirm-btn svg,
.sw-profile-cancel-btn svg {
  width: 14px;
  height: 14px;
}
.sw-profile-confirm-btn:hover { color: var(--green, #27ae60); }
.sw-profile-cancel-btn:hover { color: var(--red, #e74c3c); }

.sw-profile-dropdown {
  margin: 4px 6px 0;
}

.sw-profile-dropdown-label {
  padding: 6px 8px;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: 4px;
  transition: background 0.12s;
}
.sw-profile-dropdown-label:hover {
  background: var(--bg-hover, rgba(255,255,255,0.05));
}

.sw-profile-list {
  padding: 2px 0;
}

.sw-profile-item {
  display: flex;
  align-items: center;
  padding: 4px 8px;
  gap: 4px;
}

.sw-profile-item-name {
  flex: 1;
  font-size: 12px;
  color: var(--text-primary);
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  transition: background 0.12s;
}
.sw-profile-item-name:hover {
  background: var(--bg-hover, rgba(255,255,255,0.05));
}

.sw-profile-item-delete {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
}
.sw-profile-item-delete svg { width: 12px; height: 12px; }
.sw-profile-item-delete:hover { color: var(--red, #e74c3c); }

.sw-nav-version {
  margin-top: auto;
  padding: 8px 14px;
  font-size: 11px;
  color: var(--text-muted);
  text-align: center;
}

.sw-content-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.sw-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px 28px;
  min-width: 480px;
}

.sw-banner-slot {
  flex-shrink: 0;
}

/* Section cards for Desktop tab */
.sw-section-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 8px;
  margin-bottom: 16px;
  overflow: hidden;
}

.sw-section-card-header {
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
}

.sw-section-card-body {
  padding: 12px 14px;
}

/* ══════════════════════════════════════════════════════════════

/* ══════════════════════════════════════════════════════════════
   Settings — Legacy Inner Component Styles (ported from styles.css)
   Scoped under .sw-root to prevent leaking
   ══════════════════════════════════════════════════════════════ */

.sw-root .settings-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.sw-root .settings-section-title {
  font-size: var(--text-2xl, 24px);
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.sw-root .settings-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sw-root .settings-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-muted);
  letter-spacing: 0.5px;
}

/* ── Device Dropdown ── */
.sw-root .device-dropdown {
  width: 100%;
  padding: 8px 10px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-family: var(--font);
  font-size: 13px;
  outline: none;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a6b5c' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px;
}

.sw-root .device-dropdown:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.sw-root .device-dropdown option {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

/* ── Volume Slider ── */
.sw-root .settings-volume-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sw-root .volume-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: var(--bg-tertiary);
  border-radius: 2px;
  outline: none;
}

.sw-root .volume-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  border: 2px solid var(--bg-secondary);
  transition: background 0.1s;
}

.sw-root .volume-slider::-webkit-slider-thumb:hover {
  background: var(--accent-hover);
}

.sw-root .settings-volume-value {
  font-size: 13px;
  color: var(--text-secondary);
  min-width: 36px;
  text-align: right;
}

/* ── Keybind Rows ── */
.sw-root .keybind-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}

.sw-root .keybind-action {
  flex: 1;
  font-size: 14px;
  color: var(--text-primary);
}

.sw-root .keybind-combo {
  font-size: 13px;
  font-family: var(--font-mono);
  color: var(--text-secondary);
  background: var(--bg-primary);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  min-width: 80px;
  text-align: center;
}

.sw-root .keybind-combo.keybind-recording {
  color: var(--accent);
  border-color: var(--accent);
  animation: keybind-pulse 1s ease-in-out infinite;
}

@keyframes keybind-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.sw-root .keybind-rebind-btn {
  background: var(--bg-tertiary);
  border: none;
  color: var(--text-secondary);
  padding: 4px 10px;
  font-size: 12px;
  font-family: var(--font);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s;
}

.sw-root .keybind-rebind-btn:hover {
  background: var(--bg-hover-strong);
  color: var(--text-primary);
}

.sw-root .settings-reset-btn {
  margin-top: 8px;
  background: var(--bg-tertiary);
  border: none;
  color: var(--text-secondary);
  padding: 8px 16px;
  font-size: 13px;
  font-family: var(--font);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s;
  align-self: flex-start;
}

.sw-root .settings-reset-btn:hover {
  background: var(--bg-hover-strong);
  color: var(--text-primary);
}

/* ── Toggle Switch ── */
.sw-root .toggle-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sw-root .toggle-switch {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 22px;
  flex-shrink: 0;
  cursor: pointer;
}

.sw-root .toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}

.sw-root .toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--bg-tertiary);
  border-radius: 11px;
  transition: background 0.2s;
}

.sw-root .toggle-slider::before {
  content: '';
  position: absolute;
  height: 16px;
  width: 16px;
  left: 3px;
  bottom: 3px;
  background: var(--text-muted);
  border-radius: 50%;
  transition: transform 0.2s, background 0.2s;
}

.sw-root .toggle-switch input:checked + .toggle-slider {
  background: var(--accent);
}

.sw-root .toggle-switch input:checked + .toggle-slider::before {
  transform: translateX(18px);
  background: var(--text-on-accent);
}

.sw-root .toggle-description {
  font-size: 13px;
  color: var(--text-secondary);
}

/* ── Mic Test ── */
.sw-root .mic-test-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.sw-root .mic-test-status {
  display: none;
  width: 100%;
  color: var(--red);
  font-size: 12px;
  margin-top: 2px;
}

.sw-root .mic-test-btn {
  background: var(--bg-tertiary);
  border: none;
  color: var(--text-secondary);
  padding: 6px 14px;
  font-size: 13px;
  font-family: var(--font);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}

.sw-root .mic-test-btn:hover {
  background: var(--bg-hover-strong);
  color: var(--text-primary);
}

.sw-root .mic-test-btn.active {
  background: var(--accent);
  color: var(--text-on-accent);
}

.sw-root .mic-meter-container {
  flex: 1;
  height: 14px;
  background: var(--bg-primary);
  border-radius: 7px;
  overflow: visible;
  border: 1px solid var(--border);
  position: relative;
}

.sw-root .mic-meter-container.active {
  border-color: var(--status-online);
}

.sw-root .mic-meter-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--status-online), #e2a84b);
  border-radius: 7px;
  transition: width 0.05s linear;
}

.sw-root .mic-meter-gate-line {
  position: absolute;
  top: -4px;
  bottom: -4px;
  width: 3px;
  background: var(--red);
  border-radius: 1px;
  pointer-events: none;
  z-index: 1;
  display: none;
  box-shadow: 0 0 4px var(--red);
}

.sw-root .mic-meter-vad-line {
  position: absolute;
  top: -4px;
  bottom: -4px;
  width: 3px;
  background: var(--yellow);
  border-radius: 1px;
  pointer-events: none;
  z-index: 1;
  display: none;
  box-shadow: 0 0 4px var(--yellow);
}

/* ── Keybind Button Row ── */
.sw-root .keybind-btn-row {
  display: flex;
  gap: 6px;
}

.sw-root .keybind-clear-btn {
  color: var(--text-muted);
}

.sw-root .keybind-clear-btn:hover {
  color: var(--text-danger);
  background: rgba(200, 60, 60, 0.15);
}

/* ── Visual Gamepad Mapper (WO-D46) ── */
.sw-root .gm-svg-wrapper {
  max-width: 500px;
  margin: 8px auto 16px;
  padding: 16px 12px 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.sw-root .gm-svg {
  width: 100%;
  height: auto;
  display: block;
}

.sw-root .gm-btn-shape {
  fill: var(--bg-primary);
  stroke: var(--border-strong);
  stroke-width: 1.5;
  transition: fill 0.15s, stroke 0.15s;
}

.sw-root .gm-btn-zone {
  cursor: pointer;
}

.sw-root .gm-btn-zone:hover .gm-btn-shape {
  fill: var(--accent-dim);
  stroke: var(--accent);
}

.sw-root .gm-btn-zone.recording .gm-btn-shape {
  fill: var(--accent-dim);
  stroke: var(--accent);
  animation: gm-pulse 0.8s ease-in-out infinite alternate;
}

@keyframes gm-pulse {
  from { opacity: 0.6; }
  to { opacity: 1; }
}

.sw-root .gm-btn-action {
  font-size: 8px;
  font-weight: 700;
  fill: var(--text-secondary);
  text-anchor: middle;
  dominant-baseline: middle;
  pointer-events: none;
  user-select: none;
}

.sw-root .gm-btn-label {
  font-size: 7px;
  font-weight: 600;
  fill: var(--accent);
  text-anchor: middle;
  dominant-baseline: middle;
  pointer-events: none;
  user-select: none;
}

.sw-root .gm-instr {
  font-size: 10px;
  fill: var(--text-muted);
  text-anchor: middle;
  dominant-baseline: middle;
  pointer-events: none;
  user-select: none;
}

/* ── Settings Note ── */
.sw-root .settings-note {
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
  padding: 4px 0;
  line-height: 1.4;
}

/* ── User Bar (bottom of sidebar) ── */
.sw-root .user-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 12px;
  background: var(--bg-primary);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}

.sw-root .user-bar-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.sw-root .user-bar-avatar-fallback {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-on-accent);
  flex-shrink: 0;
}

.sw-root .user-bar-avatar-wrapper {
  position: relative;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
}

.sw-root .user-bar-presence-dot {
  position: absolute;
  bottom: -1px;
  right: -1px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid var(--bg-primary);
  background-color: var(--status-online, #2ECC71);
}

.sw-root .user-bar-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.sw-root .user-bar-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sw-root .user-bar-status {
  font-size: 11px;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sw-root .user-bar-settings-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 16px;
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
  transition: all 0.15s;
  flex-shrink: 0;
}

.sw-root .user-bar-settings-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.sw-root .user-bar-leave-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 16px;
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
  transition: all 0.15s;
  flex-shrink: 0;
}

.sw-root .user-bar-leave-btn:hover {
  color: var(--red);
  background: rgba(196, 90, 74, 0.15);
}

/* ── Avatar Styles ── */

/* Profile section in settings */
.sw-root .profile-section {
  gap: 20px;
}

.sw-root .avatar-preview-row {
  display: flex;
  align-items: center;
  gap: 16px;
}

.sw-root .avatar-preview {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.sw-root .avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sw-root .avatar-preview-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  font-weight: 700;
  color: var(--text-primary);
  border-radius: 50%;
}

.sw-root .avatar-username-display {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
}

.sw-root .avatar-btn-row {
  display: flex;
  gap: 8px;
}

.sw-root .avatar-drop-zone {
  border: 2px dashed var(--border-strong);
  border-radius: var(--radius);
  padding: 16px 24px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
  cursor: default;
  transition: all 0.15s;
  outline: none;
}

.sw-root .avatar-drop-zone.drag-over {
  border-color: var(--accent);
  background: var(--accent-dim);
  color: var(--accent);
}

.sw-root .avatar-remove-btn {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  border: none;
  border-radius: var(--radius-sm);
  padding: 8px 16px;
  font-size: 13px;
  font-family: var(--font);
  cursor: pointer;
  transition: all 0.15s;
}

.sw-root .avatar-remove-btn:hover {
  background: rgba(196, 90, 74, 0.2);
  color: var(--red);
}

/* ── Settings Section Header ── */
.sw-root .settings-section-header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-muted);
  letter-spacing: 0.5px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
  margin-top: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.sw-root .settings-section-header::before {
  content: '';
  width: 3px;
  height: 12px;
  background: var(--accent);
  border-radius: 2px;
  flex-shrink: 0;
}

/* ── Setting Row (generic label + control layout) ── */
.sw-root .setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 6px;
  margin: 0 -6px;
  border-radius: var(--radius-sm);
  transition: background 0.1s;
}

.sw-root .setting-row:hover {
  background: var(--bg-hover);
}

.sw-root .setting-row-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}

.sw-root .setting-row-label {
  font-size: 14px;
  color: var(--text-primary);
}

.sw-root .setting-row-desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.3;
}

.sw-root .setting-row-control {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ── Settings Select Dropdown ── */
.sw-root .settings-select {
  padding: 6px 28px 6px 10px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-family: var(--font);
  font-size: 13px;
  outline: none;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a6b5c' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
}

.sw-root .settings-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.sw-root .settings-select option {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

/* ── Settings Slider ── */
.sw-root .settings-slider-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sw-root .settings-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: var(--bg-tertiary);
  border-radius: 2px;
  outline: none;
  min-width: 100px;
}

.sw-root .settings-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  border: 2px solid var(--bg-secondary);
  transition: background 0.1s;
}

.sw-root .settings-slider::-webkit-slider-thumb:hover {
  background: var(--accent-hover);
}

.sw-root .settings-slider-value {
  font-size: 13px;
  color: var(--text-secondary);
  min-width: 36px;
  text-align: right;
}

/* ── Settings Radio ── */
.sw-root .settings-radio {
  accent-color: var(--accent);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* ── Settings Buttons ── */
.sw-root .settings-btn-small {
  background: var(--bg-tertiary);
  border: none;
  color: var(--text-secondary);
  padding: 6px 14px;
  font-size: 12px;
  font-family: var(--font);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s;
}

.sw-root .settings-btn-small:hover {
  background: var(--bg-hover-strong);
  color: var(--text-primary);
}

.sw-root .settings-btn-danger {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  border: none;
  border-radius: var(--radius-sm);
  padding: 6px 14px;
  font-size: 12px;
  font-family: var(--font);
  cursor: pointer;
  transition: all 0.15s;
}

.sw-root .settings-btn-danger:hover {
  background: rgba(196, 90, 74, 0.2);
  color: var(--red);
}

/* ── Avatar Library Grid ── */
.sw-root .avatar-library-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sw-root .avatar-library-item {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color 0.15s, transform 0.15s;
  flex-shrink: 0;
}

.sw-root .avatar-library-item:hover {
  transform: scale(1.1);
  border-color: var(--text-muted);
}

.sw-root .avatar-library-item.active {
  border-color: var(--accent);
}

.sw-root .avatar-library-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ── Name Color Picker ── */
.sw-root .name-color-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sw-root .name-color-preview {
  font-size: 16px;
  font-weight: 700;
}

.sw-root .name-color-input {
  width: 36px;
  height: 36px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  background: none;
  padding: 0;
  flex-shrink: 0;
}

/* ── Font Dropdown ── */
.sw-root .font-dropdown {
  position: relative;
}

.sw-root .font-dropdown-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 14px;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
  font-family: inherit;
}

.sw-root .font-dropdown-trigger:hover { border-color: var(--accent); }
.sw-root .font-dropdown-trigger.open { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-dim); }

.sw-root .font-dropdown-arrow {
  color: var(--text-muted);
  font-size: 12px;
  transition: transform 0.15s;
}

.sw-root .font-dropdown-trigger.open .font-dropdown-arrow { transform: rotate(180deg); }

.sw-root .font-dropdown-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  max-height: 320px;
  overflow-y: auto;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg);
  z-index: 100;
  display: none;
  padding: 4px;
}

.sw-root .font-dropdown-menu.open { display: block; }

.sw-root .font-dropdown-category {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  padding: 8px 10px 4px;
  margin-top: 2px;
}

.sw-root .font-dropdown-category:first-child { margin-top: 0; }

.sw-root .font-dropdown-item {
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 14px;
  color: var(--text-primary);
  transition: background 0.1s;
}

.sw-root .font-dropdown-item:hover { background: var(--bg-hover); }
.sw-root .font-dropdown-item.active { background: var(--accent-dim); color: var(--accent); font-weight: 600; }

/* ── Settings Text Input ── */
.sw-root .settings-text-input {
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  padding: 8px 12px;
  font-size: 14px;
  font-family: var(--font);
  width: 100%;
  max-width: 300px;
  outline: none;
  transition: border-color 0.15s;
}

.sw-root .settings-text-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.sw-root .settings-text-input::placeholder {
  color: var(--text-muted);
}

/* ── Name Font Picker Grid ── */
.sw-root .name-font-picker-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sw-root .name-font-option {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  background: transparent;
  transition: background 0.1s, border-color 0.1s;
}

.sw-root .name-font-option:hover {
  background: var(--bg-hover);
}

.sw-root .name-font-option.active {
  border-color: var(--accent);
  background: var(--accent-dim);
}

.sw-root .name-font-option-label {
  font-size: 11px;
  color: var(--text-muted);
  width: 100px;
  flex-shrink: 0;
}

.sw-root .name-font-option-preview {
  font-size: 15px;
  font-weight: 600;
}

/* ── Name Effect Picker ── */
.sw-root .name-effect-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}

.sw-root .name-effect-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 6px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg-tertiary);
  cursor: pointer;
  transition: background 0.1s, border-color 0.1s;
}

.sw-root .name-effect-option:hover {
  background: var(--bg-hover);
}

.sw-root .name-effect-option.active {
  border-color: var(--accent);
  background: var(--accent-dim);
}

.sw-root .name-effect-preview {
  font-size: 14px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.sw-root .name-effect-label {
  font-size: 10px;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
}

/* ── Name Effect Animations ── */

.sw-root .name-effect-rainbow {
  background: linear-gradient(90deg, #ff0000, #ff8800, #ffff00, #00ff00, #0088ff, #8800ff, #ff0000);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: name-rainbow 3s linear infinite;
}

@keyframes name-rainbow {
  0% { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

.sw-root .name-effect-glow {
  animation: name-glow 2s ease-in-out infinite;
}

@keyframes name-glow {
  0%, 100% { text-shadow: 0 0 4px currentColor, 0 0 8px currentColor; }
  50% { text-shadow: 0 0 8px currentColor, 0 0 16px currentColor, 0 0 24px currentColor; }
}

.sw-root .name-effect-shimmer {
  background: linear-gradient(90deg, currentColor 0%, #ffffff 50%, currentColor 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: name-shimmer 2s ease-in-out infinite;
}

@keyframes name-shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.sw-root .name-effect-pulse {
  animation: name-pulse 1.5s ease-in-out infinite;
}

@keyframes name-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.02); }
}

.sw-root .name-effect-wave {
  display: inline-block;
  animation: name-wave 2s ease-in-out infinite;
}

@keyframes name-wave {
  0%, 100% { transform: translateY(0); }
  25% { transform: translateY(-2px); }
  75% { transform: translateY(2px); }
}

/* ── Settings Nav Icon ── */
.sw-root .settings-nav-icon {
  font-size: 14px;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}

/* ── Settings Preview Column (third column for Profile tab) ── */
.sw-preview-column {
  width: 260px;
  flex-shrink: 0;
  border-left: 1px solid var(--border);
  padding: 20px;
  display: flex;
  align-items: flex-start;
  overflow-y: auto;
}
.sw-preview-column .settings-preview-pane {
  position: sticky;
  top: 20px;
  width: 100%;
}
@container (max-width: 980px) {
  .sw-preview-column { display: none !important; }
}

/* ── Settings Preview Pane (inline, used by Appearance tab) ── */
.sw-root .settings-section-with-preview { display: flex; gap: 24px; }
.sw-root .settings-section-controls { flex: 1; min-width: 0; }
.sw-root .settings-preview-pane { width: 280px; flex-shrink: 1; min-width: 180px; position: sticky; top: 0; align-self: flex-start; }
.sw-root .theme-picker { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 16px; }
.sw-root .theme-swatch {
  width: 72px; height: 56px; border-radius: var(--radius); cursor: pointer;
  border: 2px solid transparent; display: flex; flex-wrap: wrap;
  overflow: hidden; transition: border-color 0.15s, transform 0.15s;
  position: relative;
}
.sw-root .theme-swatch:hover { transform: scale(1.08); }
.sw-root .theme-swatch.active { border-color: var(--accent); }
.sw-root .theme-swatch-color { width: 50%; height: 50%; }
.sw-root .theme-swatch-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  font-size: 9px; text-align: center; padding: 1px 0;
  background: rgba(0,0,0,0.55); color: #fff;
}

.sw-root .custom-theme-editor { margin-top: 12px; }
.sw-root .custom-theme-section { margin-bottom: 16px; }
.sw-root .custom-theme-section-header {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  color: var(--text-secondary); margin-bottom: 8px; letter-spacing: 0.5px;
  cursor: pointer; user-select: none; display: flex; align-items: center; gap: 6px;
}
.sw-root .custom-theme-section-header::before {
  content: '\25B6'; font-size: 8px; transition: transform 0.15s;
}
.sw-root .custom-theme-section-header.expanded::before { transform: rotate(90deg); }
.sw-root .custom-theme-vars { display: none; flex-wrap: wrap; gap: 8px; }
.sw-root .custom-theme-section-header.expanded + .custom-theme-vars { display: flex; }
.sw-root .custom-theme-var {
  display: flex; align-items: center; gap: 6px; width: calc(50% - 4px);
}
.sw-root .custom-theme-var label { font-size: 12px; color: var(--text-secondary); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sw-root .custom-theme-var input[type="color"] {
  width: 28px; height: 28px; border: 1px solid var(--border); border-radius: 4px;
  cursor: pointer; background: none; padding: 0; flex-shrink: 0;
}

/* ── Icon Theme Picker ── */
.sw-root .icon-theme-picker { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 16px; }
.sw-root .icon-theme-card {
  width: 100px; border-radius: 10px; cursor: pointer;
  border: 2px solid var(--border); background: var(--bg-secondary);
  transition: transform 0.15s, border-color 0.15s;
  display: flex; flex-direction: column; align-items: center;
  padding: 10px 6px 6px; gap: 6px;
}
.sw-root .icon-theme-card:hover { transform: scale(1.06); }
.sw-root .icon-theme-card.active { border-color: var(--theme-accent, var(--accent)); }
.sw-root .icon-theme-preview {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  width: 100%; justify-items: center;
}
.sw-root .icon-theme-sample {
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  color: var(--text-primary);
}
.sw-root .icon-theme-sample svg { width: 100%; height: 100%; }
.sw-root .icon-theme-label {
  font-size: 11px; color: var(--text-muted); font-weight: 600; text-align: center;
}

.sw-root .settings-time-input {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 4px 8px;
  color: var(--text-primary);
  font-size: 13px;
  cursor: pointer;
}

.sw-root .settings-time-input:focus {
  outline: none;
  border-color: var(--accent-color);
}


.sw-root .settings-textarea {
  width: 100%;
  min-height: 80px;
  padding: 8px 12px;
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 14px;
  resize: vertical;
}

/* ── Settings Phase 3 Visual Polish ── */

/* Consistent section spacing */
.sw-root .settings-section {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 0;
}

/* Section title polish */
.sw-root .settings-section-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 12px 0;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

/* Setting rows — consistent padding and grouping */
.sw-root .setting-row {
  padding: 10px 12px;
  border-radius: var(--radius-sm, 6px);
  margin: 0;
}

/* Color picker inputs — larger, more visible */
.sw-root .name-color-input {
  width: 36px;
  height: 28px;
  border: 2px solid var(--border);
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  padding: 0;
  background: none;
}
.sw-root .name-color-input:hover {
  border-color: var(--accent);
}
.sw-root .name-color-input::-webkit-color-swatch-wrapper { padding: 2px; }
.sw-root .name-color-input::-webkit-color-swatch { border: none; border-radius: 3px; }

/* Settings text input polish */
.sw-root .settings-text-input {
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 6px);
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: 14px;
  font-family: inherit;
  transition: border-color 0.1s;
}
.sw-root .settings-text-input:focus {
  outline: none;
  border-color: var(--accent);
}

/* Settings button polish */
.sw-root .settings-btn-small {
  padding: 4px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 6px);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.1s, border-color 0.1s;
}
.sw-root .settings-btn-small:hover {
  background: var(--bg-hover);
  border-color: var(--accent);
}

/* Select dropdowns */
.sw-root .settings-select {
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 6px);
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: 13px;
  cursor: pointer;
  min-width: 120px;
}
.sw-root .settings-select:focus {
  outline: none;
  border-color: var(--accent);
}

/* Slider polish */
.sw-root .settings-slider {
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  background: var(--bg-tertiary);
  border-radius: 3px;
  outline: none;
  flex: 1;
  min-width: 100px;
}
.sw-root .settings-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  background: var(--accent);
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid var(--bg-primary);
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
.sw-root .settings-slider-value {
  font-size: 12px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  min-width: 40px;
  text-align: right;
}

/* Avatar upload button */
.sw-root button[class*="avatar"] {
  cursor: pointer;
}

/* Profile section — equipped cosmetic items */
.sw-root .settings-section div[style*="border-bottom: 1px solid"] {
  padding: 8px 12px;
  border-radius: var(--radius-sm, 6px);
  transition: background 0.1s;
}
.sw-root .settings-section div[style*="border-bottom: 1px solid"]:hover {
  background: var(--bg-hover);
}

/* Radio buttons */
.sw-root .settings-radio {
  accent-color: var(--accent);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* styles/economy.css — Files window, soundboard */

 * WO-D35: Files Window Premium Redesign (fw-*)
 * ═══════════════════════════════════════════════════════════════════ */

/* ── Root & Header ── */
.fw-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  color: var(--text-primary);
  position: relative;
}

.fw-header {
  padding: 14px 16px 8px;
  flex-shrink: 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}

.fw-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px;
  margin-bottom: 10px;
  font-size: 13px;
}

.fw-breadcrumb-item {
  color: var(--text-muted);
  padding: 3px 6px;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}
.fw-breadcrumb-item.clickable {
  cursor: pointer;
}
.fw-breadcrumb-item.clickable:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}
.fw-breadcrumb-item.current {
  color: var(--text-primary);
  font-weight: 600;
}

.fw-breadcrumb-sep {
  color: var(--text-muted);
  font-size: 11px;
  opacity: 0.5;
}

.fw-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* ── View Toggle ── */
.fw-view-toggle {
  display: flex;
  background: var(--bg-tertiary);
  border-radius: 6px;
  padding: 2px;
  gap: 1px;
}
.fw-view-toggle button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 24px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  font-size: 13px;
  transition: background 0.12s, color 0.12s;
}
.fw-view-toggle button:hover {
  color: var(--text-primary);
}
.fw-view-toggle button.active {
  background: rgba(255,255,255,0.1);
  color: var(--text-primary);
}

/* ── Search ── */
.fw-search {
  flex: 1;
  min-width: 120px;
  padding: 6px 10px;
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.fw-search:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(var(--accent-rgb, 200,160,120), 0.15);
}

/* ── Buttons (shared by files, soundboard, music) ── */
.fw-btn {
  padding: 5px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 6px;
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
  display: flex;
  align-items: center;
  gap: 4px;
}
.fw-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
.fw-btn.active {
  background: rgba(255,255,255,0.1);
}
.fw-btn.fav-active {
  color: #f5c518;
  border-color: #f5c518;
}
.fw-btn svg { width: 14px; height: 14px; }

.fw-btn-primary {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  border-color: var(--accent);
}
.fw-btn-primary:hover {
  filter: brightness(1.1);
  color: var(--text-on-accent, #fff);
}

/* ── Danger button (confirm dialogs) ── */
.fw-btn-danger {
  background: var(--red, #e74c3c);
  color: var(--text-on-accent, #fff);
  border-color: var(--red, #e74c3c);
}
.fw-btn-danger:hover {
  filter: brightness(1.1);
  color: var(--text-on-accent, #fff);
}

/* ── Storage bar ── */
.fw-storage {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 16px 10px;
  flex-shrink: 0;
}

.fw-storage-track {
  flex: 1;
  height: 4px;
  background: var(--bg-tertiary);
  border-radius: 2px;
  overflow: hidden;
}

.fw-storage-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 70%, #fff));
  border-radius: 2px;
  transition: width 0.4s ease;
}

.fw-storage-label {
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
}

/* ── Tree / Content Area ── */
.fw-tree {
  flex: 1;
  overflow-y: auto;
  padding: 4px 8px 12px;
  transition: background 0.15s;
}

.fw-drag-over {
  background: rgba(var(--accent-rgb, 200,160,120), 0.06);
  outline: 2px dashed var(--accent);
  outline-offset: -4px;
  border-radius: 8px;
}

/* ── List View Items ── */
.fw-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.12s, transform 0.1s;
  position: relative;
}
.fw-item:hover {
  background: rgba(255,255,255,0.05);
}
.fw-item:active {
  transform: scale(0.995);
}

.fw-item-icon {
  font-size: 20px;
  flex-shrink: 0;
  width: 28px;
  text-align: center;
  line-height: 1;
}

.fw-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 1.5px solid rgba(255,255,255,0.08);
}

.fw-avatar-dot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  font-size: 10px;
  font-weight: 600;
  flex-shrink: 0;
}

.fw-item-name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 450;
  color: var(--text-primary);
}

.fw-item-meta {
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

.fw-item-actions {
  display: none;
  gap: 4px;
  flex-shrink: 0;
}
.fw-item:hover .fw-item-actions {
  display: flex;
}

.fw-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  transition: color 0.12s, background 0.12s;
}
.fw-action-btn:hover {
  background: rgba(255,255,255,0.1);
  color: var(--text-primary);
}
.fw-action-btn.active { color: #f5c518; }
.fw-action-btn svg { width: 14px; height: 14px; }

/* ── Grid View ── */
.fw-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  padding: 4px;
}

.fw-grid-card {
  display: flex;
  flex-direction: column;
  border-radius: 10px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, transform 0.12s, box-shadow 0.15s;
  position: relative;
}
.fw-grid-card:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.1);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.fw-grid-thumb {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  background: var(--bg-tertiary);
  display: block;
}

.fw-grid-folder-icon {
  width: 100%;
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--accent-rgb, 200,160,120), 0.08);
  font-size: 36px;
}

.fw-grid-icon-fallback {
  width: 100%;
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
  font-size: 32px;
}

.fw-grid-info {
  padding: 8px 10px;
  min-width: 0;
}

.fw-grid-name {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3;
}

.fw-grid-meta {
  font-size: 10px;
  color: var(--text-muted);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fw-grid-overlay {
  position: absolute;
  top: 6px;
  right: 6px;
  display: none;
  gap: 3px;
}
.fw-grid-card:hover .fw-grid-overlay {
  display: flex;
}
.fw-grid-overlay .fw-action-btn {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  color: rgba(255,255,255,0.85);
}
.fw-grid-overlay .fw-action-btn:hover {
  background: rgba(0,0,0,0.7);
  color: #fff;
}
.fw-grid-overlay .fw-action-btn.active {
  color: #f5c518;
}

/* Context menu */
.fw-context-menu {
  position: fixed;
  z-index: 99999;
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 6px;
  padding: 4px;
  min-width: 140px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}

.fw-ctx-btn {
  display: block;
  width: 100%;
  padding: 6px 12px;
  background: none;
  border: none;
  border-radius: 4px;
  color: var(--text-primary);
  font-size: 13px;
  text-align: left;
  cursor: pointer;
  transition: background 0.12s;
}
.fw-ctx-btn:hover { background: rgba(255,255,255,0.06); }
.fw-ctx-danger { color: var(--red, #e74c3c); }
.fw-ctx-danger:hover { background: rgba(231,76,60,0.1); }

/* ── Dialog button row (shared) ── */
.fw-dialog-btnrow {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.fw-dialog-btnrow.mt {
  margin-top: 16px;
}

/* ── Dialog input spacing ── */
.fw-dialog-input {
  margin-bottom: 12px;
}

/* ── Move dialog indent ── */
.fw-dialog-item[data-depth="1"] { padding-left: 32px; }
.fw-dialog-item[data-depth="2"] { padding-left: 48px; }
.fw-dialog-item[data-depth="3"] { padding-left: 64px; }
.fw-dialog-item[data-depth="4"] { padding-left: 80px; }
.fw-dialog-item[data-depth="5"] { padding-left: 96px; }

/* ── Move dialog cancel margin ── */
.fw-dialog-cancel-mt {
  margin-top: 12px;
}

/* Overlay & dialog (shared by files, soundboard, music) */
.fw-overlay {
  position: fixed;
  inset: 0;
  z-index: 99998;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(2px);
}

.fw-dialog {
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 12px;
  padding: 20px;
  min-width: 300px;
  max-width: 420px;
  max-height: 60vh;
  overflow-y: auto;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}

.fw-dialog-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 12px;
}

.fw-dialog-list {
  margin-bottom: 12px;
  max-height: 200px;
  overflow-y: auto;
}

.fw-dialog-item {
  padding: 8px 16px;
  font-size: 13px;
  color: var(--text-primary);
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.12s;
}
.fw-dialog-item:hover { background: rgba(255,255,255,0.06); }
.fw-dialog-item.current {
  color: var(--accent);
  font-weight: 500;
}

/* Legacy compat — redundant with .fw-item but kept for safety */
.fw-file { display: flex; align-items: center; gap: 8px; padding: 6px 8px; border-radius: var(--radius-sm, 6px); cursor: pointer; }
.fw-file:hover { background: var(--bg-hover, rgba(255,255,255,0.05)); }
.fw-folder { display: flex; align-items: center; gap: 8px; padding: 6px 8px; border-radius: var(--radius-sm, 6px); cursor: pointer; font-weight: 500; }
.fw-folder:hover { background: var(--bg-hover, rgba(255,255,255,0.05)); }


/* ═══════════════════════════════════════════════════════════════════
 * WO-6B: Soundboard Window (sb-*)
 * ═══════════════════════════════════════════════════════════════════ */

/* ── Root ── */
.sb-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  color: var(--text-primary);
}

.sb-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5, 12px) var(--space-6, 16px) var(--space-2, 6px);
  flex-shrink: 0;
}

.sb-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  text-transform: uppercase;
}

.sb-header-btns {
  display: flex;
  gap: 4px;
}

.sb-icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: var(--radius-sm, 4px);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  transition: background 0.12s, color 0.12s;
}
.sb-icon-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
.sb-icon-btn svg { width: 16px; height: 16px; }

/* ── Volume control ── */
.sb-vol-control {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  margin-right: 4px;
}

.sb-vol-icon {
  display: flex;
  color: var(--text-muted);
  flex-shrink: 0;
}
.sb-vol-icon svg { width: 14px; height: 14px; }

.sb-vol-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 72px;
  height: 4px;
  border-radius: 2px;
  background: var(--bg-tertiary);
  outline: none;
  cursor: pointer;
}
.sb-vol-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  border: none;
}

.sb-vol-label {
  font-size: 11px;
  color: var(--text-muted);
  min-width: 28px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.sb-tabs {
  display: flex;
  gap: 2px;
  padding: 0 var(--space-6, 16px) var(--space-3, 8px);
  flex-shrink: 0;
}

.sb-tab {
  flex: 1;
  padding: 6px 0;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: color 0.12s, border-color 0.12s;
}
.sb-tab:hover { color: var(--text-secondary); }
.sb-tab.active {
  color: var(--text-primary);
  border-bottom-color: var(--accent);
}

.sb-name-form {
  padding: var(--space-3, 8px) var(--space-6, 16px) var(--space-5, 12px);
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 8px);
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
}

.sb-name-input {
  padding: 6px 10px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-sm, 6px);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s;
}
.sb-name-input:focus { border-color: var(--accent); }

.sb-personal-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
}

.sb-form-btns {
  display: flex;
  gap: var(--space-3, 8px);
}

/* ── Clip grid ── */
.sb-grid {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-2, 4px) var(--space-5, 12px) var(--space-5, 12px);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3, 8px);
  align-content: flex-start;
}

/* ── Clip buttons with hover-lift ── */
.sb-clip-btn {
  padding: 8px 14px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-md, 8px);
  color: var(--text-primary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.12s, transform 0.12s, box-shadow 0.2s, border-color 0.15s;
  white-space: nowrap;
}
.sb-clip-btn:hover {
  background: rgba(255,255,255,0.08);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  border-color: var(--accent);
}
.sb-clip-btn:active {
  transform: translateY(0) scale(0.97);
}

/* ── Personal clip dashed border ── */
.sb-clip-btn.sb-clip-personal {
  border-style: dashed;
  border-color: rgba(var(--accent-rgb, 200,160,120), 0.35);
}
.sb-clip-btn.sb-clip-personal:hover {
  border-color: var(--accent);
  border-style: solid;
}

/* ── Playing pulse animation (green glow) ── */
.sb-clip-btn.sb-clip-playing {
  background: rgba(39,174,96,0.2);
  border-color: #27ae60;
  color: #4ade80;
  box-shadow: 0 0 12px rgba(39,174,96,0.3);
  animation: sb-playing-pulse 1.2s ease-in-out infinite;
}
@keyframes sb-playing-pulse {
  0%, 100% { box-shadow: 0 0 8px rgba(39,174,96,0.2); }
  50% { box-shadow: 0 0 18px rgba(39,174,96,0.45); }
}

/* ── Voice-required note ── */
.sb-voice-note {
  padding: var(--space-4, 10px) var(--space-6, 16px);
  text-align: center;
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
  background: rgba(255,255,255,0.02);
  border-top: 1px solid var(--border, var(--bg-tertiary));
}

/* styles/admin.css — Trivia window */
/* ═══════════════════════════════════════════════════════════════════
 * WO-6C: Trivia Window (tv-*)
 * ═══════════════════════════════════════════════════════════════════ */

/* ── Root ── */
.tv-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: var(--text-primary);
  padding: var(--space-6, 16px);
  overflow-y: auto;
}

.tv-home { max-width: 600px; margin: 0 auto; width: 100%; }

/* ── Home header ── */
.tv-header {
  text-align: center;
  margin-bottom: var(--space-8, 20px);
}
.tv-header h2 {
  font-size: 22px;
  margin: 0 0 4px;
  color: var(--text-primary);
}
.tv-header p {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0;
}

/* ── Create form ── */
.tv-create-form {
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-lg, 10px);
  padding: var(--space-6, 16px);
  margin-bottom: var(--space-8, 20px);
}
.tv-create-form h3 {
  font-size: 14px;
  margin: 0 0 12px;
  color: var(--text-primary);
}

.tv-form-row {
  margin-bottom: var(--space-5, 12px);
}
.tv-form-row label {
  display: block;
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 6px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.tv-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.tv-pill {
  padding: 5px 14px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-pill, 16px);
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.tv-pill:hover { background: rgba(255,255,255,0.08); }
.tv-pill.active {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  border-color: var(--accent);
}

.tv-select {
  width: 100%;
  padding: 6px 10px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-sm, 6px);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
}
.tv-select:focus { border-color: var(--accent); }

/* ── Buttons ── */
.tv-btn {
  padding: 8px 20px;
  border: none;
  border-radius: var(--radius-sm, 6px);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.12s, filter 0.12s, transform 0.08s;
}
.tv-btn:active { transform: scale(0.97); }
.tv-btn-primary {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  width: 100%;
  margin-top: 4px;
}
.tv-btn-primary:hover { filter: brightness(1.1); }
.tv-btn-secondary {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}
.tv-btn-secondary:hover { background: rgba(255,255,255,0.08); }
.tv-btn-join {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
}
.tv-btn-join:hover { filter: brightness(1.1); }

/* ── Open games list ── */
.tv-games-list {
  margin-bottom: var(--space-8, 20px);
}
.tv-games-list h3 {
  font-size: 14px;
  margin: 0 0 10px;
  color: var(--text-primary);
}

.tv-game-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5, 12px) var(--space-5, 14px);
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-md, 8px);
  margin-bottom: 8px;
  transition: border-color 0.15s;
}
.tv-game-card:hover { border-color: var(--accent); }

.tv-game-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.tv-game-host { font-size: 13px; font-weight: 500; color: var(--text-primary); }
.tv-game-meta { font-size: 11px; color: var(--text-muted); }
.tv-game-players { font-size: 11px; color: var(--text-secondary); }

/* ── Leaderboard ── */
.tv-leaderboard {
  margin-bottom: var(--space-8, 20px);
}
.tv-leaderboard h3 {
  font-size: 14px;
  margin: 0 0 10px;
  color: var(--text-primary);
}

.tv-lb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.tv-lb-table th {
  text-align: left;
  padding: 6px 8px;
  color: var(--text-muted);
  font-weight: 500;
  font-size: 11px;
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
}
.tv-lb-table td {
  padding: 6px 8px;
  color: var(--text-primary);
  border-bottom: 1px solid rgba(255,255,255,0.03);
}
.tv-lb-table tr:first-child td { color: #f5c518; font-weight: 600; }
.tv-lb-rank { font-weight: 600; }
.tv-gold { color: #f5c518; }
.tv-silver { color: #c0c0c0; }
.tv-bronze { color: #cd7f32; }

/* ── Lobby ── */
.tv-lobby {
  max-width: 500px;
  margin: 0 auto;
  width: 100%;
  text-align: center;
}
.tv-lobby h2 { font-size: 20px; margin: 0 0 12px; }

.tv-config-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: var(--space-6, 16px);
}
.tv-config-summary span {
  padding: 4px 12px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-pill, 12px);
  font-size: 12px;
  color: var(--text-secondary);
}

.tv-player-list {
  text-align: left;
  margin-bottom: var(--space-6, 16px);
}
.tv-player-list h3 { font-size: 13px; margin: 0 0 8px; }

.tv-player-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: var(--radius-sm, 6px);
  background: var(--bg-secondary);
  margin-bottom: 4px;
  transition: background 0.12s;
}
.tv-player-row:hover { background: var(--bg-tertiary); }
.tv-player-name { font-size: 13px; }
.tv-host-badge {
  padding: 1px 6px;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.tv-lobby-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: var(--space-5, 12px);
}

.tv-wait-msg {
  font-size: 13px;
  color: var(--text-muted);
  font-style: italic;
}

/* ── Countdown ── */
.tv-countdown {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.tv-countdown-number {
  font-size: 80px;
  font-weight: 700;
  color: var(--accent);
  animation: tv-pulse 0.8s ease-in-out infinite;
}
@keyframes tv-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.15); opacity: 0.8; }
}

/* ── Question / Reveal screens ── */
.tv-question-screen, .tv-reveal-screen {
  max-width: 650px;
  margin: 0 auto;
  width: 100%;
}

.tv-q-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--space-5, 12px);
  flex-wrap: wrap;
}
.tv-q-number { font-size: 12px; color: var(--text-muted); font-weight: 500; }
.tv-q-category {
  padding: 2px 8px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-pill, 10px);
  font-size: 11px;
  color: var(--text-secondary);
}

/* ── Difficulty badge pills ── */
.tv-q-difficulty {
  padding: 2px 10px;
  border-radius: var(--radius-pill, 10px);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
}
.tv-diff-easy { background: rgba(39,174,96,0.12); color: #4ade80; }
.tv-diff-medium { background: rgba(241,196,15,0.12); color: #fbbf24; }
.tv-diff-hard { background: rgba(231,76,60,0.12); color: #f87171; }

/* ── Timer ring ── */
.tv-timer-wrap {
  position: relative;
  width: 72px;
  height: 72px;
  margin: 0 auto var(--space-5, 12px);
}
.tv-timer-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.tv-timer-bg { fill: none; stroke: var(--bg-tertiary); stroke-width: 5; }
.tv-timer-fg {
  fill: none;
  stroke: var(--accent);
  stroke-width: 5;
  stroke-linecap: round;
  transition: stroke-dashoffset 0.1s linear;
}
.tv-timer-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
}

.tv-q-text {
  font-size: 17px;
  font-weight: 500;
  text-align: center;
  margin-bottom: var(--space-6, 16px);
  line-height: 1.4;
  color: var(--text-primary);
}

/* ── Answer options grid ── */
.tv-options-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3, 8px);
  margin-bottom: var(--space-5, 12px);
}

.tv-option {
  padding: 14px 16px;
  border: 2px solid transparent;
  border-radius: var(--radius-md, 8px);
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s, opacity 0.2s, transform 0.1s;
  font-size: 13px;
  color: #fff;
}
.tv-opt-red { background: rgba(231,76,60,0.18); border-color: rgba(231,76,60,0.35); }
.tv-opt-blue { background: rgba(52,152,219,0.18); border-color: rgba(52,152,219,0.35); }
.tv-opt-green { background: rgba(46,204,113,0.18); border-color: rgba(46,204,113,0.35); }
.tv-opt-yellow { background: rgba(241,196,15,0.18); border-color: rgba(241,196,15,0.35); }

.tv-option:hover:not(.tv-option-locked) {
  transform: scale(1.02);
  filter: brightness(1.15);
}

.tv-opt-label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  font-weight: 700;
  font-size: 12px;
  flex-shrink: 0;
}

.tv-opt-text {
  flex: 1;
  min-width: 0;
}

.tv-option-selected {
  border-color: #fff !important;
  box-shadow: 0 0 8px rgba(255,255,255,0.2);
}
.tv-option-locked { cursor: default; }
.tv-option-correct {
  border-color: #27ae60 !important;
  background: rgba(39,174,96,0.3) !important;
  box-shadow: 0 0 12px rgba(39,174,96,0.3);
}
.tv-option-wrong {
  border-color: #e74c3c !important;
  background: rgba(231,76,60,0.3) !important;
}
.tv-option-dimmed { opacity: 0.35; }

/* ── Answered dots ── */
.tv-answered {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-bottom: var(--space-4, 10px);
}
.tv-answered-dot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 600;
  transition: background 0.2s, transform 0.15s;
}
.tv-answered-dot.answered {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  transform: scale(1.1);
}

/* ── Score bar + streak ── */
.tv-score-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 13px;
  padding: var(--space-3, 6px) 0;
}
.tv-my-score { font-weight: 600; color: var(--text-primary); }
.tv-streak-badge {
  padding: 2px 10px;
  background: rgba(241,196,15,0.15);
  color: #fbbf24;
  border-radius: var(--radius-pill, 10px);
  font-size: 11px;
  font-weight: 600;
  animation: tv-streak-pop 0.3s ease;
}
@keyframes tv-streak-pop {
  0% { transform: scale(0.8); }
  60% { transform: scale(1.1); }
  100% { transform: scale(1); }
}

/* ── Reveal results ── */
.tv-reveal-results {
  margin-top: var(--space-5, 14px);
}
.tv-reveal-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-sm, 6px);
  margin-bottom: 4px;
  font-size: 13px;
  transition: background 0.12s;
}
.tv-reveal-correct { background: rgba(39,174,96,0.1); }
.tv-reveal-wrong { background: rgba(231,76,60,0.08); }
.tv-reveal-timeout { background: rgba(255,255,255,0.03); }
.tv-reveal-name { flex: 1; font-weight: 500; }
.tv-reveal-points { font-weight: 600; min-width: 60px; }
.tv-reveal-total { color: var(--text-muted); font-size: 12px; }

/* ── Final screen ── */
.tv-final-screen {
  max-width: 500px;
  margin: 0 auto;
  width: 100%;
  text-align: center;
}
.tv-final-title {
  font-size: 24px;
  margin: 0 0 var(--space-8, 20px);
  color: var(--text-primary);
}

.tv-podium {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: var(--space-5, 12px);
  margin-bottom: var(--space-8, 20px);
  height: 160px;
}

.tv-podium-spot {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100px;
}
.tv-podium-medal {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 6px;
  background: var(--bg-tertiary);
  color: var(--text-primary);
  transition: transform 0.2s;
}
.tv-podium-spot:first-child .tv-podium-medal { transform: scale(1.1); }
.tv-podium-medal.tv-gold { background: #f5c518; color: #1a1a1a; box-shadow: 0 0 16px rgba(245,197,24,0.4); }
.tv-podium-medal.tv-silver { background: #c0c0c0; color: #1a1a1a; }
.tv-podium-medal.tv-bronze { background: #cd7f32; color: #fff; }

.tv-podium-name { font-size: 13px; font-weight: 500; margin-bottom: 2px; }
.tv-podium-score { font-size: 12px; color: var(--text-muted); margin-bottom: 6px; }

.tv-podium-bar {
  width: 100%;
  border-radius: 4px 4px 0 0;
  background: var(--bg-tertiary);
}
.tv-podium-bar-1 { height: 70px; background: rgba(245,197,24,0.2); }
.tv-podium-bar-2 { height: 50px; background: rgba(192,192,192,0.15); }
.tv-podium-bar-3 { height: 35px; background: rgba(205,127,50,0.15); }

.tv-final-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin-bottom: var(--space-6, 16px);
  text-align: left;
}
.tv-final-table th {
  padding: 6px 8px;
  color: var(--text-muted);
  font-weight: 500;
  font-size: 11px;
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
}
.tv-final-table td {
  padding: 6px 8px;
  color: var(--text-primary);
  border-bottom: 1px solid rgba(255,255,255,0.03);
}

.tv-final-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
}

/* styles/media.css — Music window, visual polish animations */
/* ═══════════════════════════════════════════════════════════════════
 * WO-6D: Music Window (mw-*)
 * ═══════════════════════════════════════════════════════════════════ */

.mw-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  color: var(--text-primary);
}

/* Player bar */
.mw-player-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
  flex-shrink: 0;
  flex-wrap: wrap;
}
.mw-player-bar.mw-player-empty {
  padding: 10px 14px;
}
.mw-player-idle {
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
}

.mw-player-art {
  width: 36px;
  height: 36px;
  border-radius: 4px;
  background: var(--bg-tertiary);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}
.mw-player-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mw-player-art svg { width: 18px; height: 18px; }

.mw-player-info {
  min-width: 0;
  flex-shrink: 1;
  max-width: 160px;
}
.mw-player-title {
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mw-player-artist {
  font-size: 11px;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mw-transport {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.mw-transport-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0;
  transition: background 0.12s, color 0.12s;
}
.mw-transport-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
.mw-transport-btn svg { width: 16px; height: 16px; }
.mw-transport-play {
  width: 32px;
  height: 32px;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
}
.mw-transport-play:hover {
  filter: brightness(1.1);
  background: var(--accent);
  color: var(--text-on-accent, #fff);
}
.mw-transport-play svg { width: 18px; height: 18px; }

.mw-modes {
  display: flex;
  gap: 2px;
  flex-shrink: 0;
}

.mw-mode-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  transition: color 0.12s;
}
.mw-mode-btn:hover { color: var(--text-secondary); }
.mw-mode-btn.active { color: var(--accent); }
.mw-mode-btn svg { width: 14px; height: 14px; }

.mw-seek {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 120px;
}

.mw-time {
  font-size: 10px;
  color: var(--text-muted);
  min-width: 30px;
  text-align: center;
}

.mw-seekbar,
.mw-volbar {
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  border-radius: 2px;
  background: var(--bg-tertiary);
  outline: none;
  cursor: pointer;
  flex: 1;
}
.mw-seekbar::-webkit-slider-thumb,
.mw-volbar::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  border: none;
}

.mw-volume {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  width: 90px;
}

.mw-vol-icon {
  display: flex;
  color: var(--text-muted);
}
.mw-vol-icon svg { width: 14px; height: 14px; }

/* Tabs */
.mw-tabs {
  display: flex;
  gap: 0;
  padding: 0 14px;
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
  flex-shrink: 0;
}

.mw-tab {
  padding: 8px 14px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: color 0.12s, border-color 0.12s;
  display: flex;
  align-items: center;
  gap: 4px;
}
.mw-tab:hover { color: var(--text-secondary); }
.mw-tab.active {
  color: var(--text-primary);
  border-bottom-color: var(--accent);
}
.mw-tab-yt { margin-left: auto; }

.mw-tab-badge {
  padding: 0 5px;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  border-radius: 8px;
  font-size: 10px;
  min-width: 14px;
  text-align: center;
}

/* Search / Toolbar */
.mw-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-3, 8px);
  padding: var(--space-3, 8px) var(--space-4, 14px);
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
  flex-shrink: 0;
}

.mw-toolbar .mw-search-input {
  flex: 1;
  max-width: 300px;
}

.mw-search-input {
  width: 100%;
  padding: 6px 10px;
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  box-sizing: border-box;
}
.mw-search-input:focus { border-color: var(--accent); }

.mw-sortable-header {
  cursor: pointer;
  user-select: none;
}
.mw-sortable-header:hover {
  color: var(--text-primary);
}

/* YouTube form */
.mw-yt-form {
  padding: 0 14px 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
}

.mw-yt-btns {
  display: flex;
  gap: 8px;
}

.mw-yt-status {
  font-size: 12px;
  color: var(--text-muted);
  min-height: 16px;
}
.mw-yt-status-success { color: var(--green, #27ae60); }
.mw-yt-status-error { color: var(--red, #e74c3c); }

/* Content */
.mw-content {
  flex: 1;
  overflow-y: auto;
  padding: 0 14px 14px;
}

.mw-play-all-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  margin: 10px 0 8px;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  border: none;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: filter 0.12s;
}
.mw-play-all-btn:hover { filter: brightness(1.1); }
.mw-play-all-btn svg { width: 14px; height: 14px; }

/* Track table */
.mw-track-table {
  width: 100%;
}

.mw-track-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 4px;
  transition: background var(--duration-fast, 0.12s);
  font-size: var(--text-sm, 13px);
  height: 36px;
  box-sizing: border-box;
}
.mw-track-row:hover { background: rgba(255,255,255,0.04); }
.mw-track-row.mw-track-header {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--bg-secondary);
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
  font-weight: var(--weight-medium, 500);
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
}
.mw-track-row.mw-track-header:hover { background: var(--bg-secondary); }
.mw-track-row.mw-track-playing {
  background: rgba(var(--accent-rgb, 200,160,120), 0.1);
}

.mw-track-title { flex: 3; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mw-track-artist { flex: 2; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-secondary); }
.mw-track-album { flex: 2; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-muted); }
.mw-track-duration { width: 50px; text-align: right; color: var(--text-muted); font-size: 12px; flex-shrink: 0; }

.mw-track-actions {
  display: flex;
  gap: 2px;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity 0.15s;
}
.mw-track-row:hover .mw-track-actions { opacity: 1; }
.mw-track-header .mw-track-actions { opacity: 1; }

.mw-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  font-size: 12px;
  transition: background 0.12s, color 0.12s;
}
.mw-action-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
.mw-action-btn svg { width: 12px; height: 12px; }

/* Playlist picker popup */
.mw-pl-picker {
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 6px;
  padding: 4px;
  min-width: 160px;
  max-height: 200px;
  overflow-y: auto;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}

.mw-pl-picker-item {
  display: block;
  width: 100%;
  padding: 6px 10px;
  background: none;
  border: none;
  border-radius: 4px;
  color: var(--text-primary);
  font-size: 12px;
  text-align: left;
  cursor: pointer;
  transition: background 0.12s;
}
.mw-pl-picker-item:hover { background: rgba(255,255,255,0.06); }

/* Playlists list */
.mw-playlist-create {
  display: flex;
  gap: 8px;
  margin: 10px 0;
}

.mw-playlist-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.mw-playlist-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.12s;
}
.mw-playlist-card:hover { background: rgba(255,255,255,0.04); }

.mw-playlist-info { min-width: 0; flex: 1; }
.mw-playlist-name { font-size: 13px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mw-playlist-meta { font-size: 11px; color: var(--text-muted); margin-top: 2px; }

/* Detail header */
.mw-detail-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0 4px;
}

.mw-back-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  transition: background 0.12s, color 0.12s;
}
.mw-back-btn:hover { background: rgba(255,255,255,0.06); color: var(--text-primary); }
.mw-back-btn svg { width: 14px; height: 14px; }

.mw-detail-title {
  font-size: 16px;
  font-weight: 600;
}

/* Queue */
.mw-queue-controls {
  display: flex;
  gap: 8px;
  margin: 10px 0;
}

.mw-queue-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mw-queue-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px;
  border-radius: 4px;
  transition: background 0.12s;
}
.mw-queue-row:hover { background: rgba(255,255,255,0.04); }
.mw-queue-row.mw-queue-current {
  background: rgba(var(--accent-rgb, 200,160,120), 0.1);
  border-left: 3px solid var(--accent);
}

.mw-queue-num {
  width: 22px;
  text-align: center;
  font-size: 12px;
  color: var(--text-muted);
  flex-shrink: 0;
}

.mw-queue-info { flex: 1; min-width: 0; }
.mw-queue-title { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mw-queue-artist { font-size: 11px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ══════════════════════════════════════════════════════════════════════
   WO-6F: Visual Polish — Animations & Transitions
   ══════════════════════════════════════════════════════════════════════ */

/* ── Taskbar button press feedback ── */
.bean-taskbar .tb-launcher:active,
.bean-taskbar .tb-unpinned-item:active,
.tb-quick-btn:active {
  transform: scale(0.95);
}

/* ── Command palette slide-in ── */
@keyframes cmd-backdrop-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes cmd-palette-slide {
  from {
    opacity: 0;
    transform: translateY(-12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.cmd-palette-overlay {
  animation: cmd-backdrop-fade 0.15s ease-out;
}

.cmd-palette {
  animation: cmd-palette-slide 0.15s ease-out;
}

/* ── Smooth scrolling on modern window bodies ── */
.bean-desktop .window-body > * {
  scroll-behavior: smooth;
}

/* ── Focus shadow depth (unfocused lighter shadow) ── */
.bean-desktop .window:not(.focused) {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

/* styles/voice.css — Voice window premium polish */
/* ══════════════════════════════════════════════════════════════════════
   WO-D36: Voice Window — Premium Polish
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root ── */

.vw-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--bg-primary);
  overflow: hidden;
}

/* ── Header ── */

.vw-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border-color);
  flex-shrink: 0;
}

.vw-header-icon {
  color: var(--accent);
  display: flex;
  align-items: center;
}
.vw-header-icon svg { width: 18px; height: 18px; }

.vw-header-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.vw-member-count {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 500;
  flex-shrink: 0;
}

/* ── Channel Browser ── */

.vw-channel-list {
  padding: 8px;
  flex: 1;
  overflow-y: auto;
}

.vw-channel-item {
  padding: 10px 14px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 2px;
}
.vw-channel-item:hover {
  background: var(--bg-secondary);
}

.vw-channel-name {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
}
.vw-channel-icon { display: flex; align-items: center; color: var(--text-muted); }
.vw-channel-icon svg { width: 16px; height: 16px; }

.vw-channel-members {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 6px;
  padding-left: 22px;
}

.vw-channel-member-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  overflow: hidden;
  border: 1px solid var(--border-color);
}
.vw-channel-member-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.vw-channel-member-count {
  font-size: 11px;
  color: var(--text-muted);
  margin-left: 4px;
}

/* ── Avatar Grid ── */

.vw-avatar-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 16px;
  justify-content: center;
  flex: 1;
  align-content: flex-start;
  overflow-y: auto;
}

.vw-avatar-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 8px;
  border-radius: 10px;
  position: relative;
  transition: background 0.15s;
  min-width: 80px;
}
.vw-avatar-cell:hover {
  background: var(--bg-secondary);
}

.vw-avatar-ring {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  padding: 3px;
  border: 2px solid transparent;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.vw-avatar-cell.speaking .vw-avatar-ring {
  border-color: var(--green);
  box-shadow: 0 0 12px rgba(16, 185, 129, 0.45);
}

.vw-avatar {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  color: var(--text-secondary);
  overflow: hidden;
}
.vw-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.vw-avatar-name {
  font-size: 12px;
  color: var(--text-secondary);
  max-width: 80px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
  font-weight: 500;
}

.vw-avatar-status {
  display: flex;
  gap: 3px;
  align-items: center;
}
.vw-status-icon {
  display: flex;
  align-items: center;
}
.vw-status-icon svg { width: 12px; height: 12px; }
.vw-status-icon.muted { color: var(--red); }
.vw-status-icon.deafened { color: var(--red); }
.vw-status-icon.streaming { color: var(--accent); }
.vw-status-icon.camera { color: var(--green); }

/* ── Per-User Volume ── */

.vw-avatar-vol-overlay {
  position: absolute;
  bottom: -4px;
  left: 50%;
  transform: translateX(-50%) scale(0.9);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 4px 10px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s, transform 0.15s;
  z-index: 10;
}
.vw-avatar-cell:hover .vw-avatar-vol-overlay {
  opacity: 1;
  pointer-events: all;
  transform: translateX(-50%) scale(1);
}

.vw-vol-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 80px;
  height: 4px;
  background: var(--bg-secondary);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}
.vw-vol-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
}

/* ── Compact Mode ── */

.vw-compact .vw-avatar-name { display: none; }
.vw-compact .vw-avatar-status { display: none; }


/* styles/arcade.css — BeanTV window, changelog window, arcade window */
/* ══════════════════════════════════════════════════════════════════════
   WO-D33: BeanTV Window — Premium Redesign
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root ── */

.btv-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--bg-primary);
}

/* ── Lobby Header ── */

.btv-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border-color);
  flex-shrink: 0;
}

.btv-header-icon {
  color: var(--accent);
  display: flex;
  align-items: center;
}
.btv-header-icon svg { width: 20px; height: 20px; }

.btv-header-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}

/* ── Tab Bar ── */

.btv-tab-bar {
  display: flex;
  gap: 2px;
  padding: 8px 14px 0;
  border-bottom: 1px solid var(--border-color);
  flex-shrink: 0;
}

.btv-tab {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 7px 16px 9px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.btv-tab:hover { color: var(--text-secondary); }
.btv-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.btv-lobby-content {
  flex: 1;
  overflow-y: auto;
  padding: 14px;
}

/* ── Channel Cards ── */

.btv-create-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
}

.btv-create-btn {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 7px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}
.btv-create-btn:hover { opacity: 0.9; }
.btv-create-btn:active { transform: scale(0.97); }

.btv-create-input {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 7px 12px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  width: 200px;
  transition: border-color 0.15s;
}
.btv-create-input:focus { border-color: var(--accent); }

.btv-channel-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.btv-channel-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  padding: 12px 14px;
  transition: border-color 0.2s, box-shadow 0.2s;
  position: relative;
  overflow: hidden;
}
/* Status bar — colored left accent via ::before */
.btv-channel-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  border-radius: 10px 0 0 10px;
  background: #6b7280;
  transition: background 0.2s;
}
.btv-channel-card.playing::before { background: var(--green); }
.btv-channel-card.paused::before { background: #f59e0b; }
.btv-channel-card.idle::before { background: #6b7280; }
.btv-channel-card.tuned {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 2px 8px rgba(0,0,0,0.12);
}

.btv-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.btv-card-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  transition: background 0.2s;
}
.btv-card-dot.playing { background: var(--green); }
.btv-card-dot.paused { background: #f59e0b; }
.btv-card-dot.idle { background: #6b7280; }

.btv-card-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.btv-tune-btn {
  border: none;
  border-radius: 6px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}
.btv-tune-btn:hover { opacity: 0.85; }
.btv-tune-btn:active { transform: scale(0.96); }
.btv-tune-btn.in {
  background: var(--accent);
  color: #fff;
}
.btv-tune-btn.out {
  background: var(--red);
  color: #fff;
}

.btv-card-info {
  font-size: 12px;
  color: var(--text-secondary);
  margin-bottom: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.btv-card-info.idle { color: var(--text-muted); font-style: italic; }

.btv-card-stats {
  display: flex;
  gap: 12px;
  font-size: 11px;
  color: var(--text-muted);
}

.btv-card-delete {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 11px;
  cursor: pointer;
  padding: 2px 6px;
  margin-top: 4px;
  float: right;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}
.btv-card-delete:hover { color: var(--red); background: rgba(239, 68, 68, 0.08); }

/* ── URL Input ── */

.btv-url-form {
  padding: 4px 0;
}

.btv-url-label {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 10px;
}

.btv-url-input-row {
  display: flex;
  gap: 6px;
}

.btv-url-input {
  flex: 1;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 9px 14px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s;
}
.btv-url-input:focus { border-color: var(--accent); }

.btv-url-play-btn,
.btv-url-queue-btn {
  border: none;
  border-radius: 8px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}
.btv-url-play-btn {
  background: var(--accent);
  color: #fff;
}
.btv-url-queue-btn {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}
.btv-url-play-btn:hover,
.btv-url-queue-btn:hover { opacity: 0.85; }
.btv-url-play-btn:active,
.btv-url-queue-btn:active { transform: scale(0.97); }

/* ── Library Browser ── */

.btv-search-row {
  margin-bottom: 10px;
}

.btv-search-input {
  width: 100%;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 9px 14px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.15s;
}
.btv-search-input:focus { border-color: var(--accent); }

.btv-library-list {
  display: flex;
  flex-direction: column;
}

.btv-lib-section-header {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--text-muted);
  padding: 12px 0 6px;
}

.btv-lib-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 8px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}
.btv-lib-item:hover { background: var(--bg-secondary); }

.btv-lib-thumb {
  width: 42px;
  height: 30px;
  border-radius: 4px;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
  color: var(--text-muted);
}
.btv-lib-thumb svg { width: 16px; height: 16px; }
.btv-lib-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.btv-lib-info {
  flex: 1;
  min-width: 0;
}

.btv-lib-title {
  font-size: 13px;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.btv-lib-meta {
  font-size: 11px;
  color: var(--text-muted);
}

.btv-lib-play,
.btv-lib-queue {
  background: var(--bg-tertiary);
  border: none;
  border-radius: 4px;
  padding: 4px 8px;
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s, transform 0.1s;
  flex-shrink: 0;
}
.btv-lib-play svg { width: 14px; height: 14px; }
.btv-lib-play:hover,
.btv-lib-queue:hover { background: var(--accent); color: #fff; }
.btv-lib-play:active,
.btv-lib-queue:active { transform: scale(0.92); }

.btv-lib-queue {
  font-size: 14px;
  font-weight: 700;
  width: 24px;
  height: 24px;
}

/* ── Playback Header ── */

.btv-playback-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-color);
  flex-shrink: 0;
  gap: 10px;
  background: var(--bg-primary);
}

.btv-playback-title-area {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 1;
}

.btv-playback-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.btv-sync-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  flex-shrink: 0;
  background: var(--bg-tertiary);
  color: var(--text-muted);
  transition: background 0.2s, color 0.2s;
}
.btv-sync-badge.ok {
  background: rgba(16, 185, 129, 0.15);
  color: var(--green);
}
.btv-sync-badge.paused {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
}
.btv-sync-badge.catching {
  background: rgba(96, 165, 250, 0.15);
  color: #60a5fa;
}

.btv-viewer-count {
  font-size: 12px;
  color: var(--text-muted);
  padding-right: 4px;
}

.btv-playback-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.btv-save-btn,
.btv-leave-btn,
.btv-end-btn {
  border: none;
  border-radius: 6px;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}
.btv-save-btn {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}
.btv-leave-btn {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}
.btv-end-btn {
  background: var(--red);
  color: #fff;
}
.btv-save-btn:hover,
.btv-leave-btn:hover,
.btv-end-btn:hover { opacity: 0.85; }
.btv-save-btn:active,
.btv-leave-btn:active,
.btv-end-btn:active { transform: scale(0.96); }

/* ── Media Container ── */

.btv-media-container {
  background: #000;
  position: relative;
  flex-shrink: 0;
}

.btv-video {
  width: 100%;
  max-height: 400px;
  object-fit: contain;
  display: block;
}

.btv-audio-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 20px;
  background: var(--bg-secondary);
  text-align: center;
}
.btv-audio-icon {
  color: var(--accent);
  margin-bottom: 10px;
}
.btv-audio-icon svg { width: 44px; height: 44px; }
.btv-audio-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  max-width: 80%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Controls ── */

.btv-controls-section {
  background: var(--bg-secondary);
  border-top: 1px solid var(--border-color);
}

.btv-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  flex-wrap: wrap;
}

.btv-ctrl-btn {
  background: var(--bg-tertiary);
  border: none;
  border-radius: 6px;
  padding: 6px 8px;
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s, transform 0.1s;
}
.btv-ctrl-btn svg { width: 18px; height: 18px; }
.btv-ctrl-btn:hover { background: var(--bg-primary); color: var(--text-primary); }
.btv-ctrl-btn:active { transform: scale(0.93); }
.btv-ctrl-btn.primary {
  background: var(--accent);
  color: #fff;
}
.btv-ctrl-btn.primary:hover { opacity: 0.9; }
.btv-ctrl-btn.small { padding: 4px 6px; }
.btv-ctrl-btn.small svg { width: 16px; height: 16px; }
.btv-ctrl-btn.active {
  background: var(--accent);
  color: #fff;
}

.btv-seek-bar {
  -webkit-appearance: none;
  appearance: none;
  flex: 1;
  min-width: 80px;
  height: 4px;
  background: var(--bg-tertiary);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
  transition: height 0.15s;
}
.btv-seek-bar:hover {
  height: 6px;
}
.btv-seek-bar::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  transition: transform 0.1s;
}
.btv-seek-bar:hover::-webkit-slider-thumb {
  transform: scale(1.25);
}

.btv-time {
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
  min-width: 70px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.btv-vol-control {
  display: flex;
  align-items: center;
  gap: 4px;
}

.btv-vol-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 64px;
  height: 4px;
  background: var(--bg-tertiary);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
  transition: height 0.15s;
}
.btv-vol-slider:hover {
  height: 6px;
}
.btv-vol-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
}

/* ── Queue ── */

.btv-section-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  padding: 10px 14px 4px;
}

.btv-queue-section {
  border-top: 1px solid var(--border-color);
}

.btv-queue-list {
  padding: 0 8px;
}

.btv-queue-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  transition: background 0.15s;
  position: relative;
}
.btv-queue-item:hover { background: var(--bg-secondary); }
.btv-queue-item.current {
  background: rgba(96, 165, 250, 0.08);
  border-left: 3px solid var(--accent);
  padding-left: 5px;
}

.btv-queue-idx {
  width: 20px;
  text-align: center;
  font-size: 12px;
  color: var(--text-muted);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-variant-numeric: tabular-nums;
}
.btv-queue-idx svg { width: 14px; height: 14px; color: var(--accent); }

.btv-queue-title {
  flex: 1;
  font-size: 13px;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.btv-queue-dur {
  font-size: 11px;
  color: var(--text-muted);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}

.btv-queue-remove {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  display: flex;
  align-items: center;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
}
.btv-queue-item:hover .btv-queue-remove { opacity: 1; }
.btv-queue-remove:hover { color: var(--red); }
.btv-queue-remove svg { width: 14px; height: 14px; }

.btv-queue-clear {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  padding: 6px 14px;
  transition: color 0.15s;
}
.btv-queue-clear:hover { color: var(--red); }

/* ── Participants ── */

.btv-participants-section {
  border-top: 1px solid var(--border-color);
  padding-bottom: 10px;
}

.btv-participants-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 4px 14px;
}

.btv-participant {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 16px;
  padding: 3px 10px 3px 4px;
}

.btv-participant-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  flex-shrink: 0;
  overflow: hidden;
}
.btv-participant-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.btv-you {
  font-size: 10px;
  color: var(--text-muted);
}

.btv-controller-badge {
  font-size: 10px;
  background: rgba(96, 165, 250, 0.15);
  color: #60a5fa;
  padding: 1px 6px;
  border-radius: 8px;
  font-weight: 600;
}

.btv-transfer-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
}

.btv-transfer-label {
  font-size: 12px;
  color: var(--text-muted);
}

.btv-transfer-select {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 12px;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.15s;
}
.btv-transfer-select:focus { border-color: var(--accent); }

/* ══════════════════════════════════════════════════════════════════════
   WO-7E: Changelog Window
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root ── */
.cl-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background: var(--bg-primary);
}

.cl-header {
  padding: var(--space-6, 16px) var(--space-8, 20px) var(--space-5, 12px);
  border-bottom: 1px solid var(--border, var(--bg-tertiary));
  flex-shrink: 0;
}

.cl-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--text-primary);
}

.cl-current-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-pill, 10px);
  font-size: 11px;
  font-weight: 600;
  background: var(--accent, #c8a078);
  color: var(--bg-primary, #1a1510);
}

.cl-toggle-row {
  display: flex;
  gap: 6px;
  margin-top: var(--space-3, 8px);
}

.cl-toggle-btn {
  padding: 3px 10px;
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-sm, 4px);
  background: transparent;
  color: var(--text-muted);
  font-size: 11px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.cl-toggle-btn:hover {
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
}

/* ── Timeline layout ── */
.cl-list {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-3, 8px) var(--space-5, 12px) var(--space-6, 16px);
}

.cl-entry {
  border: 1px solid var(--border, var(--bg-tertiary));
  border-radius: var(--radius-md, 8px);
  margin-bottom: var(--space-3, 8px);
  background: var(--bg-secondary);
  transition: border-color 0.15s;
  position: relative;
}
.cl-entry-current {
  border-color: var(--accent, #c8a078);
  box-shadow: 0 0 0 1px var(--accent-dim, rgba(196,122,58,0.15));
}

.cl-version-header {
  display: flex;
  align-items: center;
  gap: var(--space-3, 8px);
  padding: var(--space-4, 10px) var(--space-5, 14px);
  cursor: pointer;
  user-select: none;
  transition: background 0.12s;
  border-radius: var(--radius-md, 8px);
}
.cl-version-header:hover {
  background: rgba(255,255,255,0.03);
}

.cl-chevron {
  font-size: 10px;
  color: var(--text-muted);
  transition: transform 0.15s;
  flex-shrink: 0;
  width: 14px;
  text-align: center;
}
.cl-chevron-open {
  transform: rotate(90deg);
}

/* ── Accent version numbers ── */
.cl-version-label {
  font-size: 15px;
  font-weight: 700;
  color: var(--accent);
}

.cl-current-indicator {
  padding: 1px 7px;
  border-radius: var(--radius-pill, 8px);
  font-size: 10px;
  font-weight: 600;
  background: var(--accent, #c8a078);
  color: var(--bg-primary, #1a1510);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.cl-date {
  font-size: 12px;
  color: var(--text-muted);
  margin-left: auto;
}

.cl-highlights {
  padding: 0 var(--space-5, 14px) var(--space-3, 8px) 36px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.cl-highlight-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-pill, 12px);
  font-size: 11px;
  background: var(--accent-dim, rgba(196,122,58,0.15));
  color: var(--text-secondary);
  line-height: 1.4;
}

.cl-detail {
  padding: 0 var(--space-5, 14px) var(--space-5, 12px) 36px;
  border-top: 1px solid var(--border, var(--bg-tertiary));
  margin-top: 4px;
}

.cl-section {
  margin-top: var(--space-4, 10px);
}

.cl-section-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.cl-item-list {
  margin: 0;
  padding-left: 16px;
}

.cl-item {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: 1px;
}
.cl-item::marker {
  color: var(--accent);
}

.cl-no-detail {
  padding: var(--space-3, 8px) var(--space-5, 14px) var(--space-5, 12px) 36px;
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
}

/* ══════════════════════════════════════════════════════════════════════
   WO-D32: Arcade Window — Premium Redesign
   Design-token based CSS, snapshot-friendly architecture.
   ══════════════════════════════════════════════════════════════════════ */

/* ── Root & layout ── */
.aw-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background: var(--bg-primary);
  position: relative;
}

/* ── Tab bar ── */
.aw-tab-bar {
  display: flex;
  gap: var(--space-1, 2px);
  padding: var(--space-4, 8px) var(--space-6, 12px) 0;
  flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}

.aw-tab {
  padding: var(--space-3, 6px) var(--space-6, 14px);
  border: none;
  border-radius: var(--radius-sm, 6px) var(--radius-sm, 6px) 0 0;
  background: transparent;
  color: var(--text-muted);
  font-size: var(--text-sm, 12px);
  font-weight: var(--weight-semibold, 600);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s), color var(--duration-base, 0.12s);
  position: relative;
}
.aw-tab:hover {
  background: var(--bg-hover, rgba(255,255,255,0.04));
  color: var(--text-secondary);
}
.aw-tab.active {
  background: var(--bg-secondary);
  color: var(--text-primary);
}
.aw-tab.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--space-4, 8px);
  right: var(--space-4, 8px);
  height: 2px;
  background: var(--accent);
  border-radius: 1px 1px 0 0;
}

/* ── Toolbar ── */
.aw-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-3, 6px);
  padding: var(--space-4, 8px) var(--space-6, 12px);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.aw-status-badge {
  padding: var(--space-1, 2px) var(--space-4, 8px);
  border-radius: var(--radius-full, 10px);
  font-size: var(--text-xs, 11px);
  font-weight: var(--weight-semibold, 600);
}
.aw-status-ready {
  background: rgba(16, 185, 129, 0.12);
  color: #34d399;
}

/* ── Buttons — preserved from D26 (already token-based) ── */
.aw-btn-primary {
  padding: var(--space-2) var(--space-6);
  border: none;
  border-radius: var(--radius-sm);
  background: var(--accent);
  color: var(--text-on-accent);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  transition: filter var(--duration-base);
  white-space: nowrap;
}
.aw-btn-primary:hover { filter: brightness(1.1); }
.aw-btn-primary:disabled { opacity: 0.5; cursor: default; filter: none; }

.aw-btn-secondary {
  padding: var(--space-2) var(--space-6);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: background var(--duration-base);
}
.aw-btn-secondary:hover { background: var(--bg-hover); }

.aw-btn-danger {
  padding: var(--space-2) var(--space-6);
  border: none;
  border-radius: var(--radius-sm);
  background: var(--red);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  transition: filter var(--duration-base);
}
.aw-btn-danger:hover { filter: brightness(1.1); }

/* ── Size toggle ── */
.aw-size-toggle {
  width: 28px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 6px);
  background: transparent;
  color: var(--text-muted);
  font-size: var(--text-sm, 12px);
  font-weight: var(--weight-bold, 700);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s), color var(--duration-base, 0.12s), border-color var(--duration-base, 0.12s);
}
.aw-size-toggle:hover {
  background: var(--bg-hover, rgba(255,255,255,0.06));
  color: var(--text-secondary);
  border-color: var(--border-strong);
}

/* ── Filters ── */
.aw-filters {
  display: flex;
  gap: var(--space-2, 4px);
  padding: var(--space-3, 6px) var(--space-6, 12px);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.aw-pill-btn {
  padding: var(--space-2, 4px) var(--space-5, 10px);
  border: 1px solid var(--border);
  border-radius: var(--radius-full, 12px);
  background: transparent;
  color: var(--text-muted);
  font-size: var(--text-xs, 11px);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s), color var(--duration-base, 0.12s), border-color var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s);
  white-space: nowrap;
}
.aw-pill-btn:hover {
  background: var(--bg-hover, rgba(255,255,255,0.06));
  color: var(--text-secondary);
  border-color: var(--border-strong);
}
.aw-pill-btn.active {
  background: var(--accent);
  color: var(--text-on-accent, var(--bg-primary));
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}
.aw-pill-btn svg { width: 12px; height: 12px; vertical-align: -1px; margin-right: 2px; }

/* ── Search ── */
.aw-search-bar {
  padding: var(--space-2, 4px) var(--space-6, 12px) var(--space-4, 8px);
  flex-shrink: 0;
}

.aw-search {
  width: 100%;
  padding: var(--space-3, 6px) var(--space-5, 10px);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 6px);
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: var(--text-base, 13px);
  outline: none;
  box-sizing: border-box;
  transition: border-color var(--duration-base, 0.15s), box-shadow var(--duration-base, 0.15s);
}
.aw-search:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(var(--accent-rgb, 200,160,120), 0.15);
}

/* ── Scrollable content area ── */
.aw-content {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  padding: 0 var(--space-6, 12px) var(--space-8, 16px);
}

.aw-section-header {
  font-size: var(--text-xs, 12px);
  font-weight: var(--weight-bold, 700);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: var(--space-5, 10px) 0 var(--space-3, 6px);
}

/* ── Upload / scan progress ── */
.aw-upload-row {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
  margin-bottom: var(--space-4, 8px);
}

.aw-progress-bar {
  position: relative;
  height: 24px;
  background: var(--bg-secondary);
  border-radius: var(--radius-sm, 6px);
  overflow: hidden;
  flex: 1;
  margin-bottom: var(--space-4, 8px);
  border: 1px solid var(--border);
}

.aw-progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: var(--accent);
  opacity: 0.25;
  transition: width 0.3s ease;
}

.aw-progress-text {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  font-size: var(--text-xs, 11px);
  color: var(--text-secondary);
  z-index: 1;
  font-weight: var(--weight-medium, 500);
}

/* ── ROM grid ── */
.aw-grid {
  display: grid;
  gap: var(--space-5, 10px);
}
.aw-size-small  { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); }
.aw-size-medium { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
.aw-size-large  { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }

/* ── ROM card ── */
.aw-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s), border-color var(--duration-base, 0.12s);
}
.aw-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg, 0 4px 12px rgba(0,0,0,0.3));
  border-color: var(--border-strong);
}

.aw-card-art {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--bg-tertiary);
}
.aw-card-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.aw-card:hover .aw-card-art img {
  transform: scale(1.03);
}

.aw-card-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 32px;
  background: var(--bg-tertiary);
}

.aw-card-badge {
  position: absolute;
  top: var(--space-3, 6px);
  right: var(--space-3, 6px);
  padding: var(--space-1, 2px) var(--space-3, 6px);
  border-radius: var(--radius-sm, 4px);
  font-size: 10px;
  font-weight: var(--weight-bold, 700);
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  backdrop-filter: blur(8px);
  letter-spacing: 0.02em;
}

.aw-card-fav {
  position: absolute;
  top: var(--space-3, 6px);
  left: var(--space-3, 6px);
  color: var(--yellow, #f1c40f);
  font-size: 14px;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.5));
  pointer-events: none;
}

/* ── Card hover overlay ── */
.aw-card-overlay,
.aw-card-actions {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3, 6px);
  padding: var(--space-4, 8px);
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.2) 50%, transparent 100%);
  opacity: 0;
  transition: opacity var(--duration-base, 0.15s);
}
.aw-card:hover .aw-card-overlay,
.aw-card:hover .aw-card-actions {
  opacity: 1;
}

.aw-card-play-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
  transition: transform var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s);
}
.aw-card-play-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 16px rgba(0,0,0,0.5);
}
.aw-card-play-btn svg { width: 18px; height: 18px; }

.aw-card-action-row {
  display: flex;
  gap: var(--space-2, 4px);
}

.aw-card-action {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: background var(--duration-base, 0.12s), transform var(--duration-base, 0.12s);
  padding: 0;
}
.aw-card-action:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.1);
}
.aw-card-action.active { color: var(--yellow, #f1c40f); }
.aw-card-action-delete:hover { background: rgba(231, 76, 60, 0.6); }
.aw-card-action svg { width: 14px; height: 14px; }

/* ── Card info area ── */
.aw-card-info {
  padding: var(--space-4, 8px) var(--space-5, 10px);
}

.aw-card-title {
  font-size: var(--text-base, 13px);
  font-weight: var(--weight-semibold, 600);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3;
}

.aw-card-meta {
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
  margin-top: var(--space-1, 2px);
}

.aw-play-btn {
  padding: 3px 10px;
  border: none;
  border-radius: var(--radius-sm, 4px);
  background: var(--green, #2ecc71);
  color: #fff;
  font-size: var(--text-xs, 11px);
  font-weight: var(--weight-bold, 700);
  cursor: pointer;
  transition: filter var(--duration-base, 0.12s);
}
.aw-play-btn:hover { filter: brightness(1.1); }

.aw-save-badge {
  padding: var(--space-1, 2px) var(--space-4, 8px);
  border: none;
  border-radius: var(--radius-full, 10px);
  background: rgba(var(--accent-rgb, 200,160,120), 0.12);
  color: var(--text-secondary);
  font-size: var(--text-xs, 11px);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s);
}
.aw-save-badge:hover { background: rgba(var(--accent-rgb, 200,160,120), 0.22); }

/* ── Emulator sessions ── */
.aw-sessions { margin-bottom: var(--space-6, 12px); }

.aw-session-card {
  position: relative;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  padding: var(--space-6, 12px);
  padding-left: calc(var(--space-6, 12px) + 3px);
  margin-bottom: var(--space-4, 8px);
  overflow: hidden;
  transition: border-color var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s);
}
.aw-session-card:hover {
  border-color: var(--border-strong);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

/* Status accent bar (left edge) */
.aw-session-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 3px;
  background: var(--text-muted);
  border-radius: var(--radius, 8px) 0 0 var(--radius, 8px);
}
.aw-session-card[data-status="running"]::before { background: #34d399; }
.aw-session-card[data-status="starting"]::before { background: #fbbf24; }
.aw-session-card[data-status="stopping"]::before { background: #fbbf24; }
.aw-session-card[data-status="stopped"]::before { background: #6b7280; }
.aw-session-card[data-status="crashed"]::before { background: #f87171; }

.aw-session-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3, 6px);
}

.aw-session-game-title,
.aw-session-title {
  font-size: var(--text-md, 14px);
  font-weight: var(--weight-semibold, 600);
  color: var(--text-primary);
}

.aw-session-host {
  font-size: var(--text-sm, 12px);
  color: var(--text-muted);
  margin-bottom: var(--space-4, 8px);
}

/* ── Session status badges ── */
.aw-session-status {
  font-size: var(--text-xs, 11px);
  font-weight: var(--weight-semibold, 600);
  padding: var(--space-1, 2px) var(--space-4, 8px);
  border-radius: var(--radius-full, 10px);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.aw-status-running { background: rgba(16, 185, 129, 0.12); color: #34d399; }
.aw-status-starting { background: rgba(251, 191, 36, 0.12); color: #fbbf24; }
.aw-status-stopping { background: rgba(251, 191, 36, 0.12); color: #fbbf24; }
.aw-status-stopped { background: rgba(107, 114, 128, 0.12); color: #9ca3af; }
.aw-status-crashed { background: rgba(248, 113, 113, 0.12); color: #f87171; }

/* ── Player slots ── */
.aw-player-slots,
.aw-slots {
  display: flex;
  gap: var(--space-3, 6px);
  flex-wrap: wrap;
  margin-bottom: var(--space-4, 8px);
}

.aw-player-slot,
.aw-slot {
  display: flex;
  align-items: center;
  gap: var(--space-3, 6px);
  padding: var(--space-2, 4px) var(--space-5, 10px);
  border-radius: var(--radius-sm, 6px);
  font-size: var(--text-sm, 12px);
  background: var(--bg-tertiary);
  border: 1px solid transparent;
  transition: border-color var(--duration-base, 0.12s), background var(--duration-base, 0.12s);
}

.aw-player-slot.taken,
.aw-slot.taken {
  border-color: var(--accent);
  background: rgba(var(--accent-rgb, 200,160,120), 0.06);
}

.aw-player-slot.open,
.aw-slot.open {
  border: 1px dashed var(--border);
}

.aw-slot-label { font-weight: var(--weight-bold, 700); color: var(--text-muted); }
.aw-slot-player { color: var(--text-primary); }
.aw-slot-open { color: var(--text-muted); font-style: italic; }

/* ── Controller status ── */
.aw-controller-status {
  display: flex;
  align-items: center;
  gap: var(--space-3, 6px);
  padding: var(--space-2, 4px) var(--space-5, 10px);
  font-size: var(--text-sm, 12px);
  border-radius: var(--radius-sm, 4px);
  background: var(--bg-tertiary);
  margin-bottom: var(--space-4, 8px);
}

.aw-ctrl-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.aw-ctrl-dot.connected { background: #34d399; }
.aw-ctrl-dot.keyboard-only { background: #fbbf24; }

.aw-ctrl-label { color: var(--text-secondary); flex: 1; }
.aw-ctrl-badge {
  padding: 1px 6px;
  border-radius: var(--radius-sm, 4px);
  font-size: 10px;
  font-weight: var(--weight-bold, 700);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-muted);
}

.aw-session-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
  flex-wrap: wrap;
}

.aw-spectator-count {
  font-size: var(--text-sm, 12px);
  color: var(--text-muted);
}

.aw-save-row {
  display: flex;
  align-items: center;
  gap: var(--space-3, 6px);
  flex-wrap: wrap;
  width: 100%;
  margin-top: var(--space-3, 6px);
}

.aw-save-info {
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
}

/* ── Lobby ── */
.aw-lobby-list {
  display: flex;
  gap: var(--space-4, 8px);
  flex-wrap: wrap;
}

.aw-lobby-card {
  display: flex;
  align-items: center;
  gap: var(--space-5, 10px);
  padding: var(--space-5, 10px) var(--space-6, 14px);
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s), border-color var(--duration-base, 0.12s);
  min-width: 200px;
  flex: 1;
}
.aw-lobby-card:hover {
  background: var(--bg-hover, rgba(255,255,255,0.04));
  border-color: var(--border-strong);
}

.aw-lobby-title { font-weight: var(--weight-semibold, 600); font-size: var(--text-base, 13px); color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.aw-lobby-meta { font-size: var(--text-xs, 11px); color: var(--text-secondary); }

.aw-lobby-player {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
  padding: var(--space-3, 6px) var(--space-6, 12px);
  border-radius: var(--radius-sm, 4px);
  font-size: var(--text-base, 13px);
  color: var(--text-primary);
  transition: background var(--duration-base, 0.12s);
}
.aw-lobby-player:hover { background: rgba(255, 255, 255, 0.03); }

/* ── Save states view ── */
.aw-save-state-row {
  display: flex;
  align-items: center;
  gap: var(--space-5, 10px);
  padding: var(--space-4, 8px) var(--space-6, 12px);
  border-radius: var(--radius-sm, 6px);
  transition: background var(--duration-base, 0.12s);
}
.aw-save-state-row:hover { background: rgba(255, 255, 255, 0.03); }

/* ── Detail / back button ── */
.aw-back-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2, 4px);
  padding: var(--space-4, 8px) var(--space-6, 12px);
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: var(--text-sm, 12px);
  cursor: pointer;
  transition: color var(--duration-base, 0.12s);
  flex-shrink: 0;
}
.aw-back-btn:hover { color: var(--text-primary); }
.aw-back-btn svg { width: 14px; height: 14px; }

.aw-detail-header {
  padding: 0 var(--space-8, 16px) var(--space-5, 10px);
}

.aw-detail-title {
  font-size: 18px;
  font-weight: var(--weight-bold, 700);
  color: var(--text-primary);
}

.aw-detail-sub {
  font-size: var(--text-sm, 12px);
  color: var(--text-secondary);
  margin-top: var(--space-2, 4px);
}

/* ── Game servers ── */
.aw-server-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  padding: var(--space-6, 14px);
  margin-bottom: var(--space-4, 8px);
  transition: border-color var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s);
}
.aw-server-card:hover {
  border-color: var(--border-strong);
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.aw-server-header {
  display: flex;
  align-items: center;
  gap: var(--space-5, 10px);
  margin-bottom: var(--space-4, 8px);
}

.aw-server-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.aw-server-name {
  font-size: 15px;
  font-weight: var(--weight-semibold, 600);
  color: var(--text-primary);
  flex: 1;
}

.aw-icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: var(--radius-sm, 4px);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  transition: background var(--duration-base, 0.12s), color var(--duration-base, 0.12s);
}
.aw-icon-btn:hover { background: rgba(255, 255, 255, 0.08); color: var(--text-primary); }
.aw-icon-btn svg { width: 16px; height: 16px; }

.aw-server-status {
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.aw-server-info {
  font-size: var(--text-sm, 12px);
  color: var(--text-secondary);
  margin-bottom: var(--space-5, 10px);
  line-height: 1.6;
}

.aw-server-actions {
  display: flex;
  gap: var(--space-4, 8px);
  flex-wrap: wrap;
}

/* ── Dialogs ── */
.aw-dialog-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}

.aw-dialog {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg, 10px);
  padding: var(--space-10, 20px);
  min-width: 280px;
  max-width: 420px;
  box-shadow: var(--shadow-lg, 0 8px 32px rgba(0,0,0,0.5));
}

.aw-config-dialog {
  max-width: 520px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
}

.aw-dialog-title {
  font-size: 16px;
  font-weight: var(--weight-bold, 700);
  color: var(--text-primary);
  margin: 0 0 var(--space-2, 4px);
}

.aw-dialog-hint {
  font-size: var(--text-sm, 12px);
  color: var(--text-secondary);
  margin-bottom: var(--space-8, 16px);
}

.aw-config-section {
  font-size: var(--text-xs, 11px);
  font-weight: var(--weight-bold, 700);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin: var(--space-8, 16px) 0 var(--space-4, 8px);
  padding-bottom: var(--space-2, 4px);
  border-bottom: 1px solid var(--border);
}

.aw-config-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3, 6px) 0;
  gap: var(--space-6, 12px);
}

/* ── Inline-style replacements (WO-D32) ── */
.aw-btn-row {
  display: flex;
  gap: var(--space-2, 4px);
  align-items: center;
}

.aw-btn-sm {
  font-size: var(--text-xs, 10px);
  padding: var(--space-1, 2px) var(--space-3, 6px);
}

.aw-btn-join {
  font-size: var(--text-xs, 11px);
  padding: var(--space-2, 4px) var(--space-6, 12px);
}

.aw-lobby-card-content {
  flex: 1;
  min-width: 0;
}

.aw-config-label-col {
  flex: 1;
  min-width: 0;
}

.aw-config-label-text {
  font-size: var(--text-base, 13px);
  font-weight: var(--weight-medium, 500);
}

.aw-config-label-desc {
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
  margin-top: 1px;
}

.aw-config-control-col {
  flex-shrink: 0;
}

.aw-config-btn-row {
  display: flex;
  gap: var(--space-4, 8px);
  justify-content: flex-end;
  margin-top: var(--space-8, 16px);
  padding-top: var(--space-6, 12px);
  border-top: 1px solid var(--border);
}

.aw-cancel-btn-sm {
  font-size: var(--text-xs, 11px);
  padding: var(--space-2, 4px) var(--space-5, 10px);
  flex-shrink: 0;
}

.aw-wait-label {
  font-size: var(--text-sm, 12px);
  color: var(--text-muted);
}

.aw-config-warning-banner {
  background: rgba(251, 191, 36, 0.08);
  border: 1px solid rgba(251, 191, 36, 0.2);
  border-radius: var(--radius-sm, 6px);
  padding: var(--space-4, 8px) var(--space-6, 12px);
  margin-bottom: var(--space-6, 12px);
  font-size: var(--text-sm, 12px);
  color: #fbbf24;
}

.aw-save-state-info-col {
  flex: 1;
  min-width: 0;
}

.aw-save-state-name {
  font-size: var(--text-base, 13px);
  font-weight: var(--weight-medium, 500);
}

.aw-save-state-meta {
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
}

.aw-lobby-detail-status {
  padding: 0 var(--space-8, 16px);
  margin-bottom: var(--space-6, 12px);
}

.aw-lobby-status-badge {
  padding: var(--space-1, 2px) var(--space-5, 10px);
  border-radius: var(--radius-full, 10px);
  font-size: var(--text-xs, 11px);
  font-weight: var(--weight-semibold, 600);
}

.aw-lobby-actions {
  padding: var(--space-8, 16px);
  display: flex;
  gap: var(--space-4, 8px);
  flex-wrap: wrap;
}

.aw-lobby-player-num {
  font-weight: var(--weight-semibold, 600);
  color: var(--text-secondary);
  width: 20px;
}

.aw-lobby-player-name {
  flex: 1;
}

.aw-lobby-player-status {
  font-size: var(--text-sm, 12px);
  color: var(--text-muted);
}

.aw-dialog-label-title {
  color: var(--text-primary);
  font-size: var(--text-md, 14px);
  font-weight: var(--weight-semibold, 600);
  margin-bottom: var(--space-6, 12px);
}

.aw-dialog-input-mb {
  width: 100%;
  margin-bottom: var(--space-6, 12px);
}

.aw-dialog-btn-row {
  display: flex;
  gap: var(--space-4, 8px);
  justify-content: flex-end;
}

.aw-dialog-full-btn {
  display: block;
  width: 100%;
  text-align: left;
  margin-bottom: var(--space-3, 6px);
  padding: var(--space-4, 8px) var(--space-6, 12px);
}

.aw-dialog-cancel-mt {
  margin-top: var(--space-4, 8px);
}

.aw-config-loading {
  padding: var(--space-10, 20px);
  text-align: center;
  color: var(--text-muted);
  font-size: var(--text-base, 13px);
}

.aw-config-toggle-label {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
  cursor: pointer;
}

.aw-config-toggle-input {
  opacity: 0;
  width: 0;
  height: 0;
}

.aw-config-toggle-slider {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: var(--radius-full, 10px);
  transition: background 0.2s;
  border: 1px solid var(--border);
}

.aw-config-toggle-knob {
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: white;
  top: 2px;
  transition: left 0.2s;
}

.aw-config-select {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 4px);
  padding: var(--space-2, 4px) var(--space-4, 8px);
  font-size: var(--text-sm, 12px);
  min-width: 100px;
}

.aw-config-slider-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
}

.aw-config-slider-input {
  width: 100px;
  accent-color: var(--accent);
}

.aw-config-slider-label {
  font-size: var(--text-sm, 12px);
  color: var(--text-secondary);
  min-width: 28px;
  text-align: right;
}

.aw-config-text-input {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 4px);
  padding: var(--space-2, 4px) var(--space-4, 8px);
  font-size: var(--text-sm, 12px);
  width: 160px;
}

.aw-world-header {
  padding: var(--space-4, 8px) var(--space-6, 12px);
  font-size: var(--text-sm, 12px);
  font-weight: var(--weight-semibold, 600);
  color: var(--text-secondary);
}

.aw-world-date {
  font-size: var(--text-xs, 11px);
  color: var(--text-muted);
}

.aw-world-separator {
  height: 1px;
  margin: var(--space-2, 4px) var(--space-4, 8px);
  background: var(--border);
}

.aw-delete-btn-sm {
  font-size: var(--text-xs, 11px);
  padding: var(--space-1, 2px) var(--space-4, 8px);
}

/* ── World picker ── */
.aw-world-picker-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
}

.aw-world-picker {
  position: fixed;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  padding: var(--space-2, 4px);
  min-width: 180px;
  max-height: 300px;
  overflow-y: auto;
  box-shadow: var(--shadow-lg, 0 4px 16px rgba(0,0,0,0.4));
  z-index: 10001;
}

.aw-world-picker-loading {
  padding: var(--space-6, 12px);
  font-size: var(--text-sm, 12px);
  color: var(--text-muted);
  text-align: center;
}

.aw-world-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-3, 6px) var(--space-6, 12px);
  background: none;
  border: none;
  border-radius: var(--radius-sm, 4px);
  color: var(--text-primary);
  font-size: var(--text-base, 13px);
  cursor: pointer;
  text-align: left;
  transition: background var(--duration-base, 0.12s);
}
.aw-world-item:hover { background: var(--bg-hover, rgba(255,255,255,0.06)); }

/* styles/chat.css — Chat window, message bubbles, input, search, legacy message styles, visualizer */
/* ── Chat Window (WO-7A) ── */

.cw-root {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--bg-primary);
}

/* Sidebar rules removed (WO-D29) — dead code after tab-strip migration */

/* ── Chat Tab Strip (WO-D14) ── */

.chat-tab-strip {
  display: flex;
  align-items: center;
  height: 32px;
  min-height: 32px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border-color, #2a2a2a);
  padding: 0 var(--space-2);
  gap: 0;
  flex-shrink: 0;
  overflow: hidden;
}
.chat-tab-scroll {
  display: flex;
  align-items: center;
  gap: 2px;
  overflow-x: auto;
  overflow-y: hidden;
  flex: 1;
  min-width: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.chat-tab-scroll::-webkit-scrollbar { display: none; }
.chat-tab {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-6);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
  transition: background var(--duration-base), color var(--duration-base);
  user-select: none;
  position: relative;
}
.chat-tab:hover {
  background: var(--bg-hover);
  color: var(--text-secondary);
}
.chat-tab.active {
  background: var(--bg-primary);
  color: var(--text-primary);
  font-weight: var(--weight-semibold);
}
.chat-tab.unread .chat-tab-label {
  font-weight: 700;
  color: var(--text-primary);
}
.chat-tab-label {
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}
.chat-tab-badge {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--text-muted);
  flex-shrink: 0;
}
.chat-tab-badge.mention {
  width: auto;
  height: auto;
  padding: 0 var(--space-2);
  border-radius: var(--space-4);
  background: var(--red);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  line-height: 14px;
}
.dm-tab {
  font-style: italic;
}
.dm-tab .chat-tab-label {
  max-width: 100px;
}
.chat-tab-add {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: var(--radius-sm);
  background: none;
  color: var(--text-muted);
  font-size: var(--text-lg);
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--duration-base), color var(--duration-base);
}
.chat-tab-add:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

/* ── Chat Tab Picker Dropdown (WO-D14) ── */
.chat-tab-picker {
  position: fixed;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: 4px;
  min-width: 180px;
  max-width: 280px;
  max-height: 400px;
  overflow-y: auto;
  box-shadow: var(--shadow-lg);
  z-index: 10003;
}
.chat-tab-picker-header {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  padding: 6px 10px 4px;
}
.chat-tab-picker-item {
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 12px;
  color: var(--text-secondary);
  transition: background 0.1s, color 0.1s;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.chat-tab-picker-item:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}
.chat-tab-picker-item.active {
  background: var(--accent-dim);
  color: var(--accent);
}

/* ── Main column ── */

.cw-main-col {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

/* ── Message list ── */

.cw-message-list-wrapper {
  flex: 1;
  position: relative;
  overflow: hidden;
}

.cw-message-list {
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
}

.cw-message-list::-webkit-scrollbar { width: 6px; }
.cw-message-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: 3px; }

.cw-message-list-inner {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  justify-content: flex-end;
  padding: 8px 0;
}

/* ── Scroll-to-bottom button ── */

.cw-scroll-bottom-btn {
  position: absolute;
  bottom: 8px;
  right: 16px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color, #333);
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  transition: background 0.15s;
}

.cw-scroll-bottom-btn:hover {
  background: var(--accent);
  color: #fff;
}

.cw-scroll-bottom-btn svg { width: 16px; height: 16px; }

/* ── New messages bar ── */

.cw-new-messages-bar {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 16px;
  border-radius: 0 0 8px 8px;
  background: var(--accent);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  z-index: 5;
  transition: opacity 0.2s;
}

.cw-new-messages-bar:hover { opacity: 0.9; }

/* ── Date Separators (WO-D29) ── */

.cw-date-separator {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4) 0;
  position: sticky;
  top: 0;
  z-index: 1;
}

.cw-date-separator-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  background: var(--bg-secondary);
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
}

/* ── Unread Divider (WO-D29) ── */

.cw-unread-divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-8);
  margin: var(--space-2) 0;
}

.cw-unread-divider::before,
.cw-unread-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--red);
}

.cw-unread-divider span {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  color: var(--red);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

/* ── Load more ── */

.cw-load-more {
  text-align: center;
  padding: 8px;
}

.cw-load-more button {
  background: none;
  border: 1px solid var(--border-color, #333);
  color: var(--text-secondary);
  padding: 4px 12px;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
  transition: background 0.15s;
}

.cw-load-more button:hover {
  background: rgba(255,255,255,0.06);
}

/* ── Typing bar ── */

.cw-typing-bar {
  padding: 2px 16px;
  font-size: 11px;
  color: var(--text-muted);
  flex-shrink: 0;
  min-height: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

/* ── Message input ── */

.cw-input-container {
  flex-shrink: 0;
  border-top: 1px solid var(--border-color, #2a2a2a);
  background: var(--bg-secondary);
}

.cw-input-container.cw-input-dragover {
  background: rgba(var(--accent-rgb, 88,101,242), 0.1);
  border-top-color: var(--accent);
}

.cw-reply-preview {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--bg-tertiary);
  font-size: 12px;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-color, #333);
}

.cw-reply-preview-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-muted);
}

.cw-reply-preview-close {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  display: flex;
}

.cw-reply-preview-close:hover { color: var(--text-primary); }
.cw-reply-preview-close svg { width: 14px; height: 14px; }

.cw-pending-uploads {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 6px 12px;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border-color, #333);
}

.cw-pending-upload {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  background: var(--bg-secondary);
  border-radius: 4px;
  font-size: 11px;
  color: var(--text-secondary);
}

.cw-pending-upload.uploading { opacity: 0.6; }

.cw-remove-upload {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  display: flex;
}

.cw-remove-upload:hover { color: var(--red); }
.cw-remove-upload svg { width: 12px; height: 12px; }

.cw-input-wrapper {
  display: flex;
  align-items: flex-end;
  gap: 0;
  padding: 8px 12px;
}

.cw-input-toolbar {
  display: flex;
  align-items: center;
  gap: 2px;
  padding-right: var(--space-2);
  flex-shrink: 0;
}

.cw-toolbar-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  width: 32px;
  height: 32px;
  padding: var(--space-2);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  transition: color var(--duration-base), background var(--duration-base);
}

.cw-toolbar-btn:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}

.cw-toolbar-btn.active {
  color: var(--accent);
}

.cw-toolbar-btn svg { width: 18px; height: 18px; }

.cw-toolbar-btn-gif {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  padding: var(--space-2) var(--space-3);
}

.cw-message-textarea {
  flex: 1;
  min-width: 0;
  padding: var(--space-3) var(--space-4);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color, #333);
  border-radius: var(--space-3);
  color: var(--text-primary);
  font-size: var(--text-base);
  font-family: inherit;
  resize: none;
  outline: none;
  max-height: 200px;
  line-height: 1.4;
}

.cw-message-textarea:focus {
  border-color: var(--accent);
}

.cw-message-textarea::placeholder {
  color: var(--text-muted);
}

.cw-send-btn {
  background: none;
  border: none;
  color: var(--accent);
  cursor: pointer;
  padding: var(--space-3);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  transition: background var(--duration-base);
}

.cw-send-btn:hover {
  background: rgba(255,255,255,0.06);
}

.cw-send-btn svg { width: 20px; height: 20px; }

/* ── Poll form ── */

.cw-poll-form {
  padding: var(--space-6);
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border-color, #333);
}

.cw-poll-form-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
}

.cw-poll-form-header svg { width: 16px; height: 16px; vertical-align: middle; }

.cw-poll-form-close {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  display: flex;
}

.cw-poll-form-close:hover { color: var(--text-primary); }
.cw-poll-form-close svg { width: 14px; height: 14px; }

.cw-poll-form-question {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color, #333);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-base);
  outline: none;
  box-sizing: border-box;
}

.cw-poll-form-question:focus { border-color: var(--accent); }

.cw-poll-form-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.cw-poll-form-option-row {
  display: flex;
  gap: var(--space-2);
}

.cw-poll-form-option-input {
  flex: 1;
  padding: 5px var(--space-4);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color, #333);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  outline: none;
}

.cw-poll-form-option-input:focus { border-color: var(--accent); }

.cw-poll-form-remove-option {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--space-2);
  display: flex;
}

.cw-poll-form-remove-option:hover { color: var(--red); }
.cw-poll-form-remove-option svg { width: 12px; height: 12px; }

.cw-poll-form-add-option {
  background: none;
  border: none;
  color: var(--accent);
  cursor: pointer;
  font-size: var(--text-sm);
  padding: var(--space-2) 0;
}

.cw-poll-form-add-option:hover { text-decoration: underline; }

.cw-poll-form-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-4);
}

.cw-poll-form-multi-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.cw-poll-form-submit {
  padding: 5px var(--space-7);
  background: var(--accent);
  border: none;
  border-radius: var(--radius-sm);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  transition: opacity var(--duration-base);
}

.cw-poll-form-submit:hover { opacity: 0.9; }

/* ── Mention dropdown ── */

.cw-mention-dropdown {
  position: absolute;
  bottom: 100%;
  left: 12px;
  right: 12px;
  max-height: 200px;
  overflow-y: auto;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color, #333);
  border-radius: 6px;
  z-index: 10;
  display: none;
}

.cw-mention-item {
  padding: 6px 12px;
  font-size: 13px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.1s;
}

.cw-mention-item:hover,
.cw-mention-item.selected {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}

/* ── Slash command autocomplete ── */

.cw-cmd-autocomplete {
  position: absolute;
  bottom: 100%;
  left: 12px;
  right: 12px;
  max-height: 260px;
  overflow-y: auto;
  background: var(--bg-secondary, #2b2d31);
  border: 1px solid var(--border-color, #333);
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  z-index: 11;
  padding: 4px 0;
}

.cw-cmd-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  cursor: pointer;
  transition: background 0.1s;
}

.cw-cmd-item:hover,
.cw-cmd-item.selected {
  background: rgba(255, 255, 255, 0.08);
}

.cw-cmd-name {
  color: var(--accent-color, #5b9eff);
  font-weight: 600;
  font-size: 13px;
  white-space: nowrap;
  min-width: 80px;
}

.cw-cmd-usage {
  color: var(--text-muted, #888);
  font-size: 12px;
  white-space: nowrap;
  flex-shrink: 0;
}

.cw-cmd-desc {
  color: var(--text-secondary, #aaa);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Picker popup positioning ── */

.cw-picker-popup {
  box-shadow: 0 4px 20px rgba(0,0,0,0.5);
  border-radius: 8px;
}

/* ══════════════════════════════════════════════════════════════
   Chat — Legacy Message Bubble Styles (ported from styles.css)
   Scoped under .cw-root to prevent leaking
   ══════════════════════════════════════════════════════════════ */

/* ── Core Message Layout (lines 2665-2995 from old styles.css) ── */

.cw-root .message {
  padding: var(--space-2) var(--space-8);
  display: flex;
  gap: var(--space-6);
  position: relative;
}

.cw-root .message:hover {
  background: var(--bg-message-hover);
}

.cw-root .message-actions {
  position: absolute;
  right: var(--space-8);
  top: -12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  display: flex;
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  pointer-events: none;
  transition: opacity var(--duration-base), visibility var(--duration-base), transform var(--duration-base);
}

.cw-root .message:hover .message-actions {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.cw-root .message-action-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  padding: var(--space-2) var(--space-4);
  cursor: pointer;
  font-size: var(--text-lg);
  transition: all var(--duration-slow);
}

.cw-root .message-action-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
  transform: scale(1.1);
}

.cw-root .message.grouped {
  padding-top: 2px;
}

.cw-root .message.grouped .message-avatar {
  visibility: hidden;
}

.cw-root .message.grouped .message-header {
  display: none;
}

.cw-root .message.system {
  padding: 2px var(--space-8);
  justify-content: center;
}

.cw-root .message.system .system-text {
  color: var(--text-muted);
  font-size: var(--text-sm);
  font-style: italic;
}

.cw-root .message-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  flex-shrink: 0;
  margin-top: 2px;
  overflow: hidden;
}
.cw-root .message-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

/* Message content images — constrain to message width */
.cw-root .message-content img:not(.custom-emoji-inline):not(.custom-emoji-img) {
  max-width: 400px;
  max-height: 400px;
  width: auto;
  height: auto;
  border-radius: var(--radius-sm);
  display: block;
}

/* Attachment images */
.cw-root .attachment-image {
  max-width: 100%;
  max-height: 350px;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: var(--radius-sm);
  display: block;
}

/* GIF messages */
.cw-root .message-gif {
  max-width: 300px;
  max-height: 300px;
  border-radius: var(--radius-sm);
  display: block;
}

.cw-root .message-body {
  flex: 1;
  min-width: 0;
}

.cw-root .message-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: 2px;
}

.cw-root .message-username {
  font-weight: var(--weight-semibold);
  font-size: var(--text-md);
  color: var(--accent);
}

.cw-root .message-time {
  font-size: 11px;
  color: var(--text-muted);
}

.cw-root .message-content {
  color: var(--text-primary);
  font-size: var(--chat-font-size);
  line-height: var(--leading-relaxed);
  word-break: break-word;
}

.cw-root .message-gif {
  max-width: 300px;
  max-height: 300px;
  border-radius: var(--radius-sm);
  cursor: pointer;
}

.cw-root .message-content p {
  margin: 0;
}

.cw-root .message-content p + p {
  margin-top: var(--space-2);
}

.cw-root .message-content code {
  background: rgba(0,0,0,0.3);
  padding: 1px var(--space-2);
  border-radius: 3px;
  font-family: var(--font-mono);
  font-size: var(--text-base);
}

.cw-root .message-content pre {
  background: rgba(0,0,0,0.3);
  padding: var(--space-6);
  border-radius: var(--radius);
  margin: var(--space-2) 0;
  overflow-x: auto;
  border: 1px solid var(--border);
}

.cw-root .message-content pre code {
  background: none;
  padding: 0;
  font-size: var(--text-base);
  line-height: 1.4;
}

.cw-root .message-content blockquote {
  border-left: 3px solid var(--accent);
  padding-left: var(--space-6);
  margin: var(--space-2) 0;
  color: var(--text-secondary);
}

.cw-root .message-content a {
  color: var(--bean-light);
  text-decoration: none;
}

.cw-root .message-content a:hover {
  text-decoration: underline;
  color: var(--bean-cream);
}

.cw-root .message-content strong { font-weight: 700; }
.cw-root .message-content em { font-style: italic; }

/* ── Reply Quote ── */
.cw-root .reply-quote {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  margin-bottom: 2px;
  font-size: var(--text-sm);
  color: var(--text-muted);
  cursor: pointer;
}

.cw-root .reply-quote:hover { color: var(--text-secondary); }

.cw-root .reply-quote .reply-bar {
  width: 2px;
  height: 14px;
  background: var(--accent);
  border-radius: 1px;
  flex-shrink: 0;
}

.cw-root .reply-quote .reply-username {
  font-weight: var(--weight-semibold);
  color: var(--accent);
}

.cw-root .reply-quote .reply-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Attachments ── */
.cw-root .message-attachments {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.cw-root .attachment-image {
  max-width: 400px;
  max-height: 300px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: opacity var(--duration-slow);
}

.cw-root .attachment-image:hover { opacity: 0.9; }

.cw-root .attachment-video {
  max-width: 400px;
  border-radius: var(--radius);
}

.cw-root .attachment-file {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 8px 12px;
  max-width: 300px;
  text-decoration: none;
  color: var(--text-primary);
  transition: background 0.15s;
}

.cw-root .attachment-file:hover {
  background: var(--bg-hover);
}

.cw-root .attachment-file-icon {
  font-size: 20px;
}

.cw-root .attachment-file-info {
  overflow: hidden;
}

.cw-root .attachment-file-name {
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cw-root .attachment-file-size {
  font-size: 11px;
  color: var(--text-muted);
}

/* ── Link Embed ── */
.cw-root .link-embed {
  border-left: 3px solid var(--accent);
  background: var(--bg-secondary);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: var(--space-6);
  margin: var(--space-2) 0;
  max-width: 400px;
  transition: box-shadow var(--duration-slow), transform var(--duration-slow);
}

.cw-root .link-embed:hover {
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
  transform: translateX(2px);
}

.cw-root .link-embed-site {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-2);
}

.cw-root .link-embed-title {
  font-size: var(--text-md);
  font-weight: var(--weight-semibold);
  color: var(--bean-light);
  text-decoration: none;
  display: block;
  margin-bottom: var(--space-2);
}

.cw-root .link-embed-title:hover {
  text-decoration: underline;
  color: var(--bean-cream);
}

.cw-root .link-embed-description {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cw-root .link-embed-image {
  margin-top: var(--space-4);
  max-width: 100%;
  max-height: 200px;
  border-radius: var(--radius-sm);
}

/* ── Typing Indicator ── */
.cw-root .typing-indicator {
  height: 24px;
  padding: 0 16px;
  display: flex;
  align-items: center;
}
.cw-root .upload-spinner {
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: upload-spin 0.6s linear infinite;
}

@keyframes upload-spin {
  to { transform: rotate(360deg); }
}

.cw-root .message-avatar.has-img {
  background: none;
  overflow: hidden;
  padding: 0;
}
.cw-root .message-avatar.has-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.cw-root .reply-btn svg { width: 16px; height: 16px; }
.cw-root .attachment-file-icon svg { width: 16px; height: 16px; }



.cw-root .poll-embed {
  border-left: 3px solid var(--accent);
  background: var(--bg-secondary);
  border-radius: var(--radius);
  padding: var(--space-6);
  margin-top: var(--space-4);
  max-width: 420px;
}

.cw-root .poll-question {
  font-weight: var(--weight-semibold);
  font-size: var(--text-md);
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

.cw-root .poll-multi-badge {
  display: inline-block;
  font-size: var(--text-sm);
  color: var(--text-muted);
  background: var(--bg-tertiary);
  padding: 2px var(--space-4);
  border-radius: var(--space-5);
  margin-bottom: var(--space-4);
}

.cw-root .poll-closed-badge {
  display: inline-block;
  font-size: var(--text-sm);
  color: var(--red);
  background: rgba(196, 90, 74, 0.15);
  padding: 2px var(--space-4);
  border-radius: var(--space-5);
  margin-bottom: var(--space-4);
  margin-left: var(--space-2);
}

.cw-root .poll-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.cw-root .poll-option {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding: var(--space-4) var(--space-6);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  background: var(--bg-primary);
  color: var(--text-primary);
  font-size: var(--text-base);
  cursor: pointer;
  text-align: left;
  overflow: hidden;
  transition: border-color var(--duration-slow), background var(--duration-slow);
}

.cw-root .poll-option:hover:not(:disabled) {
  border-color: var(--accent);
  background: var(--bg-hover);
}

.cw-root .poll-option:disabled {
  cursor: default;
  opacity: 0.8;
}

.cw-root .poll-option.voted {
  border-color: var(--accent);
}

.cw-root .poll-option-bar {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  background: var(--accent-dim);
  border-radius: var(--radius-sm);
  transition: width 0.3s ease;
  z-index: 0;
}

.cw-root .poll-option.voted .poll-option-bar {
  background: rgba(196, 122, 58, 0.25);
}

.cw-root .poll-option-text {
  position: relative;
  z-index: 1;
  flex: 1;
}

.cw-root .poll-option-count {
  position: relative;
  z-index: 1;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-left: var(--space-4);
  font-weight: var(--weight-medium);
}

.cw-root .poll-option-check {
  position: relative;
  z-index: 1;
  color: var(--accent);
  margin-left: var(--space-3);
  font-weight: var(--weight-bold);
}

.cw-root .poll-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.cw-root .poll-close-btn {
  background: none;
  border: 1px solid var(--border-strong);
  color: var(--text-secondary);
  padding: 3px var(--space-5);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: color var(--duration-slow), border-color var(--duration-slow);
}

.cw-root .poll-close-btn:hover {
  color: var(--red);
  border-color: var(--red);
}

/* ── Poll Creation Form ── */

.cw-root .poll-creation-form {
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: var(--space-6);
  margin-bottom: var(--space-2);
}

.cw-root .poll-form-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
  font-weight: var(--weight-semibold);
  font-size: var(--text-md);
  color: var(--text-primary);
}

.cw-root .poll-form-close {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: var(--text-lg);
  padding: 2px var(--space-3);
}

.cw-root .poll-form-close:hover {
  color: var(--text-primary);
}

.cw-root .poll-form-question {
  width: 100%;
  padding: var(--space-4) var(--space-5);
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-base);
  margin-bottom: var(--space-4);
  outline: none;
}

.cw-root .poll-form-question:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.cw-root .poll-form-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.cw-root .poll-form-option-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.cw-root .poll-form-option-input {
  flex: 1;
  padding: var(--space-3) var(--space-5);
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-base);
  outline: none;
}

.cw-root .poll-form-option-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

.cw-root .poll-form-remove-option {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: var(--text-md);
  padding: var(--space-2) var(--space-3);
}

.cw-root .poll-form-remove-option:hover {
  color: var(--red);
}

.cw-root .poll-form-add-option {
  width: 100%;
  padding: var(--space-3);
  background: none;
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  font-size: var(--text-sm);
  cursor: pointer;
  margin-bottom: var(--space-5);
  transition: color var(--duration-slow), border-color var(--duration-slow);
}

.cw-root .poll-form-add-option:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.cw-root .poll-form-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cw-root .poll-form-multi-label {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  cursor: pointer;
}

.cw-root .poll-form-multi-check {
  accent-color: var(--accent);
}

.cw-root .poll-form-submit {
  background: var(--accent);
  color: var(--text-on-accent);
  border: none;
  padding: var(--space-3) var(--space-8);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: background var(--duration-slow);
}

.cw-root .poll-form-submit:hover {
  background: var(--accent-hover);
}

.cw-root .reactions-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
  position: relative;
}

.cw-root .reaction-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 2px var(--space-4);
  border-radius: var(--space-6);
  border: 1px solid var(--border, #3f4147);
  background: var(--bg-tertiary, #1e1f22);
  color: var(--text-secondary);
  font-size: var(--text-base);
  cursor: pointer;
  transition: all var(--duration-slow);
}

.cw-root .reaction-chip:hover {
  background: var(--bg-hover, #35373c);
  border-color: var(--text-muted, #5c5e66);
}

.cw-root .reaction-chip.reacted {
  background: rgba(88, 101, 242, 0.15);
  border-color: var(--accent, #5865f2);
}

.cw-root .reaction-emoji {
  font-size: var(--text-md);
  line-height: 1;
}

.cw-root .reaction-count {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
}

.cw-root .reaction-add-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 26px;
  border-radius: var(--space-6);
  border: 1px dashed var(--border, #3f4147);
  background: transparent;
  color: var(--text-muted, #5c5e66);
  font-size: var(--text-md);
  cursor: pointer;
  transition: all var(--duration-slow);
}

.cw-root .reaction-add-btn:hover {
  border-color: var(--text-secondary);
  color: var(--text-secondary);
  background: var(--bg-hover, #35373c);
}

.cw-root .quick-react-picker {
  display: flex;
  gap: 2px;
  padding: 4px 6px;
  background: var(--bg-secondary, #2b2d31);
  border: 1px solid var(--border, #3f4147);
  border-radius: var(--radius-md, 8px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  position: absolute;
  bottom: calc(100% + 4px);
  left: 0;
  z-index: 50;
}

.cw-root .message-actions .quick-react-picker {
  bottom: auto;
  top: calc(100% + 4px);
  right: 0;
  left: auto;
}

.cw-root .quick-react-btn {
  background: none;
  border: none;
  font-size: 18px;
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  transition: background 0.1s;
  line-height: 1;
}

.cw-root .quick-react-btn:hover {
  background: var(--bg-hover, #35373c);
}

.cw-root .quick-react-more {
  font-size: 18px;
  color: var(--text-muted);
  font-weight: bold;
}

.cw-root .quick-react-more:hover {
  color: var(--text-primary);
  background: var(--bg-tertiary);
}

.cw-root .reaction-emoji-picker {
  width: 320px;
  max-height: 350px;
}

.cw-root .react-btn {
  font-size: 14px !important;
}

/* ── Custom Emojis ── */
.cw-root .custom-emoji-inline { height: 1.375em; vertical-align: middle; object-fit: contain; }
.cw-root .custom-emoji-img { height: 22px; width: 22px; object-fit: contain; vertical-align: middle; }
.cw-root .reaction-emoji .custom-emoji-img { height: 16px; width: 16px; }
.cw-root .emoji-upload-row { padding: 4px 8px; }
.cw-root .emoji-upload-btn {
  width: 100%; padding: 6px 8px; border: 1px dashed var(--border);
  border-radius: var(--radius-sm); background: transparent; color: var(--text-muted);
  font-size: 12px; cursor: pointer; transition: all 0.15s;
}
.cw-root .emoji-upload-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-dim); }

/* ── Code Copy Button ── */
.cw-root .code-copy-btn {
  position: absolute; top: 4px; right: 4px;
  padding: 2px 8px; font-size: 11px; border-radius: var(--radius-sm, 4px);
  background: var(--bg-hover, #35373c); color: var(--text-muted, #999); border: 1px solid var(--border, #444);
  cursor: pointer; opacity: 0; transition: opacity 0.15s; z-index: 2;
}
.cw-root pre:hover .code-copy-btn { opacity: 1; }
.cw-root .code-copy-btn:hover { background: var(--bg-tertiary, #404249); color: var(--text-primary, #fff); }

/* ── Message Edit/Delete ── */
.cw-root .edit-btn, .cw-root .delete-btn, .cw-root .pin-btn { font-size: 13px !important; }
.cw-root .message-edited-tag { color: var(--text-muted, #999); font-size: 11px; margin-left: 4px; font-style: italic; }
.cw-root .message-pin-indicator { font-size: 12px; margin-right: 4px; }
.cw-root .read-receipt-indicator {
  font-size: 11px; color: var(--text-muted, #7a6b5c); padding: 2px 16px 2px 56px;
  text-align: right; opacity: 0.8;
}
.cw-root .message-edit-textarea {
  width: 100%; min-height: 36px; max-height: 200px; padding: 6px 8px;
  background: var(--bg-primary, #1e1f22); color: var(--text-primary, #fff);
  border: 1px solid var(--accent, #c47a3a); border-radius: var(--radius-sm, 4px);
  font-family: inherit; font-size: inherit; resize: vertical;
}
.cw-root .message-edit-hint {
  font-size: 11px; color: var(--text-muted, #999); margin-top: 2px;
}
.cw-root .delete-confirm-bar {
  display: flex; align-items: center; gap: 8px; padding: 6px 8px; margin-top: 4px;
  background: var(--bg-hover, #35373c); border-radius: var(--radius-sm, 4px);
  font-size: 12px; color: var(--text-secondary, #ccc);
}
.cw-root .delete-confirm-yes {
  padding: 2px 10px; font-size: 11px; border-radius: var(--radius-sm, 4px);
  background: var(--red, #ED4245); color: #fff; border: none; cursor: pointer;
}
.cw-root .delete-confirm-yes:hover { opacity: 0.85; }
.cw-root .delete-confirm-no {
  padding: 2px 10px; font-size: 11px; border-radius: var(--radius-sm, 4px);
  background: var(--bg-tertiary, #404249); color: var(--text-secondary, #ccc);
  border: 1px solid var(--border, #444); cursor: pointer;
}
.cw-root .delete-confirm-no:hover { background: var(--bg-hover, #35373c); }

/* ── @Mentions ── */

/* ── Share Cards ── */
.share-card { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius); margin-top: 6px; max-width: 360px; }
.share-card-thumb { width: 48px; height: 48px; border-radius: var(--radius-sm); object-fit: cover; flex-shrink: 0; }
.share-card-info { flex: 1; min-width: 0; }
.share-card-title { font-size: 13px; font-weight: 600; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.share-card-subtitle { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.share-card-action { padding: 6px 14px; background: var(--accent); color: var(--text-on-accent); border: none; border-radius: var(--radius-sm); font-size: 12px; font-weight: 600; cursor: pointer; flex-shrink: 0; transition: filter 0.12s; white-space: nowrap; }
.share-card-action:hover { filter: brightness(1.1); }
.share-card-rom { border-left: 3px solid #9b59b6; }
.share-card-track { border-left: 3px solid var(--yellow); }
.share-card-file { border-left: 3px solid var(--accent); }
.share-card-profile { border-left: 3px solid var(--green); }

/* ── Visualizer Window ── */
.viz-root { width: 100%; height: 100%; background: #000; position: relative; overflow: hidden; border-radius: var(--radius-md, 8px); }
.viz-canvas { width: 100%; height: 100%; display: block; }
.viz-overlay { position: absolute; top: var(--space-6, 16px); left: 0; right: 0; text-align: center; font-size: 14px; font-weight: 600; color: rgba(255,255,255,0.85); text-shadow: 0 1px 6px rgba(0,0,0,0.7); pointer-events: none; opacity: 0; transition: opacity 0.5s ease; }
.viz-overlay.visible { opacity: 1; }
.viz-controls { position: absolute; bottom: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: center; gap: var(--space-5, 12px); padding: var(--space-5, 12px); background: linear-gradient(transparent, rgba(0,0,0,0.75)); opacity: 0; transition: opacity 0.25s ease; }
.viz-root:hover .viz-controls { opacity: 1; }
.viz-ctrl-btn { background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius-sm, 6px); color: #fff; font-size: 14px; padding: 6px 12px; cursor: pointer; transition: background 0.12s, border-color 0.12s, transform 0.08s; }
.viz-ctrl-btn:hover { background: rgba(255,255,255,0.2); border-color: rgba(255,255,255,0.4); }
.viz-ctrl-btn:active { transform: scale(0.95); }
.viz-preset-name { color: rgba(255,255,255,0.7); font-size: 12px; max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center; }

/* styles/overlays.css — Shared component patterns (bc-*), library window, accessibility reduced-motion */
/* ══════════════════════════════════════════════════════════════════
   SHARED COMPONENT PATTERNS (Bean Chat Design System)
   Used by all window redesigns (D28+). Prefix: bc-
   ══════════════════════════════════════════════════════════════════ */

/* ── Card ── */
.bc-card {
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color var(--duration-base), background var(--duration-base);
}
.bc-card:hover { border-color: var(--border-strong); }
.bc-card-header { font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--text-primary); margin-bottom: var(--space-2); }
.bc-card-subtitle { font-size: var(--text-sm); color: var(--text-muted); line-height: var(--leading-normal); }
.bc-card-body { margin-top: var(--space-4); }
.bc-card-actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); }

/* ── Buttons ── */
.bc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  cursor: pointer;
  border: none;
  transition: filter var(--duration-fast), background var(--duration-fast);
  white-space: nowrap;
  user-select: none;
  line-height: 1;
}
.bc-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.bc-btn-primary { background: var(--accent); color: var(--text-on-accent); }
.bc-btn-primary:hover:not(:disabled) { filter: brightness(1.1); }
.bc-btn-secondary { background: var(--bg-secondary); border: 1px solid var(--border-strong); color: var(--text-primary); }
.bc-btn-secondary:hover:not(:disabled) { background: var(--bg-hover); }
.bc-btn-danger { background: var(--red-dim); color: var(--red); border: 1px solid transparent; }
.bc-btn-danger:hover:not(:disabled) { background: var(--red); color: var(--text-on-accent); }
.bc-btn-ghost { background: none; color: var(--text-muted); border: none; padding: var(--space-2) var(--space-3); }
.bc-btn-ghost:hover:not(:disabled) { color: var(--text-primary); background: var(--bg-hover); }
.bc-btn-sm { padding: var(--space-2) var(--space-4); font-size: var(--text-sm); }

/* ── Input ── */
.bc-input {
  padding: var(--space-3) var(--space-4);
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-base);
  font-family: var(--font);
  outline: none;
  transition: border-color var(--duration-base);
  width: 100%;
  box-sizing: border-box;
}
.bc-input:focus { border-color: var(--accent); }
.bc-input::placeholder { color: var(--text-muted); }

/* ── Select ── */
.bc-select {
  padding: var(--space-3) var(--space-8) var(--space-3) var(--space-4);
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-base);
  font-family: var(--font);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a6b5c' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
}
.bc-select:focus { border-color: var(--accent); outline: none; }

/* ── Badge ── */
.bc-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--text-2xs);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1;
}
.bc-badge-accent { background: var(--accent-dim); color: var(--accent); }
.bc-badge-green { background: var(--green-dim); color: var(--green); }
.bc-badge-red { background: var(--red-dim); color: var(--red); }
.bc-badge-yellow { background: var(--yellow-dim); color: var(--yellow); }
.bc-badge-muted { background: var(--bg-tertiary); color: var(--text-muted); }

/* ── List Item ── */
.bc-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  transition: background var(--duration-fast);
  cursor: default;
}
.bc-list-item:hover { background: var(--bg-hover); }
.bc-list-item + .bc-list-item { border-top: 1px solid var(--border); }

/* ── Section Header ── */
.bc-section-header {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  padding: var(--space-4) 0 var(--space-2);
}

/* ── Empty State ── */
.bc-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-16) var(--space-8);
  text-align: center;
  color: var(--text-muted);
}
.bc-empty-state-icon { font-size: var(--text-3xl); margin-bottom: var(--space-4); opacity: 0.4; }
.bc-empty-state-title { font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--text-secondary); margin-bottom: var(--space-2); }
.bc-empty-state-desc { font-size: var(--text-sm); line-height: var(--leading-relaxed); max-width: 300px; }

/* ── Divider ── */
.bc-divider { height: 1px; background: var(--border); margin: var(--space-4) 0; }

/* ── Virtual Scroll ── */
.bc-virtual-scroll-container {
  position: relative;
  overflow-y: auto;
  flex: 1;
}
.bc-virtual-scroll-container::-webkit-scrollbar { width: 6px; }
.bc-virtual-scroll-container::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }
.bc-virtual-scroll-container::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover); }

/* ── Library Window — Hierarchical Browser ── */

/* Root */
.lib-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background: var(--bg-primary);
  position: relative;
}

/* Header */
.lib-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 6px);
  padding: var(--space-4, 8px) var(--space-6, 12px);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.lib-header-top {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
}

/* Breadcrumb */
.lib-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-1, 2px);
  flex-shrink: 0;
  min-width: 0;
}
.lib-breadcrumb:empty { display: none; }
.lib-breadcrumb-item {
  font-size: var(--text-sm, 11px);
  color: var(--text-muted);
  padding: var(--space-1, 2px) var(--space-3, 6px);
  border-radius: var(--radius-sm, 4px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 180px;
}
.lib-breadcrumb-item.clickable {
  cursor: pointer;
  transition: color var(--duration-base, 0.12s), background var(--duration-base, 0.12s);
}
.lib-breadcrumb-item.clickable:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}
.lib-breadcrumb-item.current {
  color: var(--text-primary);
  font-weight: var(--weight-semibold, 600);
}
.lib-breadcrumb-sep {
  color: var(--text-muted);
  opacity: 0.5;
  flex-shrink: 0;
}
.lib-breadcrumb-sep svg { width: 12px; height: 12px; }

/* Search */
.lib-search {
  flex: 1;
  min-width: 100px;
  max-width: 220px;
  padding: var(--space-2, 4px) var(--space-5, 10px);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 4px);
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: var(--text-sm, 11px);
  outline: none;
  transition: border-color var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s);
}
.lib-search::placeholder { color: var(--text-muted); }
.lib-search:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(200, 160, 120, 0.15);
}

/* View toggle */
.lib-view-toggle {
  display: flex;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm, 4px);
  padding: var(--space-1, 2px);
  gap: 1px;
  flex-shrink: 0;
}
.lib-view-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 24px;
  border: none;
  border-radius: 3px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  transition: background var(--duration-base, 0.12s), color var(--duration-base, 0.12s);
}
.lib-view-btn svg { width: 14px; height: 14px; }
.lib-view-btn:hover { color: var(--text-primary); }
.lib-view-btn.active {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
}

/* Tabs */
.lib-tabs {
  display: flex;
  gap: var(--space-2, 4px);
}
.lib-tab {
  padding: var(--space-2, 4px) var(--space-5, 10px);
  border: 1px solid var(--border);
  border-radius: var(--radius-full, 12px);
  background: transparent;
  color: var(--text-muted);
  font-size: var(--text-xs, 10px);
  font-weight: var(--weight-semibold, 600);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s), color var(--duration-base, 0.12s), border-color var(--duration-base, 0.12s);
  white-space: nowrap;
}
.lib-tab:hover {
  background: var(--bg-hover);
  color: var(--text-secondary);
  border-color: var(--border-strong);
}
.lib-tab.active {
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  border-color: var(--accent);
}

/* Content */
.lib-content {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-6, 12px);
  min-height: 0;
}
.lib-content::-webkit-scrollbar { width: 6px; }
.lib-content::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }
.lib-content::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover); }

/* ── Card Grid ── */
.lib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-5, 10px);
}
.lib-grid.video-grid {
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

.lib-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s), border-color var(--duration-base, 0.12s);
}
.lib-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg, 0 8px 32px rgba(0, 0, 0, 0.6));
  border-color: var(--border-strong);
}

.lib-card-art {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}
.lib-card-art svg { width: 32px; height: 32px; }
.lib-card-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.lib-card:hover .lib-card-art img {
  transform: scale(1.03);
}
.lib-card-art.video {
  aspect-ratio: 16 / 9;
}

/* Card overlay */
.lib-card-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.2) 50%, transparent 100%);
  opacity: 0;
  transition: opacity var(--duration-base, 0.12s);
}
.lib-card:hover .lib-card-overlay { opacity: 1; }

.lib-card-play {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  transition: transform var(--duration-base, 0.12s), box-shadow var(--duration-base, 0.12s);
}
.lib-card-play svg { width: 18px; height: 18px; }
.lib-card-play:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
}
.lib-card-play:active { transform: scale(0.95); }

/* Card info */
.lib-card-info {
  padding: var(--space-4, 8px) var(--space-5, 10px);
}
.lib-card-title {
  font-size: var(--text-base, 13px);
  font-weight: var(--weight-semibold, 600);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3;
}
.lib-card-meta {
  font-size: var(--text-xs, 10px);
  color: var(--text-muted);
  margin-top: var(--space-1, 2px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── List View ── */
.lib-list {
  display: flex;
  flex-direction: column;
}
.lib-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
  padding: var(--space-3, 6px) var(--space-4, 8px);
  border-radius: var(--radius-sm, 4px);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s);
}
.lib-list-item:hover { background: var(--bg-hover); }
.lib-list-item:active { transform: scale(0.998); }

.lib-list-thumb {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm, 4px);
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  color: var(--text-muted);
}
.lib-list-thumb svg { width: 18px; height: 18px; }
.lib-list-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lib-list-name {
  flex: 1;
  min-width: 0;
  font-size: var(--text-base, 13px);
  font-weight: var(--weight-medium, 500);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lib-list-meta {
  font-size: var(--text-sm, 11px);
  color: var(--text-muted);
  flex-shrink: 0;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lib-list-counts {
  font-size: var(--text-xs, 10px);
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Album Detail ── */
.lib-album-detail {
  display: flex;
  flex-direction: column;
  gap: var(--space-6, 12px);
}
.lib-detail-header {
  display: flex;
  gap: var(--space-8, 16px);
  padding: var(--space-4, 8px) 0;
}
.lib-detail-art {
  width: 140px;
  height: 140px;
  border-radius: var(--radius, 8px);
  overflow: hidden;
  background: var(--bg-tertiary);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}
.lib-detail-art svg { width: 40px; height: 40px; }
.lib-detail-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lib-detail-info {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-2, 4px);
  min-width: 0;
}
.lib-detail-title {
  font-size: var(--text-xl, 18px);
  font-weight: var(--weight-bold, 700);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lib-detail-sub {
  font-size: var(--text-base, 13px);
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lib-detail-stats {
  font-size: var(--text-sm, 11px);
  color: var(--text-muted);
}
.lib-detail-play {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3, 6px);
  margin-top: var(--space-4, 8px);
  padding: var(--space-3, 6px) var(--space-6, 12px);
  border: none;
  border-radius: var(--radius-sm, 4px);
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  font-size: var(--text-sm, 11px);
  font-weight: var(--weight-semibold, 600);
  cursor: pointer;
  transition: filter var(--duration-base, 0.12s);
  width: fit-content;
}
.lib-detail-play svg { width: 14px; height: 14px; }
.lib-detail-play:hover { filter: brightness(1.1); }

/* ── Track Rows (album detail only) ── */
.lib-track-list {
  display: flex;
  flex-direction: column;
}
.lib-track {
  display: flex;
  align-items: center;
  gap: var(--space-4, 8px);
  padding: var(--space-3, 6px) var(--space-4, 8px);
  border-radius: var(--radius-sm, 4px);
  cursor: pointer;
  transition: background var(--duration-base, 0.12s);
}
.lib-track:hover { background: var(--bg-hover); }

.lib-track-num {
  width: 24px;
  text-align: right;
  font-size: var(--text-sm, 11px);
  color: var(--text-muted);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.lib-track-title {
  flex: 1;
  min-width: 0;
  font-size: var(--text-base, 13px);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lib-track-dur {
  font-size: var(--text-sm, 11px);
  color: var(--text-muted);
  flex-shrink: 0;
  min-width: 40px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.lib-track-play {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: var(--accent);
  color: var(--text-on-accent, #fff);
  cursor: pointer;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity var(--duration-base, 0.12s), transform var(--duration-base, 0.12s);
}
.lib-track-play svg { width: 12px; height: 12px; }
.lib-track:hover .lib-track-play { opacity: 1; }
.lib-track-play:hover { transform: scale(1.1); }

/* ── Now-Playing Toast (WO-D50) ── */
.np-toast {
  position: fixed;
  top: calc(var(--taskbar-height, 36px) + 12px);
  right: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md, 8px);
  box-shadow: var(--shadow-lg, 0 8px 32px rgba(0,0,0,0.6));
  z-index: 9999;
  transform: translateX(calc(100% + 20px));
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  max-width: 320px;
  pointer-events: none;
}
.np-toast.visible {
  transform: translateX(0);
}

.np-toast-art {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm, 4px);
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  font-size: 20px;
  line-height: 1;
}
.np-toast-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.np-toast-info {
  min-width: 0;
  flex: 1;
}

.np-toast-label {
  font-size: var(--text-2xs, 9px);
  font-weight: var(--weight-semibold, 600);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 3px;
}

.np-toast-title {
  font-size: var(--text-sm, 11px);
  font-weight: var(--weight-semibold, 600);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: var(--leading-tight, 1.2);
}

.np-toast-artist {
  font-size: var(--text-2xs, 9px);
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: var(--leading-tight, 1.2);
  margin-top: 1px;
}

/* ── Accessibility: prefers-reduced-motion ── */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* styles/simple-mode.css — Simple mode overrides, update modal */
/* ── Simple Mode ── */

/* Hide title bars */
.bean-desktop.simple-mode .window-titlebar {
  display: none;
}

/* Maximized windows fill full desktop area */
.bean-desktop.simple-mode .window.maximized {
  border-radius: 0;
  border: none;
  box-shadow: none;
}

/* Smooth crossfade on window switch */
.bean-desktop.simple-mode .window {
  transition: opacity 250ms ease;
}

.bean-desktop.simple-mode .window.minimized {
  opacity: 0;
  pointer-events: none;
}

.bean-desktop.simple-mode .window:not(.minimized) {
  opacity: 1;
}

/* Voice window floats as PiP overlay */
.bean-desktop.simple-mode .window[data-type="voice"] {
  position: fixed !important;
  bottom: 44px;
  right: 16px;
  width: 200px !important;
  height: auto !important;
  max-height: 300px;
  z-index: 9000;
  border-radius: 8px !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.4) !important;
  opacity: 0.95;
}

.bean-desktop.simple-mode .window[data-type="voice"] .window-titlebar {
  display: flex;
  padding: 2px 6px;
  min-height: 0;
  height: 20px;
}

/* Split mode panes */
.bean-desktop.simple-mode.simple-split .window:not(.minimized):not([data-type="voice"]) {
  border-radius: 0;
  border: none;
  box-shadow: none;
  opacity: 1;
}

/* Taskbar active indicators in simple mode */
.bean-desktop.simple-mode .tb-launcher.active-primary {
  background: rgba(var(--accent-rgb, 88,101,242), 0.15);
  border-bottom: 2px solid var(--accent);
}

.bean-desktop.simple-mode .tb-launcher.active-secondary {
  background: rgba(var(--accent-rgb, 88,101,242), 0.1);
  border-bottom: 2px solid var(--border);
  opacity: 0.85;
}

/* Hide layout presets in simple mode */
.bean-desktop.simple-mode .tb-profiles-container,
.bean-desktop.simple-mode .tb-save-layout {
  display: none;
}

/* ── Update Modal ── */
.update-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(6px);
}
.update-modal {
  background: var(--bg-secondary, #1e1e2e);
  border: 1px solid var(--border, #333);
  border-radius: 16px;
  padding: 40px 48px;
  max-width: 460px;
  text-align: center;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}
.update-modal-icon {
  font-size: 48px;
  margin-bottom: 8px;
}
.update-modal-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary, #e0e0e0);
  margin: 0 0 12px;
}
.update-modal-body {
  font-size: 14px;
  color: var(--text-secondary, #aaa);
  line-height: 1.5;
  margin: 0 0 24px;
}
.update-modal-body strong {
  color: var(--text-primary, #e0e0e0);
}
/* One-click update button */
.update-modal-update-btn {
  display: block;
  width: 100%;
  background: var(--accent, #7c5cbf);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  padding: 14px 24px;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: filter 0.15s, transform 0.1s;
  margin-bottom: 8px;
}
.update-modal-update-btn:hover { filter: brightness(1.15); }
.update-modal-update-btn:active { transform: scale(0.98); }

.update-modal-detected {
  font-size: 12px;
  color: var(--text-tertiary, #777);
  margin-bottom: 20px;
}

.update-modal-immutable-note {
  background: rgba(255, 200, 50, 0.1);
  border: 1px solid rgba(255, 200, 50, 0.25);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 12px;
  color: #ddb347;
  line-height: 1.5;
  margin-bottom: 16px;
  text-align: left;
}

/* Spinner */
.update-modal-spinner {
  width: 48px;
  height: 48px;
  border: 4px solid var(--bg-tertiary, #2a2a3e);
  border-top-color: var(--accent, #7c5cbf);
  border-radius: 50%;
  margin: 0 auto 16px;
  animation: update-spin 0.8s linear infinite;
}
@keyframes update-spin {
  to { transform: rotate(360deg); }
}

/* Format picker */
.update-modal-pick-label {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-tertiary, #777);
  margin-bottom: 10px;
}
.update-modal-links {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 24px;
}
.update-modal-format-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--accent, #7c5cbf);
  color: #fff;
  border: none;
  font-size: 14px;
  font-weight: 600;
  padding: 12px 20px;
  border-radius: 8px;
  cursor: pointer;
  transition: filter 0.15s, transform 0.1s;
}
.update-modal-format-btn:hover {
  filter: brightness(1.15);
}
.update-modal-format-btn:active {
  transform: scale(0.98);
}
.update-modal-format-label {
  font-size: 15px;
}
.update-modal-format-distro {
  font-size: 12px;
  opacity: 0.75;
  font-weight: 400;
}

/* Progress bar */
.update-modal-progress-wrap {
  margin-bottom: 24px;
}
.update-modal-progress-bar {
  height: 8px;
  background: var(--bg-tertiary, #2a2a3e);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 8px;
}
.update-modal-progress-fill {
  height: 100%;
  background: var(--accent, #7c5cbf);
  border-radius: 4px;
  transition: width 0.2s ease;
}
.update-modal-progress-text {
  font-size: 12px;
  color: var(--text-tertiary, #777);
}

/* File info after download */
.update-modal-file-info {
  display: flex;
  flex-wrap: wrap;
  background: var(--bg-tertiary, #2a2a3e);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 16px;
  text-align: left;
}
.update-modal-copy-input {
  flex: 1;
  background: var(--bg-primary, #16161e);
  border: 1px solid var(--border, #333);
  color: var(--text-primary, #e0e0e0);
  font-size: 11px;
  font-family: monospace;
  padding: 8px 10px;
  border-radius: 6px 0 0 6px;
  outline: none;
  min-width: 0;
}
.update-modal-copy-btn {
  background: var(--accent, #7c5cbf);
  color: #fff;
  border: none;
  font-size: 12px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 0 6px 6px 0;
  cursor: pointer;
  white-space: nowrap;
  transition: filter 0.15s;
}
.update-modal-copy-btn:hover { filter: brightness(1.15); }
.update-modal-file-name {
  width: 100%;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #e0e0e0);
  word-break: break-all;
}
.update-modal-file-path {
  width: 100%;
  font-size: 11px;
  color: var(--text-tertiary, #777);
  margin-top: 4px;
  word-break: break-all;
}

/* Post-download instructions */
.update-modal-steps {
  background: var(--bg-tertiary, #2a2a3e);
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 16px;
  text-align: left;
}
.update-modal-steps-title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-tertiary, #777);
  margin-bottom: 10px;
}
.update-modal-step-list {
  margin: 0;
  padding-left: 20px;
  font-size: 13px;
  color: var(--text-secondary, #aaa);
  line-height: 1.8;
}
.update-modal-step-list li {
  margin-bottom: 2px;
}
.update-modal-step-list code {
  display: inline-block;
  background: var(--bg-primary, #16161e);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 12px;
  color: var(--text-primary, #e0e0e0);
  word-break: break-all;
}
.update-modal-note {
  font-size: 12px;
  color: var(--accent, #7c5cbf);
  font-weight: 500;
  margin: 0 0 20px;
}
.update-modal-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.update-modal-back {
  background: none;
  border: none;
  color: var(--text-tertiary, #777);
  font-size: 12px;
  cursor: pointer;
  padding: 6px 12px;
  text-decoration: underline;
  transition: color 0.15s;
}
.update-modal-back:hover {
  color: var(--text-secondary, #aaa);
}
.update-modal-dismiss {
  background: none;
  border: none;
  color: var(--text-tertiary, #777);
  font-size: 13px;
  cursor: pointer;
  padding: 8px 16px;
  transition: color 0.15s;
}
.update-modal-dismiss:hover {
  color: var(--text-secondary, #aaa);
}
.update-modal-dismiss-hint {
  font-size: 11px;
  color: var(--text-tertiary, #666);
  margin: 4px 0 0;
}
