/*
 * ══════════════════════════════════════════════════════════════════════════════
 * TOKEN REFERENCE — agents-ui design system
 * ══════════════════════════════════════════════════════════════════════════════
 *
 * All colors in this stylesheet flow through CSS custom properties.
 * Literal color values (hex, rgba, hsl) are ONLY allowed inside :root and
 * theme override blocks ([data-theme="light/dark"], @media prefers-color-scheme).
 *
 * TOKEN GROUPS (defined in :root below)
 * ──────────────────────────────────────
 * Base palette
 *   --bg, --bg2..4            Dark surface backgrounds (opacity tiers)
 *   --text, --text-dim        Primary and muted text
 *   --border                  Default 1px border
 *   --glass-bg, --glass-blur  Frosted glass effect
 *
 * Accent (cyan #4fc3f7 dark / #0062a3 light)
 *   --accent, --accent2       Primary and secondary accent
 *   --accent-hover            Hover state
 *   --accent-3 to --accent-85 Opacity tints (3%-85%)
 *
 * Semantic states
 *   --success  Green: ok, connected, done
 *   --warning  Amber: caution, review
 *   --danger   Red:   error, delete, alert
 *   Each has opacity tints: --success-4..50, --warning-4..50, --danger-0..50
 *
 * Extended palette
 *   --violet (#a78bfa)   Evaluating / override states  → --violet-6..45
 *   --indigo (#818cf8)   Task-type badges              → --indigo-10..15
 *   --emerald (#10b981)  Plan start / progress         → --emerald-7..40
 *   --amber (#fbbf24)    System events                 → --amber-7..30
 *   --orange (#ffb74d)   Owner badges                  → --orange-15
 *   --green (#22c55e)    Approve / confirm             → --green-12..35
 *   --blue (#3b82f6)     In-progress plans             → --blue-6..18
 *   --red (#ef4444)      Alt danger tone               → --red-8..90
 *
 * Surfaces   --surface-topbar/panel/input/heavy/mobile-sidebar/nav/dropdown/popup
 * Overlays   --white-2/12/20  |  --black-12..75
 * Shadows    --shadow-float/card/popup/side/bottom
 * Text vars  --text-em/white/black/code/ok/err
 *
 * Theme overrides (at bottom of file)
 *   [data-theme="light"]               Explicit light palette
 *   [data-theme="dark"]                Explicit dark palette
 *   @media (prefers-color-scheme:light) Auto light (html without data-theme)
 * ══════════════════════════════════════════════════════════════════════════════
 */

/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
  /* ── Layout & sizing ──────────────────────────────────────────────────────── */
  --topbar-h:    48px;
  --sidebar-w:   240px;
  --panel-w:     300px;
  --nav-h:       64px;
  --radius:      16px;
  --radius-sm:   12px;
  --radius-pill: 24px;
  --glass-blur:  20px;
  --ease:        cubic-bezier(0.25, 0.46, 0.45, 0.94);

  /* ── Base backgrounds ─────────────────────────────────────────────────────── */
  --bg:         #0a0f14;
  --bg2:        rgba(255,255,255,0.03);
  --bg3:        rgba(255,255,255,0.06);
  --bg4:        rgba(255,255,255,0.10);
  --sidebar-bg: #0d1218;
  --chat-bg:    rgba(255,255,255,0.05);
  --btn-bg:     rgba(255,255,255,0.06);
  --btn-hover:  rgba(255,255,255,0.10);
  --code-bg:    rgba(0,0,0,0.35);
  --glass-bg:   rgba(255,255,255,0.04);

  /* ── Text ─────────────────────────────────────────────────────────────────── */
  --text:       #e8eaf0;
  --text-dim:   #7a8a9a;
  --text-muted: rgba(122,138,154,0.5);
  --text-em:    #c8d8f0;
  --text-white: #fff;
  --text-black: #000;
  --text-code:  #a8e6cf;
  --text-ok:    #56d364;
  --text-err:   #f85149;

  /* ── On-color text (text when bg is a semantic color) ────────────────────── */
  --on-accent:  #fff;
  --on-danger:  #fff;
  --on-success: #fff;

  /* ── Border ───────────────────────────────────────────────────────────────── */
  --border:     rgba(255,255,255,0.07);

  /* ── Semantic base colors ─────────────────────────────────────────────────── */
  --accent:       #4fc3f7;
  --accent2:      #0288d1;
  --accent-hover: #81d4fa;
  --success:      #66bb6a;
  --warning:      #ffa726;
  --danger:       #ef5350;

  /* ── Shadows ──────────────────────────────────────────────────────────────── */
  --shadow-float:  0 4px 24px rgba(0,0,0,0.5);
  --shadow-card:   0 1px 8px rgba(0,0,0,0.3);
  --shadow-popup:  0 8px 32px rgba(0,0,0,0.60);
  --shadow-side:  -4px 0 24px rgba(0,0,0,0.25);
  --shadow-bottom: 0 -4px 24px rgba(0,0,0,0.60);

  /* ── Surfaces (semi-transparent panels; overridden in light theme) ────────── */
  --surface-topbar:         rgba(10,15,20,0.8);
  --surface-panel:          rgba(10,15,20,0.9);
  --surface-input:          rgba(10,15,20,0.6);
  --surface-heavy:          rgba(10,15,20,0.97);
  --surface-mobile-sidebar: rgba(10,15,20,0.95);
  --surface-nav:            rgba(10,15,20,0.85);
  --surface-dropdown:       #0d1520;
  --surface-popup:          #0d1520;
  --bg-blur:                rgba(10,15,20,0.80);
  --bg-sheet-60:            rgba(10,15,20,0.60);
  --bg-sheet-85:            rgba(10,15,20,0.85);
  --bg-sheet-90:            rgba(10,15,20,0.90);
  --bg-sheet-95:            rgba(10,15,20,0.95);
  --bg-sheet-97:            rgba(10,15,20,0.97);

  /* ── White tints ──────────────────────────────────────────────────────────── */
  --white-2:   rgba(255,255,255,0.02);
  --white-12:  rgba(255,255,255,0.12);
  --white-20:  rgba(255,255,255,0.20);

  /* ── Black overlays ───────────────────────────────────────────────────────── */
  --black-12:  rgba(0,0,0,0.12);
  --black-15:  rgba(0,0,0,0.15);
  --black-20:  rgba(0,0,0,0.20);
  --black-25:  rgba(0,0,0,0.25);
  --black-35:  rgba(0,0,0,0.35);
  --black-40:  rgba(0,0,0,0.40);
  --black-45:  rgba(0,0,0,0.45);
  --black-50:  rgba(0,0,0,0.50);
  --black-55:  rgba(0,0,0,0.55);
  --black-60:  rgba(0,0,0,0.60);
  --black-75:  rgba(0,0,0,0.75);

  /* ── Accent tints ─────────────────────────────────────────────────────────── */
  --accent-3:   rgba(79,195,247,0.03);
  --accent-4:   rgba(79,195,247,0.04);
  --accent-5:   rgba(79,195,247,0.05);
  --accent-6:   rgba(79,195,247,0.06);
  --accent-7:   rgba(79,195,247,0.07);
  --accent-8:   rgba(79,195,247,0.08);
  --accent-9:   rgba(79,195,247,0.09);
  --accent-10:  rgba(79,195,247,0.10);
  --accent-12:  rgba(79,195,247,0.12);
  --accent-13:  rgba(79,195,247,0.13);
  --accent-14:  rgba(79,195,247,0.14);
  --accent-15:  rgba(79,195,247,0.15);
  --accent-18:  rgba(79,195,247,0.18);
  --accent-20:  rgba(79,195,247,0.20);
  --accent-22:  rgba(79,195,247,0.22);
  --accent-25:  rgba(79,195,247,0.25);
  --accent-30:  rgba(79,195,247,0.30);
  --accent-35:  rgba(79,195,247,0.35);
  --accent-40:  rgba(79,195,247,0.40);
  --accent-45:  rgba(79,195,247,0.45);
  --accent-50:  rgba(79,195,247,0.50);
  --accent-85:  rgba(79,195,247,0.85);
  --accent2-7:  rgba(2,136,209,0.07);
  --accent2-13: rgba(2,136,209,0.13);
  /* ── Success tints ────────────────────────────────────────────────────────── */
  --success-4:   rgba(102,187,106,0.04);
  --success-6:   rgba(102,187,106,0.06);
  --success-8:   rgba(102,187,106,0.08);
  --success-10:  rgba(102,187,106,0.10);
  --success-12:  rgba(102,187,106,0.12);
  --success-15:  rgba(102,187,106,0.15);
  --success-18:  rgba(102,187,106,0.18);
  --success-25:  rgba(102,187,106,0.25);
  --success-30:  rgba(102,187,106,0.30);
  --success-35:  rgba(102,187,106,0.35);
  --success-50:  rgba(102,187,106,0.50);
  --success-55:  rgba(102,187,106,0.55);
  --success-40:  rgba(102,187,106,0.40);

  /* ── Warning tints ────────────────────────────────────────────────────────── */
  --warning-4:   rgba(255,167,38,0.04);
  --warning-8:   rgba(255,167,38,0.08);
  --warning-15:  rgba(255,167,38,0.15);
  --warning-20:  rgba(255,167,38,0.20);
  --warning-25:  rgba(255,167,38,0.25);
  --warning-40:  rgba(255,167,38,0.40);
  --warning-50:  rgba(255,167,38,0.50);
  /* ── danger tints ─────────────────────────────────────────────── */
  --danger-0:    rgba(239,83,80,0);
  --danger-8:    rgba(239,83,80,0.08);
  --danger-10:   rgba(239,83,80,0.10);
  --danger-15:   rgba(239,83,80,0.15);
  --danger-40:   rgba(239,83,80,0.40);
  --danger-12:   rgba(239,83,80,0.12);
  --danger-20:   rgba(239,83,80,0.20);
  --danger-50:   rgba(239,83,80,0.50);

  /* ── Violet (evaluating / override states) ────────────────────────────────── */
  --violet:      #a78bfa;
  --violet-6:    rgba(167,139,250,0.06);
  --violet-8:    rgba(167,139,250,0.08);
  --violet-10:   rgba(167,139,250,0.10);
  --violet-12:   rgba(167,139,250,0.12);
  --violet-15:   rgba(167,139,250,0.15);
  --violet-18:   rgba(167,139,250,0.18);
  --violet-20:   rgba(167,139,250,0.20);
  --violet-22:   rgba(167,139,250,0.22);
  --violet-30:   rgba(167,139,250,0.30);
  --violet-35:   rgba(167,139,250,0.35);
  --violet-7:    rgba(167,139,250,0.07);
  --violet-40:   rgba(167,139,250,0.40);
  --violet-45:   rgba(167,139,250,0.45);

  /* ── Indigo (task-type badges) ────────────────────────────────────────────── */
  --indigo:      #818cf8;
  --indigo-10:   rgba(99,102,241,0.10);
  --indigo-15:   rgba(99,102,241,0.15);

  /* ── Emerald (plan start / progress) ─────────────────────────────────────── */
  --emerald:       #10b981;
  --emerald-green: #34d399;
  --emerald-7:   rgba(16,185,129,0.07);
  --emerald-14:  rgba(16,185,129,0.14);
  --emerald-15:  rgba(16,185,129,0.15);
  --emerald-22:  rgba(16,185,129,0.22);
  --emerald-28:  rgba(16,185,129,0.28);
  --emerald-40:  rgba(16,185,129,0.40);

  /* ── Amber (system events) ────────────────────────────────────────────────── */
  --amber:        #fbbf24;
  --amber-alt:    #f59e0b;
  --amber-7:     rgba(251,191,36,0.07);
  --amber-12:    rgba(251,191,36,0.12);
  --amber-20:    rgba(251,191,36,0.20);
  --amber-22:    rgba(251,191,36,0.22);
  --amber-30:    rgba(251,191,36,0.30);
  --amber-alt-12: rgba(245,158,11,0.12);
  --amber-alt-30: rgba(245,158,11,0.30);
  /* ── orange (owner badge) ─────────────────────────────────────── */
  --orange:      #ffb74d;
  --orange-15:   rgba(255,183,77,0.15);

  /* ── Green (approve / confirm) ────────────────────────────────────────────── */
  --green:       #22c55e;
  --green-12:    rgba(34,197,94,0.12);
  --green-15:    rgba(34,197,94,0.15);
  --green-30:    rgba(34,197,94,0.30);
  --green-35:    rgba(34,197,94,0.35);

  /* ── Blue (in-progress plans) ─────────────────────────────────────────────── */
  --blue:        #3b82f6;
  --blue-6:      rgba(59,130,246,0.06);
  --blue-10:     rgba(59,130,246,0.10);
  --blue-18:     rgba(59,130,246,0.18);

  /* ── Red (alt danger tone) ────────────────────────────────────────────────── */
  --red:         #ef4444;
  --red-8:       rgba(239,68,68,0.08);
  --red-25:      rgba(239,68,68,0.25);
  --red-40:      rgba(239,68,68,0.40);
  --red-50:      rgba(239,68,68,0.50);
  --red-60:      rgba(239,68,68,0.60);
  --red-85:      rgba(239,68,68,0.85);
  --red-90:      rgba(239,68,68,0.90);

  /* ── Gray tints ───────────────────────────────────────────────────────────── */
  --gray-10:     rgba(122,138,154,0.10);
  --gray-20:     rgba(122,138,154,0.20);

  /* ── Toast ────────────────────────────────────────────────────────────────── */
  --toast-bg:    rgba(30,40,55,0.95);
  --toast-text:  #fff;

  /* ── Glow / magic layer ───────────────────────────────────────────────────── */
  --glow:         0 0 18px rgba(79,195,247,0.22);
  --glow-sm:      0 0 10px rgba(79,195,247,0.14);
  --glow-violet:  0 0 14px rgba(167,139,250,0.18);
  --accent-soft:  rgba(79,195,247,0.07);
  --ambient:      radial-gradient(ellipse 90% 40% at 50% 0%, rgba(79,195,247,0.04) 0%, transparent 70%);

  /* ── Light-mode element tokens (used only under [data-theme="light"]) ─────── */
  --light-bubble-bg:    rgba(255,255,255,0.72);
  --light-border-soft:  rgba(0,0,0,0.07);
  --light-code-bg:      rgba(0,0,0,0.07);
  --light-pre-bg:       rgba(0,0,0,0.06);
  --light-tool-bg:      rgba(0,0,0,0.04);
  --light-form-bg:      rgba(0,0,0,0.04);
  --light-modal-shadow: rgba(0,0,0,0.12);
  --light-scroll-thumb: rgba(0,0,0,0.15);
  --light-scroll-hover: rgba(0,0,0,0.25);
  --light-slate-900:    #0f172a;
  --light-slate-800:    #1e293b;
  --light-slate-700:    #334155;
  --light-slate-500:    #475569;
  --light-border-tool:  rgba(0,0,0,0.08);
}
/*
 * ══════════════════════════════════════════════════════════════════════════════
 * WCAG AA CONTRAST AUDIT — ratios verified against solid effective backgrounds.
 * Min: 4.5:1 normal text · 3:1 large/UI. All values rounded to 1 decimal.
 *
 * ── DARK MODE  (bg #0a0f14 L=0.005 · sidebar/modal bg #0d1218 L=0.004) ──────
 * Area                  Token (resolved hex)              Background       Ratio  Pass
 * Login label/input     --text     #e8eaf0                #0a0f14         17.1:1  AAA
 * Login hint            --text-dim #7a8a9a                #0a0f14          5.5:1  AA ✓
 * Login accent title    --accent   #4fc3f7                #0a0f14          9.6:1  AAA
 * Chat bubble text      --text     #e8eaf0                ~#0c1219        16.8:1  AAA
 * Chat links            --accent   #4fc3f7                ~#0c1219         9.4:1  AAA
 * Chat code text        --text-code #a8e6cf               code-bg~#07090b 12.3:1  AAA
 * Chat timestamps       --text-dim #7a8a9a                #0a0f14          5.5:1  AA ✓
 * Sidebar names         --text     #e8eaf0                #0d1218         17.4:1  AAA
 * Sidebar dim text      --text-dim #7a8a9a                #0d1218          5.6:1  AA ✓
 * Settings body text    --text     #e8eaf0                panel ~#0a0f14  17.1:1  AAA
 * Settings ok badge     --text-ok  #56d364                #0a0f14          9.9:1  AAA
 * Settings err badge    --text-err #f85149                #0a0f14          5.7:1  AA ✓
 * Crons success label   --success  #66bb6a                #0a0f14          8.2:1  AAA
 * Crons danger label    --danger   #ef5350                #0a0f14          5.5:1  AA ✓
 * Usage dim labels      --text-dim #7a8a9a                panel ~#0a0f14   5.5:1  AA ✓
 * Modal header/body     --text     #e8eaf0                #0d1218         17.4:1  AAA
 * Modal error text      --danger   #ef5350                #0d1218          5.6:1  AA ✓
 * Modal success text    --success  #66bb6a                #0d1218          8.3:1  AAA
 * Btn text on accent    --bg       #0a0f14                #4fc3f7          9.6:1  AAA
 *
 * ── LIGHT MODE  (bg #f0f4f8 L=0.904 · sidebar/modal bg #edf2f8 L=0.884) ─────
 * Area                  Token (resolved hex)              Background       Ratio  Pass
 * Login label/input     --text     #1a2536                #f0f4f8         13.5:1  AAA
 * Login hint            --text-dim #5a6e85                #f0f4f8          4.8:1  AA ✓
 * Login accent title    --accent   #0062a3                #f0f4f8          5.8:1  AA ✓
 * Chat bubble text      --text     #1a2536                ~#ddeef8        12.5:1  AAA
 * Chat links            --accent   #0062a3                ~#ddeef8         5.4:1  AA ✓
 * Chat code text        --text-code #1a5e32               code-bg~#e3e8ee  6.3:1  AA ✓
 * Chat timestamps       --text-dim #5a6e85                #f0f4f8          4.8:1  AA ✓
 * Sidebar names         --text     #1a2536                #edf2f8         13.2:1  AAA
 * Sidebar dim text      --text-dim #5a6e85                #edf2f8          4.6:1  AA ✓
 * Settings body text    --text     #1a2536                panel ~#f8fafc  14.1:1  AAA
 * Settings ok badge     --text-ok  #2e7d32 (=success)     #f0f4f8          4.6:1  AA ✓
 * Settings err badge    --text-err #c62828 (=danger)       #f0f4f8          5.1:1  AA ✓
 * Crons success label   --success  #2e7d32                #f0f4f8          4.6:1  AA ✓
 * Crons danger label    --danger   #c62828                #f0f4f8          5.1:1  AA ✓
 * Usage dim labels      --text-dim #5a6e85                panel ~#f8fafc   5.0:1  AA ✓
 * Modal header/body     --text     #1a2536                #edf2f8         13.2:1  AAA
 * Modal error text      --danger   #c62828                #edf2f8          5.0:1  AA ✓
 * Modal success text    --success  #2e7d32                #edf2f8          4.5:1  AA ✓
 * Btn text on accent    --bg       #f0f4f8                #0062a3          5.8:1  AA ✓
 * ══════════════════════════════════════════════════════════════════════════════
 */
/* ── Reset ─────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  font-size: 14px;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

button { cursor: pointer; border: none; background: none; color: inherit; font: inherit; touch-action: manipulation; }
textarea, input { font: inherit; color: inherit; background: none; border: none; outline: none; }
a { color: inherit; text-decoration: none; }

/* ── Login ─────────────────────────────────────────────────────────────────── */
#login-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg);
}

.login-box {
  width: min(360px, 90vw);
  padding: 40px 32px;
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-align: center;
  box-shadow: var(--shadow-float);
}

.login-logo { font-size: 40px; margin-bottom: 12px; color: var(--accent); display: flex; justify-content: center; }
.login-title { font-size: 22px; font-weight: 600; color: var(--accent); }
.login-sub { color: var(--text-dim); font-size: 13px; margin: 4px 0 24px; }

#login-form input {
  width: 100%; padding: 12px 16px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 15px;
  margin-bottom: 12px;
  transition: border-color 0.2s var(--ease);
}
#login-form input:focus { border-color: var(--accent-50); }

#login-form button {
  width: 100%; padding: 13px;
  background: var(--accent); color: var(--bg);
  border-radius: var(--radius-sm); font-size: 15px; font-weight: 600;
  transition: background 0.2s var(--ease);
}
#login-form button:hover { background: var(--accent-hover); }
#login-form button:active { background: var(--accent2); transform: scale(0.98); }
#login-form button:disabled { background: var(--bg3); color: var(--text-dim); cursor: default; }

.login-error { color: var(--danger); font-size: 13px; margin-top: 10px; min-height: 20px; }

/* ── App shell ─────────────────────────────────────────────────────────────── */
#app {
  position: fixed; inset: 0;
  display: flex; flex-direction: column;
  padding-top: var(--topbar-h);
  padding-bottom: 0;
  background: var(--bg);
}

/* ── Topbar ────────────────────────────────────────────────────────────────── */
#topbar {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--topbar-h);
  background: var(--surface-topbar);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px;
  padding: 0 12px;
  z-index: 100;
}

.thread-title {
  flex: 1; font-weight: 500; font-size: 15px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.topbar-actions { display: flex; gap: 4px; align-items: center; }

.model-picker { position: relative; flex-shrink: 0; }

.model-picker-trigger {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px 4px 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  font-size: 12px; font-weight: 500;
  color: var(--text-dim); cursor: pointer;
  transition: border-color 0.2s var(--ease), color 0.2s var(--ease);
}
.model-picker-trigger:hover { border-color: var(--accent-40); color: var(--text); }
.model-picker-trigger .lucide { width: 13px; height: 13px; }

.model-picker-dropdown {
  position: absolute; top: calc(100% + 6px); right: 0;
  min-width: 190px;
  background: var(--surface-dropdown); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-popup);
  padding: 4px; z-index: 200;
  opacity: 0; transform: translateY(-4px); pointer-events: none;
  transition: opacity 0.15s var(--ease), transform 0.15s var(--ease);
}
.model-picker.open .model-picker-dropdown {
  opacity: 1; transform: translateY(0); pointer-events: auto;
}

.model-picker-option {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.12s var(--ease);
}
.model-picker-option:hover { background: var(--border); }
.model-picker-option.active { background: var(--accent-12); }
.model-picker-option .lucide { width: 15px; height: 15px; color: var(--accent); flex-shrink: 0; }

.model-picker-option-text { display: flex; flex-direction: column; gap: 1px; }
.model-picker-option-label { font-size: 13px; font-weight: 500; color: var(--text); }
.model-picker-option-sub { font-size: 11px; color: var(--text-dim); }

/* Lucide SVG global sizing */
.lucide {
  width: 1em; height: 1em;
  vertical-align: middle;
  flex-shrink: 0;
}

.icon-btn {
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  transition: background 0.2s var(--ease);
  flex-shrink: 0;
}
.icon-btn:hover { background: var(--bg3); }
.icon-btn:active { background: var(--bg4); }

.ws-dot {
  width: 7px; height: 7px; border-radius: 50%;
  display: inline-block; flex-shrink: 0;
}
.ws-dot.connected    { background: var(--success); box-shadow: 0 0 6px var(--success-50); }
.ws-dot.connecting   { background: var(--warning); animation: pulse 1s infinite; }
.ws-dot.disconnected { background: var(--danger); }
.icon-btn.active { background: var(--bg3); color: var(--accent); }
.icon-btn.danger:hover { background: var(--danger-15); color: var(--danger); }

/* ── Main layout ───────────────────────────────────────────────────────────── */
#main {
  flex: 1; display: flex; overflow: hidden;
  height: calc(100vh - var(--topbar-h));
}

/* ── Sidebar ───────────────────────────────────────────────────────────────── */
#sidebar {
  width: var(--sidebar-w);
  background: var(--bg2);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  flex-shrink: 0; overflow: hidden;
  transition: width 0.2s var(--ease);
}
#sidebar.collapsed { width: 0; }

#sidebar-header {
  display: none;
  align-items: center; gap: 4px;
  padding: 12px 12px 8px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
#sidebar-header .sidebar-title { flex: 1; }
.sidebar-title { font-size: 12px; font-weight: 600; color: var(--text-dim); letter-spacing: .06em; text-transform: uppercase; }

#thread-search-bar {
  display: flex; align-items: center; gap: 6px;
  margin: 10px 10px 6px;
  padding: 8px 12px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  flex-shrink: 0;
  transition: border-color 0.2s var(--ease);
}
#thread-search-bar:focus-within {
  border-color: var(--accent-40);
}
#thread-search-icon {
  width: 13px; height: 13px;
  color: var(--text-dim); flex-shrink: 0;
  pointer-events: none;
}
#thread-search-input {
  flex: 1; font-size: 13px;
  background: none; border: none; outline: none;
  color: var(--text);
  min-width: 0;
}
#thread-search-input::placeholder { color: var(--text-dim); }
#thread-search-clear {
  display: none;
  width: 16px; height: 16px;
  align-items: center; justify-content: center;
  color: var(--text-dim); border-radius: 50%;
  flex-shrink: 0; padding: 0;
}
#thread-search-clear:hover { color: var(--text); }
#thread-search-clear.visible { display: flex; }
#thread-search-clear svg { width: 12px; height: 12px; }

.thread-highlight {
  background: var(--accent-20);
  border-radius: 3px;
  color: var(--text);
}

/* ── Sidebar filter button ───────────────────────────────────────────────── */
.sidebar-filter-btn {
  width: 20px; height: 20px; border-radius: 4px;
  color: var(--text-dim); background: transparent;
  border: none; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.15s; flex-shrink: 0; padding: 0;
}
.sidebar-filter-btn:hover { color: var(--text); }
.sidebar-filter-btn.filter-active { color: var(--accent); }
.sidebar-filter-btn svg, .sidebar-filter-btn i { width: 13px; height: 13px; }

/* ── Sidebar filter panel ────────────────────────────────────────────────── */
#sidebar-filter-panel {
  display: none; flex-direction: column; gap: 4px;
  padding: 8px 10px; border-bottom: 1px solid var(--border);
  background: var(--bg2);
}
#sidebar-filter-panel.open { display: flex; }
.sfilter-row { display: flex; gap: 4px; }
.sfilter-sep { height: 1px; background: var(--border); margin: 2px 0; }
.sfilter-type, .sfilter-status {
  flex: 1; font-size: 11px; font-weight: 500; padding: 4px 0;
  border-radius: 5px; border: 1px solid transparent;
  color: var(--text-dim); background: transparent;
  cursor: pointer; transition: all 0.12s;
}
.sfilter-type:hover, .sfilter-status:hover { color: var(--text); background: var(--bg3); }
.sfilter-type.active, .sfilter-status.active {
  color: var(--text); background: var(--bg3); border-color: var(--border);
}

/* Type pill shown when searching */
.thread-type-pill {
  display: inline-block; font-size: 9px; font-weight: 600;
  padding: 1px 5px; border-radius: 8px; margin-left: 5px;
  text-transform: uppercase; letter-spacing: 0.04em;
  vertical-align: middle;
}
.thread-type-pill.task { background: var(--indigo-15); color: var(--indigo); }
.thread-type-pill.plan { background: var(--emerald-15); color: var(--emerald-green); }

/* ── Unread badges ───────────────────────────────────────────────────────── */
.sidebar-unread-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--accent); color: var(--text-black);
  border-radius: 9px; font-size: 10px; font-weight: 700;
  flex-shrink: 0;
}
.thread-unread-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--accent); color: var(--text-black);
  border-radius: 9px; font-size: 10px; font-weight: 700;
  flex-shrink: 0; margin-left: 4px; margin-right: 4px;
}
.thread-item.has-unread .thread-name { font-weight: 600; }

#thread-list {
  flex: 1; overflow-y: auto; padding: 6px 8px;
}

.thread-item {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.2s var(--ease);
  margin-bottom: 2px; position: relative;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.thread-item:hover { background: var(--bg3); }
.thread-item:active { background: var(--bg4); }
.thread-item.active { background: var(--bg4); }

.thread-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.thread-dot.idle    { background: var(--success); opacity: 0.6; }
.thread-dot.running { background: var(--warning); animation: pulse 1s infinite; }
.thread-dot.error   { background: var(--danger); }

@keyframes pulse {
  0%, 100% { opacity: 1; } 50% { opacity: .3; }
}

.thread-info { flex: 1; min-width: 0; }
.thread-name {
  font-size: 13px; font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.thread-draft-icon {
  color: var(--text-dim); margin-right: 4px; flex-shrink: 0;
  vertical-align: -1px;
}
.thread-meta {
  font-size: 11px; color: var(--text-dim); margin-top: 2px;
  display: flex; align-items: center; gap: 6px;
}
.thread-snippet {
  font-size: 11px; color: var(--text-dim); margin-top: 3px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.thread-archive {
  opacity: 0; color: var(--text-dim);
  padding: 0 4px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center;
  transition: opacity 0.15s;
}
.thread-item:hover .thread-archive { opacity: 1; }
.thread-archive:hover { color: var(--accent, var(--accent)); }

.thread-mute {
  opacity: 0; color: var(--text-dim);
  padding: 0 4px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center;
  transition: opacity 0.15s;
}
.thread-item:hover .thread-mute { opacity: 1; }
.thread-mute:hover { color: var(--accent); }

.thread-delete {
  opacity: 0; font-size: 16px; color: var(--text-dim);
  padding: 0 4px; border-radius: 6px; flex-shrink: 0;
  transition: opacity 0.15s;
}
.thread-item:hover .thread-delete { opacity: 1; }
.thread-item.confirm-delete .thread-delete { opacity: 0.4; }
.thread-delete:hover { color: var(--danger); }

.thread-delete-confirm {
  display: none; font-size: 11px; font-weight: 600;
  color: var(--on-danger); background: var(--danger);
  padding: 3px 8px; border-radius: 6px; flex-shrink: 0;
  white-space: nowrap;
}
.thread-item.confirm-delete .thread-delete-confirm { display: block; }

.new-thread-btn {
  margin: 8px 10px 12px;
  padding: 11px 16px;
  background: var(--bg3);
  border: 1px dashed var(--accent-20);
  border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 500;
  color: var(--accent);
  transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
}
.new-thread-btn:hover { background: var(--bg4); border-color: var(--accent-40); }
.new-thread-btn:active { opacity: 0.8; }
.new-thread-btn:disabled { opacity: 0.5; cursor: default; }

/* ── Agent selector ────────────────────────────────────────────────────────── */
#workspace-selector-bar {
  display: flex; gap: 4px; padding: 8px 10px 0;
  flex-wrap: wrap; flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}
#workspace-selector-bar:empty { display: none; }
.workspace-pill {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  background: var(--bg2);
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  font-size: 12px; font-weight: 600;
  color: var(--text-dim); cursor: pointer;
  transition: all 0.15s var(--ease);
}
.workspace-pill:hover { background: var(--bg3); color: var(--text); }
.workspace-pill.active {
  background: var(--accent-8);
  border-color: var(--accent-30);
  color: var(--accent);
}

#agent-selector-bar {
  display: flex; gap: 6px; padding: 8px 10px 4px;
  flex-wrap: wrap; flex-shrink: 0;
}
.agent-pill {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 12px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  font-size: 12px; font-weight: 500;
  color: var(--text-dim); cursor: pointer;
  transition: all 0.2s var(--ease);
}
.agent-pill:hover { background: var(--bg4); color: var(--text); }
.agent-pill.active {
  background: var(--accent-10);
  border-color: var(--accent-40);
  color: var(--accent);
}

/* ── Admin Panel ────────────────────────────────────────────────────────────── */
#admin-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 580px; max-width: 100vw;
  background: var(--surface-heavy);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  z-index: 200;
  box-shadow: var(--shadow-float);
  transition: transform 0.25s var(--ease);
}
#admin-panel.collapsed { transform: translateX(100%); }

.admin-tabs {
  display: flex; gap: 2px; padding: 8px 12px 0;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.admin-tab {
  padding: 7px 14px; font-size: 12px; font-weight: 600;
  background: none; border: none; cursor: pointer;
  color: var(--text-dim); border-radius: 6px 6px 0 0;
  transition: all 0.15s var(--ease);
}
.admin-tab:hover { color: var(--text); background: var(--bg3); }
.admin-tab.active { color: var(--accent); background: var(--accent-6); border-bottom: 2px solid var(--accent); }

#admin-body { flex: 1; overflow-y: auto; padding: 12px; }

.admin-toolbar { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.admin-hint    { font-size: 12px; color: var(--text-dim); }

.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-table th { text-align: left; font-size: 11px; font-weight: 600; color: var(--text-dim); padding: 6px 8px; border-bottom: 1px solid var(--border); text-transform: uppercase; letter-spacing: .05em; }
.admin-table td { padding: 9px 8px; border-bottom: 1px solid var(--glass-bg); vertical-align: top; }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: var(--bg3); }

.admin-btn { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--bg3); color: var(--text); transition: all 0.15s; white-space: nowrap; }
.admin-btn:hover { background: var(--bg4); }
.admin-btn.primary { background: var(--accent-12); border-color: var(--accent-40); color: var(--accent); }
.admin-btn.primary:hover { background: var(--accent-20); }
.admin-btn.danger { border-color: var(--danger-40); color: var(--danger); }
.admin-btn.danger:hover { background: var(--danger-10); }
.admin-btn.small { padding: 3px 8px; }
.admin-btn i { width: 13px; height: 13px; }

.admin-badge { display: inline-block; padding: 2px 7px; border-radius: 20px; font-size: 11px; font-weight: 600; background: var(--bg3); color: var(--text-dim); }
.admin-badge.admin { background: var(--accent-10); color: var(--accent); }
.admin-badge.on    { background: var(--success-12); color: var(--success); }
.admin-badge.off   { background: var(--bg3); color: var(--text-dim); }

.admin-key { font-size: 11px; color: var(--text-dim); }
.admin-loading { padding: 24px; text-align: center; color: var(--text-dim); }
.admin-error   { padding: 16px; color: var(--danger); font-size: 13px; }

.admin-form { display: flex; flex-direction: column; gap: 10px; max-width: 360px; }
.admin-input { padding: 8px 12px; background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 13px; outline: none; }
.admin-input:focus { border-color: var(--accent-50); }

.admin-features-list { display: flex; flex-direction: column; gap: 2px; }
.admin-toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 4px; border-bottom: 1px solid var(--glass-bg); }
.admin-toggle-row input[type=checkbox] { width: 16px; height: 16px; cursor: pointer; }

/* ── Workspace wizard overlay ───────────────────────────────────────────────── */
#workspace-wizard-overlay {
  position: fixed; inset: 0;
  background: var(--black-60);
  display: none; align-items: center; justify-content: center;
  z-index: 300;
}
.workspace-wizard {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 14px; padding: 24px;
  width: 420px; max-width: calc(100vw - 32px);
  display: flex; flex-direction: column; gap: 16px;
}
.wizard-header { display: flex; align-items: center; justify-content: space-between; }
.wizard-header span { font-size: 15px; font-weight: 600; }
.wizard-step-label { font-size: 11px; font-weight: 600; color: var(--accent); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 12px; }
.wizard-hint { font-size: 12px; color: var(--text-dim); margin-bottom: 8px; }
.wizard-step { display: flex; flex-direction: column; gap: 10px; }
.wizard-input { padding: 9px 13px; background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 13px; outline: none; }
.wizard-input:focus { border-color: var(--accent-50); }
.wizard-footer { display: flex; gap: 8px; justify-content: flex-end; }
.wizard-btn { padding: 8px 20px; border-radius: 8px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--bg3); color: var(--text); }
.wizard-btn.primary { background: var(--accent-12); border-color: var(--accent-40); color: var(--accent); }
.wizard-btn.primary:hover { background: var(--accent-20); }
.wizard-btn.secondary { color: var(--text-dim); }
.wizard-error { font-size: 12px; color: var(--danger); padding: 8px 12px; background: var(--danger-8); border-radius: 6px; }
.wizard-result { font-size: 13px; display: flex; flex-direction: column; gap: 8px; }
.wizard-result-row { padding: 6px 0; border-bottom: 1px solid var(--bg3); }
.wizard-result code { font-size: 11px; background: var(--bg3); padding: 2px 6px; border-radius: 4px; }

/* ── Chat area ─────────────────────────────────────────────────────────────── */
#chat-area {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
  min-width: 0;
}

#messages {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 20px 16px;
  display: flex; flex-direction: column; gap: 10px;
}

/* Welcome state */
.chat-loading {
  flex: 1; display: flex; align-items: center; justify-content: center;
  padding: 40px;
}
.chat-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  color: var(--text-dim); text-align: center; gap: 10px;
}
.chat-empty .empty-icon { font-size: 36px; color: var(--text-dim); opacity: 0.5; }
.chat-empty p { font-size: 13px; opacity: 0.7; }

/* Message bubbles */
.msg {
  display: flex; flex-direction: column;
  max-width: min(680px, 92%);
  min-width: 0;
}
.msg.user { align-self: flex-end; align-items: flex-end; }
.msg.assistant {
  align-self: stretch;
  align-items: flex-start;
  max-width: min(680px, 100%);
}
.msg.system {
  align-self: center;
  align-items: center;
  max-width: min(560px, 92%);
}
.msg.system .msg-bubble {
  background: var(--violet-6);
  border: 1px solid var(--violet-18);
  border-radius: 8px;
  font-size: 12px;
  color: var(--text-dim);
  padding: 5px 12px;
  text-align: center;
}

.msg-bubble {
  padding: 10px 14px;
  line-height: 1.6;
  word-break: break-word;
  overflow-wrap: break-word;
  overflow: hidden;
  max-width: 100%;
  min-width: 0;
}

.msg.user .msg-bubble {
  background: var(--accent-12);
  border: 1px solid var(--accent-18);
  border-radius: 18px 4px 18px 18px;
  max-width: 82%;
}
.msg.assistant .msg-bubble {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px 18px 18px 18px;
}

.msg-bubble.streaming {
  opacity: .88;
  border-left: 2px solid var(--accent-25);
  padding-left: 10px;
  animation: streaming-glow 2.5s ease-in-out infinite;
}
.msg-bubble.streaming::after {
  content: '▋';
  animation: blink .7s step-start infinite;
  color: var(--accent);
  opacity: 0.7;
}
@keyframes blink { 0%, 100% { opacity: 0.8; } 50% { opacity: 0; } }
@keyframes streaming-glow {
  0%, 100% { border-left-color: var(--accent-15); }
  50%       { border-left-color: var(--accent-45); }
}

.msg-footer {
  display: flex; align-items: center; gap: 8px;
  margin-top: 5px; padding: 0 4px;
}
.msg-time { font-size: 11px; color: var(--text-dim); }
.msg-cost { font-size: 11px; color: var(--text-dim); }
.date-divider {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 8px 6px;
}
.date-divider::before, .date-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.date-divider span {
  font-size: 11px; color: var(--text-dim); font-weight: 500;
  white-space: nowrap; letter-spacing: 0.4px; text-transform: uppercase;
}
.msg-play {
  font-size: 14px; color: var(--text-dim);
  padding: 2px 6px; border-radius: 6px;
  transition: background 0.15s var(--ease);
  display: flex; align-items: center;
}
.msg-play:hover { background: var(--bg3); color: var(--accent); }
.msg-play.playing { color: var(--accent); }
.msg-copy {
  font-size: 14px; color: var(--text-dim);
  padding: 2px 6px; border-radius: 6px;
  transition: background 0.15s var(--ease), color 0.15s var(--ease);
  display: flex; align-items: center;
  opacity: 0;
}
.msg:hover .msg-copy { opacity: 1; }
.msg-copy:hover { background: var(--bg3); color: var(--accent); }
@media (hover: none) {
  .msg-copy { opacity: 1; }
}
.msg-regen {
  font-size: 14px; color: var(--text-dim);
  padding: 2px 6px; border-radius: 6px;
  transition: background 0.15s var(--ease), color 0.15s var(--ease), transform 0.2s var(--ease);
  display: flex; align-items: center;
  opacity: 0;
}
.msg:hover .msg-regen { opacity: 1; }
.msg-regen:hover { background: var(--bg3); color: var(--accent); }
.msg-regen:active { transform: rotate(180deg); }
@media (hover: none) { .msg-regen { opacity: 1; } }
.msg-feedback {
  display: flex; align-items: center; gap: 1px;
  opacity: 0; transition: opacity .15s; margin-left: 2px;
}
.msg:hover .msg-feedback { opacity: 1; }
.msg-react {
  font-size: 13px; color: var(--text-dim);
  padding: 2px 5px; border-radius: 6px;
  transition: background 0.15s var(--ease), color 0.15s var(--ease);
  display: flex; align-items: center;
}
.msg-react:hover { background: var(--bg3); color: var(--accent); }
.msg-react.active { color: var(--accent); opacity: 1 !important; }
@media (hover: none) { .msg-feedback { opacity: 1; } }

/* Inline markdown */
.msg-bubble code {
  background: var(--code-bg); padding: 2px 6px; border-radius: 5px;
  font-family: 'SF Mono', 'Fira Code', monospace; font-size: 12px;
  word-break: break-all;
  overflow-wrap: break-word;
}
.msg-bubble pre {
  background: var(--code-bg); padding: 12px 14px; border-radius: 10px;
  overflow-x: auto; max-width: 100%; word-break: normal; white-space: pre; margin: 8px 0;
  border: 1px solid var(--border);
}
.msg-bubble pre code { background: none; padding: 0; }
.msg-bubble strong { font-weight: 600; color: var(--text-white); }
.msg-bubble em { color: var(--text-em); }
.msg-bubble a { color: var(--accent); }

/* Block markdown — headings, lists, tables */
.msg-bubble .md-h1, .msg-bubble .md-h2, .msg-bubble .md-h3,
.msg-bubble .md-h4, .msg-bubble .md-h5, .msg-bubble .md-h6 {
  font-weight: 600; color: var(--text-white); line-height: 1.3; margin: 10px 0 4px;
}
.msg-bubble .md-h1 { font-size: 1.25em; }
.msg-bubble .md-h2 { font-size: 1.1em; border-bottom: 1px solid var(--border); padding-bottom: 4px; }
.msg-bubble .md-h3 { font-size: 1em; }
.msg-bubble .md-h4, .msg-bubble .md-h5, .msg-bubble .md-h6 { font-size: .95em; color: var(--text-dim); }

.msg-bubble .md-hr {
  border: none; border-top: 1px solid var(--border); margin: 10px 0;
}

.msg-bubble .md-ul, .msg-bubble .md-ol {
  padding-left: 20px; margin: 4px 0 8px;
}
.msg-bubble .md-ul li, .msg-bubble .md-ol li {
  margin-bottom: 3px; line-height: 1.55;
}
.msg-bubble .md-ul { list-style-type: disc; }
.msg-bubble .md-ol { list-style-type: decimal; }

.msg-bubble .md-bq {
  border-left: 3px solid var(--accent2); padding: 4px 10px;
  margin: 6px 0; color: var(--text-dim); font-style: italic;
}

.msg-bubble .md-table-wrap {
  overflow-x: auto; margin: 8px 0; border-radius: var(--radius-sm);
}
.msg-bubble .md-table {
  border-collapse: collapse; width: 100%; font-size: 13px; white-space: nowrap;
}
.msg-bubble .md-table th,
.msg-bubble .md-table td {
  padding: 7px 12px; border: 1px solid var(--border); text-align: left;
}
.msg-bubble .md-table th {
  background: var(--bg3); font-weight: 600; color: var(--accent);
}
.msg-bubble .md-table tr:nth-child(even) td { background: var(--black-12); }
.msg-bubble .md-table tr:hover td { background: var(--accent-5); }

/* Thinking bubble — reuses live-activity-pill animation */
.thinking-bubble { } /* pill renders inside, no extra styles needed */

/* System event chip — shown only to admins for server restart messages */
.system-event-chip { margin: 4px 12px; border-radius: 6px; font-size: 11px; overflow: hidden; border: 1px solid var(--amber-30); background: var(--amber-7); }
.system-event-chip summary { display: flex; align-items: center; gap: 6px; padding: 4px 10px; cursor: pointer; list-style: none; color: var(--amber-alt); user-select: none; }
.system-event-chip summary::-webkit-details-marker { display: none; }
.system-event-chip summary svg { width:12px; height:12px; flex-shrink:0; }
.system-event-chip .chip-title { opacity: 0.85; }
.system-event-chip[open] summary { border-bottom: 1px solid var(--amber-20); }
.system-event-chip .chip-body { padding: 8px 12px; font-family: monospace; font-size: 11px; color: var(--text-dim); white-space: pre-wrap; word-break: break-word; max-height: 200px; overflow-y: auto; }

/* Activity group — groups all tool calls from a response into one collapsible block */
.activity-group {
  margin-top: 4px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  font-size: 12px;
}
.activity-header {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; cursor: pointer;
  background: var(--white-2);
  user-select: none;
  transition: background 0.15s var(--ease);
}
.activity-header:hover { background: var(--bg3); }
.activity-icon { font-size: 13px; display: flex; align-items: center; color: var(--accent); opacity: 0.7; }
.activity-label { font-weight: 500; color: var(--text-dim); font-size: 12px; }
.activity-tools-preview {
  flex: 1; font-size: 11px; color: var(--text-dim); opacity: 0.5;
  white-space: normal; word-break: break-word;
}
.activity-group.open .activity-tools-preview { display: none; }
.activity-chevron { margin-left: auto; color: var(--text-dim); transition: transform 0.2s var(--ease); font-size: 13px; flex-shrink: 0; }
.activity-group.open .activity-chevron { transform: rotate(90deg); }
.activity-body { display: none; padding: 4px 8px 8px; background: var(--black-12); }
.activity-group.open .activity-body { display: block; }
.activity-body .tool-card { margin-top: 4px; }
.activity-body .tool-card:first-child { margin-top: 0; }

/* Hide <resumen> tag during streaming — server strips it before persisting */
resumen { display: none; }

/* Live activity pill — shown while agent is working (non-dev mode) */
.live-activity-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 500;
  color: var(--accent-85);
  background: linear-gradient(90deg,
    var(--accent2-7) 0%,
    var(--accent-13) 50%,
    var(--accent2-7) 100%);
  background-size: 200% 100%;
  border: 1px solid var(--accent-14);
  animation: lap-breathe 3s ease-in-out infinite;
  position: relative;
  overflow: hidden;
}
.live-activity-pill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--accent-7) 50%,
    transparent 100%);
  background-size: 200% 100%;
  animation: lap-sweep 2.2s linear infinite;
  pointer-events: none;
}
.lap-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  animation: lap-pulse 1.4s ease-in-out infinite;
  position: relative; z-index: 1;
}
.lap-text { position: relative; z-index: 1; letter-spacing: 0.01em; }

@keyframes lap-breathe {
  0%, 100% { background-position: 0% 0%; }
  50%       { background-position: 100% 0%; }
}
@keyframes lap-sweep {
  from { background-position: -100% 0; }
  to   { background-position: 300% 0; }
}
@keyframes lap-pulse {
  0%, 100% { opacity: 0.35; transform: scale(0.75); }
  50%       { opacity: 1;    transform: scale(1); }
}

/* Tool summary pill (shown when agent finishes, non-dev mode) */
.tool-summary-line {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 4px;
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  color: var(--text-dim);
  background: var(--bg2);
  opacity: 0.75;
}
.tool-summary-line .tool-summary-icon { display: flex; align-items: center; color: var(--accent); opacity: 0.6; }
.tool-summary-line .tool-summary-icon svg { width: 11px; height: 11px; }

.tool-summary-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  padding: 5px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 12px;
  color: var(--text-dim);
  background: var(--white-2);
}
.tool-summary-icon { display: flex; align-items: center; color: var(--accent); opacity: 0.7; }
.tool-summary-icon svg { width: 12px; height: 12px; }

/* Tool cards */
.tool-card {
  margin-top: 6px;
  background: var(--white-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  font-size: 12px;
  box-shadow: var(--shadow-card);
}
.tool-header {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; cursor: pointer;
  user-select: none;
  transition: background 0.15s var(--ease);
}
.tool-header:hover { background: var(--bg3); }
.tool-icon { font-size: 14px; display: flex; align-items: center; color: var(--text-dim); }
.tool-name { font-weight: 500; color: var(--text-dim); font-size: 12px; }
.tool-preview {
  flex: 1; font-size: 11px; color: var(--text-dim);
  white-space: normal; word-break: break-word;
  opacity: 0.6;
}
.tool-card.open .tool-preview { display: none; }
.tool-chevron { margin-left: auto; color: var(--text-dim); transition: transform 0.2s var(--ease); font-size: 13px; }
.tool-card.open .tool-chevron { transform: rotate(90deg); }
.tool-body { display: none; padding: 8px 12px 10px; background: var(--black-15); }
.tool-card.open .tool-body { display: block; }
.tool-section { margin-bottom: 8px; }
.tool-label { color: var(--text-dim); font-size: 10px; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 4px; font-weight: 600; }
.tool-content {
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: 11px; white-space: pre-wrap; word-break: break-all;
  background: var(--black-25); padding: 8px 10px; border-radius: 8px;
  max-height: 320px; overflow-y: auto; color: var(--text-code);
  border: 1px solid var(--border);
}
.tool-content.output { color: var(--text); }

/* ── Input bar ─────────────────────────────────────────────────────────────── */
#input-area {
  border-top: 1px solid var(--border);
  background: var(--surface-input);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
#input-area.drag-over { outline: 2px dashed var(--accent); outline-offset: -4px; }

#input-bar {
  display: flex; align-items: flex-end; gap: 8px;
  padding: 10px 14px 14px;
  background: transparent;
}

.mic-btn { flex-shrink: 0; }
.mic-btn.listening { color: var(--danger); background: var(--danger-12); animation: pulse 1s infinite; }
.mic-btn.cleaning  { color: var(--accent); animation: pulse 0.6s infinite; }

.topbar-autoplay-pill {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 7px;
  border: none; background: transparent;
  color: var(--text-muted); opacity: 0.35;
  cursor: pointer; flex-shrink: 0;
  transition: opacity 0.15s, color 0.15s, background 0.15s;
}
.topbar-autoplay-pill:hover { opacity: 0.7; }
.topbar-autoplay-pill.active {
  background: var(--accent-15);
  color: var(--accent2);
  opacity: 1;
}
.topbar-autoplay-pill svg { width: 16px; height: 16px; }

/* Processing status bar */
#stt-status {
  display: none;
  align-items: center; gap: 8px;
  padding: 6px 16px 0;
  font-size: 12px; color: var(--text-dim);
}
#stt-status.visible { display: flex; }
.stt-status-dots span {
  display: inline-block; width: 4px; height: 4px;
  border-radius: 50%; background: var(--accent);
  animation: stt-dot 1.2s infinite;
}
.stt-status-dots span:nth-child(2) { animation-delay: .2s; }
.stt-status-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes stt-dot {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40%           { transform: scale(1);   opacity: 1; }
}

#msg-input {
  flex: 1; resize: none; line-height: 1.55;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 9px 14px;
  max-height: 160px; overflow-y: auto;
  font-size: 14px;
  transition: border-color 0.2s var(--ease);
}
#msg-input:focus { border-color: var(--accent-35); }
#msg-input::placeholder { color: var(--text-dim); }

.send-btn {
  width: 40px; height: 40px; flex-shrink: 0;
  background: var(--accent); color: var(--bg);
  border-radius: var(--radius-sm); font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s var(--ease), transform 0.15s var(--ease);
}
.send-btn:hover { background: var(--accent-hover); }
.send-btn:active { background: var(--accent2); transform: scale(0.94); }
.send-btn:disabled { background: var(--bg3); color: var(--text-dim); cursor: default; }

/* ── Attach button + chips ─────────────────────────────────────────────────── */
#attached-files {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 8px 14px 0;
}

.attach-btn {
  cursor: pointer; flex-shrink: 0;
  font-size: 18px; opacity: 0.5;
  padding: 0 4px;
  transition: opacity 0.15s;
}
.attach-btn:hover { opacity: 1; }

.attach-chip {
  display: flex; align-items: center; gap: 5px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 4px 8px 4px 6px;
  font-size: 12px; max-width: 160px;
}
.attach-thumb {
  width: 28px; height: 28px; object-fit: cover;
  border-radius: 6px; flex-shrink: 0;
}
.attach-icon { font-size: 16px; flex-shrink: 0; display: flex; align-items: center; color: var(--text-dim); }
.attach-name {
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text-dim);
}
.attach-remove {
  color: var(--text-dim); font-size: 14px;
  padding: 0 2px; flex-shrink: 0;
}
.attach-remove:hover { color: var(--danger); }

/* ── Mobile bottom nav ─────────────────────────────────────────────────────── */
#mobile-nav {
  display: none;
  height: var(--nav-h);
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--surface-nav);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-top: 1px solid var(--border);
  z-index: 90;
  flex-shrink: 0;
  padding-bottom: env(safe-area-inset-bottom, 0);
}

.nav-btn {
  flex: 1;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px;
  font-size: 11px; font-weight: 500;
  color: var(--text-dim);
  transition: color 0.2s var(--ease);
  min-height: 44px;
  padding: 8px 0;
  border-radius: var(--radius-sm);
  -webkit-tap-highlight-color: transparent;
}
.nav-btn svg { width: 22px; height: 22px; }
.nav-btn.active { color: var(--accent); }
.nav-btn:active { opacity: 0.7; }

/* External link nav item */
a.nav-btn { text-decoration: none; }

/* ── Panel overlay (mobile backdrop) ──────────────────────────────────────── */
#panel-overlay {
  display: none;
  position: fixed; inset: 0;
  background: var(--black-50);
  z-index: 49;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
#panel-overlay.visible { display: block; }

/* ── Shared panel styles ───────────────────────────────────────────────────── */
.panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 14px 10px;
  font-weight: 600; font-size: 13px; color: var(--text-dim);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.close-panel-btn {
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  color: var(--text-dim);
  background: var(--bg3);
}
.close-panel-btn:hover { background: var(--bg4); color: var(--text); }
.close-panel-btn:active { background: var(--bg4); }

/* ── Files panel ───────────────────────────────────────────────────────────── */
#files-panel {
  width: var(--panel-w);
  background: var(--surface-panel);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  flex-shrink: 0; transition: width 0.2s var(--ease); overflow: hidden;
  box-shadow: var(--shadow-float);
}
#files-panel.collapsed { width: 0; }

#files-body {
  flex: 1; overflow-y: auto; padding: 10px;
}

.file-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  margin-bottom: 8px;
  background: var(--bg3);
  transition: background 0.15s var(--ease);
}
.file-item:hover { background: var(--bg4); }

.file-thumb {
  width: 40px; height: 40px;
  object-fit: cover; border-radius: 8px;
  flex-shrink: 0; cursor: pointer;
}

.file-icon {
  width: 40px; height: 40px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: var(--text-dim);
}

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

.file-name {
  font-size: 12px; font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.file-meta {
  font-size: 11px; color: var(--text-dim); margin-top: 2px;
}

.file-actions {
  display: flex; gap: 4px; flex-shrink: 0;
}

.file-actions a.cron-btn {
  text-decoration: none;
  display: flex; align-items: center; justify-content: center;
}

/* ── Load-more sentinel ─────────────────────────────────────────────────────── */
.load-more-sentinel {
  display: flex; justify-content: center;
  padding: 8px 0 4px;
}
.load-more-label {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--text-dim);
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill); padding: 4px 12px;
  pointer-events: none;
}

/* ── File card (inline in chat) ─────────────────────────────────────────────── */
a.file-card {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--text); margin: 6px 0;
  max-width: 340px; width: fit-content;
  transition: background 0.15s var(--ease), border-color 0.15s var(--ease);
}
a.file-card:hover { background: var(--bg4); border-color: var(--accent-30); }
.file-card-icon { color: var(--accent); flex-shrink: 0; display: flex; }
.file-card-name { flex: 1; font-size: 13px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.file-card-cta { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--accent); flex-shrink: 0; font-weight: 600; }
.file-card-cta svg { width: 12px; height: 12px; }

/* Image preview variant */
.file-card-image-wrap {
  display: inline-block; margin: 6px 0;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  overflow: hidden; max-width: min(380px, 100%);
}
.file-card-preview {
  display: block; width: 100%; max-height: 280px;
  object-fit: cover; cursor: zoom-in;
  transition: opacity .15s;
}
.file-card-preview:hover { opacity: .9; }
a.file-card.file-card-under {
  border-radius: 0; border-top: 1px solid var(--border); border-left: none; border-right: none; border-bottom: none;
  margin: 0; max-width: none; width: 100%;
  background: var(--black-20); padding: 8px 12px;
}

.file-card-wrap { display: flex; align-items: center; gap: 8px; margin: 6px 0; }
.file-card-wrap a.file-card { margin: 0; flex: 1; min-width: 0; max-width: none; }
.file-card-open-btn {
  display: flex; align-items: center; gap: 4px; flex-shrink: 0;
  padding: 8px 12px; border-radius: var(--radius-sm);
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text-dim); font-size: 12px; font-weight: 600;
  text-decoration: none; white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.file-card-open-btn:hover { background: var(--bg4); color: var(--text); }

/* ── Settings panel ────────────────────────────────────────────────────────── */
#settings-panel {
  width: var(--panel-w);
  background: var(--surface-panel);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  flex-shrink: 0; transition: width 0.2s var(--ease); overflow: hidden;
  box-shadow: var(--shadow-float);
}
#settings-panel.collapsed { width: 0; }

#settings-body {
  flex: 1; overflow-y: auto; padding: 14px 12px;
}

/* Settings toggle row (for switch-style toggles) */
.settings-toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 0;
}
.settings-toggle-label {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; color: var(--text);
}
.settings-toggle-label svg { width: 14px; height: 14px; color: var(--text-dim); }

.settings-switch {
  position: relative; width: 40px; height: 24px; flex-shrink: 0;
  background: var(--bg4);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
  cursor: pointer;
}
.settings-switch::after {
  content: ''; position: absolute;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--text-dim); top: 2px; left: 2px;
  transition: transform 0.2s var(--ease), background 0.2s var(--ease);
}
.settings-switch.active,
.settings-switch.on { background: var(--accent2); border-color: var(--accent-50); }
.settings-switch.active::after,
.settings-switch.on::after { transform: translateX(16px); background: var(--on-accent); }

/* Icon action buttons inside settings */
.settings-btn-icon {
  display: inline-flex; align-items: center; gap: 6px;
}
.settings-btn-icon svg { width: 13px; height: 13px; }
.settings-btn-danger { color: var(--danger) !important; }
.settings-btn-danger:hover { border-color: var(--danger) !important; background: var(--danger-8) !important; }

.settings-section {
  margin-bottom: 22px;
}
.settings-section-title {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .8px; color: var(--text-dim);
  padding: 0 0 7px; margin-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.settings-section-desc {
  font-size: 12px; color: var(--text-dim); margin-bottom: 10px; line-height: 1.5;
}
.settings-row {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.notify-prefs-table {
  display: flex; flex-direction: column; gap: 6px;
}
.notify-prefs-row {
  display: grid; grid-template-columns: 1fr repeat(3, 44px);
  align-items: center; gap: 4px;
}
.notify-prefs-header {
  font-size: 10px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .4px;
}
.notify-prefs-channel-label {
  text-align: center;
}
.notify-prefs-category-label {
  font-size: 12px; color: var(--text);
}
.notify-prefs-check {
  display: flex; justify-content: center; align-items: center;
}
.notify-prefs-check input[type="checkbox"] {
  width: 15px; height: 15px; accent-color: var(--accent2, var(--accent)); cursor: pointer;
}
.settings-btn {
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius-sm);
  padding: 8px 12px; font-size: 12px; font-weight: 500;
  cursor: pointer;
  white-space: nowrap; text-decoration: none; display: inline-block;
  transition: background 0.15s var(--ease), border-color 0.15s var(--ease);
}
.settings-btn:hover { background: var(--bg4); border-color: var(--white-12); }
.settings-btn:active { opacity: .7; }
.settings-textarea {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 9px 10px; color: var(--text); font-size: 12px;
  resize: vertical; min-height: 60px; line-height: 1.5;
  transition: border-color 0.2s var(--ease);
}
.settings-textarea:focus { border-color: var(--accent-35); }
.settings-hint {
  font-size: 11px; color: var(--text-dim); line-height: 1.4;
}
.settings-status {
  font-size: 12px; margin-top: 6px; min-height: 18px;
}
.settings-status.ok { color: var(--text-ok); }
.settings-status.err { color: var(--text-err); }

/* ── Usage panel ───────────────────────────────────────────────────────────── */
#usage-panel {
  position: absolute; top: var(--topbar-h); right: 0; bottom: 0;
  width: var(--panel-w);
  background: var(--surface-heavy);
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  transition: width 0.25s var(--ease), opacity 0.2s;
  overflow: hidden; z-index: 30;
  backdrop-filter: blur(var(--glass-blur));
}
#usage-panel.collapsed { width: 0; opacity: 0; }
#usage-body {
  flex: 1; overflow-y: auto; padding: 14px;
  display: flex; flex-direction: column; gap: 16px;
}
.usage-notice {
  display: flex; align-items: flex-start; gap: 7px;
  background: var(--accent-7); border: 1px solid var(--accent-18);
  border-radius: var(--radius-sm); padding: 9px 11px;
  font-size: 11px; color: var(--text-dim); line-height: 1.5;
}
.usage-notice strong { color: var(--accent); }
.usage-stats-full {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.usage-stat-box-lg {
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 12px 10px; text-align: center;
}
.usage-stat-label { font-size: 10px; color: var(--text-dim); margin-bottom: 4px; text-transform: uppercase; letter-spacing: .5px; }
.usage-stat-value-lg { font-size: 18px; font-weight: 700; color: var(--accent); font-variant-numeric: tabular-nums; }
.usage-chart-section { display: flex; flex-direction: column; gap: 6px; }
.usage-chart-title { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--text-dim); }
.usage-chart-full {
  display: flex; align-items: flex-end; gap: 3px; height: 72px;
  padding: 4px 0;
}
.usage-bar {
  flex: 1; background: var(--accent2); border-radius: 3px 3px 0 0;
  min-height: 2px; transition: background 0.15s; cursor: default;
}
.usage-bar:hover { background: var(--accent); }
.usage-bar.today { background: var(--accent); box-shadow: 0 0 6px var(--accent-40); }
.usage-chart-labels {
  display: flex; justify-content: space-between;
  font-size: 9px; color: var(--text-dim);
}
.usage-meta-row {
  font-size: 11px; color: var(--text-dim); text-align: center; line-height: 1.5;
}
.usage-external-link {
  display: flex; align-items: center; gap: 6px; justify-content: center;
  font-size: 11px; color: var(--text-dim); text-decoration: none;
  padding: 10px; border-top: 1px solid var(--border); margin-top: 4px;
  transition: color 0.15s;
}
.usage-external-link:hover { color: var(--accent); }
@media (max-width: 768px) {
  #usage-panel { width: 100%; border-left: none; border-top: 1px solid var(--border); top: auto; bottom: 0; height: 75vh; }
  #usage-panel.collapsed { width: 100%; height: 0; opacity: 0; }
}

/* ── Crons panel ───────────────────────────────────────────────────────────── */
#crons-panel {
  width: var(--panel-w);
  background: var(--surface-panel);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  flex-shrink: 0; transition: width 0.2s var(--ease); overflow: hidden;
  box-shadow: var(--shadow-float);
}
#crons-panel.collapsed { width: 0; }

/* (legacy class kept for backward compat with JS) */
.crons-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 14px 10px;
  font-weight: 600; font-size: 13px; color: var(--text-dim);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.close-crons-btn { display: none; }
@media (max-width: 768px) {
  .close-crons-btn { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%; color: var(--text-dim); }
  .close-crons-btn:active { background: var(--bg4); }
}

#crons-body {
  flex: 1; overflow-y: auto; padding: 10px;
}

.crons-section-title {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .8px; color: var(--text-dim);
  padding: 6px 4px 5px;
}

.crons-empty {
  font-size: 11px; color: var(--text-dim);
  padding: 6px 4px 10px; font-style: italic;
}

.cron-item {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 10px 12px;
  margin-bottom: 8px;
  transition: background 0.15s var(--ease);
}
.cron-item:hover { background: var(--bg4); }

.cron-item-header {
  display: flex; align-items: center; gap: 7px; margin-bottom: 5px;
}

.cron-status-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
}
.cron-status-dot.ok      { background: var(--success); }
.cron-status-dot.running { background: var(--warning); animation: pulse 1s infinite; }
.cron-status-dot.error   { background: var(--danger); }
.cron-status-dot.skipped,
.cron-status-dot.idle    { background: var(--text-dim); opacity: 0.5; }

.cron-name {
  font-size: 12px; font-weight: 600; flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.cron-badge {
  font-size: 9px; font-weight: 700; padding: 2px 6px;
  border-radius: var(--radius-pill); flex-shrink: 0; letter-spacing: .3px;
}
.cron-badge.openclaw { background: var(--accent-12); color: var(--accent); }
.cron-badge.claude   { background: var(--success-12); color: var(--success); }

.cron-schedule {
  font-size: 11px; color: var(--text-dim);
  font-family: 'SF Mono', 'Fira Code', monospace;
  margin-bottom: 3px;
}

.cron-meta {
  font-size: 11px; color: var(--text-dim); margin-bottom: 9px;
}

.cron-actions { display: flex; gap: 4px; flex-wrap: wrap; }

.cron-btn {
  font-size: 11px; padding: 4px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--bg3); color: var(--text-dim);
  transition: all 0.15s var(--ease); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 500;
}
.cron-btn:hover { background: var(--bg4); border-color: var(--accent-30); color: var(--accent); }
.cron-btn:active { opacity: 0.7; }

.cron-toggle.enabled  { border-color: var(--success-40); color: var(--success); background: var(--success-8); }
.cron-toggle.disabled { border-color: var(--border); color: var(--text-dim); }
.cron-toggle:hover    { opacity: .8; }

.cron-del:hover { border-color: var(--danger-40) !important; color: var(--danger) !important; background: var(--danger-8) !important; }

/* Cron add form */
#cron-form {
  border-top: 1px solid var(--border);
  padding: 12px;
  flex-shrink: 0;
  background: var(--black-20);
}

.cron-form-inner { display: flex; flex-direction: column; gap: 8px; }

.cron-form-inner input,
.cron-form-inner select,
.cron-form-inner textarea {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 8px 10px;
  font-size: 12px; color: var(--text); width: 100%;
  transition: border-color 0.2s var(--ease);
}
.cron-form-inner input:focus,
.cron-form-inner textarea:focus { border-color: var(--accent-40); outline: none; }
.cron-form-inner select { cursor: pointer; }
.cron-form-inner textarea { resize: vertical; min-height: 70px; }

.cron-form-actions { display: flex; gap: 6px; }
.cron-form-actions button { flex: 1; padding: 9px; border-radius: var(--radius-sm); font-size: 12px; font-weight: 600; cursor: pointer; }
.cron-form-actions button:first-child { background: var(--accent); color: var(--bg); border: none; }
.cron-form-actions button:first-child:hover { background: var(--accent-hover); }
.cron-form-actions button:last-child { background: var(--bg3); border: 1px solid var(--border); color: var(--text-dim); }
.cron-form-actions button:last-child:hover { background: var(--bg4); }

/* ── Scrollbars ────────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg4); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: var(--white-20); }

/* ── Mobile ────────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  #mobile-nav { display: flex; }
  #app { padding-bottom: var(--nav-h); }

  #sidebar {
    position: fixed;
    left: 0; top: var(--topbar-h);
    bottom: var(--nav-h);
    z-index: 50;
    display: none;
    width: min(320px, 88vw);
    background: var(--surface-mobile-sidebar);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    box-shadow: var(--shadow-float);
  }
  #sidebar.mobile-visible { display: flex; }
  #sidebar.mobile-visible #sidebar-header { display: flex; }

  #sidebar-toggle { display: none; }

  .close-sidebar-btn {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 50%;
    font-size: 16px; color: var(--text-dim);
    background: var(--bg3);
    touch-action: manipulation; flex-shrink: 0;
  }
  .close-sidebar-btn:active { background: var(--bg4); color: var(--text); }

  #files-panel {
    position: fixed;
    left: 0; right: 0;
    bottom: var(--nav-h);
    top: auto;
    height: 75vh;
    width: 100% !important;
    z-index: 50;
    border-left: none;
    border-top: 1px solid var(--border);
    border-radius: var(--radius) var(--radius) 0 0;
    box-shadow: var(--shadow-bottom);
  }
  #files-panel.collapsed { display: none; }

  #crons-panel {
    position: fixed;
    left: 0; right: 0;
    bottom: var(--nav-h);
    top: auto;
    height: 75vh;
    width: 100% !important;
    z-index: 50;
    border-left: none;
    border-top: 1px solid var(--border);
    border-radius: var(--radius) var(--radius) 0 0;
    box-shadow: var(--shadow-bottom);
  }
  #crons-panel.collapsed { display: none; }

  #settings-panel {
    position: fixed;
    left: 0; right: 0;
    bottom: var(--nav-h);
    top: auto;
    height: 80vh;
    width: 100% !important;
    z-index: 50;
    border-left: none;
    border-top: 1px solid var(--border);
    border-radius: var(--radius) var(--radius) 0 0;
    box-shadow: var(--shadow-bottom);
  }
  #settings-panel.collapsed { display: none; }

  #main { flex-direction: column; }
  #chat-area { display: flex; }

  /* Message bubbles — slightly tighter on mobile */
  .msg.user .msg-bubble { max-width: 88%; }
  .msg { max-width: 95%; }

  /* Input area bottom safe area */
  #input-area {
    padding-bottom: env(safe-area-inset-bottom, 0);
  }
}

@media (min-width: 769px) {
  #mobile-nav { display: none; }
  #sidebar { display: flex !important; }
  .close-sidebar-btn { display: none; }
  #panel-overlay { display: none !important; }
}

/* ── PM Feedback Banner ──────────────────────────────────────────────────────── */

#pm-feedback-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: var(--accent-8);
  border-bottom: 1px solid var(--accent-15);
  font-size: 13px;
  color: var(--text);
  animation: slideDown 0.3s ease-out;
  flex-shrink: 0;
}
#pm-feedback-banner span {
  flex: 1;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#pm-feedback-banner button {
  background: var(--accent-15);
  border: 1px solid var(--accent-25);
  color: var(--accent);
  border-radius: 8px;
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}
#pm-feedback-banner #pm-feedback-dismiss {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 14px;
  padding: 4px 6px;
  flex-shrink: 0;
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Inbox / Questions Panel ─────────────────────────────────────────────────── */

#questions-panel {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  transform: translateY(0);
  transition: transform 0.35s var(--ease);
}
#questions-panel.collapsed {
  transform: translateY(100%);
  pointer-events: none;
}

.questions-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.questions-title {
  font-size: 16px;
  font-weight: 600;
}

.questions-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px 16px calc(16px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 16px;
  -webkit-overflow-scrolling: touch;
}

/* Question card */
.q-card {
  background: var(--glass-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: opacity 0.35s var(--ease), transform 0.35s var(--ease);
}
.q-card-memo {
  border-color: var(--accent-25);
  background: var(--accent-5);
}
.q-card-done {
  opacity: 0;
  transform: translateX(50px);
}

.q-card-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.q-label-pm { color: var(--warning); }

.q-card-text {
  font-size: 17px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--text);
}

.q-card-input-wrap {
  position: relative;
}
.q-card-input {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 13px 48px 13px 15px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--text);
  resize: vertical;
  min-height: 80px;
  -webkit-appearance: none;
}
.q-card-input:focus { border-color: var(--accent); outline: none; }

/* Mic button inside the textarea wrapper */
.q-card-mic {
  position: absolute;
  bottom: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bg4);
  color: var(--text-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s, box-shadow 0.2s;
  flex-shrink: 0;
}
.q-card-mic svg { width: 16px; height: 16px; }
.q-card-mic:active { background: var(--bg4); opacity: 0.7; }
@keyframes mic-pulse {
  0%, 100% { box-shadow: 0 0 0 0 var(--danger-50); }
  50%       { box-shadow: 0 0 0 6px var(--danger-0); }
}
.q-card-mic.card-mic-listening {
  background: var(--danger);
  color: var(--on-danger);
  animation: mic-pulse 1.2s ease-in-out infinite;
}

.q-card-actions {
  display: flex;
  gap: 10px;
}
.q-btn-primary {
  flex: 1;
  background: var(--accent2);
  color: var(--on-accent);
  border-radius: var(--radius-sm);
  padding: 14px;
  font-size: 15px;
  font-weight: 600;
  min-height: 48px;
  transition: opacity 0.2s;
}
.q-btn-primary:active { opacity: 0.75; }
.q-btn-primary:disabled { opacity: 0.45; }
.q-btn-ghost {
  padding: 14px 18px;
  color: var(--text-dim);
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  min-height: 48px;
  white-space: nowrap;
}
.q-btn-ghost:active { background: var(--bg3); }

/* Empty state */
.q-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: var(--text-dim);
  font-size: 16px;
  opacity: 0.7;
}
.q-empty svg { width: 52px; height: 52px; opacity: 0.4; }

/* ── Nav badge ─────────────────────────────────────────────────────────────── */

.nav-icon-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
}
.nav-badge {
  position: absolute;
  top: -5px;
  right: -7px;
  background: var(--danger);
  color: var(--on-danger);
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  padding: 0 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  pointer-events: none;
}
@keyframes badge-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 var(--danger-50); }
  50%       { transform: scale(1.2); box-shadow: 0 0 0 5px var(--danger-0); }
}
.nav-btn.has-pending .nav-badge {
  animation: badge-pulse 2s ease-in-out infinite;
}

/* ── Tickets panel ─────────────────────────────────────────────────────────── */

#tickets-panel {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  transform: translateY(0);
  transition: transform 0.35s var(--ease);
}
#tickets-panel.collapsed {
  transform: translateY(100%);
  pointer-events: none;
}

.tickets-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.tickets-title { font-size: 16px; font-weight: 600; }
.tickets-header-right { display: flex; align-items: center; gap: 4px; }

.tickets-filter-bar {
  display: flex;
  gap: 6px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  flex-shrink: 0;
  scrollbar-width: none;
}
.tickets-filter-bar::-webkit-scrollbar { display: none; }

.tkt-filter-btn {
  flex-shrink: 0;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 500;
  background: var(--bg3);
  color: var(--text-dim);
  transition: background 0.15s, color 0.15s;
}
.tkt-filter-btn.active,
.tkt-filter-btn:hover { background: var(--accent); color: var(--bg); }

.tickets-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 8px;
  -webkit-overflow-scrolling: touch;
}

/* ── Ticket cards ──────────────────────────────────────────────────────────── */

.tkt-card {
  background: var(--glass-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: background 0.15s var(--ease);
}
.tkt-card:hover { background: var(--bg3); }
.tkt-card:active { background: var(--bg4); transform: scale(0.99); }

.tkt-card-header { display: flex; align-items: center; gap: 6px; }

.tkt-priority, .tkt-status {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  letter-spacing: 0.02em;
}

.tkt-pri-low    { background: var(--success-15); color: var(--success); }
.tkt-pri-med    { background: var(--warning-15);  color: var(--warning); }
.tkt-pri-high   { background: var(--danger-20);    color: var(--danger);  }

.tkt-status-open     { background: var(--gray-20);  color: var(--text-dim); }
.tkt-status-assigned { background: var(--accent-12);  color: var(--accent);   }
.tkt-status-progress { background: var(--accent-22);  color: var(--accent);   }
.tkt-status-review   { background: var(--warning-20);   color: var(--warning);  }
.tkt-status-done     { background: var(--success-15); color: var(--success);  }
.tkt-status-archived  { background: var(--gray-10);  color: var(--text-dim); }
.tkt-status-cancelled  { background: var(--red-8);  color: var(--red-60); }
.tkt-status-evaluating { background: var(--violet-18); color: var(--violet); }

.tkt-card-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.3;
}
.tkt-card-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--text-dim);
}
.tkt-meta-icon { width: 11px; height: 11px; vertical-align: middle; margin-right: 2px; }

.tkt-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: var(--text-dim);
  font-size: 14px;
  padding: 56px 0;
  opacity: 0.7;
}
.tkt-empty svg { width: 48px; height: 48px; opacity: 0.35; }

/* ── Ticket create modal (bottom sheet) ────────────────────────────────────── */

.tkt-modal {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: var(--black-55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  transition: opacity 0.25s var(--ease);
}
.tkt-modal.collapsed { opacity: 0; pointer-events: none; }

.tkt-modal-inner {
  width: 100%;
  max-width: 560px;
  background: var(--bg);
  border-top: 1px solid var(--border);
  border-radius: var(--radius) var(--radius) 0 0;
  display: flex;
  flex-direction: column;
  max-height: 90vh;
  transform: translateY(0);
  transition: transform 0.3s var(--ease);
}
.tkt-modal.collapsed .tkt-modal-inner { transform: translateY(100%); }

.tkt-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  font-size: 15px;
  font-weight: 600;
  flex-shrink: 0;
}
.tkt-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.tkt-input, .tkt-textarea, .tkt-select {
  width: 100%;
  padding: 10px 14px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 14px;
  color: var(--text);
  transition: border-color 0.15s;
}
.tkt-input:focus, .tkt-textarea:focus, .tkt-select:focus {
  border-color: var(--accent-50);
  outline: none;
}
.tkt-textarea { resize: vertical; min-height: 60px; }
.tkt-select { cursor: pointer; }
.tkt-select option { background: var(--bg); }

.tkt-form-row { display: flex; align-items: center; gap: 8px; }
.tkt-form-row .tkt-select { flex: 1; }
.tkt-attach-row { flex-wrap: wrap; }

.tkt-attach-label {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  flex-shrink: 0;
}
.tkt-attach-label:hover { background: var(--bg4); color: var(--text); }

.tkt-attach-chips { display: flex; flex-wrap: wrap; gap: 4px; flex: 1; }
.tkt-attach-chip {
  font-size: 11px;
  padding: 3px 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  color: var(--text-dim);
}

.tkt-auto-row { padding: 6px 0; align-items: center; min-height: 44px; cursor: pointer; user-select: none; }
.tkt-switch-label { font-size: 13px; color: var(--text-dim); flex: 1; }

.tkt-modal-footer {
  display: flex;
  gap: 8px;
  padding: 14px 20px calc(14px + env(safe-area-inset-bottom, 0px));
  flex-shrink: 0;
  border-top: 1px solid var(--border);
}
.tkt-btn-cancel {
  padding: 11px 18px;
  border-radius: var(--radius-sm);
  font-size: 14px;
  background: var(--bg3);
  color: var(--text-dim);
  border: 1px solid var(--border);
  transition: background 0.15s;
}
.tkt-btn-cancel:hover { background: var(--bg4); }
.tkt-btn-submit {
  flex: 1;
  padding: 11px;
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: 600;
  background: var(--accent);
  color: var(--bg);
  transition: background 0.15s;
}
.tkt-btn-submit:hover { background: var(--accent-hover); }
.tkt-btn-submit:disabled { background: var(--bg3); color: var(--text-dim); cursor: default; }

/* Recording active state */
#tkt-mic-btn.active { color: var(--danger); animation: mic-pulse 1s ease-in-out infinite; }
#btn-dispatch-tickets.spinning { animation: spin 1s linear infinite; color: var(--accent); }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Ticket detail (slide from right) ──────────────────────────────────────── */

.tkt-detail {
  position: fixed;
  inset: 0;
  z-index: 250;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  transform: translateX(0);
  transition: transform 0.3s var(--ease);
}
.tkt-detail.collapsed { transform: translateX(100%); pointer-events: none; }

.tkt-detail-inner { display: flex; flex-direction: column; height: 100%; }

.tkt-detail-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  padding-top: calc(12px + env(safe-area-inset-top, 0px));
}
.tkt-detail-id-label {
  font-size: 11px;
  color: var(--text-dim);
  font-family: monospace;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tkt-detail-header-right { display: flex; gap: 4px; }

.tkt-detail-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px 20px calc(20px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 16px;
  -webkit-overflow-scrolling: touch;
}
.tkt-detail-title { font-size: 18px; font-weight: 600; line-height: 1.3; }

.tkt-detail-fields { display: flex; flex-direction: column; gap: 8px; }
.tkt-detail-field { display: flex; align-items: center; gap: 12px; }
.tkt-detail-field label { font-size: 12px; color: var(--text-dim); width: 68px; flex-shrink: 0; }
.tkt-detail-field select {
  flex: 1;
  padding: 6px 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
}
.tkt-detail-field select option { background: var(--bg); }

.tkt-detail-desc {
  font-size: 14px;
  color: var(--text-dim);
  line-height: 1.5;
  white-space: pre-wrap;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
}

.tkt-attachments-list { display: flex; flex-wrap: wrap; gap: 8px; }
.tkt-attach-item { border-radius: var(--radius-sm); overflow: hidden; }
.tkt-attach-image img {
  width: 80px; height: 80px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  display: block;
}
.tkt-attach-file {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 12px;
  color: var(--text-dim);
}

.tkt-thread-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  background: var(--bg3);
  border: 1px solid var(--border);
  font-size: 13px;
  color: var(--accent);
  align-self: flex-start;
  transition: background 0.15s;
}
.tkt-thread-btn:hover { background: var(--bg4); }

.tkt-detail-actions-row { display: flex; flex-wrap: wrap; gap: 8px; }

.tkt-btn-approve {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 16px;
  border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 600;
  background: var(--success-18);
  color: var(--success);
  border: 1px solid var(--success-30);
  transition: background 0.15s;
}
.tkt-btn-approve:hover { background: var(--success-30); }

.tkt-btn-start {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 16px;
  border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 600;
  background: var(--accent-15);
  color: var(--accent);
  border: 1px solid var(--accent-30);
  transition: background 0.15s;
}
.tkt-btn-start:hover { background: var(--accent-25); }

.tkt-btn-archive {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  background: var(--bg3);
  color: var(--text-dim);
  border: 1px solid var(--border);
  transition: background 0.15s, color 0.15s;
}
.tkt-btn-archive:hover { background: var(--danger-10); color: var(--danger); }

.tkt-comments-section { display: flex; flex-direction: column; gap: 10px; }
.tkt-comments-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.tkt-comment {
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: var(--bg3);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.tkt-comment-user  { border-left: 2px solid var(--accent); }
.tkt-comment-agent { border-left: 2px solid var(--success); }
.tkt-comment-author { font-size: 11px; font-weight: 600; color: var(--text-dim); }
.tkt-comment-text  { font-size: 13px; line-height: 1.45; color: var(--text); white-space: pre-wrap; }
.tkt-comment-time  { font-size: 10px; color: var(--text-dim); opacity: 0.6; }
.tkt-comment-empty { font-size: 12px; color: var(--text-dim); font-style: italic; padding: 4px 0; }

.tkt-comment-form { display: flex; gap: 8px; align-items: flex-end; }
.tkt-comment-form textarea {
  flex: 1;
  padding: 8px 12px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--text);
  resize: none;
  min-height: 40px;
  max-height: 100px;
}
.tkt-comment-form textarea:focus { border-color: var(--accent-50); outline: none; }
.tkt-comment-form button {
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  background: var(--accent);
  color: var(--bg);
  font-size: 13px;
  font-weight: 600;
  flex-shrink: 0;
  transition: background 0.15s;
}
.tkt-comment-form button:hover { background: var(--accent-hover); }

/* ── Claude Reauth Modal ──────────────────────────────────────────────────── */
#reauth-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--black-75);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
}
#reauth-modal {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 28px 24px 24px;
  max-width: 420px; width: 90%;
  display: flex; flex-direction: column; gap: 14px;
  box-shadow: var(--shadow-float);
}
.reauth-icon { color: var(--warning); display: flex; }
.reauth-icon svg { width: 28px; height: 28px; }
.reauth-title { font-size: 18px; font-weight: 600; color: var(--text); }
.reauth-desc { font-size: 13px; color: var(--text-dim); line-height: 1.5; }
.reauth-url {
  font-size: 12px; word-break: break-all; color: var(--accent);
  background: var(--bg3); border-radius: var(--radius-sm);
  padding: 8px 12px; text-decoration: none;
  border: 1px solid var(--border);
}
.reauth-url:empty { display: none; }
.reauth-url:hover { text-decoration: underline; }
.reauth-input-row { display: flex; gap: 8px; }
#reauth-token-input {
  flex: 1; padding: 9px 12px; background: var(--bg3);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  font-size: 13px; color: var(--text);
  font-family: monospace;
}
#reauth-token-input:focus { border-color: var(--accent-50); outline: none; }
#reauth-submit-btn {
  padding: 9px 16px; border-radius: var(--radius-sm);
  background: var(--accent); color: var(--bg);
  font-size: 13px; font-weight: 600; flex-shrink: 0;
  transition: background 0.15s;
}
#reauth-submit-btn:hover { background: var(--accent-hover); }
#reauth-submit-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.reauth-status { font-size: 12px; color: var(--text-dim); min-height: 16px; }
.reauth-status.ok { color: var(--success); }
.reauth-status.err { color: var(--danger); }

/* ── Thread share button & badges ──────────────────────────────────────────── */
.thread-share-btn {
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: var(--radius-sm);
  color: var(--text-dim); opacity: 0; transition: opacity 0.15s, color 0.15s;
  background: transparent;
}
.thread-item:hover .thread-share-btn { opacity: 1; }
.thread-share-btn:hover { color: var(--accent); }
.thread-shared-badge {
  display: inline-block; font-size: 9px; font-weight: 600; padding: 1px 5px;
  border-radius: 8px; background: var(--accent-15); color: var(--accent);
  vertical-align: middle; margin-left: 4px; text-transform: uppercase; letter-spacing: 0.04em;
}
.thread-owner-badge {
  display: inline-block; font-size: 9px; font-weight: 600; padding: 1px 5px;
  border-radius: 8px; background: var(--violet-15); color: var(--violet);
  vertical-align: middle; margin-left: 4px; letter-spacing: 0.02em;
}
.thread-share-count {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; color: var(--text-dim); margin-left: 4px;
}
.thread-task-badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 9px; font-weight: 600; padding: 1px 6px;
  border-radius: 8px; background: var(--amber-12); color: var(--amber);
  cursor: pointer; white-space: nowrap; overflow: hidden; max-width: 120px;
  text-overflow: ellipsis; vertical-align: middle; margin-top: 2px;
}
.thread-task-badge:hover { background: var(--amber-22); }
.thread-context-bar {
  font-size: 11px; color: var(--text-dim); display: flex; align-items: center;
  gap: 6px; padding: 0 12px; height: 22px; border-bottom: 1px solid var(--border);
  background: var(--bg2); overflow: hidden;
}
.thread-context-bar:empty { display: none; }
.thread-context-link {
  display: inline-flex; align-items: center; gap: 4px;
  color: var(--accent); cursor: pointer; font-weight: 500; white-space: nowrap;
}
.thread-context-link:hover { text-decoration: underline; }
.thread-context-sep { opacity: 0.4; }

/* ── Modals (change-password, share, team) ──────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--black-60); backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center; padding: 16px;
}
.modal-box {
  background: var(--sidebar-bg); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 0; width: 100%; max-width: 380px;
  box-shadow: 0 8px 32px var(--black-40); display: flex; flex-direction: column;
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  font-size: 14px; font-weight: 600; color: var(--text);
}
.modal-body {
  padding: 16px; display: flex; flex-direction: column; gap: 10px;
}
.modal-input {
  width: 100%; padding: 8px 10px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); background: var(--chat-bg);
  color: var(--text); font-size: 13px; outline: none; box-sizing: border-box;
}
.modal-input:focus { border-color: var(--accent-40); }
.modal-error   { font-size: 12px; color: var(--danger); }
.modal-success { font-size: 12px; color: var(--success); }
.modal-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 12px 16px; border-top: 1px solid var(--border);
}
.modal-btn {
  padding: 7px 14px; border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 600; cursor: pointer; transition: background 0.15s;
}
.modal-btn.primary { background: var(--accent); color: var(--bg); }
.modal-btn.primary:hover { background: var(--accent-hover); }
.modal-btn.secondary { background: var(--btn-bg); color: var(--text); }
.modal-btn.secondary:hover { background: var(--btn-hover); }
.modal-btn.small { padding: 6px 10px; font-size: 12px; }

/* ── Close Plan intent modal ───────────────────────────────────────────────── */
.close-plan-modal-box { max-width: 320px; }
.close-plan-modal-body { gap: 8px; }
.close-plan-choice {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 12px 14px; border-radius: 8px; cursor: pointer;
  background: var(--btn-bg); border: 1px solid var(--border);
  text-align: left; transition: border-color .15s, background .15s;
}
.close-plan-choice svg { width: 18px; height: 18px; flex-shrink: 0; }
.close-plan-choice-title { font-size: 13px; font-weight: 600; color: var(--text); }
.close-plan-choice-desc  { font-size: 11px; color: var(--text-dim); margin-top: 1px; }
.close-plan-choice-complete:hover { border-color: var(--green); background: var(--green-12); }
.close-plan-choice-complete:hover svg { color: var(--green); }
.close-plan-choice-cancel:hover { border-color: var(--danger); background: var(--danger-8); }
.close-plan-choice-cancel:hover svg { color: var(--danger); }

/* ── Share list & team members ──────────────────────────────────────────────── */
.share-list {
  display: flex; flex-direction: column; gap: 6px;
  max-height: 160px; overflow-y: auto;
}
.share-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px; border-radius: var(--radius-sm);
  background: var(--chat-bg); font-size: 13px; color: var(--text);
}
.share-item span:first-child { flex: 1; }
.share-remove-btn {
  width: 20px; height: 20px; border-radius: 50%; background: transparent;
  color: var(--text-dim); font-size: 14px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.12s, color 0.12s;
}
.share-remove-btn:hover { background: var(--danger); color: var(--on-danger); }
.share-add-row { display: flex; gap: 8px; align-items: center; }
.share-add-row .modal-input { flex: 1; margin: 0; }
.team-role-badge {
  font-size: 10px; font-weight: 600; padding: 2px 6px; border-radius: 8px;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.team-role-badge.owner  { background: var(--orange-15); color: var(--orange); }
.team-role-badge.member { background: var(--accent-12); color: var(--accent); }
.team-role-badge.admin  { background: var(--danger-12);  color: var(--danger); }

/* ── Tareas panel ──────────────────────────────────────────────────────────── */
#tareas-panel {
  position: fixed; inset: 0; background: var(--bg);
  z-index: 300; display: flex; flex-direction: column;
  transform: translateY(0); transition: transform 0.35s var(--ease);
}
#tareas-panel.collapsed { transform: translateY(100%); pointer-events: none; }
.tareas-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 10px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.tareas-title { font-size: 15px; font-weight: 600; }
.tareas-header-right { display: flex; gap: 4px; align-items: center; }
.tareas-filter-bar {
  display: flex; gap: 6px; padding: 8px 16px; overflow-x: auto;
  border-bottom: 1px solid var(--border); flex-shrink: 0; scrollbar-width: none;
}
.tareas-filter-bar::-webkit-scrollbar { display: none; }
.task-filter-btn {
  padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 500;
  border: 1px solid var(--border); background: transparent; color: var(--text-dim);
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
}
.task-filter-btn.active { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.plan-chips-bar {
  display: flex; gap: 6px; padding: 6px 16px; overflow-x: auto; flex-shrink: 0;
  background: var(--bg2); border-bottom: 1px solid var(--border); scrollbar-width: none;
}
.plan-chips-bar::-webkit-scrollbar { display: none; }
.plan-chip {
  padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 500;
  border: 1px solid var(--border); background: var(--bg3); color: var(--text-dim);
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
}
.plan-chip.active { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.plan-detail-bar {
  padding: 8px 16px; background: var(--bg2);
  border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.plan-detail-goal {
  font-size: 12px; color: var(--text-dim); margin-bottom: 0; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  flex: 1; min-width: 0;
}
.plan-detail-progress-row { display: flex; align-items: center; gap: 8px; }
.plan-progress-bar-wrap {
  flex: 1; height: 6px; background: var(--border); border-radius: 3px; overflow: hidden;
}
.plan-progress-fill { height: 100%; background: var(--accent); border-radius: 3px; transition: width .3s ease; min-width: 0; }
.plan-progress-pct { font-size: 11px; color: var(--text-dim); width: 30px; text-align: right; flex-shrink: 0; }
.tareas-body { flex: 1; overflow-y: auto; padding: 8px 16px 80px; }
.task-plan-badge {
  font-size: 10px; padding: 2px 6px; background: var(--bg3);
  border: 1px solid var(--border); border-radius: 4px; color: var(--text-dim);
}
.task-dep-badge {
  font-size: 10px; padding: 2px 6px; background: var(--amber-alt-12);
  border: 1px solid var(--amber-alt-30); border-radius: 4px; color: var(--amber-alt);
  display: inline-flex; align-items: center; gap: 3px;
}
.task-approve-btn {
  margin-left: auto; font-size: 11px; padding: 2px 8px;
  background: var(--green-15); border: 1px solid var(--green-35);
  color: var(--green); border-radius: 4px; cursor: pointer;
  display: inline-flex; align-items: center; gap: 3px;
}
.task-approve-btn:active { opacity: 0.7; }

/* ── Thread list empty states ─────────────────────────────────────────────── */
.thread-list-empty { padding: 24px 16px; color: var(--text-dim); font-size: 12px; text-align: center; }
.thread-list-clean { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 40px 16px; }
.thread-list-clean .clean-icon { font-size: 28px; opacity: 0.6; }
.thread-list-clean .clean-sub { font-size: 11px; opacity: 0.5; margin-top: 2px; }
.settings-bark-row { display: flex; gap: 8px; align-items: center; padding: 8px 12px; }

/* ── Task list redesign ───────────────────────────────────────────────────── */

.task-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 0 6px;
}
.task-section-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-dim);
}
.task-section-count {
  font-size: 10px;
  padding: 1px 5px;
  background: var(--bg3);
  border-radius: 10px;
  color: var(--text-dim);
}
.task-section-review .task-section-label { color: var(--warning); }
.task-section-review .task-section-count { background: var(--warning-15); color: var(--warning); }
.task-section-progress .task-section-label { color: var(--accent); }
.task-section-done .task-section-label { color: var(--success); opacity: 0.7; }
.task-section-gap { height: 4px; }
.task-section-sub-label {
  font-size: 10px;
  color: var(--text-dim);
  opacity: 0.5;
  padding: 6px 0 2px;
  font-style: italic;
}

.task-card-review {
  border-color: var(--warning-25);
  background: var(--warning-4);
}
.task-card-review:hover { background: var(--warning-8); }

.task-card-ready {
  border-color: var(--success-30);
  background: var(--success-4);
}
.task-card-ready:hover { background: var(--success-8); }

.task-ready-badge {
  font-size: 10px; padding: 2px 6px;
  background: var(--success-15);
  border: 1px solid var(--success-35);
  border-radius: 4px; color: var(--success);
  display: inline-flex; align-items: center; gap: 3px;
}

/* ── Plan chip new dot ────────────────────────────────────────────────────── */
.plan-chip { position: relative; }
.plan-chip-dot {
  position: absolute; top: -3px; right: -3px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); border: 2px solid var(--bg2);
}

/* ── Plan next step banner ────────────────────────────────────────────────── */
.plan-next-step-banner {
  display: flex; flex-direction: column; gap: 4px;
  padding: 10px 12px; margin-bottom: 10px;
  background: var(--success-6);
  border: 1px solid var(--success-25);
  border-radius: var(--radius); cursor: pointer;
  transition: background 0.15s;
}
.plan-next-step-banner:hover { background: var(--success-10); }
.plan-next-step-label {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--success);
  display: flex; align-items: center; gap: 4px;
}
.plan-next-step-title {
  font-size: 13px; font-weight: 500; color: var(--text);
}
.plan-next-step-btn {
  align-self: flex-start; margin-top: 4px;
  padding: 5px 12px; border-radius: var(--radius-sm);
  font-size: 12px; font-weight: 600;
  background: var(--success-15);
  border: 1px solid var(--success-35);
  color: var(--success); cursor: pointer;
  display: inline-flex; align-items: center; gap: 4px;
  transition: background 0.15s;
}
.plan-next-step-btn:hover { background: var(--success-25); }

/* ── Plan in-progress strip ──────────────────────────────────────────────── */
.plan-inprogress-strip {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; margin-bottom: 6px;
  background: var(--blue-6);
  border: 1px solid var(--blue-18);
  border-radius: var(--radius); cursor: pointer;
  transition: background 0.15s;
}
.plan-inprogress-strip:hover { background: var(--blue-10); }
.plan-inprogress-spin {
  width: 14px; height: 14px; color: var(--accent); flex-shrink: 0;
  animation: spin 1.2s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.plan-inprogress-title {
  flex: 1; font-size: 13px; color: var(--text); font-weight: 500;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.plan-inprogress-label {
  font-size: 10px; color: var(--accent); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.04em; flex-shrink: 0;
}
.plan-inprogress-chevron { width: 14px; height: 14px; color: var(--text-dim); flex-shrink: 0; }
.plan-inprogress-strip--pipeline { opacity: 0.6; margin-bottom: 4px; }

/* ── Plan pipeline separator & cards ────────────────────────────────────── */
.plan-pipeline-sep {
  display: flex; align-items: center; gap: 8px;
  margin: 14px 0 8px; color: var(--text-dim);
}
.plan-pipeline-sep::before, .plan-pipeline-sep::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.plan-pipeline-sep span { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; flex-shrink: 0; }

.pipeline-card {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; margin-bottom: 4px;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--bg2); cursor: pointer; transition: background 0.15s;
}
.pipeline-card:hover { background: var(--bg3); }
.pipeline-card-done { opacity: 0.5; }
.pipeline-card-blocked { opacity: 0.65; }
.pipeline-card-icon { width: 14px; height: 14px; color: var(--text-dim); flex-shrink: 0; }
.pipeline-card-done .pipeline-card-icon { color: var(--success); }
.pipeline-card-title {
  flex: 1; font-size: 12px; color: var(--text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pipeline-card-done .pipeline-card-title { text-decoration: line-through; color: var(--text-dim); }
.pipeline-card-chevron { width: 13px; height: 13px; color: var(--text-dim); flex-shrink: 0; }
.pipeline-dep { margin-left: auto; flex-shrink: 0; }
.pipeline-card-next {
  border-color: var(--success-30);
  background: var(--success-6);
  opacity: 0.75;
}
.pipeline-card-next .pipeline-card-icon { color: var(--success); }
.pipeline-card-next .pipeline-card-title { color: var(--text); }
.pipeline-card-cancelled {
  opacity: 0.35; border-style: dashed;
}
.pipeline-card-cancelled .pipeline-card-icon { color: var(--red-50); }
.pipeline-card-cancelled .pipeline-card-title { text-decoration: line-through; color: var(--text-dim); }

/* ── Cancel button in drawer ─────────────────────────────────────────────── */
.task-btn-cancel {
  width: 100%; margin-top: 12px;
  padding: 7px 12px; border-radius: var(--radius-sm);
  font-size: 11px; background: transparent;
  border: 1px solid var(--red-25);
  color: var(--red-50); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  transition: all 0.15s;
}
.task-btn-cancel:hover { background: var(--red-8); border-color: var(--red-50); color: var(--red-90); }

/* ── "Ver canceladas" toggle ─────────────────────────────────────────────── */
.task-cancelled-toggle {
  display: flex; align-items: center; gap: 5px;
  width: 100%; margin-top: 12px; padding: 6px 0;
  background: none; border: none; cursor: pointer;
  font-size: 11px; color: var(--text-dim); opacity: 0.5;
  transition: opacity 0.15s;
}
.task-cancelled-toggle:hover { opacity: 1; }

.task-card-summary {
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.5;
  margin: 4px 0 2px;
  padding: 6px 8px;
  background: var(--bg3);
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--warning-40);
}

.task-card-eval {
  font-size: 12px;
  line-height: 1.45;
  margin: 4px 0 2px;
  padding: 6px 8px;
  border-radius: var(--radius-sm);
}
.task-card-eval-passed {
  background: var(--success-10);
  border-left: 2px solid var(--success-50);
  color: var(--success);
}
.task-card-eval-failed {
  background: var(--red-8);
  border-left: 2px solid var(--red-40);
  color: var(--red-85);
}
.task-card-evaluating {
  background: var(--violet-6);
  border: 1px solid var(--violet-20);
}
.task-card-evaluating:hover { background: var(--violet-10); }

.task-eval-spin {
  display: inline-block;
  animation: spin 1.2s linear infinite;
  vertical-align: -2px;
  margin-right: 4px;
}

.task-drawer-criteria {
  font-size: 13px;
  color: var(--text);
  line-height: 1.5;
  padding: 8px 10px;
  background: var(--violet-8);
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--violet-45);
}

.task-drawer-eval-result {
  font-size: 13px;
  line-height: 1.5;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
}
.task-drawer-eval-passed {
  background: var(--success-10);
  border-left: 2px solid var(--success-50);
  color: var(--success);
}
.task-drawer-eval-failed {
  background: var(--red-8);
  border-left: 2px solid var(--red-40);
  color: var(--red-85);
}
.task-drawer-eval-meta {
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 4px;
}
.task-btn-override {
  flex: 1;
  padding: 7px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  background: var(--violet-12);
  border: 1px solid var(--violet-30);
  color: var(--violet);
  cursor: pointer;
  transition: background 0.15s;
  display: flex; align-items: center; gap: 5px; justify-content: center;
}
.task-btn-override:hover { background: var(--violet-22); }

.plan-success-criteria {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 4px;
  padding: 5px 8px;
  background: var(--violet-6);
  border-left: 2px solid var(--violet-30);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  line-height: 1.4;
}

.task-card-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}
.task-btn-approve {
  flex: 1;
  padding: 7px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  background: var(--success-15);
  border: 1px solid var(--success-35);
  color: var(--success);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: background 0.15s;
}
.task-btn-approve:hover { background: var(--success-25); }
.task-btn-approve:active { opacity: 0.7; }
.task-btn-reject {
  flex: 1;
  padding: 7px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: background 0.15s;
}
.task-btn-reject:hover { background: var(--bg4); color: var(--text); }
.task-btn-secondary {
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background 0.15s;
}
.task-btn-secondary:hover { background: var(--bg4); color: var(--text); }
.task-btn-small { font-size: 12px; padding: 5px 10px; }

/* ── Task drawer ──────────────────────────────────────────────────────────── */

.task-drawer {
  position: fixed;
  inset: 0;
  z-index: 350;
  pointer-events: none;
}
.task-drawer:not(.collapsed) { pointer-events: all; }

.task-drawer-overlay {
  position: absolute;
  inset: 0;
  background: var(--black-45);
  opacity: 0;
  transition: opacity 0.3s var(--ease);
}
.task-drawer:not(.collapsed) .task-drawer-overlay { opacity: 1; }

.task-drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(480px, 100vw);
  background: var(--bg);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s var(--ease);
  box-shadow: var(--shadow-side);
}
.task-drawer:not(.collapsed) .task-drawer-panel { transform: translateX(0); }

.task-drawer-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  padding-top: calc(12px + env(safe-area-inset-top, 0px));
}

.task-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  -webkit-overflow-scrolling: touch;
}

.task-drawer-title {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.35;
  margin: 0;
}

.task-drawer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 12px;
  color: var(--text-dim);
}
.task-drawer-meta > span { display: flex; align-items: center; gap: 3px; }
.task-drawer-time { font-style: italic; }

.task-drawer-section { display: flex; flex-direction: column; gap: 6px; }
.task-drawer-section-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-dim);
}
.task-drawer-summary-box {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg3);
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--warning-50);
  padding: 10px 12px;
  white-space: pre-wrap;
}
.task-drawer-desc-text {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-dim);
  white-space: pre-wrap;
}

.task-dep-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  padding: 4px 0;
}
.task-dep-item.met { color: var(--success); }
.task-dep-item.unmet { color: var(--text-dim); }
.task-dep-icon { width: 13px; height: 13px; flex-shrink: 0; }

.task-drawer-notes-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.task-drawer-note {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 12px;
  padding: 6px 8px;
  background: var(--bg3);
  border-radius: var(--radius-sm);
}
.task-drawer-note-author {
  font-size: 10px;
  color: var(--text-dim);
  font-weight: 600;
  text-transform: uppercase;
}
.task-drawer-note-text { color: var(--text); line-height: 1.4; }
.task-drawer-empty-notes { font-size: 12px; color: var(--text-dim); opacity: 0.6; }
.task-drawer-note-input-row {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-top: 4px;
}
.task-drawer-note-input-row .tkt-input { flex: 1; padding: 8px 12px; }

.task-drawer-footer {
  border-top: 1px solid var(--border);
  padding: 14px 20px calc(14px + env(safe-area-inset-bottom, 0px));
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.task-drawer-reject-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.task-drawer-reject-section.collapsed { display: none; }
.task-drawer-reject-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.task-drawer-reject-actions .tkt-btn-cancel { padding: 8px 14px; }
.task-drawer-main-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.task-drawer-main-actions .task-btn-approve { flex: 1; padding: 11px; font-size: 14px; }
.task-drawer-main-actions .task-btn-reject { flex: 1; padding: 11px; font-size: 14px; }

@media (max-width: 600px) {
  .task-drawer-panel { width: 100vw; border-left: none; }
}

/* ── Plan detail bar enhancements ──────────────────────────────────────────── */
.plan-detail-header-row {
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.plan-start-banner {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 7px; padding: 9px 12px;
  background: var(--emerald-7); border: 1px solid var(--emerald-22);
  border-radius: 8px; cursor: pointer; transition: background 0.15s;
}
.plan-start-banner:hover { background: var(--emerald-14); }
.plan-start-banner-icon { color: var(--emerald); flex-shrink: 0; display: flex; }
.plan-start-banner-icon svg { width: 18px; height: 18px; }
.plan-start-banner-text { flex: 1; min-width: 0; }
.plan-start-banner-title { font-size: 12px; font-weight: 600; color: var(--emerald); }
.plan-start-banner-sub { font-size: 11px; color: var(--text-dim); margin-top: 1px; }
.plan-start-banner-arrow { color: var(--emerald); opacity: 0.5; flex-shrink: 0; display: flex; }
.plan-start-banner-arrow svg { width: 14px; height: 14px; }
.plan-status-badge {
  font-size: 10px; padding: 2px 7px; border-radius: 999px; flex-shrink: 0;
  background: var(--green-12); border: 1px solid var(--green-30);
  color: var(--green); font-weight: 600; white-space: nowrap; align-self: center;
}
.plan-close-btn {
  font-size: 11px; padding: 2px 9px; border-radius: 5px; cursor: pointer; flex-shrink: 0;
  background: transparent; border: 1px solid var(--border); color: var(--text-dim);
  white-space: nowrap; align-self: center;
}
.plan-close-btn:hover { border-color: var(--accent); color: var(--accent); }

.plan-pm-btn {
  font-size: 11px; padding: 2px 9px; border-radius: 5px; cursor: pointer; flex-shrink: 0;
  background: var(--violet-12); border: 1px solid var(--violet-35);
  color: var(--violet); white-space: nowrap; align-self: center;
  display: flex; align-items: center; gap: 4px;
}
.plan-pm-btn:hover { background: var(--violet-22); }
.plan-start-btn {
  font-size: 11px; padding: 2px 10px; border-radius: 5px; cursor: pointer; flex-shrink: 0;
  background: var(--emerald-15); border: 1px solid var(--emerald-40);
  color: var(--emerald); white-space: nowrap; align-self: center;
  display: flex; align-items: center; gap: 4px; font-weight: 600;
}
.plan-start-btn:hover { background: var(--emerald-28); }
.plan-card-pending-start { font-size: 11px; color: var(--emerald); display: flex; align-items: center; gap: 3px; }
.plan-card-pending-start svg { width: 12px; height: 12px; }
.plan-card-cancelled-label { font-size: 11px; color: var(--text-dim); display: flex; align-items: center; gap: 3px; opacity: 0.7; }
.plan-card-cancelled-label svg { width: 12px; height: 12px; }
.plan-status-badge-cancelled {
  font-size: 10px; padding: 2px 7px; border-radius: 999px; flex-shrink: 0;
  background: var(--btn-bg); border: 1px solid var(--border);
  color: var(--text-dim); font-weight: 600; white-space: nowrap; align-self: center;
}
.plan-hub-footer-link-cancelled { color: var(--text-dim); opacity: 0.7; }
.plan-hub-section-label-cancelled { color: var(--text-dim); opacity: 0.7; }
.plan-chip-done { opacity: 0.55; }
.plan-chip-done.active { opacity: 1; }
.plan-chip-cancelled { opacity: 0.4; text-decoration: line-through; }
.plan-chip-cancelled.active { opacity: 0.75; }

/* ── Plans Hub ──────────────────────────────────────────────────────────────── */
.plan-hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
  padding: 12px 16px 4px;
}
.plan-hub-card {
  background: var(--bg2); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px; cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}
.plan-hub-card:hover { border-color: var(--accent); box-shadow: 0 2px 8px var(--black-15); }
.plan-hub-card-done { opacity: 0.5; }
.plan-hub-card-done:hover { opacity: 0.8; }
.plan-hub-card-cancelled { opacity: 0.35; filter: grayscale(0.6); }
.plan-hub-card-cancelled:hover { opacity: 0.65; }
.plan-hub-card-name { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.plan-hub-card-goal { font-size: 11px; color: var(--text-dim); line-height: 1.4; margin-bottom: 10px; }
.plan-hub-progress-row { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; }
.plan-hub-progress-bar { flex: 1; height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; }
.plan-hub-progress-fill { height: 100%; background: var(--accent); border-radius: 2px; transition: width .3s ease; }
.plan-hub-pct { font-size: 11px; color: var(--text-dim); width: 28px; text-align: right; flex-shrink: 0; }
.plan-hub-card-meta { display: flex; align-items: center; justify-content: space-between; gap: 6px; flex-wrap: wrap; }
.plan-card-alert { font-size: 11px; color: var(--amber-alt); display: flex; align-items: center; gap: 3px; }
.plan-card-alert svg { width: 12px; height: 12px; }
.plan-card-running { font-size: 11px; color: var(--accent); display: flex; align-items: center; gap: 3px; }
.plan-card-running svg { width: 12px; height: 12px; }
.plan-hub-task-count { font-size: 11px; color: var(--text-dim); margin-left: auto; }
.plan-hub-footer {
  display: flex; gap: 12px; padding: 10px 16px; flex-wrap: wrap;
  border-top: 1px solid var(--border); margin-top: 4px;
}
.plan-hub-footer-link {
  font-size: 12px; color: var(--text-dim); background: none; border: none; cursor: pointer;
  display: flex; align-items: center; gap: 5px; padding: 2px 0;
}
.plan-hub-footer-link:hover { color: var(--text); }
.plan-hub-footer-link svg { width: 13px; height: 13px; }
.plan-hub-section-label {
  font-size: 11px; font-weight: 600; color: var(--text-dim); text-transform: uppercase;
  letter-spacing: .06em; padding: 12px 16px 4px;
}
@media (max-width: 480px) {
  .plan-hub-grid { grid-template-columns: 1fr; }
}

/* ── Light palette ─────────────────────────────────────────────────────────── */
/* Fondos casi-blancos con sutil tinte frío. Contraste WCAG AA en texto.        */
/* --accent #0062a3 (azul-cyan AA) ≈ 5.8:1 vs #f0f4f8 — pasa AA para texto normal */
[data-theme="light"] {
  color-scheme: light;
  /* Backgrounds */
  --bg:        #f0f4f8;
  --bg2:       rgba(0,0,0,0.02);
  --bg3:       rgba(0,0,0,0.05);
  --bg4:       rgba(0,0,0,0.09);
  /* Text — #1a2536 vs #f0f4f8 ≈ 14:1 (AAA); text-dim #5a6e85 ≈ 4.8:1 (AA) */
  --text:      #1a2536;
  --text-dim:  #5a6e85;
  /* Accent — #0062a3 ≈ 5.8:1 vs #f0f4f8 — AA para texto normal + UI */
  --accent:    #0062a3;
  --accent2:   #004080;
  --accent-hover: #004f8a;
  /* Semantic — variantes oscuras para contraste sobre fondo claro */
  --success:   #2e7d32;
  --warning:   #e65100;
  --danger:    #c62828;
  /* Borders + glass */
  --border:    rgba(0,0,0,0.09);
  --glass-bg:  rgba(255,255,255,0.7);
  --shadow-float:  0 4px 24px rgba(0,0,0,0.12);
  --shadow-card:   0 1px 8px rgba(0,0,0,0.07);
  --shadow-popup:  0 8px 32px rgba(0,0,0,0.18);
  /* Surfaces */
  --sidebar-bg: #edf2f8;
  --chat-bg:   rgba(255,255,255,0.6);
  --btn-bg:    rgba(0,0,0,0.04);
  --btn-hover: rgba(0,0,0,0.08);
  /* Code + text tokens */
  --code-bg:    rgba(0,0,0,0.07);
  --text-white: var(--text);
  --text-em:    var(--text-dim);
  --text-code:  #1a5e32;
  /* Panel surfaces */
  --surface-topbar:         rgba(240,244,248,0.88);
  --surface-panel:          rgba(248,250,252,0.97);
  --surface-input:          rgba(240,244,248,0.8);
  --surface-heavy:          rgba(248,250,252,0.99);
  --surface-mobile-sidebar: rgba(248,250,252,0.98);
  --surface-nav:            rgba(240,244,248,0.9);
  --surface-dropdown:       #e8eef5;
  --surface-popup:          #e8eef5;
  /* Black overlays — más suaves en light */
  --black-12:  rgba(0,0,0,0.05);
  --black-15:  rgba(0,0,0,0.07);
  --black-20:  rgba(0,0,0,0.08);
  --black-25:  rgba(0,0,0,0.07);
  --black-35:  rgba(0,0,0,0.08);
  --black-45:  rgba(0,0,0,0.10);
  --black-50:  rgba(0,0,0,0.12);
  /* Glow */
  --text-ok:      var(--success);    /* #2e7d32 ≈ 4.6:1 vs #f0f4f8 (AA) */
  --text-err:     var(--danger);     /* #c62828 ≈ 5.1:1 vs #f0f4f8 (AA) */
  --glow:         0 0 14px rgba(0,98,163,0.14);
  --glow-sm:      0 0 8px rgba(0,98,163,0.09);
  --glow-violet:  0 0 10px rgba(99,102,241,0.10);
  --accent-soft:  rgba(0,98,163,0.05);
  --ambient:      radial-gradient(ellipse 90% 40% at 50% 0%, rgba(0,98,163,0.025) 0%, transparent 70%);
  /* ── accent tints — #0062a3 = rgba(0,98,163) */
  --accent-3:   rgba(0,98,163,0.03);
  --accent-4:   rgba(0,98,163,0.04);
  --accent-5:   rgba(0,98,163,0.05);
  --accent-6:   rgba(0,98,163,0.06);
  --accent-7:   rgba(0,98,163,0.07);
  --accent-8:   rgba(0,98,163,0.08);
  --accent-9:   rgba(0,98,163,0.09);
  --accent-10:  rgba(0,98,163,0.10);
  --accent-12:  rgba(0,98,163,0.12);
  --accent-13:  rgba(0,98,163,0.13);
  --accent-14:  rgba(0,98,163,0.14);
  --accent-15:  rgba(0,98,163,0.15);
  --accent-18:  rgba(0,98,163,0.18);
  --accent-20:  rgba(0,98,163,0.20);
  --accent-22:  rgba(0,98,163,0.22);
  --accent-25:  rgba(0,98,163,0.25);
  --accent-30:  rgba(0,98,163,0.30);
  --accent-35:  rgba(0,98,163,0.35);
  --accent-40:  rgba(0,98,163,0.40);
  --accent-45:  rgba(0,98,163,0.45);
  --accent-50:  rgba(0,98,163,0.50);
  --accent-85:  rgba(0,98,163,0.85);
  --accent2-7:  rgba(0,64,128,0.07);
  --accent2-13: rgba(0,64,128,0.13);
  /* ── background sheets */
  --bg-blur:      rgba(240,244,248,0.88);
  --bg-sheet-60:  rgba(240,244,248,0.60);
  --bg-sheet-85:  rgba(240,244,248,0.85);
  --bg-sheet-90:  rgba(240,244,248,0.90);
  --bg-sheet-95:  rgba(240,244,248,0.95);
  --bg-sheet-97:  rgba(240,244,248,0.97);
  /* ── white/black overlays — remapeados para fondo claro */
  --white-2:   rgba(255,255,255,0.50);
  --white-12:  rgba(255,255,255,0.70);
  --white-20:  rgba(0,0,0,0.12);
  --black-40:  rgba(0,0,0,0.08);
  --black-55:  rgba(0,0,0,0.12);
  --black-60:  rgba(0,0,0,0.12);
  --black-75:  rgba(0,0,0,0.18);
  /* ── shadows laterales */
  --shadow-side:   -4px 0 16px rgba(0,0,0,0.08);
  --shadow-bottom: 0 -4px 16px rgba(0,0,0,0.08);
  /* ── success tints — #2e7d32 = rgba(46,125,50) */
  --success-4:   rgba(46,125,50,0.04);
  --success-6:   rgba(46,125,50,0.06);
  --success-8:   rgba(46,125,50,0.08);
  --success-10:  rgba(46,125,50,0.10);
  --success-12:  rgba(46,125,50,0.12);
  --success-15:  rgba(46,125,50,0.15);
  --success-18:  rgba(46,125,50,0.18);
  --success-25:  rgba(46,125,50,0.25);
  --success-30:  rgba(46,125,50,0.30);
  --success-35:  rgba(46,125,50,0.35);
  --success-40:  rgba(46,125,50,0.40);
  --success-50:  rgba(46,125,50,0.50);
  --success-55:  rgba(46,125,50,0.55);
  /* ── warning tints — #e65100 = rgba(230,81,0) */
  --warning-4:   rgba(230,81,0,0.04);
  --warning-8:   rgba(230,81,0,0.08);
  --warning-15:  rgba(230,81,0,0.15);
  --warning-20:  rgba(230,81,0,0.20);
  --warning-25:  rgba(230,81,0,0.25);
  --warning-40:  rgba(230,81,0,0.40);
  --warning-50:  rgba(230,81,0,0.50);
  /* ── danger tints — #c62828 = rgba(198,40,40) */
  --danger-0:    rgba(198,40,40,0);
  --danger-8:    rgba(198,40,40,0.08);
  --danger-10:   rgba(198,40,40,0.10);
  --danger-12:   rgba(198,40,40,0.12);
  --danger-15:   rgba(198,40,40,0.15);
  --danger-20:   rgba(198,40,40,0.20);
  --danger-40:   rgba(198,40,40,0.40);
  --danger-50:   rgba(198,40,40,0.50);
  /* ── extended palette tints (colores decorativos, rgba iguales) */
  --violet-6:    rgba(167,139,250,0.06);
  --violet-7:    rgba(167,139,250,0.07);
  --violet-8:    rgba(167,139,250,0.08);
  --violet-10:   rgba(167,139,250,0.10);
  --violet-12:   rgba(167,139,250,0.12);
  --violet-15:   rgba(167,139,250,0.15);
  --violet-18:   rgba(167,139,250,0.18);
  --violet-20:   rgba(167,139,250,0.20);
  --violet-22:   rgba(167,139,250,0.22);
  --violet-30:   rgba(167,139,250,0.30);
  --violet-35:   rgba(167,139,250,0.35);
  --violet-40:   rgba(167,139,250,0.40);
  --violet-45:   rgba(167,139,250,0.45);
  --indigo-10:   rgba(99,102,241,0.10);
  --indigo-15:   rgba(99,102,241,0.15);
  --emerald-7:   rgba(16,185,129,0.07);
  --emerald-14:  rgba(16,185,129,0.14);
  --emerald-15:  rgba(16,185,129,0.15);
  --emerald-22:  rgba(16,185,129,0.22);
  --emerald-28:  rgba(16,185,129,0.28);
  --emerald-40:  rgba(16,185,129,0.40);
  --amber-7:     rgba(251,191,36,0.07);
  --amber-12:    rgba(251,191,36,0.12);
  --amber-20:    rgba(251,191,36,0.20);
  --amber-22:    rgba(251,191,36,0.22);
  --amber-30:    rgba(251,191,36,0.30);
  --amber-alt-12: rgba(245,158,11,0.12);
  --amber-alt-30: rgba(245,158,11,0.30);
  --orange-15:   rgba(255,183,77,0.15);
  --green-12:    rgba(34,197,94,0.12);
  --green-15:    rgba(34,197,94,0.15);
  --green-30:    rgba(34,197,94,0.30);
  --green-35:    rgba(34,197,94,0.35);
  --blue-6:      rgba(59,130,246,0.06);
  --blue-10:     rgba(59,130,246,0.10);
  --blue-18:     rgba(59,130,246,0.18);
  --red-8:       rgba(239,68,68,0.08);
  --red-25:      rgba(239,68,68,0.25);
  --red-40:      rgba(239,68,68,0.40);
  --red-50:      rgba(239,68,68,0.50);
  --red-60:      rgba(239,68,68,0.60);
  --red-85:      rgba(239,68,68,0.85);
  --red-90:      rgba(239,68,68,0.90);
  /* ── on-color tokens */
  --on-accent:   #fff;
  --on-danger:   #fff;
  --on-success:  #fff;
  /* ── misc */
  --emerald-green: #34d399;
  --gray-10:     rgba(90,110,133,0.10);
  --gray-20:     rgba(90,110,133,0.20);
  --toast-bg:    rgba(232,238,245,0.97);
  --toast-text:  var(--text);
  --text-muted:  rgba(90,110,133,0.50);
}

/* ── Auto theme: sigue prefers-color-scheme ─────────────────────────────────── */
@media (prefers-color-scheme: light) {
  /* Activa si data-theme="auto" (elegido por usuario) o sin atributo (default) */
  html:not([data-theme]),
  [data-theme="auto"] {
    color-scheme: light;
    --bg:        #f0f4f8;
    --bg2:       rgba(0,0,0,0.02);
    --bg3:       rgba(0,0,0,0.05);
    --bg4:       rgba(0,0,0,0.09);
    --text:      #1a2536;
    --text-dim:  #5a6e85;
    --accent:    #0062a3;
    --accent2:   #004080;
    --accent-hover: #004f8a;
    --success:   #2e7d32;
    --warning:   #e65100;
    --danger:    #c62828;
    --border:    rgba(0,0,0,0.09);
    --glass-bg:  rgba(255,255,255,0.7);
    --shadow-float:  0 4px 24px rgba(0,0,0,0.12);
    --shadow-card:   0 1px 8px rgba(0,0,0,0.07);
    --shadow-popup:  0 8px 32px rgba(0,0,0,0.18);
    --shadow-side:  -4px 0 16px rgba(0,0,0,0.08);
    --shadow-bottom: 0 -4px 16px rgba(0,0,0,0.08);
    --sidebar-bg: #edf2f8;
    --chat-bg:   rgba(255,255,255,0.6);
    --btn-bg:    rgba(0,0,0,0.04);
    --btn-hover: rgba(0,0,0,0.08);
    --code-bg:    rgba(0,0,0,0.07);
    --text-white: var(--text);
    --text-em:    var(--text-dim);
    --text-code:  #1a5e32;
    --surface-topbar:         rgba(240,244,248,0.88);
    --surface-panel:          rgba(248,250,252,0.97);
    --surface-input:          rgba(240,244,248,0.8);
    --surface-heavy:          rgba(248,250,252,0.99);
    --surface-mobile-sidebar: rgba(248,250,252,0.98);
    --surface-nav:            rgba(240,244,248,0.9);
    --surface-dropdown:       #e8eef5;
    --surface-popup:          #e8eef5;
    --black-12:  rgba(0,0,0,0.05);
    --black-15:  rgba(0,0,0,0.07);
    --black-20:  rgba(0,0,0,0.08);
    --black-25:  rgba(0,0,0,0.07);
    --black-35:  rgba(0,0,0,0.08);
    --black-45:  rgba(0,0,0,0.10);
    --black-50:  rgba(0,0,0,0.12);
    --text-ok:   var(--success);
    --text-err:  var(--danger);
    --glow:         0 0 14px rgba(0,98,163,0.14);
    --glow-sm:      0 0 8px rgba(0,98,163,0.09);
    --glow-violet:  0 0 10px rgba(99,102,241,0.10);
    --accent-soft:  rgba(0,98,163,0.05);
    --ambient:      radial-gradient(ellipse 90% 40% at 50% 0%, rgba(0,98,163,0.025) 0%, transparent 70%);
    /* ── accent tints — #0062a3 = rgba(0,98,163) */
    --accent-3:   rgba(0,98,163,0.03);
    --accent-4:   rgba(0,98,163,0.04);
    --accent-5:   rgba(0,98,163,0.05);
    --accent-6:   rgba(0,98,163,0.06);
    --accent-7:   rgba(0,98,163,0.07);
    --accent-8:   rgba(0,98,163,0.08);
    --accent-9:   rgba(0,98,163,0.09);
    --accent-10:  rgba(0,98,163,0.10);
    --accent-12:  rgba(0,98,163,0.12);
    --accent-13:  rgba(0,98,163,0.13);
    --accent-14:  rgba(0,98,163,0.14);
    --accent-15:  rgba(0,98,163,0.15);
    --accent-18:  rgba(0,98,163,0.18);
    --accent-20:  rgba(0,98,163,0.20);
    --accent-22:  rgba(0,98,163,0.22);
    --accent-25:  rgba(0,98,163,0.25);
    --accent-30:  rgba(0,98,163,0.30);
    --accent-35:  rgba(0,98,163,0.35);
    --accent-40:  rgba(0,98,163,0.40);
    --accent-45:  rgba(0,98,163,0.45);
    --accent-50:  rgba(0,98,163,0.50);
    --accent-85:  rgba(0,98,163,0.85);
    --accent2-7:  rgba(0,64,128,0.07);
    --accent2-13: rgba(0,64,128,0.13);
    /* ── background sheets */
    --bg-blur:      rgba(240,244,248,0.88);
    --bg-sheet-60:  rgba(240,244,248,0.60);
    --bg-sheet-85:  rgba(240,244,248,0.85);
    --bg-sheet-90:  rgba(240,244,248,0.90);
    --bg-sheet-95:  rgba(240,244,248,0.95);
    --bg-sheet-97:  rgba(240,244,248,0.97);
    /* ── white/black overlays — remapeados para fondo claro */
    --white-2:   rgba(255,255,255,0.50);
    --white-12:  rgba(255,255,255,0.70);
    --white-20:  rgba(0,0,0,0.12);
    --black-40:  rgba(0,0,0,0.08);
    --black-55:  rgba(0,0,0,0.12);
    --black-60:  rgba(0,0,0,0.12);
    --black-75:  rgba(0,0,0,0.18);
    /* ── success tints — #2e7d32 = rgba(46,125,50) */
    --success-4:   rgba(46,125,50,0.04);
    --success-6:   rgba(46,125,50,0.06);
    --success-8:   rgba(46,125,50,0.08);
    --success-10:  rgba(46,125,50,0.10);
    --success-12:  rgba(46,125,50,0.12);
    --success-15:  rgba(46,125,50,0.15);
    --success-18:  rgba(46,125,50,0.18);
    --success-25:  rgba(46,125,50,0.25);
    --success-30:  rgba(46,125,50,0.30);
    --success-35:  rgba(46,125,50,0.35);
    --success-40:  rgba(46,125,50,0.40);
    --success-50:  rgba(46,125,50,0.50);
    --success-55:  rgba(46,125,50,0.55);
    /* ── warning tints — #e65100 = rgba(230,81,0) */
    --warning-4:   rgba(230,81,0,0.04);
    --warning-8:   rgba(230,81,0,0.08);
    --warning-15:  rgba(230,81,0,0.15);
    --warning-20:  rgba(230,81,0,0.20);
    --warning-25:  rgba(230,81,0,0.25);
    --warning-40:  rgba(230,81,0,0.40);
    --warning-50:  rgba(230,81,0,0.50);
    /* ── danger tints — #c62828 = rgba(198,40,40) */
    --danger-0:    rgba(198,40,40,0);
    --danger-8:    rgba(198,40,40,0.08);
    --danger-10:   rgba(198,40,40,0.10);
    --danger-12:   rgba(198,40,40,0.12);
    --danger-15:   rgba(198,40,40,0.15);
    --danger-20:   rgba(198,40,40,0.20);
    --danger-40:   rgba(198,40,40,0.40);
    --danger-50:   rgba(198,40,40,0.50);
    /* ── extended palette tints (colores decorativos, rgba iguales) */
    --violet-6:    rgba(167,139,250,0.06);
    --violet-7:    rgba(167,139,250,0.07);
    --violet-8:    rgba(167,139,250,0.08);
    --violet-10:   rgba(167,139,250,0.10);
    --violet-12:   rgba(167,139,250,0.12);
    --violet-15:   rgba(167,139,250,0.15);
    --violet-18:   rgba(167,139,250,0.18);
    --violet-20:   rgba(167,139,250,0.20);
    --violet-22:   rgba(167,139,250,0.22);
    --violet-30:   rgba(167,139,250,0.30);
    --violet-35:   rgba(167,139,250,0.35);
    --violet-40:   rgba(167,139,250,0.40);
    --violet-45:   rgba(167,139,250,0.45);
    --indigo-10:   rgba(99,102,241,0.10);
    --indigo-15:   rgba(99,102,241,0.15);
    --emerald-7:   rgba(16,185,129,0.07);
    --emerald-14:  rgba(16,185,129,0.14);
    --emerald-15:  rgba(16,185,129,0.15);
    --emerald-22:  rgba(16,185,129,0.22);
    --emerald-28:  rgba(16,185,129,0.28);
    --emerald-40:  rgba(16,185,129,0.40);
    --amber-7:     rgba(251,191,36,0.07);
    --amber-12:    rgba(251,191,36,0.12);
    --amber-20:    rgba(251,191,36,0.20);
    --amber-22:    rgba(251,191,36,0.22);
    --amber-30:    rgba(251,191,36,0.30);
    --amber-alt-12: rgba(245,158,11,0.12);
    --amber-alt-30: rgba(245,158,11,0.30);
    --orange-15:   rgba(255,183,77,0.15);
    --green-12:    rgba(34,197,94,0.12);
    --green-15:    rgba(34,197,94,0.15);
    --green-30:    rgba(34,197,94,0.30);
    --green-35:    rgba(34,197,94,0.35);
    --blue-6:      rgba(59,130,246,0.06);
    --blue-10:     rgba(59,130,246,0.10);
    --blue-18:     rgba(59,130,246,0.18);
    --red-8:       rgba(239,68,68,0.08);
    --red-25:      rgba(239,68,68,0.25);
    --red-40:      rgba(239,68,68,0.40);
    --red-50:      rgba(239,68,68,0.50);
    --red-60:      rgba(239,68,68,0.60);
    --red-85:      rgba(239,68,68,0.85);
    --red-90:      rgba(239,68,68,0.90);
    /* ── on-color tokens */
    --on-accent:   #fff;
    --on-danger:   #fff;
    --on-success:  #fff;
    /* ── misc */
    --emerald-green: #34d399;
    --gray-10:     rgba(90,110,133,0.10);
    --gray-20:     rgba(90,110,133,0.20);
    --toast-bg:    rgba(232,238,245,0.97);
    --toast-text:  var(--text);
    --text-muted:  rgba(90,110,133,0.50);
  }
}

/* ── Dark theme (explicit data-theme="dark") ─────────────────────────────────── */
[data-theme="dark"] {
  color-scheme: dark;
  --bg:        #0a0f14;
  --bg2:       rgba(255,255,255,0.03);
  --bg3:       rgba(255,255,255,0.06);
  --bg4:       rgba(255,255,255,0.10);
  --accent:    #4fc3f7;
  --accent2:   #0288d1;
  --accent-hover: #81d4fa;
  --success:   #66bb6a;
  --warning:   #ffa726;
  --danger:    #ef5350;
  --text:      #e8eaf0;
  --text-dim:  #7a8a9a;
  --border:    rgba(255,255,255,0.07);
  --glass-bg:  rgba(255,255,255,0.04);
  --shadow-float: 0 4px 24px rgba(0,0,0,0.5);
  --shadow-card:  0 1px 8px rgba(0,0,0,0.3);
  --shadow-popup: 0 8px 32px rgba(0,0,0,0.60);
  --sidebar-bg: #0d1218;
  --chat-bg:   rgba(255,255,255,0.05);
  --btn-bg:    rgba(255,255,255,0.06);
  --btn-hover: rgba(255,255,255,0.10);
  --code-bg:   rgba(0,0,0,0.35);
  --text-white: #ffffff;
  --text-em:   #c8d8f0;
  --text-code: #a8e6cf;
  --surface-topbar:         rgba(10,15,20,0.8);
  --surface-panel:          rgba(10,15,20,0.9);
  --surface-input:          rgba(10,15,20,0.6);
  --surface-heavy:          rgba(10,15,20,0.97);
  --surface-mobile-sidebar: rgba(10,15,20,0.95);
  --surface-nav:            rgba(10,15,20,0.85);
  --surface-dropdown:       #0d1520;
  --surface-popup:          #0d1520;
  --black-12:  rgba(0,0,0,0.12);
  --black-15:  rgba(0,0,0,0.15);
  --black-20:  rgba(0,0,0,0.20);
  --black-25:  rgba(0,0,0,0.25);
  --black-35:  rgba(0,0,0,0.35);
  --black-45:  rgba(0,0,0,0.45);
  --black-50:  rgba(0,0,0,0.50);
  --text-ok:   #56d364;
  --text-err:  #f85149;
  --glow:         0 0 18px rgba(79,195,247,0.22);
  --glow-sm:      0 0 10px rgba(79,195,247,0.14);
  --glow-violet:  0 0 14px rgba(167,139,250,0.18);
  --accent-soft:  rgba(79,195,247,0.07);
  --ambient:      radial-gradient(ellipse 90% 40% at 50% 0%, rgba(79,195,247,0.04) 0%, transparent 70%);
}

/* Ambient gradient en paneles laterales — luz sutil desde el borde superior */
#sidebar,
#files-panel,
#settings-panel,
#crons-panel {
  background-image: var(--ambient);
}

/* Topbar — halo muy tenue en el borde inferior */
#topbar {
  box-shadow: 0 1px 0 var(--border), 0 4px 24px var(--accent-3);
}

/* Send button — glow suave cuando está disponible */
.send-btn:not(:disabled) {
  box-shadow: var(--glow-sm);
  transition: background 0.2s var(--ease), transform 0.15s var(--ease), box-shadow 0.25s var(--ease);
}
.send-btn:hover:not(:disabled) {
  box-shadow: var(--glow);
}

/* Pills activas — workspace, agente */
.workspace-pill.active {
  box-shadow: var(--glow-sm);
}
.agent-pill.active {
  box-shadow: var(--glow-sm);
}

/* Input focus — glow cian en el borde */
#msg-input:focus {
  box-shadow: var(--glow-sm);
}
.q-card-input:focus {
  box-shadow: var(--glow-sm);
}
#login-form input:focus {
  box-shadow: var(--glow-sm);
}

/* Thread items — sombra violeta cromática en hover */
.thread-item:hover {
  box-shadow: 0 2px 12px var(--violet-7);
}
.thread-item.active {
  box-shadow: 0 0 0 1px var(--accent-8);
}

/* Ticket y plan cards — sombra cian en hover */
.tkt-card:hover {
  box-shadow: 0 2px 14px var(--accent-9);
}
.plan-hub-card:hover {
  box-shadow: 0 2px 16px var(--accent-10);
  border-color: var(--accent-35);
}

/* Primary buttons — glow en hover */
.admin-btn.primary:hover {
  box-shadow: var(--glow-sm);
}
.wizard-btn.primary:hover,
.tkt-btn-submit:not(:disabled):hover {
  box-shadow: var(--glow-sm);
}
.modal-btn.primary:hover {
  box-shadow: var(--glow-sm);
}

/* New thread button */
.new-thread-btn:hover {
  box-shadow: var(--glow-sm);
}

/* Filter pills activas */
.task-filter-btn.active {
  box-shadow: var(--glow-sm);
}
.tkt-filter-btn.active {
  box-shadow: var(--glow-sm);
}

/* WS dot connected — glow verde más cálido */
.ws-dot.connected {
  box-shadow: 0 0 8px var(--success-55);
}

/* Streaming bubble — micro-aura cian lateral */
.msg-bubble.streaming {
  box-shadow: -2px 0 12px var(--accent-6);
}

/* Admin tab activo */
.admin-tab.active {
  box-shadow: 0 2px 0 var(--accent);
}

/* Login button */
#login-form button:not(:disabled):hover {
  box-shadow: var(--glow);
}

/* ── Theme transition ──────────────────────────────────────────────────────── */
html { color-scheme: dark light; }

/* ── Theme segmented control ────────────────────────────────────────────────── */
.theme-segmented {
  display: flex;
  gap: 4px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 3px;
}
.theme-seg-btn {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 5px;
  padding: 6px 8px;
  border-radius: calc(var(--radius-sm) - 2px);
  font-size: 12px; font-weight: 500;
  color: var(--text-dim);
  background: transparent;
  transition: background 0.15s var(--ease), color 0.15s var(--ease);
  white-space: nowrap;
}
.theme-seg-btn:hover { color: var(--text); background: var(--bg4); }
.theme-seg-btn.active {
  background: var(--surface-dropdown);
  color: var(--accent);
  box-shadow: var(--shadow-card);
}
.theme-seg-btn svg, .theme-seg-btn i { width: 13px; height: 13px; flex-shrink: 0; }


/* ── Light mode element overrides ────────────────────────────────────────── */
[data-theme="light"] .msg.assistant .msg-bubble {
  background: var(--light-bubble-bg);
  border-color: var(--light-border-soft);
}
[data-theme="light"] .msg-bubble code {
  background: var(--light-border-soft);
  color: var(--light-slate-700);
}
[data-theme="light"] .msg-bubble pre {
  background: var(--light-pre-bg);
  color: var(--light-slate-800);
}
[data-theme="light"] .msg-bubble strong { color: var(--light-slate-900); }
[data-theme="light"] .msg-bubble em     { color: var(--light-slate-500); }
[data-theme="light"] .activity-body,
[data-theme="light"] .tool-body { background: var(--light-tool-bg); }
[data-theme="light"] .tool-content {
  background: var(--light-pre-bg); color: var(--light-slate-700); border-color: var(--light-border-tool);
}
[data-theme="light"] .tool-content.output { color: var(--text); }
[data-theme="light"] #cron-form { background: var(--light-tool-bg); }
[data-theme="light"] .modal-box { box-shadow: 0 8px 32px var(--light-modal-shadow); }
[data-theme="light"] ::-webkit-scrollbar-thumb       { background: var(--light-scroll-thumb); }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: var(--light-scroll-hover); }
@media (prefers-color-scheme: light) {
  html:not([data-theme]) .msg.assistant .msg-bubble {
    background: var(--light-bubble-bg); border-color: var(--light-border-soft);
  }
  html:not([data-theme]) .msg-bubble code { background: var(--light-border-soft); color: var(--light-slate-700); }
  html:not([data-theme]) .msg-bubble pre  { background: var(--light-pre-bg); color: var(--light-slate-800); }
  html:not([data-theme]) .msg-bubble strong { color: var(--light-slate-900); }
  html:not([data-theme]) .msg-bubble em     { color: var(--light-slate-500); }
  html:not([data-theme]) .activity-body,
  html:not([data-theme]) .tool-body { background: var(--light-tool-bg); }
  html:not([data-theme]) .tool-content { background: var(--light-pre-bg); color: var(--light-slate-700); border-color: var(--light-border-tool); }
  html:not([data-theme]) .tool-content.output { color: var(--text); }
  html:not([data-theme]) #cron-form { background: var(--light-tool-bg); }
  html:not([data-theme]) .modal-box { box-shadow: 0 8px 32px var(--light-modal-shadow); }
  html:not([data-theme]) ::-webkit-scrollbar-thumb       { background: var(--light-scroll-thumb); }
  html:not([data-theme]) ::-webkit-scrollbar-thumb:hover { background: var(--light-scroll-hover); }
}

/* ── prefers-reduced-motion: silencia todos los glows nuevos ─────────────────── */
@media (prefers-reduced-motion: reduce) {
  .send-btn,
  .send-btn:not(:disabled),
  .send-btn:hover:not(:disabled),
  .workspace-pill.active,
  .agent-pill.active,
  #msg-input:focus,
  .q-card-input:focus,
  #login-form input:focus,
  .thread-item:hover,
  .thread-item.active,
  .tkt-card:hover,
  .plan-hub-card:hover,
  .admin-btn.primary:hover,
  .wizard-btn.primary:hover,
  .tkt-btn-submit:not(:disabled):hover,
  .modal-btn.primary:hover,
  .new-thread-btn:hover,
  .task-filter-btn.active,
  .tkt-filter-btn.active,
  .ws-dot.connected,
  .msg-bubble.streaming,
  .admin-tab.active,
  #login-form button:not(:disabled):hover {
    box-shadow: none;
  }
  #topbar { box-shadow: 0 1px 0 var(--border); }
  .live-activity-pill { animation: none; background: var(--accent-10); }
  .live-activity-pill::after { animation: none; }
  .lap-dot { animation: none; opacity: 0.7; }
  .msg-bubble.streaming { animation: none; }
  .msg-bubble.streaming::after { animation: none; }
}
