*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root,:root[data-theme="dark"]{
  --bg:#0e0f11;--surface:#16181c;--surface2:#1e2128;--surface3:#262930;
  --border:#2a2d35;--border2:#363a44;--text:#e8eaf0;--muted:#7a7f8e;
  --accent:#3b82f6;--accent-d:#1d4ed8;
  --codex-awaiting-input-bg:rgba(34,197,94,.14);--codex-awaiting-input-border:rgba(34,197,94,.42);
  --high:#ef4444;--high-bg:#2a1515;--high-text:#fca5a5;
  --med:#f59e0b;--med-bg:#2a2010;--med-text:#fcd34d;
  --low:#22c55e;--low-bg:#102a18;--low-text:#86efac;
  --inspect-outline:rgba(248,113,113,.95);--inspect-fill:rgba(127,29,29,.14);
  --inspect-pill-bg:#7f1d1d;--inspect-pill-text:#fee2e2;
  --mono:'Cascadia Code',monospace;--sans:'DM Sans',sans-serif;
  --shadow:0 8px 24px rgba(0,0,0,.4);
  --header-band-min-height:56px;
  --header-band-pad-y:11px;
  --header-band-pad-x:20px;
  --detail-header-pad-x:16px;
  --detail-chip-pad-top:11px;
  --detail-chip-pad-bottom:11px;
}
:root[data-theme="light"]{
  --bg:#f5f6f8;--surface:#ffffff;--surface2:#f0f1f4;--surface3:#e6e8ec;
  --border:#dcdfe5;--border2:#c8ccd4;--text:#1a1d24;--muted:#6b7280;
  --accent:#2563eb;--accent-d:#1d4ed8;
  --codex-awaiting-input-bg:#f0fdf4;--codex-awaiting-input-border:#86efac;
  --high:#dc2626;--high-bg:#fef2f2;--high-text:#b91c1c;
  --med:#d97706;--med-bg:#fffbeb;--med-text:#92400e;
  --low:#16a34a;--low-bg:#f0fdf4;--low-text:#166534;
  --inspect-outline:rgba(220,38,38,.9);--inspect-fill:rgba(254,202,202,.2);
  --inspect-pill-bg:#b91c1c;--inspect-pill-text:#fff1f2;
  --shadow:0 8px 24px rgba(0,0,0,.08);
}
html,body{height:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--text);overflow:hidden;font-size:17px;line-height:1.5}
body.element-inspector-active,body.element-inspector-active *{cursor:crosshair!important}
.shell{display:flex;height:100%;min-height:0}

#element-inspector-overlay{position:fixed;inset:0;pointer-events:none;z-index:9998;overflow:hidden}
.element-inspector-box{position:fixed;pointer-events:none;border:1px solid var(--inspect-outline);background:var(--inspect-fill);border-radius:6px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.element-inspector-pill{position:fixed;pointer-events:none;display:flex;flex-direction:column;align-items:flex-start;gap:1px;max-width:min(360px,calc(100vw - 8px));padding:4px 9px;border-radius:12px;border:1px solid var(--inspect-outline);background:var(--inspect-pill-bg);color:var(--inspect-pill-text);font:600 11px/1.35 var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 8px 18px rgba(0,0,0,.28)}
#element-inspector-overlay.element-inspector-frozen .element-inspector-pill{pointer-events:auto;cursor:copy}
.element-inspector-box-parent{opacity:.95;border-style:dashed;border-color:#facc15;background:rgba(250,204,21,.16)}
.element-inspector-box-child{opacity:.95;border-style:dashed;border-color:#f97316;background:rgba(249,115,22,.16)}
.element-inspector-box-hover{border-width:2px;opacity:1;border-color:#ef4444;background:rgba(239,68,68,.16)}
.element-inspector-pill-parent,.element-inspector-pill-child{opacity:.92}
.element-inspector-pill-parent{background:#713f12;border-color:#facc15;color:#fef3c7}
.element-inspector-pill-child{background:#9a3412;border-color:#f97316;color:#ffedd5}
.element-inspector-pill-hover{font-weight:700;background:#991b1b;border-color:#ef4444;color:#fee2e2}
.element-inspector-pill-label{max-width:100%;overflow:hidden;text-overflow:ellipsis}
.element-inspector-pill-meta{max-width:100%;overflow:hidden;text-overflow:ellipsis;font-size:10px;line-height:1.3;opacity:.86}

/* ── Sidebar ── */
.sidebar{width:236px;min-width:236px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width .22s cubic-bezier(.4,0,.2,1),min-width .22s cubic-bezier(.4,0,.2,1)}
.sidebar.collapsed{width:56px;min-width:56px;overflow:visible}
/* hide text when collapsed */
.sidebar.collapsed .logo-name,
.sidebar.collapsed .logo-ai,
.sidebar.collapsed .sidebar-labels,
.sidebar.collapsed .user-name,
.sidebar.collapsed .user-role,
.sidebar.collapsed .user-chevron,
.sidebar.collapsed .accordion-children,
.sidebar.collapsed .sidebar-divider,
.sidebar.collapsed .section-add,
.sidebar.collapsed .child-badge{display:none!important}
.sidebar.collapsed .top-nav-item{justify-content:center;padding:8px 0}
.sidebar.collapsed .sidebar-user{justify-content:center;padding:12px 0}
.sidebar.collapsed .nav-section{padding:10px 6px 2px}
/* collapse toggle button */
.sidebar-toggle{width:20px;height:20px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .1s;margin-left:auto;flex-shrink:0}
.sidebar-toggle:hover{background:var(--surface2);color:var(--text)}
/* custom tooltip */
#sb-tooltip{position:fixed;z-index:9999;background:var(--surface3);color:var(--text);font-family:var(--sans);font-size:12px;font-weight:500;padding:5px 10px;border-radius:6px;border:1px solid var(--border2);pointer-events:none;white-space:nowrap;opacity:0;transition:opacity .12s;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.logo{display:flex;align-items:center;gap:10px;padding:18px 16px 14px;border-bottom:1px solid var(--border);flex-shrink:0}
.logo-mark{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:14px;font-weight:500;color:#fff;flex-shrink:0}
.logo-name{font-size:16px;font-weight:600;letter-spacing:-0.3px}
.logo-ai{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:0.1em}
.sidebar-scroll{flex:1;overflow-y:auto;padding:8px 0 8px}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* User footer */
.sidebar-user{display:flex;align-items:center;gap:9px;padding:12px 14px;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface)}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-d);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;font-family:var(--mono);flex-shrink:0}
.user-name{font-size:14px;font-weight:500;color:var(--text)}
.user-role{font-size:12px;color:var(--muted)}
.sidebar-user-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.sidebar-user-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.footer-status{font-size:11px;color:var(--muted);min-height:14px}
.footer-status.error{color:var(--high-text)}

/* Nav */
.nav-section{padding:10px 8px 2px}
.section-add{width:18px;height:18px;border-radius:4px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;transition:all 0.1s;line-height:1}
.section-add:hover{background:var(--surface2);color:var(--text)}
.top-nav-row{display:flex;align-items:center;gap:6px;margin-bottom:1px}
.top-nav-row .top-nav-item{flex:1;min-width:0;margin-bottom:0}
.top-nav-row .section-add{flex-shrink:0}
.top-nav-item{display:flex;align-items:center;gap:9px;padding:8px 8px;border-radius:7px;font-size:15px;font-weight:500;color:var(--muted);cursor:pointer;transition:all 0.12s;border:none;background:none;width:100%;text-align:left;margin-bottom:1px}
.top-nav-item:hover{background:var(--surface2);color:var(--text)}
.top-nav-item.active{background:var(--surface3);color:var(--text)}
.restart-server-nav-item{color:var(--danger)}
.restart-server-nav-item:hover{background:rgba(239,68,68,.08);color:var(--danger)}
.extension-download-nav-item{text-decoration:none;color:var(--text)}
.extension-download-nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-section-recents{padding-bottom:2px}
.sidebar-mini-heading{padding:2px 8px 8px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.recent-section-header{position:relative;min-width:0;padding:2px 8px 8px}
.recent-section-trigger{display:inline-flex;align-items:center;gap:5px;padding:0;border:none;background:none;color:var(--muted);font:inherit;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.recent-section-trigger:hover{color:var(--text)}
.recent-section-trigger.static{width:100%;justify-content:space-between;cursor:default}
.recent-section-trigger .recent-section-caret{font-size:9px;letter-spacing:0}
.recent-task-owner-menu{left:0;right:auto;min-width:0!important;width:100%;max-width:100%}
.recent-task-list{display:flex;flex-direction:column;gap:2px}
.bookmark-task-row{display:flex;align-items:center;gap:6px}
.recent-task-item{padding-left:8px;padding-right:8px}
.recent-task-item.recent-task-item-colorized{box-shadow:inset 3px 0 0 var(--recent-task-accent);background:linear-gradient(90deg,rgba(var(--recent-task-accent-rgb),.1),transparent 55%)}
.recent-task-item.recent-task-item-colorized:hover{background:linear-gradient(90deg,rgba(var(--recent-task-accent-rgb),.14),transparent 55%),var(--surface2)}
.recent-task-item.empty{cursor:default;color:var(--muted);font-size:12px}
.recent-task-item.active{background:var(--surface2);color:var(--text)}
.recent-task-item.recent-task-item-colorized.active{background:linear-gradient(90deg,rgba(var(--recent-task-accent-rgb),.16),transparent 55%),var(--surface2)}
.recent-task-more{font-size:12px;color:var(--accent)}
.recent-task-meta{display:flex;align-items:center;gap:8px;min-width:0;width:100%}
.recent-task-status-dot{width:7px;height:7px;border-radius:999px;flex-shrink:0;box-shadow:0 0 0 1px rgba(255,255,255,.06) inset}
.recent-task-id{font-family:var(--mono);font-size:11px;color:var(--muted);flex-shrink:0}
.recent-task-title{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bookmark-task-toggle{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;transition:border-color .12s,background .12s,color .12s;flex-shrink:0}
.bookmark-task-toggle:hover{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.1);color:#fbbf24}
.bookmark-task-toggle.active{border-color:rgba(245,158,11,.45);background:rgba(245,158,11,.14);color:#fbbf24}
.accordion-children{overflow:hidden;max-height:0;transition:max-height 0.26s cubic-bezier(.4,0,.2,1)}
.accordion-children.collapsed{max-height:0!important}
.child-item{display:flex;align-items:center;gap:8px;padding:6px 8px 6px 28px;border-radius:6px;font-size:14px;color:var(--muted);cursor:pointer;transition:all 0.1s;border:none;background:none;width:100%;text-align:left}
.child-item:hover{background:var(--surface2);color:var(--text)}
.child-item.active{background:var(--surface2);color:var(--text)}
.child-item.drag-over{background:var(--surface2)!important;outline:1px dashed var(--accent);outline-offset:-1px}
.child-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.child-badge{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--muted);min-width:16px;text-align:right}
.c-blue{background:#3b82f6}.c-purple{background:#8b5cf6}.c-amber{background:#f59e0b}
.c-green{background:#22c55e}.c-red{background:#ef4444}.c-pink{background:#ec4899}
.c-teal{background:#14b8a6}.c-gray{background:#6b7280}
.sidebar-divider{border-top:1px solid var(--border);margin:8px 8px 4px}

/* ── Main ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.content-area{position:relative;flex:1;display:flex;overflow:hidden;min-height:0}
.view-pane{flex:1;display:flex;flex-direction:column;overflow:hidden}

/* Topbar */
.topbar{display:flex;align-items:center;gap:10px;min-height:var(--header-band-min-height);padding:var(--header-band-pad-y) var(--header-band-pad-x);border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;box-sizing:border-box}
.topbar-title{font-size:17px;font-weight:600;flex-shrink:0;display:flex;align-items:center;gap:7px;min-width:120px}
.view-switcher{position:relative;cursor:pointer;user-select:none}
.view-switcher:hover{color:var(--text)}
.view-switcher-text{min-width:0}
.view-switcher-caret{font-size:11px;color:var(--muted);transform:translateY(1px)}
.view-switcher-menu{min-width:220px;max-width:min(320px,calc(100vw - 24px))}
.view-switcher-item-icon{width:16px;text-align:center;flex-shrink:0;color:var(--muted);font-size:13px}
.nav-section-recents{scroll-margin-top:12px}
.recent-section-flash{border-radius:10px;box-shadow:0 0 0 1px rgba(59,130,246,.35),0 0 0 6px rgba(59,130,246,.08);transition:box-shadow .18s ease}
.search-wrap{position:relative;width:220px;flex-shrink:0}
.search-wrap svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--muted);width:13px;height:13px}
.search-input{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--sans);font-size:15px;padding:6px 10px 6px 28px;border-radius:7px;outline:none;transition:border 0.15s}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--muted)}
.search-recent-menu{top:calc(100% + 6px);left:0;width:min(360px,calc(100vw - 24px));min-width:100%;max-width:calc(100vw - 24px);max-height:min(70vh,560px);overflow-y:auto;padding:4px}
.search-recent-item{width:100%;border:none;background:none;text-align:left}
.search-recent-empty{padding:10px;color:var(--muted);font-size:12px}
.search-autocomplete-item{align-items:flex-start;padding:8px 10px}
.search-autocomplete-kind{display:inline-flex;align-items:center;justify-content:center;min-width:58px;padding:3px 7px;border-radius:999px;background:var(--surface2);font-size:10px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.search-autocomplete-kind-developer{background:rgba(139,92,246,.12);color:#c4b5fd}
.search-autocomplete-kind-project{background:rgba(59,130,246,.12);color:#93c5fd}
.search-autocomplete-kind-task{background:rgba(34,197,94,.12);color:#86efac}
.search-autocomplete-kind-chat{background:rgba(236,72,153,.12);color:#f9a8d4}
.search-autocomplete-kind-customer{background:rgba(251,146,60,.12);color:#fdba74}
.search-autocomplete-kind-search{background:rgba(59,130,246,.12);color:var(--accent)}
.search-autocomplete-copy{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.search-autocomplete-label{font-size:13px;color:var(--text);line-height:1.3;white-space:normal;overflow-wrap:anywhere;word-break:break-word}
.search-autocomplete-meta{font-size:11px;color:var(--muted);line-height:1.3;white-space:normal;overflow-wrap:anywhere;word-break:break-word}
.search-autocomplete-hit{background:rgba(250,204,21,.85);color:#111827;border-radius:3px;padding:0 1px}
.message-search-hit{background:rgba(250,204,21,.9);color:#111827;border-radius:3px;padding:0 1px}
.search-autocomplete-section{padding-top:8px}
.search-autocomplete-section:first-child{padding-top:4px}
.search-autocomplete-action{border-top:1px solid var(--border);margin-top:4px;padding-top:10px}
.search-autocomplete-action .search-autocomplete-kind{background:rgba(59,130,246,.12);color:var(--accent)}
.topbar-cost{display:inline-flex;align-items:baseline;gap:8px;padding:6px 10px;border:1px solid rgba(59,130,246,.22);border-radius:9px;background:rgba(59,130,246,.07);color:var(--text);flex-shrink:0}
.topbar-cost-label{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.topbar-cost-value{font-size:13px;font-family:var(--mono);font-weight:600}
.topbar-codex-menu-wrap{position:relative;flex-shrink:0}
.topbar-codex-trigger{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid rgba(45,212,191,.2);border-radius:9px;background:rgba(45,212,191,.08);color:var(--text);cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.topbar-codex-trigger:hover{border-color:rgba(45,212,191,.42);background:rgba(45,212,191,.14)}
.topbar-codex-trigger-label{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.topbar-codex-trigger-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:rgba(45,212,191,.18);font-size:12px;font-family:var(--mono);font-weight:600;color:var(--text)}
.col-menu.topbar-codex-menu,.topbar-codex-menu{right:0;left:auto;width:min(340px,calc(100vw - 24px));min-width:min(310px,calc(100vw - 24px));max-width:calc(100vw - 24px);padding:6px}
.topbar-codex-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;width:100%;border:none;background:transparent;text-align:left;border-left:3px solid var(--codex-task-accent, var(--accent));border-radius:8px;padding-left:10px;background:linear-gradient(90deg,color-mix(in srgb,var(--codex-task-accent, var(--accent)) 10%, transparent),transparent 42%)}
.topbar-codex-copy{display:flex;flex-direction:column;gap:3px;min-width:0}
.topbar-codex-title{display:-webkit-box;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:normal;-webkit-box-orient:vertical;-webkit-line-clamp:2;font-size:13px;font-weight:600;color:var(--text);line-height:1.35}
.topbar-codex-meta{font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:.02em}
.topbar-codex-state{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--codex-task-accent, var(--accent));flex-shrink:0;padding-top:1px}
.topbar-codex-empty{padding:10px 12px;font-size:13px;color:var(--muted)}
.topbar-spacer{flex:1}
.topbar-notification-wrap{position:relative;flex-shrink:0}
.topbar-notification-slot{display:flex;align-items:center;flex-shrink:0}
.topbar-notification-btn{position:relative;width:34px;height:34px;padding:0;border:1px solid var(--border2);border-radius:10px;background:var(--surface2);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .12s,background .12s,color .12s;flex-shrink:0}
.topbar-notification-btn:hover{border-color:var(--accent);background:var(--surface3);color:var(--text)}
.topbar-notification-btn:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.35)}
.topbar-notification-btn svg{display:block;width:17px;height:17px}
.topbar-notification-count{position:absolute;top:-6px;right:-6px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--accent);border:2px solid var(--surface);font-size:11px;font-family:var(--mono);font-weight:700;color:#fff;line-height:1}
.col-menu.topbar-notification-menu{right:0;left:auto;width:min(460px,calc(100vw - 20px));min-width:min(360px,calc(100vw - 20px));max-width:calc(100vw - 20px);padding:0;border-radius:20px;overflow:hidden;box-shadow:0 18px 42px rgba(0,0,0,.22),0 2px 0 rgba(255,255,255,.06) inset}
.topbar-notification-shell{display:flex;flex-direction:column;max-height:min(74vh,680px);background:var(--surface)}
.topbar-notification-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 14px 12px;border-bottom:1px solid var(--border);background:var(--surface)}
.topbar-notification-head-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.topbar-notification-tabs{display:inline-flex;align-items:center;gap:4px;padding:3px;border-radius:10px;background:var(--surface2);border:1px solid var(--border2)}
.topbar-notification-tab{height:30px;padding:0 11px;border:none;border-radius:8px;background:transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}
.topbar-notification-tab:hover{color:var(--text)}
.topbar-notification-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.16)}
.topbar-notification-list{overflow-y:auto;padding:0}
.topbar-notification-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:10px;width:100%;padding:13px 14px;border:none;border-bottom:1px solid var(--border);background:transparent;text-align:left;color:var(--text);cursor:pointer;transition:background .12s}
.topbar-notification-row:last-child{border-bottom:none}
.topbar-notification-row:hover{background:var(--surface2)}
.topbar-notification-avatar{width:44px;height:44px;border-radius:50%;font-size:14px;flex-shrink:0}
.topbar-notification-main{display:flex;flex-direction:column;gap:3px;min-width:0}
.topbar-notification-top{display:flex;align-items:baseline;gap:8px;min-width:0}
.topbar-notification-actor{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-notification-time{font-size:12px;color:var(--muted);white-space:nowrap}
.topbar-notification-summary{font-size:13px;line-height:1.35;font-weight:600;color:var(--text);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
.topbar-notification-summary strong{font-weight:700;color:var(--text)}
.topbar-notification-snippet{font-size:12px;line-height:1.35;color:var(--muted);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
.topbar-notification-taskline{font-size:11px;line-height:1.3;font-weight:500;color:var(--muted);font-family:var(--mono);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;overflow:hidden}
.topbar-notification-kind{display:inline-flex;align-items:center;align-self:flex-start;margin-top:2px;padding:2px 7px;border-radius:999px;border:1px solid transparent;font-size:10px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase}
.topbar-notification-kind.mention{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.28);color:var(--accent)}
.topbar-notification-kind.assigned{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.28);color:#34d399}
.topbar-notification-kind.review{background:rgba(251,146,60,.14);border-color:rgba(251,146,60,.3);color:#fdba74}
.topbar-notification-kind.update{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.28);color:#fbbf24}
.topbar-notification-indicator{display:flex;align-items:center;justify-content:center;min-width:12px;padding-top:5px}
.topbar-notification-unread-dot{width:10px;height:10px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 2px rgba(34,197,94,.2)}
.topbar-notification-empty{padding:20px 14px;font-size:13px;color:var(--muted);text-align:center}
.topbar-notification-overflow{padding:10px 14px;border-top:1px solid var(--border);font-size:12px;color:var(--muted);text-align:center;background:var(--surface)}
.filter-chips{display:flex;gap:5px;align-items:center}
.chip{font-size:13px;padding:4px 9px;border-radius:20px;border:1px solid var(--border2);color:var(--muted);background:transparent;cursor:pointer;transition:all 0.12s;white-space:nowrap}
.chip:hover{border-color:var(--accent);color:var(--text)}
.chip.active{border-color:var(--accent);color:var(--accent);background:rgba(59,130,246,0.08)}
.chip.attn{border-color:rgba(59,130,246,.28);color:#2563eb;background:rgba(59,130,246,.14)}
.chip.attn:hover{border-color:rgba(59,130,246,.4);color:#1d4ed8;background:rgba(59,130,246,.18)}
.chip.high.active{border-color:var(--high);color:var(--high-text);background:var(--high-bg)}
.chip.med.active{border-color:var(--med);color:var(--med-text);background:var(--med-bg)}
.chip.low.active{border-color:var(--low);color:var(--low-text);background:var(--low-bg)}
.topbar-action{font-family:var(--sans);font-size:14px;font-weight:500;padding:6px 14px;border-radius:7px;border:none;background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;transition:background 0.12s;flex-shrink:0}
.topbar-action:hover{background:var(--accent-d)}

/* Active filter bubbles row */
.filter-bar{display:flex;align-items:center;gap:8px;padding:8px 20px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap}
.filter-chip-wrap{position:relative}
.filter-chip-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:13px;padding:4px 10px;border-radius:20px;border:1px solid var(--border2);background:var(--surface3);color:var(--text);cursor:pointer;white-space:nowrap;transition:all 0.12s}
.filter-chip-btn:hover{border-color:var(--accent)}
.filter-chip-label{font-weight:500}
.filter-chip-btn.active-filter .filter-chip-label{display:none}
.filter-chip-value{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.filter-chip-btn .fb-x{cursor:pointer;color:var(--muted);font-size:15px;line-height:1;transition:color 0.1s}
.filter-chip-btn .fb-x:hover{color:var(--text)}
.filter-chip-btn .filter-chip-caret{font-size:10px;color:var(--muted)}
.filter-chip-btn.active-filter .filter-chip-caret{display:none}
.filter-chip-btn.fb-proj .filter-chip-value,
.filter-chip-btn.fb-dev .filter-chip-value,
.filter-chip-btn.fb-creator .filter-chip-value,
.filter-chip-btn.fb-status-open .filter-chip-value,
.filter-chip-btn.fb-status-closed .filter-chip-value,
.filter-chip-btn.fb-status-todo .filter-chip-value,
.filter-chip-btn.fb-status-in_progress .filter-chip-value,
.filter-chip-btn.fb-status-pause .filter-chip-value,
.filter-chip-btn.fb-status-review .filter-chip-value,
.filter-chip-btn.fb-status-tested .filter-chip-value,
.filter-chip-btn.fb-status-resolved .filter-chip-value,
.filter-chip-btn.fb-status-done .filter-chip-value,
.filter-chip-btn.fb-status-deleted .filter-chip-value,
.filter-chip-btn.fb-pri-high .filter-chip-value,
.filter-chip-btn.fb-pri-medium .filter-chip-value,
.filter-chip-btn.fb-pri-low .filter-chip-value,
.filter-chip-btn.fb-customer .filter-chip-value{color:inherit}
.filter-bubble{display:inline-flex;align-items:center;gap:5px;font-size:13px;padding:3px 8px 3px 10px;border-radius:20px;background:var(--surface3);border:1px solid var(--border2);color:var(--text);white-space:nowrap}
.filter-bubble .fb-x{cursor:pointer;color:var(--muted);font-size:15px;line-height:1;padding-left:2px;transition:color 0.1s}
.filter-bubble .fb-x:hover{color:var(--text)}
.filter-bubble.fb-proj,.filter-chip-btn.fb-proj{border-color:rgba(59,130,246,.3);background:rgba(59,130,246,.08)}
.filter-bubble.fb-dev,.filter-chip-btn.fb-dev{border-color:rgba(139,92,246,.3);background:rgba(139,92,246,.08)}
.filter-bubble.fb-creator,.filter-chip-btn.fb-creator{border-color:rgba(14,165,233,.28);background:rgba(14,165,233,.1);color:#7dd3fc}
.filter-bubble.fb-status-open,.filter-chip-btn.fb-status-open{border-color:rgba(100,116,139,.3);background:rgba(100,116,139,.08);color:var(--text)}
.filter-bubble.fb-status-closed,.filter-chip-btn.fb-status-closed{border-color:rgba(167,139,250,.24);background:rgba(167,139,250,.12);color:#c4b5fd}
.filter-bubble.fb-status-todo,.filter-chip-btn.fb-status-todo{border-color:#2a2d35;background:#1a1d24;color:#64748b}
.filter-bubble.fb-status-in_progress,.filter-chip-btn.fb-status-in_progress{border-color:rgba(59,130,246,.22);background:rgba(59,130,246,.1);color:#93c5fd}
.filter-bubble.fb-status-pause,.filter-chip-btn.fb-status-pause{border-color:rgba(251,191,36,.24);background:rgba(251,191,36,.12);color:#fcd34d}
.filter-bubble.fb-status-review,.filter-chip-btn.fb-status-review{border-color:rgba(251,146,60,.22);background:#2a1f0e;color:#fb923c}
.filter-bubble.fb-status-tested,.filter-chip-btn.fb-status-tested{border-color:rgba(132,204,22,.24);background:#17220f;color:#bef264}
.filter-bubble.fb-status-resolved,.filter-chip-btn.fb-status-resolved{border-color:rgba(167,139,250,.24);background:rgba(167,139,250,.12);color:#c4b5fd}
.filter-bubble.fb-status-done,.filter-chip-btn.fb-status-done{border-color:rgba(34,197,94,.22);background:var(--low-bg);color:var(--low-text)}
.filter-bubble.fb-status-deleted,.filter-chip-btn.fb-status-deleted{border-color:rgba(75,85,99,.28);background:rgba(75,85,99,.12);color:#9ca3af}
.filter-bubble.fb-search{border-color:rgba(100,116,139,.3);background:rgba(100,116,139,.08)}
.filter-bubble.fb-pri-high,.filter-chip-btn.fb-pri-high{border-color:rgba(239,68,68,.3);background:var(--high-bg);color:var(--high-text)}
.filter-bubble.fb-pri-medium,.filter-chip-btn.fb-pri-medium{border-color:rgba(245,158,11,.3);background:var(--med-bg);color:var(--med-text)}
.filter-bubble.fb-pri-low,.filter-chip-btn.fb-pri-low{border-color:rgba(34,197,94,.3);background:var(--low-bg);color:var(--low-text)}
.filter-bubble.fb-customer,.filter-chip-btn.fb-customer{border-color:rgba(236,72,153,.28);background:rgba(236,72,153,.1);color:#f9a8d4}
.filter-bubble.fb-sort{border-color:rgba(59,130,246,.2);background:rgba(59,130,246,.06);color:var(--muted)}
.clear-all{font-size:13px;color:var(--muted);cursor:pointer;padding:2px 6px;border-radius:4px;white-space:nowrap;transition:color 0.1s}
.clear-all:hover{color:var(--text)}

/* Stats */
.stats-bar{display:flex;gap:1px;background:var(--border);border-bottom:1px solid var(--border);flex-shrink:0}
.stat-cell{flex:1;padding:9px 14px;background:var(--surface);display:flex;flex-direction:column;gap:1px;transition:background 0.1s,box-shadow 0.1s}
.stat-cell:hover{background:var(--surface2)}
.stat-cell.active{background:var(--surface2);box-shadow:inset 0 0 0 1px var(--accent)}
.stat-cell.active .stat-num{font-weight:700}
.stat-cell.active .stat-label{color:var(--text);font-weight:600}
.stat-num{font-family:var(--mono);font-size:21px;font-weight:500;line-height:1.1}
.stat-label{font-size:12px;color:var(--muted)}
.stat-num.stat-progress{color:var(--accent)}
.stat-num.stat-pause{color:#fbbf24}
.stat-num.stat-review{color:#fb923c}
.stat-num.stat-closed{color:#c4b5fd}
.stat-num.stat-done{color:var(--low)}
.stat-num.stat-tested{color:#84cc16}

/* Task table */
.content-scroll{flex:1;overflow-y:auto;padding:0}
.tasks-scroll{display:flex;flex-direction:column;min-height:0}
.mobile-board-section{display:none}
.mobile-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:0 16px}
.mobile-section-kicker{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.mobile-section-title{font-size:20px;font-weight:600;letter-spacing:-.02em;color:var(--text)}
.mobile-section-meta{font-size:12px;color:var(--muted)}
.mobile-task-list,.mobile-relevant-list{display:flex;flex-direction:column;gap:10px;padding:0 16px 16px}
.mobile-task-card,.mobile-relevant-card{width:100%;border:1px solid var(--border);border-radius:18px;background:var(--surface);text-align:left;color:var(--text);font:inherit;box-shadow:var(--shadow);transition:border-color .12s ease,transform .12s ease,box-shadow .12s ease}
.mobile-task-card{padding:14px 14px 12px}
.mobile-relevant-card{padding:13px 14px}
.mobile-task-card:hover,.mobile-relevant-card:hover{border-color:rgba(59,130,246,.34);transform:translateY(-1px);box-shadow:0 14px 28px rgba(0,0,0,.16)}
.mobile-task-card-head,.mobile-relevant-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.mobile-task-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.mobile-task-card-main,.mobile-relevant-card-main{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.mobile-task-card-id,.mobile-relevant-card-id{font-size:11px;font-family:var(--mono);color:var(--muted)}
.mobile-task-card-title,.mobile-relevant-card-title{font-size:15px;font-weight:500;line-height:1.35;color:var(--text)}
.mobile-task-card-preview,.mobile-relevant-card-preview{font-size:13px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
.mobile-task-card-preview strong,.mobile-relevant-card-preview strong{color:var(--text);font-weight:600}
.mobile-task-card-meta,.mobile-relevant-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px}
.mobile-task-card-pill,.mobile-relevant-card-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);font-size:11px;font-family:var(--mono);color:var(--muted)}
.mobile-task-card-pill.primary,.mobile-relevant-card-pill.primary{border-color:rgba(59,130,246,.24);background:rgba(59,130,246,.08);color:var(--accent)}
.mobile-task-card-foot,.mobile-relevant-card-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.mobile-task-card-time,.mobile-relevant-card-time{font-size:11px;font-family:var(--mono);color:var(--muted)}
.mobile-task-card-cta,.mobile-relevant-card-cta{font-size:12px;font-weight:600;color:var(--accent)}
.mobile-task-empty,.mobile-relevant-empty{padding:14px 16px;border:1px dashed var(--border2);border-radius:16px;background:rgba(255,255,255,.02);font-size:13px;line-height:1.5;color:var(--muted)}
.stat-cell-recents .stat-num{color:var(--accent)}
.mobile-top-tabs{display:none}
.task-table{width:100%;border-collapse:collapse}

/* Sortable column headers */
.th-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--muted);font-size:12px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;padding:0;font-family:var(--sans);white-space:nowrap;transition:color 0.1s}
.th-btn:hover{color:var(--text)}
.th-btn.sorted{color:var(--accent)}
.th-sort-icon{font-size:11px;opacity:0.6}
th{padding:10px 10px 9px;text-align:left;border-bottom:1px solid var(--border);position:relative}
th:first-child{padding-left:20px}

/* Column filter dropdown */
.col-menu{position:absolute;top:calc(100% + 2px);left:0;z-index:100;background:var(--surface);border:1px solid var(--border2);border-radius:8px;min-width:160px;padding:4px;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none}
.col-menu.open{display:block}
.col-menu-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:5px;font-size:14px;color:var(--muted);cursor:pointer;transition:all 0.08s;white-space:nowrap}
.col-menu-item:hover{background:var(--surface2);color:var(--text)}
.col-menu-item.active{color:var(--text);background:var(--surface2)}
.col-menu-item .cm-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.col-menu-sep{height:1px;background:var(--border);margin:4px 0}
.col-menu-label{font-size:11px;color:var(--muted);padding:4px 10px 2px;letter-spacing:0.1em;text-transform:uppercase}
.search-menu-list{max-height:260px;overflow:auto}
.search-menu-empty{padding:10px;color:var(--muted);font-size:12px}

.task-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.08s,box-shadow 0.08s}
.task-row:hover{background:var(--surface2)}
.task-row.task-row-colorized{background:rgba(var(--task-row-accent-rgb),.13);box-shadow:inset 0 0 0 1px rgba(var(--task-row-accent-rgb),.18)}
.task-row.task-row-colorized:hover{background:rgba(var(--task-row-accent-rgb),.2);box-shadow:inset 0 0 0 1px rgba(var(--task-row-accent-rgb),.28)}
.task-row.active-row{background:var(--surface3)!important;box-shadow:inset 0 0 0 1px rgba(59,130,246,.18)}
.task-row.done-row{}
.task-section-row{border-bottom:none}
.task-section-row td{padding:14px 10px 6px}
.task-section-divider{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.task-row.dragging-row{opacity:0.25}
.task-row.new-row{animation:rowFlash 1.8s ease-out forwards}
@keyframes rowFlash{
  0%{background:rgba(59,130,246,0.28)}
  30%{background:rgba(59,130,246,0.18)}
  100%{background:transparent}
}
.task-row td{padding:10px 10px;vertical-align:middle}
.task-row td:first-child{padding-left:20px}
.row-lead{display:inline-flex;align-items:flex-start;gap:6px}
.row-expand-stack{display:flex;flex-direction:column;align-items:center;gap:3px}
.row-expand-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:13px;transition:all .12s;vertical-align:middle;text-decoration:none}
.row-expand-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(59,130,246,.08)}
.row-task-id{font-family:var(--mono);font-size:10px;line-height:1;color:var(--muted)}
.drag-grip{color:var(--border2);font-size:15px;cursor:grab;user-select:none;padding-right:4px}
.drag-grip:hover{color:var(--muted)}
.task-cell-main{display:flex;align-items:center;gap:12px;min-width:0}
.task-cell-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.task-cell-copy .proj-pill{align-self:flex-start}
.task-title-line{display:flex;align-items:center;gap:8px;min-width:0}
.task-row-color-menu{padding:6px}
.task-row-color-option-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0;box-shadow:0 0 0 1px rgba(255,255,255,.08) inset}
.task-row-color-option-empty{background:transparent;border:1px dashed var(--border2);box-shadow:none}
.task-reaction-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-top:8px;position:relative}
.task-reaction-bar.compact{margin-top:6px;gap:6px}
.task-reaction-bar.summary{margin-top:auto;padding-top:2px}
.task-reaction-list{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.task-reaction-chip,.task-reaction-add,.task-reaction-option{border:1px solid var(--border2);background:var(--surface2);color:var(--text);font:inherit}
.task-reaction-chip{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 9px;cursor:pointer;font-size:12px;line-height:1}
.task-reaction-chip span{font-family:var(--mono);font-size:11px;color:var(--muted)}
.task-reaction-chip.active{border-color:rgba(245,158,11,.45);background:rgba(245,158,11,.12)}
.task-reaction-add-wrap{position:relative;margin-left:auto}
.task-reaction-add{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:4px 12px;cursor:pointer;font-size:11px;font-weight:600;color:var(--muted);position:relative}
.task-reaction-add.icon{width:28px;height:28px;justify-content:center;padding:0;border-radius:999px}
.task-reaction-add-face{font-size:14px;line-height:1;opacity:.9}
.task-reaction-add-text{font-family:var(--mono);letter-spacing:.02em}
.task-reaction-add-plus{display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px;border-radius:999px;background:var(--surface3);font-size:10px;line-height:1;color:var(--text);border:1px solid var(--border2)}
.task-reaction-add.icon .task-reaction-add-plus{position:absolute;right:1px;bottom:1px;width:11px;height:11px;font-size:9px;background:var(--surface)}
.task-reaction-add:hover,.task-reaction-chip:hover{border-color:var(--border);background:var(--surface3)}
.task-reaction-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:150px;padding:6px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);display:none;z-index:30}
.task-reaction-menu.open{display:grid;gap:4px}
.task-reaction-option{display:flex;align-items:center;gap:10px;width:100%;border-radius:10px;padding:8px 10px;cursor:pointer;font-size:12px}
.task-reaction-option:hover,.task-reaction-option.active{background:var(--surface3);border-color:var(--border)}
.task-reaction-option-emoji{font-size:16px;line-height:1}
.task-media-thumb{position:relative;width:46px;height:46px;border-radius:12px;overflow:hidden;flex-shrink:0;border:1px solid var(--border2);background:var(--surface2);display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:var(--text);box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}
.task-media-thumb:hover{border-color:rgba(59,130,246,.32)}
.task-media-thumb.is-video{background:#0b0d10}
.task-media-thumb.is-pdf{background:linear-gradient(160deg,rgba(239,68,68,.14),rgba(239,68,68,.04)),var(--surface2)}
.task-media-thumb-asset{width:100%;height:100%;display:block;object-fit:cover;background:transparent}
.task-media-thumb-video-placeholder{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:14px;font-family:var(--mono);font-weight:700;letter-spacing:.04em;color:#cbd5e1;background:radial-gradient(circle at top,rgba(59,130,246,.35),rgba(15,23,42,.9))}
.task-media-thumb-pdf{pointer-events:none;background:#fff}
.task-media-fallback{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:12px;font-family:var(--mono);font-weight:700;letter-spacing:.08em;color:var(--high-text);background:rgba(239,68,68,.08)}
.task-media-badge{position:absolute;right:4px;bottom:4px;padding:1px 4px;border-radius:999px;background:rgba(0,0,0,.72);color:#fff;font-size:9px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;line-height:1.4}
.task-title-text{font-size:15px;font-weight:500;color:var(--text)}
.task-title-accomplished{font-weight:800!important;color:#dbe8e0}
.task-hashtag-list{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:3px}
.task-hashtag-list.compact{margin-top:5px;gap:5px}
.task-hashtag-chip{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(59,130,246,.26);background:rgba(59,130,246,.08);color:#93c5fd;border-radius:999px;padding:1px 7px;font-size:11px;font-family:var(--mono);line-height:1.45;cursor:pointer}
.task-hashtag-chip:hover{background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.38);color:#bfdbfe}
.task-hashtag-more{font-size:10px;color:var(--muted);font-family:var(--mono)}
.task-sub{font-size:13px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}
.proj-pill{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-family:var(--mono);padding:1px 6px;border-radius:8px;background:var(--surface3);color:var(--muted);margin-top:3px;cursor:pointer}
.proj-pill:hover{color:var(--text)}
.badge{display:inline-flex;align-items:center;font-size:12px;font-weight:500;font-family:var(--mono);padding:2px 7px;border-radius:4px;white-space:nowrap}
.b-high{background:var(--high-bg);color:var(--high-text);border:1px solid rgba(239,68,68,.22)}
.b-medium{background:var(--med-bg);color:var(--med-text);border:1px solid rgba(245,158,11,.22)}
.b-low{background:var(--low-bg);color:var(--low-text);border:1px solid rgba(34,197,94,.22)}
.s-badge{font-size:12px;font-family:var(--mono);padding:2px 7px;border-radius:4px;white-space:nowrap}
.s-todo{background:#1a1d24;color:#64748b;border:1px solid #2a2d35}
.s-in_progress{background:rgba(59,130,246,.1);color:#93c5fd;border:1px solid rgba(59,130,246,.22)}
.s-pause{background:rgba(251,191,36,.12);color:#fcd34d;border:1px solid rgba(251,191,36,.24)}
.s-review{background:#2a1f0e;color:#fb923c;border:1px solid rgba(251,146,60,.22)}
.s-tested{background:#17220f;color:#bef264;border:1px solid rgba(132,204,22,.24)}
.s-resolved{background:rgba(167,139,250,.12);color:#c4b5fd;border:1px solid rgba(167,139,250,.24)}
.s-done{background:var(--low-bg);color:var(--low-text);border:1px solid rgba(34,197,94,.22)}
.dev-cell{display:flex;align-items:center;gap:6px;font-size:14px}
.avatar{width:22px;height:22px;border-radius:50%;background:var(--accent-d);display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:600;color:#fff;font-family:var(--mono);flex-shrink:0}
.avatar.md{width:32px;height:32px;font-size:13px}
.due-sm{font-family:var(--mono);font-size:13px;color:var(--muted)}
.due-sm.over{color:var(--high)}.due-sm.soon{color:var(--med)}
.msg-ct{font-size:13px;color:var(--muted);font-family:var(--mono)}
.msg-ct.has{color:var(--accent)}
.empty-state{text-align:center;padding:60px;color:var(--muted)}
.empty-big{font-size:32px;margin-bottom:10px}

/* Developers view */
.dev-range-controls{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.dev-range-label{font-size:12px;color:var(--muted);font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}
.dev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:11px;padding:20px 22px}
.dev-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:9px}
.dev-card-top{display:flex;align-items:center;gap:11px}
.dev-card-name{font-size:16px;font-weight:500}
.dev-card-sub{font-size:13px;color:var(--muted)}
.dev-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}
.dev-stat{flex:1;background:var(--surface2);border-radius:6px;padding:7px 8px;text-align:center}
.dev-stat-n{font-family:var(--mono);font-size:17px;font-weight:500}
.dev-stat-l{font-size:12px;color:var(--muted)}
.dev-actions{display:flex;gap:6px;flex-wrap:wrap}
.dev-summary-toggle{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);cursor:pointer}
.dev-summary-toggle input{accent-color:var(--accent)}
.dev-btn{font-size:13px;padding:5px 11px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;font-family:var(--sans);transition:all 0.1s}
.dev-btn:hover{color:var(--text);background:var(--surface2)}
.dev-btn.danger:hover{color:var(--high-text);border-color:rgba(239,68,68,.4);background:var(--high-bg)}
.password-popup-card{display:flex;flex-direction:column;gap:10px}
.password-popup-user{font-size:13px;color:var(--muted);line-height:1.45}
.password-popup-value{font-family:var(--mono)!important;font-size:14px!important;letter-spacing:.03em}

/* Customers view */
.customers-view-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;padding:20px}
.customers-view-grid-compact{justify-content:center}
.customer-view-card{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,rgba(34,197,94,.08),transparent 120px),var(--surface);box-shadow:var(--shadow)}
.customers-view-grid-compact .customer-view-card{max-width:420px;width:min(100%,420px)}
.customer-view-media{position:relative;display:flex;align-items:flex-end;justify-content:flex-start;min-height:148px;padding:14px;border:1px solid var(--border2);border-radius:16px;background:
  radial-gradient(circle at top right, rgba(59,130,246,.22), transparent 38%),
  linear-gradient(135deg, rgba(34,197,94,.22), rgba(59,130,246,.12)),
  var(--surface2)}
.customer-view-media::after{content:"";position:absolute;inset:14px 14px auto auto;width:78px;height:78px;border-radius:24px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06)}
.customer-view-media-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:14px;background:rgba(15,23,42,.68);border:1px solid rgba(255,255,255,.14);font-size:16px;font-weight:700;color:#fff;font-family:var(--mono);backdrop-filter:blur(6px)}
.customer-view-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.customer-view-head-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.customer-view-name{font-size:18px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.customer-view-sub{font-size:12px;color:var(--muted)}
.customer-view-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;font-size:11px;font-family:var(--mono);color:var(--muted)}
.customer-view-stats span{padding:5px 8px;border-radius:999px;background:var(--surface2);border:1px solid var(--border2)}
.customer-view-task-list{display:flex;flex-direction:column;gap:8px}
.customer-view-task{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:11px 12px;border:1px solid var(--border2);border-radius:14px;background:var(--surface2);cursor:pointer;text-align:left;transition:border-color .12s,background .12s}
.customer-view-task:hover{border-color:var(--accent);background:rgba(59,130,246,.08)}
.customer-view-task-main{display:flex;flex-direction:column;gap:4px;min-width:0}
.customer-view-task-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.customer-view-task-meta{font-size:11px;color:var(--muted);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.customer-view-task-side{flex-shrink:0}

/* Summary view */
.summary-controls-slot{display:flex;align-items:center;justify-content:flex-start;min-width:0}
.summary-controls-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}
.summary-chip-pair{display:flex;align-items:center;gap:6px;min-width:0}
.summary-dev-picker-wrap{width:260px;min-width:260px;display:flex;align-items:center}
.summary-dev-picker{max-width:100%;justify-content:flex-start}
.summary-dev-picker .filter-chip-value{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.summary-dev-picker .filter-chip-value .avatar{flex-shrink:0}
.summary-dev-nav{display:flex;align-items:center;gap:8px;margin-right:4px}
.summary-range-context-inline{font-size:12px;color:var(--muted);font-family:var(--mono);white-space:nowrap}
.summary-range-menu{max-width:min(360px,calc(100vw - 24px));padding:6px}
.summary-range-preset-list{display:flex;flex-direction:column;gap:2px}
.summary-range-custom-preset-disabled{opacity:.55}
.summary-range-custom{display:flex;flex-direction:column;gap:8px;padding:8px 9px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.02)}
.summary-range-custom-title{font-size:10px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-range-custom-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.summary-range-custom-field{display:flex;flex-direction:column;gap:4px;font-size:11px;font-family:var(--mono);color:var(--muted)}
.summary-range-date-input{width:100%;padding:6px 8px;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);color:var(--text);font:inherit;font-size:12px;outline:none}
.summary-range-date-input:focus{border-color:var(--accent)}
.summary-range-custom-actions{display:flex;align-items:center;gap:6px}
.summary-range-custom-actions .dev-btn{font-size:12px;padding:5px 10px}
.summary-range-custom-actions .dev-btn:disabled{opacity:.55;cursor:not-allowed}
.summary-range-custom-hint{font-size:11px;color:var(--muted);line-height:1.35}
.summary-range-custom-hint.valid{color:#86efac}
.summary-view-toggle{display:inline-flex;align-items:center;gap:4px;margin-left:auto;padding:4px;border:1px solid var(--border2);border-radius:999px;background:var(--surface2)}
.summary-view-toggle-btn{border:none;background:transparent;color:var(--muted);padding:6px 12px;border-radius:999px;font:inherit;font-size:12px;font-weight:600;cursor:pointer}
.summary-view-toggle-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.14)}
.summary-feed{padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.summary-top-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}
.summary-compare{padding:16px 18px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,rgba(37,99,235,.08),transparent 120px),var(--surface);box-shadow:var(--shadow)}
.summary-compare-full{width:100%}
.summary-compare-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.summary-compare-title{font-size:16px;font-weight:600;color:var(--text)}
.summary-compare-sub{font-size:12px;color:var(--muted);font-family:var(--mono)}
.summary-compare-chart{display:flex;flex-direction:column;gap:10px}
.summary-compare-row{display:grid;grid-template-columns:minmax(120px,180px) minmax(0,1fr) 58px;align-items:center;gap:10px}
.summary-compare-row.active .summary-compare-name{color:var(--text)}
.summary-compare-name{border:none;background:none;padding:0;font:inherit;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;cursor:pointer}
.summary-compare-name:hover{color:var(--text)}
.summary-compare-bar-track{height:12px;border-radius:999px;background:var(--surface2);border:1px solid var(--border2);overflow:hidden;padding:0;cursor:pointer}
.summary-compare-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#3b82f6);position:relative;overflow:hidden}
.summary-compare-bar-customer{position:absolute;left:0;top:0;bottom:0;border-radius:999px;background:linear-gradient(90deg,#f59e0b,#ef4444)}
.summary-compare-value{border:none;background:none;padding:0;font:inherit;font-size:12px;font-family:var(--mono);color:var(--text);text-align:right;cursor:pointer}
.summary-team-totals{padding:16px 18px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,rgba(34,197,94,.08),transparent 120px),var(--surface);box-shadow:var(--shadow)}
.summary-team-periods{display:flex;flex-direction:column;gap:10px}
.summary-team-period{padding:12px 14px;border:1px solid var(--border2);border-radius:16px;background:rgba(255,255,255,.03)}
.summary-team-period-previous{background:linear-gradient(180deg,rgba(245,158,11,.12),rgba(255,255,255,.02))}
.summary-team-period-current{background:linear-gradient(180deg,rgba(34,197,94,.12),rgba(255,255,255,.02))}
.summary-team-period-head{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}
.summary-team-period-label{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-team-period-context{font-size:12px;color:var(--muted)}
.summary-team-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.summary-team-metric{padding:10px 12px;border:1px solid var(--border2);border-radius:14px;background:rgba(15,23,42,.14)}
.summary-team-metric-label{font-size:11px;font-family:var(--mono);color:var(--muted);margin-bottom:6px}
.summary-team-metric-value{font-size:28px;line-height:1;font-weight:700;color:var(--text)}
.summary-team-current{margin-top:12px;padding:12px 14px;border:1px dashed var(--border2);border-radius:16px;background:rgba(255,255,255,.03)}
.summary-team-current-label{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-team-current-value{font-size:32px;line-height:1.05;font-weight:700;color:var(--text);margin-top:6px}
.summary-team-current-sub{font-size:12px;color:var(--muted);margin-top:4px}
.summary-tips{padding:16px 18px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,rgba(245,158,11,.08),transparent 120px),var(--surface);box-shadow:var(--shadow)}
.summary-tips-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.summary-tips-title{font-size:16px;font-weight:600;color:var(--text)}
.summary-tips-list{display:flex;flex-wrap:wrap;gap:10px}
.summary-tip-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid rgba(245,158,11,.35);border-radius:999px;background:rgba(245,158,11,.08);color:var(--text);font:inherit;font-size:13px;font-weight:600;cursor:pointer}
.summary-tip-chip:hover{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.48)}
.summary-dev-metrics{padding:16px 18px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,rgba(148,163,184,.08),transparent 120px),var(--surface);box-shadow:var(--shadow)}
.summary-dev-metrics-table{display:flex;flex-direction:column;gap:8px}
.summary-dev-metrics-header,.summary-dev-metrics-row{display:grid;grid-template-columns:minmax(140px,1.2fr) repeat(7,minmax(100px,1fr));gap:8px;align-items:stretch}
.summary-dev-metrics-header{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-dev-metrics-row{padding:8px 0}
.summary-dev-metrics-name{border:none;background:none;padding:10px 0;text-align:left;font:inherit;font-weight:600;color:var(--text);cursor:pointer}
.summary-dev-metrics-name:hover{color:var(--accent)}
.summary-dev-metric-card{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;padding:10px 12px;border:1px solid var(--border2);border-radius:14px;background:rgba(255,255,255,.03);color:var(--text);cursor:pointer}
.summary-dev-metric-card:hover{border-color:var(--border);background:rgba(255,255,255,.05)}
.summary-dev-metric-card-accomplished{background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(134,239,172,.08)),var(--surface2);border-color:rgba(34,197,94,.34)}
.summary-dev-metric-card-review{background:linear-gradient(135deg,rgba(251,146,60,.24),rgba(254,215,170,.08)),var(--surface2);border-color:rgba(251,146,60,.36)}
.summary-dev-metric-card-customer{background:linear-gradient(135deg,rgba(22,163,74,.24),rgba(187,247,208,.08)),var(--surface2);border-color:rgba(34,197,94,.38)}
.summary-dev-metric-card-customer-progress{background:linear-gradient(135deg,rgba(14,165,233,.22),rgba(186,230,253,.08)),var(--surface2);border-color:rgba(14,165,233,.34)}
.summary-dev-metric-card-progress{background:linear-gradient(135deg,rgba(59,130,246,.24),rgba(191,219,254,.08)),var(--surface2);border-color:rgba(59,130,246,.36)}
.summary-dev-metric-card-open{background:linear-gradient(135deg,rgba(96,165,250,.22),rgba(219,234,254,.08)),var(--surface2);border-color:rgba(96,165,250,.34)}
.summary-dev-metric-card-label{font-size:10px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-dev-metric-card-value{font-size:22px;line-height:1;font-weight:700}
.summary-customer-panel{padding:16px 18px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,rgba(34,197,94,.08),transparent 120px),var(--surface);box-shadow:var(--shadow)}
.summary-customer-panel .summary-workflow{padding:0;margin-top:14px}
.summary-mini-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.summary-mini-stat{padding:7px 10px;border:1px solid var(--border2);border-radius:999px;background:rgba(255,255,255,.04);font-size:11px;font-family:var(--mono);color:var(--muted)}
.summary-mini-stat strong{color:var(--text);font-weight:600}
.summary-panel-segments{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:999px;background:var(--surface2);border:1px solid var(--border2)}
.summary-panel-segment{border:none;background:transparent;color:var(--muted);padding:6px 12px;border-radius:999px;font:inherit;font-size:12px;font-weight:600;cursor:pointer}
.summary-panel-segment.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.12)}
.summary-cleared-undo{border:none;background:rgba(34,197,94,.14);color:#22c55e;padding:5px 10px;border-radius:999px;font:inherit;font-size:11px;font-weight:600;cursor:pointer}
.summary-cleared-undo:hover{background:rgba(34,197,94,.22)}
.summary-customer-grid{display:grid;grid-template-columns:1fr;gap:10px}
.summary-customer-tile{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--surface2)}
.summary-customer-tile-cleared{opacity:.88}
.summary-customer-images{display:block}
.summary-customer-image{width:100%;height:160px;border-radius:14px;overflow:hidden;border:1px solid var(--border2);display:block;background:var(--surface);flex-shrink:0}
.summary-customer-image img{width:100%;height:100%;display:block;object-fit:cover}
.summary-customer-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.summary-customer-actions{display:flex;align-items:center;gap:8px}
.summary-customer-dev{font-size:11px;font-family:var(--mono);color:var(--muted)}
.summary-customer-clear{border:none;background:rgba(239,68,68,.12);color:#ef4444;width:24px;height:24px;border-radius:999px;display:grid;place-items:center;font:inherit;font-size:16px;line-height:1;cursor:pointer}
.summary-customer-clear:hover{background:rgba(239,68,68,.2)}
.summary-group{background:linear-gradient(180deg,rgba(59,130,246,.06),transparent 120px),var(--surface);border:1px solid var(--border);border-radius:18px;overflow:visible;box-shadow:var(--shadow)}
.summary-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}
.summary-group-meta{display:flex;align-items:center;gap:10px;min-width:0}
.summary-group-name{font-size:17px;font-weight:600;color:var(--text)}
.summary-group-sub{font-size:12px;color:var(--muted)}
.summary-group-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.summary-generated{margin:16px;padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),var(--surface2)}
.summary-generated-collapsed{padding-bottom:12px}
.summary-generated-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.summary-generated-collapsed .summary-generated-head{margin-bottom:0}
.summary-generated-title{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-generated-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.summary-generated-error{margin-bottom:10px;font-size:12px;color:var(--high)}
.summary-generated-sections{display:flex;flex-direction:column;gap:12px;padding-top:10px;border-top:1px solid var(--border2)}
.summary-generated-section{padding:0;border:none;border-radius:0;background:transparent}
.summary-generated-section + .summary-generated-section{padding-top:12px;border-top:1px solid var(--border2)}
.summary-generated-label{font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px}
.summary-generated-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:12px;line-height:1.45}
.summary-generated-list li{margin:0}
.summary-inline-link{border:none;background:none;padding:0;color:var(--muted);font:inherit;font-size:12px;line-height:1.45;text-align:left;cursor:pointer}
.summary-inline-link:hover{color:var(--accent)}
.summary-inline-customer{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;margin-right:6px;background:rgba(245,158,11,.14);border:1px solid rgba(245,158,11,.24);color:#f59e0b;font-size:10px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}
.summary-generated-raw{padding:10px 11px;border:1px solid var(--border2);border-radius:10px;background:rgba(255,255,255,.02);white-space:pre-wrap;font-size:12px;color:var(--muted);line-height:1.45}
.summary-kpi-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px;padding:16px;border-bottom:1px solid var(--border)}
.summary-kpi{display:flex;flex-direction:column;justify-content:space-between;gap:8px;padding:16px;border:1px solid var(--border);border-radius:16px;background:var(--surface2)}
.summary-kpi-button{appearance:none;width:100%;text-align:left;cursor:pointer;transition:border-color .12s,transform .12s,box-shadow .12s}
.summary-kpi-button:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--shadow)}
.summary-kpi-button.active{box-shadow:inset 0 0 0 1px rgba(255,255,255,.14),var(--shadow);transform:translateY(-1px)}
.summary-kpi-primary{background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(134,239,172,.08)),var(--surface2);border-color:rgba(34,197,94,.34)}
.summary-kpi-review{background:linear-gradient(135deg,rgba(251,146,60,.24),rgba(254,215,170,.08)),var(--surface2);border-color:rgba(251,146,60,.36)}
.summary-kpi-customer{background:linear-gradient(135deg,rgba(22,163,74,.24),rgba(187,247,208,.08)),var(--surface2);border-color:rgba(34,197,94,.38)}
.summary-kpi-customer-progress{background:linear-gradient(135deg,rgba(14,165,233,.22),rgba(186,230,253,.08)),var(--surface2);border-color:rgba(14,165,233,.34)}
.summary-kpi-progress{background:linear-gradient(135deg,rgba(59,130,246,.24),rgba(191,219,254,.08)),var(--surface2);border-color:rgba(59,130,246,.36)}
.summary-kpi-open{background:linear-gradient(135deg,rgba(96,165,250,.22),rgba(219,234,254,.08)),var(--surface2);border-color:rgba(96,165,250,.34)}
.summary-kpi-label{font-size:11px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.summary-kpi-value{font-size:64px;line-height:.9;font-weight:700;color:var(--text)}
.summary-kpi:not(.summary-kpi-primary) .summary-kpi-value{font-size:40px}
.summary-kpi-sub{font-size:12px;color:var(--muted)}
.summary-workflow{display:flex;flex-direction:column;gap:16px;padding:16px}
.summary-status-column{display:flex;flex-direction:column;gap:10px}
.summary-status-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.summary-status-label{font-size:11px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.summary-status-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:var(--surface2);border:1px solid var(--border2);font-size:12px;font-family:var(--mono);color:var(--text)}
.summary-primary-grid{display:grid;gap:12px}
.summary-primary-grid-capped{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),340px));justify-content:start}
.summary-primary-grid-capped .summary-primary-tile,.summary-primary-grid-capped .summary-empty{width:min(100%,340px)}
.summary-primary-grid-fill{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.summary-primary-tile,.summary-mini-tile{display:flex;flex-direction:column;gap:6px;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--surface2);border-radius:16px;padding:14px 14px 12px;position:relative;overflow:visible}
.summary-primary-tile{cursor:pointer;transition:border-color .14s,box-shadow .14s}
.summary-primary-tile:hover{box-shadow:0 12px 24px rgba(0,0,0,.12)}
.summary-primary-tile:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.summary-accomplished-tile{border-color:rgba(34,197,94,.2)}
.summary-progress-tile{border-color:rgba(59,130,246,.22)}
.summary-customer-task{box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.summary-tile-accomplished{background:linear-gradient(180deg,rgba(34,197,94,.18),rgba(134,239,172,.05)),var(--surface2);border-color:rgba(34,197,94,.34)}
.summary-tile-accomplished:hover{border-color:rgba(34,197,94,.72)}
.summary-tile-customer-done{background:linear-gradient(180deg,rgba(22,163,74,.22),rgba(187,247,208,.06)),var(--surface2);border-color:rgba(34,197,94,.38)}
.summary-tile-customer-done:hover{border-color:rgba(34,197,94,.76)}
.summary-tile-progress{background:linear-gradient(180deg,rgba(59,130,246,.2),rgba(191,219,254,.05)),var(--surface2);border-color:rgba(59,130,246,.36)}
.summary-tile-progress:hover{border-color:rgba(96,165,250,.74)}
.summary-tile-customer-progress{background:linear-gradient(180deg,rgba(14,165,233,.22),rgba(186,230,253,.06)),var(--surface2);border-color:rgba(14,165,233,.38)}
.summary-tile-customer-progress:hover{border-color:rgba(14,165,233,.76)}
.summary-primary-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.summary-status-badge-btn{align-self:flex-start}
.summary-status-badge-btn .s-badge{font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px}
.summary-status-badge-control{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.summary-status-badge-btn:hover .summary-status-badge-control{filter:brightness(1.05)}
.summary-status-badge-caret{font-size:9px;opacity:.9}
.summary-status-tone-accomplished{background:rgba(34,197,94,.2);color:#86efac;border:1px solid rgba(34,197,94,.34)}
.summary-status-tone-customer-done{background:rgba(22,163,74,.24);color:#bbf7d0;border:1px solid rgba(34,197,94,.38)}
.summary-status-tone-review{background:rgba(251,146,60,.2);color:#fdba74;border:1px solid rgba(251,146,60,.34)}
.summary-status-tone-customer-review{background:rgba(249,115,22,.24);color:#fed7aa;border:1px solid rgba(251,146,60,.38)}
.summary-status-tone-progress{background:rgba(59,130,246,.2);color:#bfdbfe;border:1px solid rgba(59,130,246,.34)}
.summary-status-tone-customer-progress{background:rgba(14,165,233,.24);color:#bae6fd;border:1px solid rgba(14,165,233,.38)}
.summary-task-link{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;min-height:calc(1.35em * 2);color:var(--text);font-size:14px;font-weight:500;line-height:1.35;text-align:left}
.summary-task-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.summary-task-media{display:flex;margin-top:-2px}
.summary-task-media-thumb{width:100%;height:auto;min-height:168px;aspect-ratio:16/9;border-radius:14px}
.summary-task-media-trigger{padding:0;border:1px solid var(--border2);background:var(--surface2);cursor:pointer;color:var(--text);overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.summary-task-media-trigger:hover{border-color:rgba(96,165,250,.5)}
.summary-task-media-trigger.is-video{background:#0b0d10}
.summary-task-media-placeholder{background:linear-gradient(180deg,rgba(148,163,184,.14),rgba(100,116,139,.22));border:1px solid rgba(148,163,184,.18)}
.summary-task-media-placeholder span{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-task-media-thumb .task-media-badge{right:8px;bottom:8px}
.summary-role-pills{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.summary-role-pill{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;border:1px solid rgba(59,130,246,.24);background:rgba(59,130,246,.1);font-size:11px;font-family:var(--mono);color:var(--accent)}
.summary-role-pill-customer{border-color:rgba(245,158,11,.28);background:rgba(245,158,11,.14);color:#f59e0b}
.summary-task-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.summary-task-meta-item{display:inline-flex;align-items:center;gap:6px}
.summary-task-meta-item-customer{color:#f59e0b}
.summary-task-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.summary-task-comment{padding:8px 10px;background:rgba(255,255,255,.02);border:1px solid var(--border2);border-radius:10px}
.summary-task-comment-label{font-size:9px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;line-height:1}
.summary-task-comment-body{font-size:12px;color:var(--muted);line-height:1.35;word-break:break-word}
.summary-task-comment-body strong{color:var(--text);font-weight:500}
.summary-task-comment-time{font-size:10px;color:var(--muted);font-family:var(--mono);margin-left:4px}
.summary-secondary-sections{display:flex;flex-direction:column;gap:14px;padding:0 16px 16px}
.summary-secondary-group{display:flex;flex-direction:column;gap:10px}
.summary-secondary-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.summary-secondary-title{font-size:11px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.summary-secondary-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:var(--surface2);border:1px solid var(--border2);font-size:12px;font-family:var(--mono);color:var(--text)}
.summary-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.summary-mini-kicker{font-size:10px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.summary-mini-sub{font-size:12px;color:var(--muted)}
.summary-group-footer{display:flex;justify-content:flex-end;padding:0 16px 16px}
.summary-empty{padding:18px 16px;border:1px dashed var(--border2);border-radius:14px;color:var(--muted);font-size:13px;background:rgba(255,255,255,.02)}
@media (max-width: 860px){
  .summary-kpi-row{grid-template-columns:1fr}
  .summary-dev-metrics-header,.summary-dev-metrics-row{grid-template-columns:1fr}
  .summary-group-head,.summary-primary-top{flex-direction:column;align-items:flex-start}
  .summary-group-actions,.summary-task-badges{justify-content:flex-start}
  .summary-controls-slot,.summary-controls-row{width:100%}
  .summary-range-context-inline{white-space:normal}
  .summary-view-toggle{margin-left:0}
  .summary-top-grid{grid-template-columns:1fr}
  .summary-compare-row,.summary-team-metrics{grid-template-columns:1fr}
  .summary-customer-top,.summary-customer-actions,.summary-compare-head{flex-wrap:wrap}
  .summary-compare-value{text-align:left}
  .summary-generated-head,.summary-generated-actions{flex-direction:column;align-items:flex-start}
  .summary-primary-grid,.summary-mini-grid{grid-template-columns:1fr}
  .summary-task-media-thumb{min-height:144px}
}

/* Projects view */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:11px;padding:20px 22px}
.project-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px;cursor:pointer;transition:border-color 0.12s}
.project-card:hover{border-color:var(--border2)}
.project-card.new-card{border-style:dashed;align-items:center;justify-content:center;min-height:120px;cursor:pointer}
.proj-card-top{display:flex;align-items:center;gap:10px}
.proj-card-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.proj-card-name{font-size:17px;font-weight:500}
.proj-card-desc{font-size:14px;color:var(--muted);line-height:1.4}
.proj-card-stats{display:flex;gap:7px}
.proj-stat{flex:1;background:var(--surface2);border-radius:6px;padding:6px 8px;text-align:center}
.proj-stat-n{font-family:var(--mono);font-size:16px;font-weight:500}
.proj-stat-l{font-size:12px;color:var(--muted)}
.proj-card-actions{display:flex;gap:6px;margin-top:2px}

/* Customers view */
.customers-grid{display:grid;gap:14px;padding:20px 22px}
.customers-grid-capped{grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),420px));justify-content:start}
.customers-grid-capped .customer-card{width:min(100%,420px)}
.customers-grid-fill{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.customer-card{background:linear-gradient(180deg,rgba(59,130,246,.04),transparent 150px),var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);transition:border-color .12s,box-shadow .12s,transform .12s,opacity .12s}
.customer-card[draggable="true"]{cursor:grab}
.customer-card.dragging-customer{opacity:.45;cursor:grabbing;transform:scale(.99)}
.customer-card.customer-drop-target{border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,130,246,.24),var(--shadow)}
.customer-card-empty{min-height:160px;align-items:center;justify-content:center;text-align:center}
.customer-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.customer-card-title-wrap{display:flex;align-items:flex-start;gap:9px;min-width:0}
.customer-card-copy{min-width:0}
.customer-card-name{font-size:17px;font-weight:600;color:var(--text)}
.customer-card-sub{font-size:12px;color:var(--muted);line-height:1.4;margin-top:2px}
.customer-star-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;margin-top:-2px;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);color:var(--muted);line-height:1;cursor:pointer;flex-shrink:0;transition:border-color .12s,background .12s,color .12s,transform .12s}
.customer-star-btn svg{width:17px;height:17px;display:block;fill:transparent;transition:fill .12s}
.customer-star-btn:hover{border-color:rgba(250,204,21,.55);background:rgba(250,204,21,.1);color:#facc15}
.customer-star-btn.active{border-color:rgba(250,204,21,.5);background:rgba(250,204,21,.13);color:#facc15}
.customer-star-btn.active svg{fill:currentColor}
.customer-card-stats{display:flex;gap:8px;flex-wrap:wrap}
.customer-card-actions{display:flex;justify-content:flex-end}
.customer-image-toggle{display:inline-flex;align-items:center;gap:7px;padding:6px 10px;border:1px solid var(--border2);border-radius:999px;background:var(--surface2);color:var(--muted);font-size:12px;font-family:var(--mono);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:border-color .12s,background .12s,color .12s}
.customer-image-toggle:hover{border-color:var(--accent);background:rgba(59,130,246,.08);color:var(--text)}
.customer-image-toggle input{accent-color:var(--accent);margin:0}
.customer-image-toggle:has(input:checked){border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--text)}
.customer-stat{display:flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid var(--border2);border-radius:999px;background:var(--surface2);font-size:11px;font-family:var(--mono);color:var(--muted);cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.customer-stat:hover{border-color:var(--accent);background:rgba(59,130,246,.08);color:var(--text)}
.customer-stat.active{border-color:var(--accent);background:rgba(59,130,246,.14);color:var(--text)}
.customer-stat strong{color:var(--text);font-size:12px}
.customer-task-list{display:flex;flex-direction:column;gap:8px}
.customer-task-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;width:100%;padding:12px;border:1px solid var(--border2);border-radius:12px;background:var(--surface2);cursor:pointer;text-align:left;font:inherit;color:var(--text);transition:border-color .12s,background .12s,box-shadow .12s;position:relative}
.customer-task-row:hover{border-color:var(--border);background:var(--surface3);box-shadow:0 8px 20px rgba(0,0,0,.08)}
.customer-task-add-row{align-items:center;justify-content:flex-start;border-style:dashed;color:var(--muted)}
.customer-task-add-row:hover{border-color:var(--accent);background:rgba(59,130,246,.08);color:var(--text)}
.customer-task-add-row.editing{border-style:solid;cursor:default}
.customer-task-add-row.editing:hover{border-color:var(--border2);background:var(--surface2);box-shadow:none}
.customer-task-add-icon{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:999px;border:1px solid var(--border2);background:var(--surface);color:var(--accent);font-size:18px;line-height:1;flex-shrink:0}
.customer-task-main{display:flex;flex:1;flex-direction:column;gap:6px;min-width:0}
.customer-task-title{font-size:14px;font-weight:500;line-height:1.35;color:var(--text)}
.customer-task-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--muted)}
.customer-task-meta span{display:inline-flex;align-items:center;gap:5px}
.customer-task-assignee{display:flex;align-items:center;margin-top:2px}
.customer-task-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(62px,1fr));gap:7px;margin-top:2px;max-width:100%}
.customer-task-image{display:block;height:62px;border:1px solid var(--border2);border-radius:10px;overflow:hidden;background:var(--surface);text-decoration:none;transition:border-color .12s,transform .12s}
.customer-task-image:hover{border-color:var(--accent);transform:translateY(-1px)}
.customer-task-image img{width:100%;height:100%;display:block;object-fit:cover}
.customer-task-side{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-shrink:0;flex-wrap:wrap;max-width:46%}
.customer-task-control{display:inline-flex;align-items:center;gap:6px;min-height:26px;padding:0;border:none;background:transparent;color:inherit;font:inherit;cursor:pointer;border-radius:999px;position:relative}
.customer-task-control:hover{filter:brightness(1.12)}
.customer-task-dev-control{padding:4px 7px;border:1px solid var(--border2);background:var(--surface);font-size:11px;font-family:var(--mono);color:var(--muted)}
.customer-task-dev-control:hover{border-color:var(--accent);color:var(--text)}
.customer-task-unassigned{color:var(--muted)}
.customer-empty{padding:14px;border:1px dashed var(--border2);border-radius:12px;background:rgba(255,255,255,.02);font-size:12px;color:var(--muted)}
.customer-task-add-input{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:14px;padding:8px 10px;border-radius:8px;outline:none;transition:border .15s}
.customer-task-add-input:focus{border-color:var(--accent)}
.customer-task-add-input::placeholder{color:var(--muted)}
.customer-task-add-submit{background:var(--accent);color:#fff;border:none;border-radius:7px;font-family:var(--sans);font-size:13px;font-weight:500;padding:8px 12px;cursor:pointer;transition:background .12s,opacity .12s;opacity:.4;white-space:nowrap}
.customer-task-add-submit.ready{opacity:1}
.customer-task-add-submit:hover{background:var(--accent-d)}
.customer-task-add-cancel{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--border2);border-radius:8px;background:transparent;color:var(--muted);font:inherit;font-size:18px;line-height:1;cursor:pointer;flex-shrink:0}
.customer-task-add-cancel:hover{border-color:var(--border);background:var(--surface3);color:var(--text)}

@media (max-width: 700px){
  .customer-task-row{flex-direction:column;align-items:stretch}
  .customer-task-side{max-width:none;justify-content:flex-start}
  .customer-task-add-row.editing{flex-wrap:wrap}
  .customer-task-add-input{flex-basis:calc(100% - 36px);font-size:16px}
  .customer-task-add-submit{flex:1;opacity:1}
}

/* Quick-add bar */
.quick-add{display:flex;align-items:center;gap:7px;padding:10px 20px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}
.quick-input-wrap{flex-wrap:wrap;column-gap:8px;row-gap:6px;padding-top:6px !important;padding-bottom:6px !important}
.quick-input{flex:1;background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:15px;padding:9px 13px;border-radius:8px;outline:none;transition:border .15s}
.quick-input:focus{border-color:var(--accent)}
.quick-input::placeholder{color:var(--muted)}
.quick-attachment-pills{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex-basis:100%}
.quick-attachment-pill{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:5px 8px;border-radius:999px;border:1px solid var(--border2);background:var(--surface);color:var(--text);font-size:12px;line-height:1}
.quick-attachment-pill-label{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.quick-attachment-pill-remove{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;padding:0;font:inherit}
.quick-attachment-pill-remove:hover{background:var(--surface2);color:var(--text)}
.quick-sel{background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:14px;padding:8px 9px;border-radius:8px;outline:none;cursor:pointer;max-width:130px}
.quick-sel option{background:var(--surface2)}
.ptog{font-size:12px;font-weight:500;font-family:var(--mono);padding:6px 9px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all 0.1s}
.ptog.sel-low{background:var(--low-bg);color:var(--low-text);border-color:rgba(34,197,94,.35)}
.ptog.sel-medium{background:var(--med-bg);color:var(--med-text);border-color:rgba(245,158,11,.35)}
.ptog.sel-high{background:var(--high-bg);color:var(--high-text);border-color:rgba(239,68,68,.35)}
.add-btn{background:var(--accent);color:#fff;border:none;border-radius:7px;font-family:var(--sans);font-size:14px;font-weight:500;padding:9px 16px;cursor:pointer;transition:background .12s,opacity .12s;opacity:.4;white-space:nowrap}
.add-btn.ready{opacity:1}.add-btn:hover{background:var(--accent-d)}

/* Right drawer — single pane */
.drawer{position:absolute;top:0;right:0;bottom:0;z-index:120;width:var(--drawer-width, 420px);min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--surface);border-left:1px solid var(--border);box-shadow:-18px 0 36px rgba(0,0,0,.18);transform:translateX(100%);pointer-events:none;transition:transform 0.22s cubic-bezier(0.4,0,0.2,1);height:auto;min-height:0;max-width:100%}
.drawer.open{transform:translateX(0);pointer-events:auto}
.drawer-resize-handle{position:absolute;left:0;top:0;bottom:0;width:10px;cursor:col-resize;z-index:30;background:transparent;display:none}
.drawer.open .drawer-resize-handle{display:block}
.drawer-resize-handle::after{content:'';position:absolute;left:1px;top:0;bottom:0;width:2px;background:transparent;transition:background .15s}
.drawer.open .drawer-resize-handle:hover::after,
.drawer.open.resizing .drawer-resize-handle::after{background:rgba(59,130,246,.38)}
.shell.standalone-task .sidebar,.shell.standalone-task .view-pane{display:none!important}
.shell.standalone-task #quick-add-bar{display:none}
.shell.standalone-task .main,.shell.standalone-task .content-area,.shell.standalone-task .drawer{height:100%;min-height:0}
.shell.standalone-task .content-area{display:flex}
.shell.standalone-task .drawer,.shell.standalone-task .drawer.open{position:relative;inset:auto;z-index:auto;width:100%;min-width:0;border-left-width:0;box-shadow:none;transform:none;pointer-events:auto;flex:1}
.shell.standalone-task .drawer-resize-handle{display:none!important}
.shell.standalone-task .detail-panel{width:100%;max-width:none;margin:0;border-left:0;height:100%;display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) auto;min-height:0}
.shell.standalone-task .detail-head{min-height:var(--header-band-min-height);padding:var(--header-band-pad-y) 20px;box-sizing:border-box;z-index:12}
.shell.standalone-task .detail-badges,.shell.standalone-task .detail-meta{padding-left:20px;padding-right:20px}
.shell.standalone-task .chat-compose{padding:8px 10px}
.shell.standalone-task .detail-body{overflow:hidden;padding:10px 12px;min-height:0}
.shell.standalone-task .detail-columns{--detail-resizer-size:18px;--detail-diff-width:360px;--detail-log-width:400px;display:grid;grid-template-columns:minmax(0,1fr) var(--detail-resizer-size) minmax(260px,var(--detail-diff-width)) var(--detail-resizer-size) minmax(260px,var(--detail-log-width));height:100%;min-height:0;align-items:stretch}
.shell.standalone-task .detail-column{min-height:0;background:var(--surface2);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.shell.standalone-task .detail-column-chat{display:flex;flex-direction:column;min-height:0}
.shell.standalone-task .detail-column-resizer{position:relative;cursor:col-resize;user-select:none}
.shell.standalone-task .detail-column-resizer::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:16px;transform:translateX(-50%)}
.shell.standalone-task .detail-column-resizer::after{content:'';position:absolute;left:50%;top:12px;bottom:12px;width:2px;border-radius:999px;transform:translateX(-50%);background:rgba(148,163,184,.2);transition:background .15s ease,box-shadow .15s ease}
.shell.standalone-task .detail-column-resizer:hover::after,
.shell.standalone-task .detail-columns.resizing-columns .detail-column-resizer::after{background:rgba(59,130,246,.55);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.shell.standalone-task .pinned-checklist-host{padding:12px 10px 0}
.shell.standalone-task .chat-msgs{padding:12px 10px 0;flex:1;min-height:0;overflow-y:auto}
.shell.standalone-task .chat-bub{max-width:920px}
.shell.standalone-task .detail-column-log,.shell.standalone-task .detail-column-diff{display:flex;flex-direction:column;min-height:0}
.shell.standalone-task .detail-column-stack{display:flex;flex-direction:column;gap:14px;min-height:0}
.shell.standalone-task .detail-stack-panel{min-height:0}
.shell.standalone-task .detail-column-stack .detail-column-log{flex:1 1 55%}
.shell.standalone-task .detail-column-stack .detail-notes{flex:0 0 auto}
.shell.standalone-task .log-panel-head{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface)}
.shell.standalone-task .detail-panel .chip{font-size:12px;padding:2px 8px;line-height:1.15}
.shell.standalone-task .log-panel-title{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.shell.standalone-task .log-panel-body{margin:0;padding:14px;flex:1;overflow:auto;font:11px/1.45 var(--mono);color:var(--text);white-space:pre;background:var(--surface2)}
.shell.standalone-task .log-panel-body-nowrap{white-space:pre;word-break:normal;overflow:auto}
.shell.standalone-task .log-panel-stream{display:flex;flex-direction:column;gap:2px;white-space:normal}
.shell.standalone-task .log-line{display:block;white-space:pre-wrap;word-break:break-word}
.shell.standalone-task .log-line-server{color:var(--text)}
.shell.standalone-task .log-line-codex-command{color:var(--accent-d)}
.shell.standalone-task .log-line-empty{color:var(--muted)}
.shell.standalone-task .log-panel-empty{color:var(--muted)}
.detail-columns{display:flex;flex-direction:column;height:100%;min-height:0;flex:1}
.detail-column{min-height:0}
.detail-column-chat{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.detail-column-log,.detail-column-diff,.detail-column-stack{display:none}
@media (max-width: 1100px){
  .topbar{flex-wrap:wrap}
  .topbar-spacer{display:none}
  .search-wrap{width:min(220px,100%);flex:1 1 220px}
  .topbar-cost{order:3}
  .topbar-codex-menu-wrap{order:4}
  .shell.standalone-task .detail-columns{grid-template-columns:minmax(0,1fr)}
  .shell.standalone-task .detail-column-log,.shell.standalone-task .detail-column-diff,.shell.standalone-task .detail-column-stack{min-height:240px}
  .shell.standalone-task .detail-column-resizer{display:none}
}
.detail-head{display:flex;align-items:center;justify-content:space-between;min-height:var(--header-band-min-height);padding:var(--header-band-pad-y) var(--detail-header-pad-x);border-bottom:1px solid var(--border);flex-shrink:0;gap:8px;position:relative;z-index:3;background:var(--surface);min-width:0;box-sizing:border-box}
.detail-head-left{flex:1;min-width:0;position:relative}
.detail-back-circle{width:26px;height:26px;border-radius:999px!important;background:var(--surface2);border:1px solid var(--border2)!important;color:var(--muted);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s,color .12s;flex-shrink:0;margin-top:-1px}
.detail-back-circle:hover{background:var(--surface3);border-color:var(--accent)!important;color:var(--text)}
.detail-head-actions{display:flex;align-items:center;gap:6px;flex-shrink:1;min-width:0;flex-wrap:wrap;justify-content:flex-end}
.detail-active-codex-slot{display:flex;align-items:center;flex-shrink:0}
.mobile-notification-wrap{display:none;position:relative}
.mobile-notification-btn{position:relative;width:40px;height:40px;border:none;border-radius:999px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.mobile-notification-btn:hover{border-color:var(--accent);background:var(--surface3);color:var(--text)}
.mobile-notification-btn:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.35)}
.mobile-notification-btn svg{display:block;width:18px;height:18px}
.mobile-notification-count{position:absolute;top:-4px;right:-3px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--accent);border:2px solid var(--surface);font-size:10px;font-family:var(--mono);font-weight:700;color:#fff;line-height:1}
.detail-notification-wrap{display:block;position:relative;flex-shrink:0}
.detail-notification-btn{position:relative;width:26px;height:26px;border-radius:5px;background:var(--surface2);border:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;flex-shrink:0}
.detail-notification-btn:hover{background:var(--surface3);color:var(--text)}
.detail-notification-btn:focus-visible{outline:none;box-shadow:0 0 0 1px rgba(59,130,246,.35)}
.detail-notification-btn svg{display:block;width:16px;height:16px}
.detail-notification-count{position:absolute;top:-5px;right:-5px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--accent);border:2px solid var(--surface);font-size:9px;font-family:var(--mono);font-weight:700;color:#fff;line-height:1}
.detail-title-row{display:flex;align-items:center;gap:8px;min-width:0}
.detail-panel{--task-accent:var(--accent);--task-accent-rgb:59,130,246}
.shell.standalone-task .detail-panel.task-colorized{background:linear-gradient(180deg,rgba(var(--task-accent-rgb),.09) 0,rgba(var(--task-accent-rgb),.03) 180px,var(--surface) 320px)}
.shell.standalone-task .detail-panel.task-colorized .detail-head{background:linear-gradient(180deg,rgba(var(--task-accent-rgb),.20),rgba(var(--task-accent-rgb),.08) 72%,rgba(var(--task-accent-rgb),.03)),var(--surface);border-bottom-color:rgba(var(--task-accent-rgb),.28)}
.shell.standalone-task .detail-panel.task-colorized .detail-badges{background:linear-gradient(180deg,rgba(var(--task-accent-rgb),.07),rgba(var(--task-accent-rgb),.02)),var(--surface);box-shadow:inset 0 -1px 0 rgba(var(--task-accent-rgb),.12)}
.shell.standalone-task .detail-panel.task-colorized .detail-codex-nav,
.shell.standalone-task .detail-panel.task-colorized .detail-meta-card,
.shell.standalone-task .detail-panel.task-colorized .detail-column,
.shell.standalone-task .detail-panel.task-colorized .detail-notes-card{border-color:rgba(var(--task-accent-rgb),.18)}
.shell.standalone-task .detail-panel.task-colorized .detail-codex-nav-btn:hover,
.shell.standalone-task .detail-panel.task-colorized .task-link-copy-btn:hover{border-color:rgba(var(--task-accent-rgb),.34)}
.detail-codex-nav{display:inline-flex;align-items:center;gap:6px;min-width:0;padding:4px 6px;border:1px solid var(--border2);border-radius:999px;background:var(--surface2)}
.detail-codex-nav-label{font-size:11px;font-family:var(--mono);letter-spacing:.04em;color:var(--muted);white-space:nowrap}
.detail-codex-nav-btn{font-size:11px;line-height:1.2;padding:4px 8px;border-radius:999px;border:1px solid var(--border2);background:var(--surface);color:var(--muted);cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap}
.detail-codex-nav-btn:hover{border-color:var(--accent);background:var(--surface3);color:var(--text)}
.detail-codex-nav-btn:disabled{opacity:.5;cursor:not-allowed}
.detail-codex-nav-btn:disabled:hover{border-color:var(--border2);background:var(--surface);color:var(--muted)}
/* Title — view mode: plain text, edit mode: input */
.detail-title-view{font-size:16px;font-weight:600;color:var(--text);line-height:1.4;cursor:text;border-radius:4px;padding:2px 4px;margin:-2px -4px;transition:background 0.12s;min-width:0;flex:1}
.detail-title-view:hover{background:var(--surface2)}
.detail-title-view.editing{background:var(--surface2);box-shadow:0 0 0 1px rgba(59,130,246,.7)}
.detail-title-view.editing:focus{outline:none;box-shadow:0 0 0 1px rgba(59,130,246,.9),0 0 0 3px rgba(59,130,246,.12)}
.detail-title-input{font-size:16px;font-weight:600;color:var(--text);background:var(--surface2);border:1px solid var(--accent);border-radius:6px;padding:4px 8px;outline:none;width:100%;font-family:var(--sans);line-height:1.4}
.detail-title-emoji-popup{position:fixed;z-index:260;min-width:320px;max-width:min(360px,calc(100vw - 24px))}
.task-link-copy-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;transition:background .12s,border-color .12s,color .12s;flex-shrink:0}
.task-link-copy-btn svg{display:block;width:16px;height:16px}
.task-link-copy-btn:hover{background:var(--surface2);border-color:var(--border2);color:var(--text)}
.task-link-copy-btn:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.35)}
.task-link-copy-btn:disabled{opacity:.45;cursor:default}
.task-link-copy-btn:disabled:hover{background:transparent;border-color:transparent;color:var(--muted)}
.detail-task-link-copy{margin-top:-1px}
.detail-theme-toggle{display:none;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;transition:background .12s,border-color .12s,color .12s;flex-shrink:0}
.shell.standalone-task .detail-theme-toggle{display:inline-flex}
.detail-theme-toggle:hover{background:var(--surface2);border-color:var(--border2);color:var(--text)}
.detail-theme-toggle:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.35)}
.detail-theme-toggle-icon{display:none;align-items:center;justify-content:center}
.detail-theme-toggle svg{display:block;width:15px;height:15px}
:root[data-theme="dark"] .detail-theme-toggle-moon{display:inline-flex}
:root[data-theme="light"] .detail-theme-toggle-sun{display:inline-flex}

.detail-close{width:26px;height:26px;border-radius:5px;background:var(--surface2);border:none;color:var(--muted);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .1s;flex-shrink:0}
.detail-close:hover{background:var(--surface3);color:var(--text)}

/* Badge row */
.detail-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:var(--detail-chip-pad-top) var(--detail-header-pad-x) var(--detail-chip-pad-bottom);flex-shrink:0;position:relative;z-index:4;background:var(--surface);min-width:0;box-sizing:border-box}
.detail-badges > *{max-width:100%}
.detail-badges .badge,
.detail-badges .s-badge,
.detail-badges .dev-badge,
.detail-badges .cust-badge,
.detail-badges .detail-proj-pill,
.detail-badges .detail-pr-pill,
.detail-badges .detail-attach-pill,
.detail-badges .detail-home-link,
.detail-badges .due-badge{max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis}
.shell:not(.standalone-task) .detail-badges{display:block;padding:3px var(--detail-header-pad-x);border-bottom:1px solid var(--border)}
.shell:not(.standalone-task) .detail-badges-primary{display:flex;align-items:center;gap:5px;min-width:0;white-space:nowrap;overflow:hidden}
.shell:not(.standalone-task) .detail-badges-primary > .badge-btn,
.shell:not(.standalone-task) .detail-badges-primary > span{flex:0 1 auto;min-width:0}
.shell:not(.standalone-task) .detail-badges-primary .badge,
.shell:not(.standalone-task) .detail-badges-primary .s-badge,
.shell:not(.standalone-task) .detail-badges-primary .dev-badge,
.shell:not(.standalone-task) .detail-badges-primary .due-badge,
.shell:not(.standalone-task) .detail-badges-primary .detail-attach-pill{font-size:11px;line-height:16px;padding-top:1px;padding-bottom:1px}
.shell:not(.standalone-task) .detail-badges-primary .dev-badge{max-width:112px}
.shell:not(.standalone-task) .detail-badges-primary .detail-proj-pill{max-width:118px}
.shell:not(.standalone-task) .detail-badges-primary .detail-proj-pill span{flex:0 0 6px}
.shell:not(.standalone-task) .detail-badges-primary .due-badge{max-width:92px}
.shell:not(.standalone-task) .detail-badges-primary .detail-attach-pill{padding-left:7px;padding-right:7px}
.shell:not(.standalone-task) .detail-badges-secondary{display:none;align-items:center;gap:5px;flex-wrap:wrap;margin-top:4px;max-height:128px;overflow:auto;padding-top:5px;border-top:1px solid var(--border)}
.shell:not(.standalone-task) .detail-badges.expanded .detail-badges-secondary{display:flex}
.detail-badges-more{display:inline-flex;align-items:center;justify-content:center;width:24px;height:20px;margin-left:auto;border:1px solid var(--border2);border-radius:999px;background:var(--surface2);color:var(--muted);font-size:15px;line-height:1;cursor:pointer;flex:0 0 auto}
.detail-badges-more:hover,.detail-badges.expanded .detail-badges-more{border-color:var(--accent);background:var(--surface3);color:var(--text)}
.shell.standalone-task .detail-badges-more{display:none}
.detail-home-link{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);text-decoration:none;white-space:nowrap;transition:border-color .12s,background .12s,color .12s}
.detail-home-link:hover{color:var(--text);border-color:var(--accent);background:var(--surface3)}
.detail-attach-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);cursor:pointer;white-space:nowrap}
.detail-attach-pill:hover{color:var(--text)}
.detail-codex-controls{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0;max-width:100%}
.detail-codex-controls-lite{gap:5px}
.detail-codex-btn{font-size:11px;line-height:1.2;padding:3px 7px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap}
.detail-codex-btn:hover{border-color:var(--accent);color:var(--text);background:var(--surface3)}
.detail-codex-btn:disabled{opacity:.55;cursor:not-allowed}
.detail-codex-btn:disabled:hover{border-color:var(--border2);color:var(--muted);background:var(--surface2)}
.compose-codex-controls{display:flex;align-items:center;justify-content:flex-start;min-height:0}
.compose-codex-controls:empty{display:none}
.compose-codex-bar{display:flex;align-items:center;gap:5px;flex-wrap:wrap;min-width:0;max-width:100%;padding:0}
.compose-codex-status{font-size:10px;line-height:1.2;padding:3px 7px}
.compose-codex-btn{font-size:10px;line-height:1.2;padding:3px 7px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap}
.compose-codex-btn:hover{border-color:var(--accent);color:var(--text);background:var(--surface3)}
.compose-codex-start-btn{border-color:var(--compose-codex-project-accent,var(--border2));background:rgba(var(--compose-codex-project-accent-rgb,59,130,246),.12);color:var(--compose-codex-project-accent,var(--muted))}
.compose-codex-start-btn:hover{border-color:var(--compose-codex-project-accent,var(--accent));background:var(--compose-codex-project-accent,var(--surface3));color:#fff}
.compose-codex-btn:disabled{opacity:.5;cursor:not-allowed}
.compose-codex-btn:disabled:hover{border-color:var(--border2);color:var(--muted);background:var(--surface2)}
.compose-codex-bar .detail-codex-config-pill{font-size:10px;line-height:1.2;padding:3px 7px}

/* Clickable badges that open a mini select */
.badge-btn{cursor:pointer;position:relative;display:inline-flex;min-width:0;max-width:100%}
.attachment-badge-btn{position:static}
.badge-btn:hover .badge,.badge-btn:hover .s-badge{opacity:0.75;outline:1px solid var(--border2)}
.badge-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:120;background:var(--surface);border:1px solid var(--border2);border-radius:7px;min-width:130px;max-width:min(320px,calc(100vw - 24px));padding:4px;box-shadow:0 8px 24px rgba(0,0,0,.45);display:none;overflow:auto}
.badge-dropdown.open{display:block}
.attachments-dropdown{left:0;right:0;max-width:none;width:auto;padding:6px}
.checklist-dropdown{left:0;right:0;max-width:none;width:auto;padding:6px}
.bd-item{padding:6px 10px;border-radius:5px;font-size:14px;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:7px;white-space:nowrap}
.bd-item:hover{background:var(--surface2);color:var(--text)}
.bd-item.selected{color:var(--text);background:var(--surface2)}
.bd-dot{width:7px;height:7px;border-radius:50%}
.attachment-menu-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:7px 8px;border-radius:8px}
.attachment-menu-row:hover{background:var(--surface2)}
.attachment-menu-item{display:flex;align-items:center;gap:10px;min-width:0;flex:1;border:0;background:transparent;padding:0;color:inherit;text-align:left;cursor:pointer}
.checklist-menu-item{align-items:flex-start}
.checklist-menu-checkbox{width:16px;height:16px;margin:2px 0 0;accent-color:var(--accent);flex-shrink:0;cursor:pointer}
.attachment-menu-thumb{display:block;width:44px;height:44px;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);flex-shrink:0;overflow:hidden}
.checklist-menu-thumb{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-top:2px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);font-size:11px;line-height:1;flex-shrink:0}
.checklist-menu-thumb.done{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.attachment-menu-thumb-image{object-fit:cover}
.attachment-menu-thumb-pdf{pointer-events:none;background:#fff}
.attachment-menu-thumb-file{display:flex;align-items:center;justify-content:center;font-size:10px;font-family:var(--mono);color:var(--accent);background:linear-gradient(135deg,var(--surface2),var(--surface3))}
.attachment-menu-text{display:flex;flex-direction:column;min-width:0;gap:2px}
.attachment-menu-name{font-size:12px;color:var(--text);word-break:break-word}
.attachment-menu-meta{font-size:10px;color:var(--muted);font-family:var(--mono);word-break:break-word}
.attachment-menu-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}

/* Dev badge (avatar style) */
.dev-badge{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;padding:2px 8px 2px 4px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--text);cursor:pointer;white-space:nowrap}
.dev-badge:hover{border-color:var(--border2);background:var(--surface3)}
.detail-role-badge{gap:6px}
.detail-role-badge-label{font-size:10px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}

/* Customer badge */
.cust-badge{display:inline-flex;align-items:center;gap:4px;font-size:13px;padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);cursor:pointer;white-space:nowrap}
.cust-badge:hover{color:var(--text)}

/* Due date badge */
.due-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);cursor:pointer;white-space:nowrap}
.due-badge:hover{color:var(--text)}
.due-badge.over{color:var(--high-text);background:var(--high-bg);border-color:rgba(239,68,68,.3)}
.due-badge.soon{color:var(--med-text);background:var(--med-bg);border-color:rgba(245,158,11,.3)}

/* Date input inline */
.due-date-input{font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--accent);color:var(--text);outline:none;cursor:pointer}

/* Project pill on detail */
.detail-proj-pill{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);cursor:pointer;white-space:nowrap}
.detail-proj-pill:hover{color:var(--text)}
.detail-task-color-wrap{flex:0 0 auto}
.detail-bookmark-toggle{width:26px;height:26px}
.detail-task-color-trigger{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:999px;background:rgba(var(--task-accent-rgb,59,130,246),.12);border:1px solid rgba(var(--task-accent-rgb,59,130,246),.32);cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease;box-sizing:border-box}
.detail-task-color-trigger:hover{transform:scale(1.06);background:rgba(var(--task-accent-rgb,59,130,246),.18);border-color:rgba(var(--task-accent-rgb,59,130,246),.48)}
.detail-task-color-trigger.is-empty{background:var(--surface2);border-color:var(--border2)}
.detail-task-color-trigger.is-empty:hover{background:var(--surface3);border-color:var(--border)}
.detail-task-color-swatch,.detail-task-color-option-dot{width:8px;height:8px;border-radius:999px;display:inline-block;flex-shrink:0}
.detail-task-color-swatch.is-empty,.detail-task-color-option-empty{background:transparent;border:1px dashed var(--border2)}
.detail-pr-pill{display:inline-flex;align-items:center;gap:4px;max-width:210px;font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.22);color:var(--accent);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.detail-pr-pill:hover{border-color:rgba(59,130,246,.38);background:rgba(59,130,246,.14)}
.detail-pr-pill.empty{background:var(--surface2);border-color:var(--border2);color:var(--muted)}
.detail-pr-pill.empty:hover{color:var(--text)}
.detail-meta{padding:8px 16px 0;flex-shrink:0}
.detail-meta-card{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface2)}
.detail-meta-item{min-width:0}
.detail-meta-item-wide{grid-column:1/-1}
.detail-meta-item-inline{display:flex;align-items:center;gap:10px}
.detail-meta-item-inline .detail-meta-label{margin-bottom:0;flex:0 0 auto}
.detail-meta-label{font-size:10px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.detail-meta-stats{display:flex;flex-wrap:wrap;gap:8px}
.detail-meta-stats-inline{flex:1 1 auto;min-width:0}
.detail-meta-stat{display:flex;align-items:center;gap:6px;min-width:0;padding:5px 8px;border:1px solid var(--border2);border-radius:8px;background:var(--surface)}
.detail-meta-stat-expanded{align-items:flex-start}
.detail-meta-stat .detail-meta-label{margin-bottom:0;white-space:nowrap}
.detail-meta-value{font-size:12px;font-family:var(--mono);color:var(--text);word-break:break-all}
.detail-meta-item-inline > .detail-meta-value{flex:1 1 auto;min-width:0}
.detail-meta-stat .detail-meta-value{min-width:0;word-break:normal;overflow-wrap:anywhere}
.detail-meta-value-button{display:block;width:100%;padding:0;border:none;background:none;text-align:left;cursor:pointer}
.detail-meta-stat .detail-meta-value-button{display:inline;width:auto;min-width:0}
.detail-meta-value-button:hover{color:var(--accent)}
.detail-meta-value-button:focus-visible{outline:1px solid var(--accent);outline-offset:2px;border-radius:4px}
.detail-meta-value-expanded{line-height:1.45;word-break:break-word}
.detail-meta-value.empty{color:var(--muted)}
.detail-codex-config-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);cursor:pointer;white-space:nowrap}
.detail-codex-config-pill:hover{color:var(--text);border-color:var(--accent);background:var(--surface3)}
.detail-codex-config-menu{padding:8px}
.detail-codex-config-fields{display:flex;flex-direction:column;gap:8px}
.detail-codex-config-label{display:flex;flex-direction:column;gap:4px;font-size:10px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.detail-codex-config-select{min-width:180px;padding:6px 8px;border:1px solid var(--border2);border-radius:7px;background:var(--surface2);color:var(--text);font-size:12px;font-family:var(--mono);text-transform:none;letter-spacing:0}
.detail-codex-config-select:disabled{opacity:.7;cursor:not-allowed}
.detail-codex-config-note{font-size:11px;color:var(--muted)}
.detail-meta-link{display:block;font-size:12px;font-family:var(--mono);color:var(--accent);word-break:break-all;text-decoration:none}
.detail-meta-link:hover{text-decoration:underline}
.detail-meta-command{display:block;flex:1 1 auto;min-width:0;width:100%;padding:0;border:none;background:none;outline:none;font-size:12px;font-family:var(--mono);color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.current-browser-preview{position:fixed;top:82px;right:18px;z-index:45;display:flex;flex-direction:column;width:320px;height:240px;min-width:240px;min-height:160px;max-width:calc(100vw - 24px);max-height:calc(100vh - 24px);border:1px solid var(--border);border-radius:14px;background:rgba(12,18,28,.94);backdrop-filter:blur(12px);box-shadow:0 20px 50px rgba(0,0,0,.28);overflow:hidden}
.current-browser-preview-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);cursor:move;user-select:none}
.current-browser-preview-title{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:#d9e3f0}
.current-browser-preview-actions{display:flex;align-items:center;gap:6px}
.current-browser-preview-btn{width:28px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#d9e3f0;cursor:pointer}
.current-browser-preview-btn:hover{background:rgba(255,255,255,.12)}
.current-browser-preview-body{display:flex;flex:1;min-height:0;flex-direction:column;gap:8px;padding:10px 12px}
.current-browser-preview-status{font-size:11px;line-height:1.45;color:#b7c6da}
.current-browser-preview-frame{display:flex;flex:1;min-height:0;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:#0a0f18}
.current-browser-preview-image{display:block;width:100%;height:100%;object-fit:cover;background:#0a0f18}
.current-browser-preview.is-collapsed .current-browser-preview-body{display:none}
.current-browser-preview.is-collapsed{height:auto!important;min-height:0}
.current-browser-preview.is-collapsed .current-browser-preview-head{border-bottom:none}
.current-browser-preview.is-dragging,.current-browser-preview.is-resizing{user-select:none}
.current-browser-preview-resize{position:absolute;right:0;bottom:0;width:18px;height:18px;cursor:nwse-resize}
.current-browser-preview-resize::before{content:'';position:absolute;right:4px;bottom:4px;width:10px;height:10px;border-right:2px solid rgba(255,255,255,.28);border-bottom:2px solid rgba(255,255,255,.28);border-bottom-right-radius:3px}
.current-browser-preview-resize:hover::before,
.current-browser-preview.is-resizing .current-browser-preview-resize::before{border-right-color:rgba(255,255,255,.55);border-bottom-color:rgba(255,255,255,.55)}
.current-browser-preview.is-collapsed .current-browser-preview-resize{display:none}
.detail-notes{padding:0;flex-shrink:0}
.detail-notes-card{display:flex;flex-direction:column;gap:10px;padding:12px;height:100%;border:1px solid var(--border);border-radius:10px;background:var(--surface2)}
.detail-notes-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.detail-notes-title{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.detail-notes-sub{font-size:13px;color:var(--muted);margin-top:2px}
.detail-notes-status{font-size:11px;font-family:var(--mono);color:var(--muted);white-space:nowrap}
.detail-notes-status.status-saving{color:var(--accent)}
.detail-notes-status.status-saved{color:var(--low)}
.detail-notes-status.status-error{color:var(--high-text)}
.detail-notes-input{width:100%;min-height:110px;resize:vertical;background:var(--surface);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.55;padding:11px 12px;outline:none}
.detail-notes-input:focus{border-color:var(--accent)}
.detail-notes-input::placeholder{color:var(--muted)}
@media (max-width: 1100px){
  .detail-meta-card{grid-template-columns:minmax(0,1fr)}
  .detail-meta-item-inline{align-items:flex-start;flex-wrap:wrap}
  .detail-meta-stats-inline{flex-basis:100%}
  .detail-meta-command,.detail-meta-item-inline > .detail-meta-value{flex-basis:100%}
  .detail-notes-head{flex-direction:column}
  .detail-notes-status{white-space:normal}
  .current-browser-preview{display:none!important}
}

/* Detail body — fixed pinned checklist + scrollable activity feed */
.detail-body{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0;min-height:0;min-width:0}

/* Footer actions */
.detail-foot{padding:10px 16px 13px;display:flex;justify-content:flex-end;gap:7px;border-top:1px solid var(--border);flex-shrink:0}

/* Save indicator */
.save-flash{font-size:13px;color:var(--low);opacity:0;transition:opacity 0.3s;margin-right:auto;align-self:center}
.save-flash.show{opacity:1}
/* Task detail panel — full single pane */
.detail-panel{flex:1;display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) auto;overflow:visible;background:var(--surface);min-height:0;height:100%;width:100%;min-width:0}
.shell:not(.standalone-task) .detail-panel{grid-template-rows:auto auto auto minmax(0,1fr) auto}
.chat-head{padding:4px 0 0;border-bottom:1px solid var(--border);flex-shrink:0;min-width:0}
.pinned-checklist-host{display:none;flex-shrink:0;padding:11px 8px 0;min-height:0}
.pinned-checklist-host.has-items{display:flex;flex-direction:column}
.chat-msgs{flex:1;overflow-y:auto;padding:11px 8px 0;display:flex;flex-direction:column;gap:8px;min-height:0;min-width:0}
.chat-load-more-wrap{display:flex;justify-content:center;margin:2px 0 6px}
.chat-load-more-btn{height:32px;padding:0 14px;border-radius:999px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);font-size:12px;font-family:var(--mono);cursor:pointer}
.chat-load-more-btn:hover{border-color:var(--border);color:var(--text);background:var(--surface3)}
.chat-load-more-btn:disabled{opacity:.65;cursor:wait}
.chat-msg{display:flex;gap:6px}
.chat-bub{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:7px 9px;flex:1;min-width:0}
.message-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.chat-auth{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:1px}
.message-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.message-edit,.message-task,.message-delete{height:28px;border-radius:7px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .15s}
.message-task{padding:0 9px;font-size:11px;font-family:var(--mono)}
.message-edit{padding:0 9px;font-size:11px;font-family:var(--mono)}
.message-delete{width:28px}
.chat-msg:hover .message-edit,.chat-msg:hover .message-task,.chat-msg:hover .message-delete,.chat-msg:focus-within .message-edit,.chat-msg:focus-within .message-task,.chat-msg:focus-within .message-delete,.pinned-checklist-item:hover .message-edit,.pinned-checklist-item:hover .message-task,.pinned-checklist-item:hover .message-delete,.pinned-checklist-item:focus-within .message-edit,.pinned-checklist-item:focus-within .message-task,.pinned-checklist-item:focus-within .message-delete,.message-edit:focus-visible,.message-task:focus-visible,.message-delete:focus-visible{opacity:1;pointer-events:auto}
.message-task:hover{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.12);color:#86efac}
.message-edit:hover{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.message-edit.active{opacity:1;pointer-events:auto;border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.message-delete:hover{border-color:rgba(239,68,68,.35);background:var(--high-bg);color:var(--high-text)}
.message-task.compact,.message-edit.compact{height:26px;padding:0 8px}
.message-delete.compact{width:26px;height:26px}
.chat-txt{font-size:14px;line-height:1.5;word-break:break-word}
.chat-txt-pre{white-space:pre-wrap;word-break:break-word;font-family:var(--mono);background:transparent;border:0;padding:0;margin:0;font-size:13px}
.codex-md{font-size:14px;line-height:1.55;word-break:break-word}
.codex-md>*:first-child{margin-top:0}
.codex-md>*:last-child{margin-bottom:0}
.codex-md p,.codex-md ul,.codex-md ol,.codex-md pre,.codex-md blockquote,.codex-md hr{margin:8px 0}
.codex-md h1,.codex-md h2,.codex-md h3,.codex-md h4,.codex-md h5,.codex-md h6{margin:12px 0 6px;line-height:1.25;font-weight:700;color:var(--text)}
.codex-md h1{font-size:20px}
.codex-md h2{font-size:18px}
.codex-md h3{font-size:16px}
.codex-md h4,.codex-md h5,.codex-md h6{font-size:14px}
.codex-md ul,.codex-md ol{padding-left:20px}
.codex-md li+li{margin-top:4px}
.codex-md blockquote{padding:2px 0 2px 12px;border-left:3px solid rgba(59,130,246,.45);color:var(--muted)}
.codex-md hr{border:0;border-top:1px solid var(--border2)}
.codex-md code{font-family:var(--mono);font-size:12px;padding:1px 5px;border-radius:5px;background:var(--surface3);color:var(--text)}
.codex-md pre{overflow:auto;padding:10px 11px;border-radius:8px;border:1px solid var(--border2);background:var(--surface2)}
.codex-md pre code{display:block;padding:0;border-radius:0;background:transparent;font-size:12px;line-height:1.55;white-space:pre;word-break:normal}
.codex-md del{opacity:.82}
.inline-message-edit{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.inline-message-edit.compact{margin-top:2px}
.inline-message-edit-input{width:100%;background:var(--surface3);border:1px solid rgba(59,130,246,.35);color:var(--text);font-family:var(--sans);font-size:14px;padding:8px 9px;border-radius:8px;outline:none;resize:none;min-height:72px;line-height:1.45}
.inline-message-edit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.inline-message-edit-actions{display:flex;align-items:center;justify-content:flex-end;gap:7px}
.inline-message-edit-btn{height:30px;padding:0 11px;border-radius:7px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);font-size:12px;font-family:var(--mono);cursor:pointer}
.inline-message-edit-btn:hover{border-color:var(--border);color:var(--text)}
.inline-message-edit-btn.save{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.inline-message-edit-btn.save:hover{background:rgba(59,130,246,.18)}
.shell:not(.standalone-task) .chat-msg-codex .codex-md{max-height:260px;overflow:hidden;mask-image:linear-gradient(to bottom,#000 0,#000 calc(100% - 28px),transparent 100%)}
.chat-link{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;word-break:break-word}
.chat-link:hover{color:#93c5fd}
.chat-codex-turn-meta{display:inline-flex;align-items:center;gap:4px;max-width:100%;padding:1px 6px;border-radius:999px;border:1px solid rgba(59,130,246,.2);background:rgba(59,130,246,.08);color:var(--muted);font-size:10px;line-height:1.2;font-family:var(--mono);white-space:nowrap}
.chat-ts{font-size:11px;color:var(--muted);margin-top:2px;font-family:var(--mono)}
.linked-task-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.linked-task-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid rgba(34,197,94,.22);border-radius:999px;background:rgba(34,197,94,.10);color:var(--low-text);font-size:11px;font-family:var(--mono);cursor:pointer}
.linked-task-chip:hover{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.16);color:var(--text)}
.linked-task-chip-prefix{color:var(--muted)}
.chat-empty{text-align:center;padding:24px 12px;color:var(--muted);font-size:13px}
.pinned-checklist{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 11px;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}
.pinned-checklist.collapsed{gap:0}
.pinned-checklist-head{width:100%;padding:0;border:none;background:none;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--muted);font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;text-align:left;cursor:pointer}
.pinned-checklist-head:hover{color:var(--text)}
.pinned-checklist-head:focus-visible{outline:1px solid var(--accent);outline-offset:2px;border-radius:6px}
.pinned-checklist-head-right{display:flex;align-items:center;gap:8px}
.pinned-checklist-count{font-size:10px;color:var(--muted)}
.pinned-checklist-toggle{font-size:10px}
.pinned-checklist-caret{font-size:12px;line-height:1}
.pinned-checklist-scroll{margin-top:9px;min-height:0}
.pinned-checklist-items{display:flex;flex-direction:column;gap:9px;min-height:0}
.pinned-checklist-item{display:grid;grid-template-columns:1fr auto;gap:4px 10px;padding:8px 9px;border:1px solid var(--border2);border-radius:8px;background:var(--surface2)}
.pinned-checklist-item.done{opacity:.78}
.pinned-checklist-main{display:flex;align-items:flex-start;gap:9px;min-width:0;cursor:pointer}
.pinned-checklist-edit{min-width:0}
.pinned-checklist-text{font-size:14px;line-height:1.45;word-break:break-word}
.pinned-checklist-text.done{text-decoration:line-through;color:var(--muted)}
.pinned-checklist-attachment-preview{grid-column:1 / -1;display:flex;align-items:center;gap:8px;padding-left:29px;text-decoration:none;min-width:0}
.pinned-checklist-attachment-preview:hover .pinned-checklist-attachment-label{color:var(--accent)}
.pinned-checklist-attachment-label{font-size:11px;color:var(--muted);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .12s}
.pinned-checklist-item .linked-task-row,.pinned-checklist-meta{grid-column:1 / -1}
.pinned-checklist-meta{font-size:10px;color:var(--muted);font-family:var(--mono);padding-left:29px}
.checklist-message{display:flex;flex-direction:column;gap:6px}
.checklist-message.done{opacity:.82}
.checklist-row{display:flex;align-items:flex-start;gap:9px}
.checklist-text{font-size:14px;line-height:1.45;word-break:break-word}
.checklist-text.done{text-decoration:line-through;color:var(--muted)}
.checklist-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}
.checklist-badges{display:flex;align-items:center;gap:6px}
.checklist-flag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-family:var(--mono);padding:1px 6px;border-radius:999px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);color:var(--accent)}
.checklist-checkbox{width:16px;height:16px;margin:2px 0 0;accent-color:var(--accent);flex-shrink:0}
.checklist-pin-toggle{width:28px;height:28px;border-radius:7px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.checklist-pin-toggle:hover{border-color:var(--accent);color:var(--accent)}
.checklist-pin-toggle.active{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.chat-compose{padding:6px 8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px;flex-shrink:0}
.chat-compose.drag-over{background:rgba(59,130,246,.08);box-shadow:inset 0 0 0 1px rgba(59,130,246,.3)}
.chat-who{display:flex;align-items:center;gap:5px}
.chat-who-lbl{font-size:12px;color:var(--muted);white-space:nowrap}
.chat-who-sel{flex:1;background:var(--surface3);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:13px;padding:4px 7px;border-radius:5px;outline:none}
.chat-row{display:flex;gap:5px;min-width:0;align-items:flex-end}
.chat-in{flex:1;min-width:0;background:var(--surface3);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:14px;padding:7px 8px;border-radius:6px;outline:none;resize:none;min-height:32px;max-height:80px;line-height:1.4}
.chat-compose.codex-awaiting-message .chat-in{background:var(--codex-awaiting-input-bg);border-color:var(--codex-awaiting-input-border)}
.chat-in:focus{border-color:var(--accent)}
.chat-compose.codex-awaiting-message .chat-in:focus{border-color:#22c55e;box-shadow:0 0 0 1px rgba(34,197,94,.22)}
.chat-in:disabled{opacity:.6;cursor:not-allowed}
.chat-in::placeholder{color:var(--muted)}
.chat-send{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:7px 11px;font-size:14px;cursor:pointer;flex-shrink:0;transition:background .12s}
.chat-send:hover{background:var(--accent-d)}
.chat-send:disabled,.attach-btn:disabled,.rec-btn:disabled,.checklist-btn:disabled,.voice-btn:disabled{opacity:.55;cursor:not-allowed}
.compose-edit-btn{height:32px;padding:0 10px;border-radius:6px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--mono);transition:all .15s}
.compose-edit-btn:hover{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.compose-edit-btn:disabled{opacity:.55;cursor:not-allowed}
.chat-action-btn{position:relative}
.chat-action-btn::before,.chat-action-btn::after{position:absolute;left:50%;opacity:0;pointer-events:none;transition:opacity .14s ease,transform .14s ease;z-index:35}
.chat-action-btn::before{content:'';bottom:calc(100% + 4px);transform:translate(-50%,4px);border:5px solid transparent;border-top-color:var(--surface3)}
.chat-action-btn::after{content:attr(data-chat-tooltip);bottom:calc(100% + 10px);transform:translate(-50%,4px);background:var(--surface3);color:var(--text);border:1px solid var(--border2);border-radius:7px;padding:5px 8px;font-size:11px;font-family:var(--sans);font-weight:500;white-space:nowrap;box-shadow:0 10px 24px rgba(0,0,0,.24)}
.chat-action-btn:hover::before,.chat-action-btn:hover::after,.chat-action-btn:focus-visible::before,.chat-action-btn:focus-visible::after{opacity:1;transform:translate(-50%,0)}
.attach-btn,.rec-btn,.checklist-btn,.voice-btn{width:32px;height:32px;border-radius:6px;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.attach-btn:hover,.checklist-btn:hover{border-color:var(--accent);color:var(--accent)}
.attach-btn{font-size:18px;line-height:1}
.ai-checklist-btn{width:auto;min-width:38px;padding:0 9px;font-size:11px;font-family:var(--mono);letter-spacing:.06em}
.checklist-btn{font-size:15px}
.checklist-btn.active{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.12);color:var(--accent)}
.compose-status{font-size:11px;color:var(--muted);font-family:var(--mono);min-height:0;line-height:1.25}
.checklist-mode-hint{color:var(--accent)}
.compose-edit-hint{color:var(--accent)}
.voice-compose-hint{color:var(--accent)}
.attachment-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-family:var(--mono);padding:1px 5px;border-radius:4px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted);margin-right:5px}
.attachment-card{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.attachment-image{max-width:100%;max-height:280px;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);display:block}
.attachment-video{width:100%;max-width:280px;border-radius:8px;background:#000;display:block}
.lazy-video{position:relative;overflow:hidden;width:100%;max-width:280px;border-radius:8px;border:1px solid var(--border2);background:radial-gradient(circle at top,rgba(59,130,246,.18),rgba(15,23,42,.96));display:block;min-height:160px}
.lazy-video .attachment-video{max-width:none}
.lazy-video-poster{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;max-width:none!important;max-height:none!important;object-fit:cover;object-position:center;display:block}
.lazy-video-has-poster::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(2,6,23,.12),rgba(2,6,23,.4))}
.lazy-video-btn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(148,163,184,.5);background:rgba(15,23,42,.62);color:#e2e8f0;border-radius:999px;padding:8px 14px;font-size:12px;font-family:var(--mono);letter-spacing:.04em;cursor:pointer;transition:all .12s}
.lazy-video-btn:hover{border-color:var(--accent);color:#fff;background:rgba(37,99,235,.32)}
.lazy-video-icon{font-size:12px;line-height:1}
.attachment-pdf-frame-wrap{position:relative;display:block;width:100%;max-width:520px;border-radius:10px;border:1px solid var(--border2);overflow:hidden;background:#fff}
.attachment-pdf-frame{display:block;width:100%;height:320px;border:0;background:#fff}
.attachment-pdf-badge{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;justify-content:center;padding:2px 7px;border-radius:999px;background:rgba(15,23,42,.72);color:#fff;font-size:10px;font-family:var(--mono);letter-spacing:.08em}
.attachment-pdf-link{display:block;max-width:280px}
.attachment-pdf-preview{display:block;width:100%;height:280px;border-radius:8px;border:1px solid var(--border2);background:#fff;pointer-events:none}
.attachment-pdf-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:280px;border-radius:8px;border:1px solid var(--border2);background:linear-gradient(160deg,rgba(239,68,68,.14),rgba(239,68,68,.04)),var(--surface2);font-size:18px;font-family:var(--mono);font-weight:700;letter-spacing:.12em;color:var(--high-text)}
.attachment-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.attachment-name{font-size:13px;font-weight:500;color:var(--text);word-break:break-word}
.attachment-sub{font-size:11px;color:var(--muted);font-family:var(--mono)}
.attachment-link{font-size:11px;color:var(--accent);text-decoration:none}
.diff-panel-body{word-break:normal}
.diff-head-rows{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
.diff-head-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;min-width:0}
.diff-branch-summary{display:inline-flex;align-items:center;gap:5px;min-width:0;flex-wrap:wrap}
.diff-branch-link{appearance:none;border:1px solid transparent;background:transparent;color:inherit;font:inherit;font-family:var(--mono);padding:2px 4px;border-radius:5px;cursor:pointer;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.diff-branch-link:hover,.diff-branch-link:focus-visible{border-color:var(--border2);background:var(--surface2);color:var(--text);outline:none}
.diff-branch-link.empty{color:var(--muted)}
.diff-branch-arrow{color:var(--muted);font-family:var(--mono)}
.diff-branch-input{width:150px;max-width:38vw;background:var(--surface2);border:1px solid var(--accent);color:var(--text);border-radius:5px;font:inherit;font-family:var(--mono);padding:3px 6px;outline:none}
.diff-toggle{display:inline-flex;gap:4px}
.shell.standalone-task .diff-head-rows{gap:6px}
.shell.standalone-task .diff-head-row{gap:8px}
.shell.standalone-task .diff-toggle{gap:3px}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.chip:disabled{opacity:.55;cursor:not-allowed}
.chip:disabled:hover{border-color:var(--border2);color:var(--muted);background:transparent}
.diff-log-actions{display:flex;justify-content:center;padding:10px 12px 12px;border-top:1px solid var(--border)}
.diff-commit-box{padding:12px 14px;border-bottom:1px solid var(--border);background:var(--surface)}
.diff-commit-loader-box{display:flex;align-items:center;min-height:52px}
.diff-commit-input{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:13px;padding:9px 10px;border-radius:8px;outline:none;resize:vertical;min-height:52px}
.diff-commit-input:focus{border-color:var(--accent)}
.diff-commit-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}
.detail-inline-loader{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-family:var(--mono);color:var(--muted);white-space:nowrap}
.detail-inline-loader-spinner{width:12px;height:12px;border-radius:999px;border:2px solid rgba(59,130,246,.2);border-top-color:var(--accent);animation:detailInlineSpin .8s linear infinite;flex-shrink:0}
.diff-line{display:block}
.diff-file{color:#93c5fd;font-weight:600}
.diff-meta,.diff-filehdr{color:var(--muted)}
.diff-hunk{color:#60a5fa}
.diff-add{color:#16a34a;background:rgba(34,197,94,.08)}
.diff-del{color:#dc2626;background:rgba(239,68,68,.08)}
@keyframes detailInlineSpin{to{transform:rotate(360deg)}}

/* Overlays */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;pointer-events:none;transition:opacity .18s}
.overlay.open{opacity:1;pointer-events:all}
.modal-sm{background:var(--surface);border:1px solid var(--border2);border-radius:10px;width:380px;max-width:95vw;transform:translateY(10px);transition:transform .18s}
.modal-lg{background:var(--surface);border:1px solid var(--border2);border-radius:10px;width:min(1040px,calc(100vw - 32px));max-width:95vw;max-height:min(88vh,900px);transform:translateY(10px);transition:transform .18s;display:flex;flex-direction:column}
.overlay.open .modal-sm{transform:translateY(0)}
.overlay.open .modal-lg{transform:translateY(0)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:15px 20px 12px;border-bottom:1px solid var(--border)}
.modal-head-title{font-size:16px;font-weight:600}
.modal-x{width:26px;height:26px;border-radius:5px;background:var(--surface2);border:none;color:var(--muted);cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;transition:background .1s}
.modal-x:hover{background:var(--surface3);color:var(--text)}
.modal-body{padding:15px 20px;display:flex;flex-direction:column;gap:11px;overflow-y:auto}
.modal-foot{padding:11px 20px 14px;display:flex;justify-content:flex-end;gap:7px;border-top:1px solid var(--border)}
.project-report-modal{width:min(980px,calc(100vw - 32px))}
.project-report-head{align-items:center}
.project-report-head-actions{display:flex;align-items:center;gap:8px}
.project-report-body{max-height:min(82vh,860px)}
.project-report-shell{display:flex;flex-direction:column;gap:14px}
.project-report-meta{display:flex;flex-direction:column;gap:6px;padding:14px;border:1px solid var(--border2);border-radius:12px;background:var(--surface2)}
.project-report-project{font-size:24px;font-weight:700;line-height:1.25}
.project-report-sub{font-size:13px;color:var(--muted)}
.project-report-stats{display:flex;flex-wrap:wrap;gap:8px}
.project-report-stat{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border2);border-radius:999px;background:var(--surface);font-size:12px;color:var(--muted)}
.project-report-stat strong{font-size:14px;color:var(--text)}
.project-report-sections{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.project-report-section{display:flex;flex-direction:column;min-height:260px;border:1px solid var(--border2);border-radius:12px;background:var(--surface)}
.project-report-section-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border)}
.project-report-section-title{font-size:15px;font-weight:700}
.project-report-section-count{font-size:12px;font-family:var(--mono);color:var(--muted)}
.project-report-list{list-style:none;margin:0;padding:10px 12px;display:flex;flex-direction:column;gap:8px;overflow:auto}
.project-report-item{display:flex;flex-direction:column;gap:5px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--surface2)}
.project-report-item-title{font-size:14px;font-weight:600;line-height:1.35;color:var(--text)}
.project-report-item-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--muted);font-family:var(--mono)}
.project-report-item-chip{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;border:1px solid var(--border2);background:var(--surface)}
.project-report-item-empty{padding:18px 10px;text-align:center;font-size:13px;color:var(--muted)}
@media (max-width:980px){
  .project-report-sections{grid-template-columns:1fr}
}
@media print{
  body.project-report-print-mode .shell,
  body.project-report-print-mode .login-screen,
  body.project-report-print-mode #sb-tooltip,
  body.project-report-print-mode .app-toast{display:none!important}
  body.project-report-print-mode{overflow:visible;background:#fff;color:#111}
  body.project-report-print-mode #project-report-overlay{position:static;inset:auto;background:#fff;opacity:1!important;pointer-events:auto;z-index:auto}
  body.project-report-print-mode #project-report-overlay .project-report-modal{width:100%;max-width:none;max-height:none;border:none;border-radius:0;transform:none;box-shadow:none}
  body.project-report-print-mode #project-report-overlay .project-report-head-actions{display:none!important}
  body.project-report-print-mode #project-report-overlay .project-report-body{max-height:none;overflow:visible;padding:12px 0}
  body.project-report-print-mode #project-report-overlay .project-report-section{break-inside:avoid-page}
  body.customer-report-print-mode .shell,
  body.customer-report-print-mode .login-screen,
  body.customer-report-print-mode #sb-tooltip,
  body.customer-report-print-mode .app-toast{display:none!important}
  body.customer-report-print-mode{overflow:visible;background:#fff;color:#111}
  body.customer-report-print-mode #customer-report-overlay{position:static;inset:auto;background:#fff;opacity:1!important;pointer-events:auto;z-index:auto}
  body.customer-report-print-mode #customer-report-overlay .project-report-modal{width:100%;max-width:none;max-height:none;border:none;border-radius:0;transform:none;box-shadow:none}
  body.customer-report-print-mode #customer-report-overlay .project-report-head-actions{display:none!important}
  body.customer-report-print-mode #customer-report-overlay .project-report-body{max-height:none;overflow:visible;padding:12px 0}
  body.customer-report-print-mode #customer-report-overlay .project-report-section{break-inside:avoid-page}
}
.generated-checklist-body{max-height:min(62vh,560px)}
.generated-checklist-copy{font-size:13px;line-height:1.5;color:var(--muted)}
.generated-checklist-toolbar{display:flex;justify-content:flex-end}
.generated-checklist-select-btn{padding:6px 10px;font-size:12px}
.generated-checklist-list{display:flex;flex-direction:column;gap:8px}
.generated-checklist-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--border2);border-radius:10px;background:var(--surface2)}
.generated-checklist-item input{margin-top:3px;accent-color:var(--accent)}
.generated-checklist-item-text{font-size:14px;line-height:1.45;color:var(--text);word-break:break-word}
.generated-checklist-empty{padding:12px;border:1px dashed var(--border2);border-radius:10px;background:rgba(255,255,255,.02);font-size:13px;line-height:1.5;color:var(--muted);text-align:center}
.btn{font-family:var(--sans);font-size:14px;font-weight:500;padding:7px 16px;border-radius:7px;cursor:pointer;border:none;transition:all .12s}
.btn-ghost{background:var(--surface2);color:var(--muted);border:1px solid var(--border2)}.btn-ghost:hover{color:var(--text)}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-d)}
.btn-danger{background:transparent;color:var(--high);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:var(--high-bg)}
.fg{display:flex;flex-direction:column;gap:4px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.fl{font-size:12px;font-weight:500;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}
.fi,.fs,.ft{background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:15px;padding:7px 11px;border-radius:7px;outline:none;transition:border .15s;width:100%}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--accent)}
.fs option{background:var(--surface2)}
.ft{resize:vertical;min-height:52px}
.err{color:var(--high);font-size:13px;padding:7px 11px;background:var(--high-bg);border-radius:6px;border:1px solid rgba(239,68,68,.2)}
.cpicker{display:flex;gap:6px;flex-wrap:wrap}
.copt{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .1s}
.copt:hover,.copt.sel{border-color:var(--text);transform:scale(1.15)}

/* @mention autocomplete popup */
.mention-popup{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border2);border-radius:9px;box-shadow:0 -8px 24px rgba(0,0,0,.4);overflow:hidden;z-index:200;max-height:220px;overflow-y:auto}
.mention-item{display:flex;align-items:center;gap:9px;padding:8px 12px;cursor:pointer;transition:background .08s}
.mention-item:hover,.mention-item.active{background:var(--surface2)}
.mention-item-name{font-size:13px;font-weight:500;color:var(--text)}
.mention-item-role{font-size:11px;color:var(--muted)}
.emoji-picker-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.emoji-inline{font-size:1.15em;line-height:1;vertical-align:-.12em}

/* @mention pill in chat bubbles */
.mention-chip{display:inline-flex;align-items:center;gap:3px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:var(--accent);border-radius:4px;padding:0px 5px;font-size:12px;font-weight:500;cursor:default;white-space:nowrap}
.mention-chip.me{background:rgba(59,130,246,.28);border-color:rgba(59,130,246,.5);color:#93c5fd}

/* Chats thread list */
.chat-thread{display:flex;align-items:flex-start;gap:11px;padding:13px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .08s;position:relative}
.chat-thread:hover{background:var(--surface2)}
.chat-thread.unread{background:rgba(59,130,246,.04)}
.chat-thread-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-thread-title.chat-thread-bubble{display:inline-flex;align-items:center;max-width:min(100%,640px);padding:9px 12px;border-radius:14px;background:rgba(59,130,246,.09);border:1px solid rgba(59,130,246,.18);font-size:15px;font-weight:600;line-height:1.45;white-space:normal;overflow:hidden;text-overflow:clip}
.chat-thread-title.chat-thread-bubble strong{color:var(--text);font-weight:700}
.chat-thread-subtitle{font-size:11px;color:var(--muted);margin:4px 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-thread-preview{font-size:12px;color:var(--muted);margin-bottom:2px;max-width:100%;display:block;overflow:visible;line-height:1.4;white-space:normal}
.chat-thread-preview strong{color:var(--text);font-weight:500}
.chat-thread-preview .mention-chip{font-size:11px;padding:0 4px}
.chat-thread-meta{font-size:11px;color:var(--muted);font-family:var(--mono);white-space:nowrap;flex-shrink:0}
.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:5px}
.thread-avatar-stack{display:flex;flex-direction:column;align-items:center;gap:3px;flex-shrink:0}

/* Floating relevant chat bubble */
.floating-chat-notify{position:fixed;right:22px;bottom:86px;z-index:180;display:flex;flex-direction:column;align-items:flex-end;gap:12px;pointer-events:none;transition:bottom .16s ease}
body[data-page="task"] .floating-chat-notify{bottom:22px}
.floating-chat-panel,.floating-chat-bubble-btn{pointer-events:auto}
.floating-chat-panel{width:min(360px,calc(100vw - 28px));max-height:min(58vh,520px);background:transparent;border:none;border-radius:0;box-shadow:none;overflow:visible}
.floating-chat-panel-list{max-height:min(58vh,520px);overflow-y:auto;padding:2px 2px 4px 8px;display:flex;flex-direction:column;gap:12px}
.floating-chat-empty{padding:18px 14px;text-align:center;font-size:13px;line-height:1.5;color:var(--muted);background:var(--surface);border:1px solid var(--border2);border-radius:18px;box-shadow:0 16px 40px rgba(0,0,0,.28)}
.floating-chat-thread{width:100%;border:none;background:linear-gradient(135deg,rgba(148,163,184,.08),rgba(148,163,184,.02));border:1px solid var(--border2);border-radius:26px;padding:11px 12px;display:flex;align-items:flex-start;gap:10px;text-align:left;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease}
.floating-chat-thread:hover{transform:translateY(-1px);border-color:rgba(59,130,246,.3);background:linear-gradient(135deg,rgba(59,130,246,.14),rgba(59,130,246,.05));box-shadow:0 10px 26px rgba(15,23,42,.18)}
.floating-chat-thread.unread{border-color:rgba(59,130,246,.34);background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(59,130,246,.06))}
.floating-chat-thread-orb{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(59,130,246,.16);border:1px solid rgba(59,130,246,.28);color:var(--accent);font:600 11px/1 var(--mono)}
.floating-chat-thread-copy{min-width:0;display:flex;flex-direction:column;gap:4px;flex:1}
.floating-chat-thread-title-row{display:flex;align-items:center;gap:6px;min-width:0}
.floating-chat-thread-title{min-width:0;flex:1;font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.floating-chat-thread-flag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.floating-chat-thread-flag.mention{background:rgba(59,130,246,.16);border-color:rgba(59,130,246,.26);color:var(--accent)}
.floating-chat-thread-flag.assigned{background:rgba(16,185,129,.14);border-color:rgba(16,185,129,.24);color:#34d399}
.floating-chat-thread-preview{font-size:12px;line-height:1.45;color:var(--muted);display:block;overflow:visible;white-space:normal}
.floating-chat-thread-preview strong{color:var(--text);font-weight:600}
.floating-chat-thread-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}
.floating-chat-thread-author{font-size:11px;color:var(--muted);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.floating-chat-thread-time{font-size:11px;color:var(--muted);font-family:var(--mono);white-space:nowrap}
.floating-chat-bubble-btn{position:relative;width:58px;height:58px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--accent),var(--accent-d));color:#fff;box-shadow:0 16px 40px rgba(37,99,235,.34);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.floating-chat-bubble-btn:hover{transform:translateY(-1px) scale(1.02);box-shadow:0 20px 46px rgba(37,99,235,.4)}
.floating-chat-bubble-btn:focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:3px}
.floating-chat-bubble-icon{font-size:22px;line-height:1}
.floating-chat-bubble-count{position:absolute;top:-4px;right:-3px;min-width:24px;height:24px;padding:0 6px;border-radius:999px;background:#fff;color:var(--accent-d);font:700 12px/1 var(--mono);display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
.app-toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(8px);max-width:min(420px,calc(100vw - 24px));padding:10px 14px;border-radius:12px;border:1px solid var(--border2);background:var(--surface3);color:var(--text);box-shadow:var(--shadow);font-size:13px;line-height:1.4;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:260}
.app-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.app-toast.error{border-color:rgba(239,68,68,.35);background:var(--high-bg);color:var(--high-text)}
.accept-task-result-banner{padding:12px 14px;border-radius:12px;border:1px solid transparent;font:800 18px/1.2 var(--sans);letter-spacing:.01em;text-transform:uppercase}
.accept-task-result-banner.success{border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.14);color:#047857}
.accept-task-result-banner.conflict{border-color:rgba(239,68,68,.34);background:rgba(239,68,68,.14);color:#b91c1c}

@keyframes taskEntryFlash{0%{box-shadow:0 0 0 0 rgba(59,130,246,.42);border-color:rgba(59,130,246,.5)}100%{box-shadow:0 0 0 16px rgba(59,130,246,0);border-color:transparent}}
.task-entry-flash{animation:taskEntryFlash .9s ease-out 1}
.chat-msg.search-match-target .chat-bub,
.pinned-checklist-item.search-match-target{
  border-color:rgba(250,204,21,.68);
  box-shadow:0 0 0 1px rgba(250,204,21,.36),0 0 0 10px rgba(250,204,21,.12);
  background:linear-gradient(180deg,rgba(250,204,21,.12),rgba(250,204,21,.04));
}

@media (max-width: 900px){
  .floating-chat-notify{right:14px;bottom:80px}
  body[data-page="task"] .floating-chat-notify{bottom:16px}
  .floating-chat-panel{width:min(340px,calc(100vw - 20px))}
}

@media (max-width: 900px){
  body.mobile-board-layout{overflow:hidden}
  body.mobile-board-layout .sidebar,
  body.mobile-board-layout #view-customers,
  body.mobile-board-layout #view-projects,
  body.mobile-board-layout #view-developers,
  body.mobile-board-layout #view-activity,
  body.mobile-board-layout #view-debug-servers{display:none!important}
  body.mobile-board-layout .main{min-width:0}
  body.mobile-board-layout .mobile-top-tabs{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center}
  body.mobile-board-layout .mobile-top-tab{appearance:none;border:1px solid var(--border2);background:var(--surface2);color:var(--muted);border-radius:999px;padding:9px 12px;font:600 13px/1.2 var(--sans);cursor:pointer;transition:border-color .12s ease,background .12s ease,color .12s ease}
  body.mobile-board-layout .mobile-top-tab.active{border-color:var(--accent);background:rgba(59,130,246,.1);color:var(--text)}
  body.mobile-board-layout .mobile-notification-wrap{display:block;justify-self:end}
  body.mobile-board-layout .mobile-notification-menu{right:0;left:auto}
  body.mobile-board-layout .content-area{position:relative;min-height:0}
  body.mobile-board-layout .view-pane{min-width:0}
  body.mobile-board-layout #view-tasks,
  body.mobile-board-layout #view-summary,
  body.mobile-board-layout #view-chats{min-width:0}
  body.mobile-board-layout .topbar,
  body.mobile-board-layout .floating-chat-notify{display:none!important}
  body.mobile-board-layout .filter-bar{display:none!important}
  body.mobile-board-layout .quick-add{padding:12px 16px calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);border-bottom:0;align-items:stretch;background:var(--surface);box-shadow:0 -12px 24px rgba(0,0,0,.12)}
  body.mobile-board-layout .quick-add>div{flex-direction:column;align-items:stretch;gap:10px}
  body.mobile-board-layout #quick-input-wrap{width:100%}
  body.mobile-board-layout #quick-context-pills{flex-wrap:wrap}
  body.mobile-board-layout .quick-input{font-size:16px;padding:10px 0}
  body.mobile-board-layout .ptog{display:none}
  body.mobile-board-layout .add-btn{width:100%;padding:12px 16px;font-size:15px;opacity:1}
  body.mobile-board-layout .tasks-scroll{gap:24px;padding:18px 0 28px}
  body.mobile-board-layout .mobile-board-section{display:block}
  body.mobile-board-layout #task-list{padding:0 16px}
  body.mobile-board-layout .task-table{display:none}
  body.mobile-board-layout .empty-state{padding:8px 0}
  body.mobile-board-layout .stats-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:var(--border);border-bottom:1px solid var(--border)}
  body.mobile-board-layout .stat-cell{padding:10px 10px 9px;min-width:0}
  body.mobile-board-layout .stat-num{font-size:18px}
  body.mobile-board-layout .stat-label{font-size:11px}
  body.mobile-board-layout .drawer{position:fixed;inset:0;z-index:220;width:100%!important;min-width:0!important;transform:translateX(100%);border-left-width:0;background:var(--bg);transition:transform .22s cubic-bezier(.4,0,.2,1)}
  body.mobile-board-layout .drawer.open{transform:translateX(0)}
  body.mobile-board-layout .drawer-resize-handle{display:none!important}
}

@media (max-width: 900px){
  body.mobile-board-layout .detail-panel,
  .shell.standalone-task .detail-panel{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) auto;min-height:0}
  body.mobile-board-layout .detail-head,
  .shell.standalone-task .detail-head{min-height:var(--header-band-min-height);padding:var(--header-band-pad-y) 14px}
  body.mobile-board-layout .detail-badges,
  .shell.standalone-task .detail-badges{padding:var(--detail-chip-pad-top) 14px var(--detail-chip-pad-bottom)}
  body.mobile-board-layout .detail-meta,
  .shell.standalone-task .detail-meta{display:none!important}
  body.mobile-board-layout .detail-body,
  .shell.standalone-task .detail-body{padding:0;min-height:0;overflow:hidden}
  body.mobile-board-layout .detail-columns,
  .shell.standalone-task .detail-columns{display:flex;flex-direction:column;height:100%;min-height:0}
  body.mobile-board-layout .detail-column-chat,
  .shell.standalone-task .detail-column-chat{background:transparent;border:0;border-radius:0}
  body.mobile-board-layout .detail-column-diff,
  body.mobile-board-layout .detail-column-log,
  body.mobile-board-layout .detail-column-stack,
  body.mobile-board-layout .detail-column-resizer,
  body.mobile-board-layout .detail-notes,
  .shell.standalone-task .detail-column-diff,
  .shell.standalone-task .detail-column-log,
  .shell.standalone-task .detail-column-stack,
  .shell.standalone-task .detail-column-resizer,
  .shell.standalone-task .detail-notes{display:none!important}
  body.mobile-board-layout .pinned-checklist-host,
  .shell.standalone-task .pinned-checklist-host{padding:10px 10px 0}
  body.mobile-board-layout .chat-msgs,
  .shell.standalone-task .chat-msgs{padding:10px 10px 0!important}
  body.mobile-board-layout .chat-bub,
  .shell.standalone-task .chat-bub{max-width:100%}
  body.mobile-board-layout .chat-compose,
  .shell.standalone-task .chat-compose{padding:8px 10px calc(8px + env(safe-area-inset-bottom,0px))}
  body.mobile-board-layout .chat-row,
  .shell.standalone-task .chat-row{align-items:flex-end}
  body.mobile-board-layout .ai-checklist-btn,
  body.mobile-board-layout #checklist-btn,
  body.mobile-board-layout .rec-btn,
  .shell.standalone-task .ai-checklist-btn,
  .shell.standalone-task #checklist-btn,
  .shell.standalone-task .rec-btn{display:none}
  body.mobile-board-layout .chat-send,
  body.mobile-board-layout .voice-btn,
  body.mobile-board-layout .attach-btn,
  .shell.standalone-task .chat-send,
  .shell.standalone-task .voice-btn,
  .shell.standalone-task .attach-btn{height:38px;min-width:38px}
  body.mobile-board-layout .chat-in,
  .shell.standalone-task .chat-in{font-size:15px;max-height:132px}
  body.mobile-board-layout .detail-head-actions,
  .shell.standalone-task .detail-head-actions{flex-wrap:wrap;justify-content:flex-end}
  body.mobile-board-layout .detail-close,
  .shell.standalone-task .detail-close{width:34px;height:34px}
  body.mobile-board-layout .detail-notification-btn,
  .shell.standalone-task .detail-notification-btn{width:34px;height:34px;border-radius:8px}
  body.mobile-board-layout .detail-codex-nav,
  .shell.standalone-task .detail-codex-nav{order:-1;max-width:100%}
}

/* Topbar inline filter pills */
.topbar-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:3px 8px 3px 9px;border-radius:20px;white-space:nowrap;border:1px solid;cursor:default;animation:pillIn .12s ease-out}
@keyframes pillIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
.topbar-pill .pill-x{cursor:pointer;opacity:0.6;font-size:13px;line-height:1;margin-left:1px;transition:opacity .1s}
.topbar-pill .pill-x:hover{opacity:1}
.tp-proj{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.35);color:#93c5fd}
.tp-dev{background:rgba(139,92,246,.12);border-color:rgba(139,92,246,.35);color:#c4b5fd}
.tp-status{background:rgba(100,116,139,.12);border-color:rgba(100,116,139,.35);color:var(--muted)}
.tp-pri-high{background:var(--high-bg);border-color:rgba(239,68,68,.4);color:var(--high-text)}
.tp-pri-medium{background:var(--med-bg);border-color:rgba(245,158,11,.4);color:var(--med-text)}
.tp-pri-low{background:var(--low-bg);border-color:rgba(34,197,94,.4);color:var(--low-text)}
.tp-search{background:rgba(100,116,139,.1);border-color:rgba(100,116,139,.3);color:var(--muted)}
.tp-due{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:var(--high-text)}

/* Voice assistant */
.voice-btn:hover{border-color:var(--accent);color:var(--accent)}
.voice-btn.listening{border-color:rgba(59,130,246,.38);background:rgba(59,130,246,.12);color:var(--accent)}
.voice-btn.awake{border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.12);color:#86efac}
.voice-icon{width:9px;height:14px;border:2px solid currentColor;border-radius:999px;display:block;position:relative}
.voice-icon::before{content:"";position:absolute;left:50%;bottom:-5px;width:13px;height:7px;border:2px solid currentColor;border-top:0;border-radius:0 0 999px 999px;transform:translateX(-50%)}
.voice-icon::after{content:"";position:absolute;left:50%;bottom:-9px;width:2px;height:5px;background:currentColor;transform:translateX(-50%)}
.voice-btn.listening .voice-icon{animation:voicePulse 1.4s ease-in-out infinite}
.voice-btn.awake .voice-icon{animation:voicePulse .8s ease-in-out infinite}
@keyframes voicePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.58;transform:scale(.92)}}

/* Record button */
.rec-btn:hover{border-color:var(--high);color:var(--high)}
.rec-btn.recording{border-color:var(--high);background:var(--high-bg);color:var(--high)}
.rec-dot{width:10px;height:10px;border-radius:50%;background:currentColor;display:block;transition:all .15s}
.rec-btn.recording .rec-dot{animation:recPulse 1s ease-in-out infinite}
@keyframes recPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.8)}}
.rec-status{font-size:11px;color:var(--high);font-family:var(--mono)}

/* Global Recording Overlay */
.recording-overlay {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(239, 68, 68, 0.5);
  padding: 10px 20px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  gap: 16px;
  z-index: 100000;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.6);
  color: #fff;
  font-family: var(--sans);
  pointer-events: auto;
  animation: overlaySlideDown 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes overlaySlideDown {
  from { transform: translate(-50%, -20px); opacity: 0; }
  to { transform: translate(-50%, 0); opacity: 1; }
}


.recording-overlay .rec-dot {
  background: #ef4444;
  color: #ef4444;
  animation: recPulse 1s ease-in-out infinite;
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.5);
}

.recording-overlay-status {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
}

.recording-overlay-stop {
  background: #ef4444;
  border: none;
  color: white;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
}

.recording-overlay-stop:hover {
  background: #dc2626;
  transform: scale(1.05);
}

.recording-overlay-stop:active {
  transform: scale(0.95);
}

.video-thumb-overlay{z-index:100100}
.video-thumb-modal{width:min(860px,calc(100vw - 20px));max-width:none;max-height:min(92vh,920px);display:flex;flex-direction:column}
.video-thumb-modal .modal-body{overflow-y:auto;padding-bottom:14px}
.video-thumb-sub{font-size:12px;color:var(--muted);margin-bottom:8px;line-height:1.45}
.video-thumb-player{width:100%;max-height:min(34vh,340px);border-radius:10px;border:1px solid var(--border2);background:#000;display:block}
.video-thumb-strip-head{margin:10px 0 6px;font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.video-thumb-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0}
.video-thumb-frame{appearance:none;border:1px solid var(--border2);border-radius:8px;padding:4px;background:var(--surface2);cursor:pointer;color:var(--muted);display:flex;flex-direction:column;gap:4px}
.video-thumb-frame:hover{border-color:var(--accent);color:var(--text)}
.video-thumb-frame.active{border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.45)}
.video-thumb-frame img{width:100%;height:74px;object-fit:cover;border-radius:6px;background:#000;display:block}
.video-thumb-frame span{font-size:10px;font-family:var(--mono);line-height:1}
.summary-media-overlay{z-index:100105;align-items:stretch;justify-content:flex-start;padding:9px}
.summary-media-modal{width:calc(100vw - 18px);height:calc(100vh - 18px);max-width:none;max-height:none;display:flex;flex-direction:column;border-radius:12px}
.summary-media-head{padding-bottom:10px}
.summary-media-head-main{display:flex;flex-direction:column;gap:4px;min-width:0}
.summary-media-title-btn{border:none;background:none;padding:0;margin:0;text-align:left;cursor:pointer;color:var(--text);font:inherit;font-size:20px;font-weight:600;line-height:1.2}
.summary-media-title-btn:hover{color:var(--accent)}
.summary-media-title-btn.active{color:var(--accent)}
.summary-media-sub{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-media-body{display:flex;flex-direction:column;gap:10px;overflow:hidden;flex:1;min-height:0}
.summary-media-modal-panel-open .summary-media-body{flex-direction:row}
.summary-media-canvas{position:relative;display:flex;flex:1;min-height:0}
.summary-media-stage{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;border:1px solid var(--border2);border-radius:14px;background:rgba(0,0,0,.42);overflow:hidden}
.summary-media-image,.summary-media-video{display:block;width:100%;height:100%;object-fit:contain;background:#000}
.summary-media-empty{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:12px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.summary-media-video-poster{position:relative;width:100%;height:100%;padding:0;border:none;background:#000;cursor:pointer}
.summary-media-video-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:14px;font-family:var(--mono);letter-spacing:.08em;color:#cbd5e1}
.summary-media-play{position:absolute;left:14px;bottom:14px;display:inline-flex;align-items:center;gap:6px;padding:8px 11px;border-radius:999px;background:rgba(15,23,42,.82);border:1px solid rgba(148,163,184,.28);color:#e2e8f0;font-size:11px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase}
.summary-media-float-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:1px solid rgba(148,163,184,.35);background:rgba(15,23,42,.72);backdrop-filter:blur(2px);color:#e2e8f0;font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}
.summary-media-float-btn:hover{background:rgba(30,41,59,.86);border-color:rgba(148,163,184,.58)}
.summary-media-float-btn:disabled{opacity:.35;cursor:default}
.summary-media-float-btn-prev{left:14px}
.summary-media-float-btn-next{right:14px}
body.summary-media-drawer-open .summary-media-modal{width:calc(100vw - 18px)}
.summary-media-body .drawer.summary-media-docked{position:relative;inset:auto;z-index:auto;flex:0 0 var(--drawer-width, 420px);max-width:min(46vw,560px);height:100%;border-left-width:1px;border-left-color:var(--border);box-shadow:none;transform:none;pointer-events:auto}
.summary-media-body .drawer.summary-media-docked.open{width:var(--drawer-width, 420px)!important;min-width:var(--drawer-width, 420px)!important}
.drawer.summary-media-docked .drawer-resize-handle{display:none!important}
@media (max-width: 720px){
  .video-thumb-modal{width:min(100vw - 10px,860px);max-height:min(95vh,920px)}
  .video-thumb-player{max-height:min(30vh,240px)}
  .video-thumb-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .video-thumb-frame img{height:52px}
  .summary-media-modal{width:calc(100vw - 8px);height:calc(100vh - 8px)}
  .summary-media-modal-panel-open .summary-media-body{flex-direction:column}
  .summary-media-body .drawer.summary-media-docked{flex:1 1 auto;max-width:none;min-height:46vh}
  body.summary-media-drawer-open .summary-media-modal{width:calc(100vw - 8px)}
  .summary-media-float-btn{width:40px;height:40px;font-size:22px}
  .summary-media-float-btn-prev{left:8px}
  .summary-media-float-btn-next{right:8px}
}


/* Autocomplete ghost */
.ac-wrap{position:relative;width:100%}
.ac-ghost{position:absolute;inset:0;display:flex;align-items:center;padding:5px 8px;font-size:13px;font-family:var(--sans);pointer-events:none;white-space:pre;overflow:hidden;border-radius:7px}
.ac-ghost-typed{color:transparent}
.ac-ghost-rest{color:var(--muted);opacity:0.55}
.ac-input{position:relative;width:100%;z-index:1}
.debug-servers-view{padding:16px 20px;display:flex;flex-direction:column;gap:12px}
.debug-server-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:14px;background:var(--surface)}
.debug-server-main{display:flex;flex-direction:column;gap:6px;min-width:0}
.debug-server-url{font-family:var(--mono);font-size:13px;color:var(--accent);text-decoration:none;word-break:break-all}
.debug-server-url:hover{text-decoration:underline}
.debug-server-task-link{color:var(--text);font-weight:600;cursor:pointer}
.debug-server-task-link:hover{text-decoration:underline}
.debug-server-meta{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px}
.debug-server-stop{border:none;background:transparent;color:var(--muted);font-size:20px;line-height:1;cursor:pointer;padding:2px 4px;border-radius:6px;flex-shrink:0}
.debug-server-stop:hover{background:var(--surface2);color:var(--text)}
.debug-server-empty{padding:40px 20px;text-align:center;color:var(--muted);font-size:13px}

/* Activity log entries */
.activity-entry{display:flex;gap:6px;align-items:flex-start}
.act-icon{width:22px;height:22px;border-radius:50%;background:var(--surface3);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;margin-top:1px;color:var(--muted)}
.act-bub{flex:1;min-width:0}
.act-txt{font-size:13px;color:var(--muted);line-height:1.4}
.act-txt strong{color:var(--text);font-weight:500}
.act-ts{font-size:11px;color:var(--muted);font-family:var(--mono);margin-top:1px}
.act-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px;min-height:20px}
.activity-undo-btn{border:none;background:rgba(34,197,94,.14);color:#22c55e;padding:4px 9px;border-radius:999px;font:inherit;font-size:11px;font-weight:600;cursor:pointer;flex-shrink:0}
.activity-undo-btn:hover{background:rgba(34,197,94,.22)}
.activity-undo-btn:disabled{opacity:.65;cursor:default}

/* Login screen */
.login-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px 36px;width:360px;max-width:95vw}
.login-card h2{font-size:18px;font-weight:600;margin-bottom:4px}
.login-card .login-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
.login-input{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--sans);font-size:15px;padding:10px 14px;border-radius:8px;outline:none;margin-bottom:12px;display:block;box-sizing:border-box}
.login-input:focus{border-color:var(--accent)}
.login-input::placeholder{color:var(--muted)}
.login-btn{width:100%;background:var(--accent);color:#fff;border:none;border-radius:8px;font-family:var(--sans);font-size:15px;font-weight:500;padding:10px;cursor:pointer;transition:background .12s;margin-top:4px}
.login-btn:hover{background:var(--accent-d)}
.login-error{color:var(--high);font-size:13px;padding:7px 11px;background:var(--high-bg);border-radius:6px;border:1px solid rgba(239,68,68,.2);margin-bottom:12px;display:none}
.signout-btn{font-size:12px;color:var(--muted);background:none;border:none;cursor:pointer;font-family:var(--sans);padding:2px 4px;transition:color .1s}
.signout-btn:hover{color:var(--text)}
.signout-btn:disabled{opacity:.6;cursor:default}
.signout-btn:disabled:hover{color:var(--muted)}
.invite-link-card{display:flex;flex-direction:column;gap:10px}
.invite-link-anchor{display:block;padding:11px 12px;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);color:var(--accent);font-size:12px;line-height:1.45;word-break:break-all;text-decoration:none}
.invite-link-anchor:hover{text-decoration:underline}
.settings-modal-body{display:flex;flex-direction:column;gap:14px}
.settings-group{display:flex;flex-direction:column;gap:10px}
.settings-label{font-size:12px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.settings-help{font-size:13px;line-height:1.45;color:var(--muted)}
.settings-option{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;width:100%;padding:12px 13px;border:1px solid var(--border2);border-radius:10px;background:var(--surface2);color:var(--text);cursor:pointer;text-align:left;transition:border-color .12s,background .12s,box-shadow .12s}
.settings-option:hover{border-color:var(--accent)}
.settings-option:disabled{opacity:.65;cursor:default}
.settings-option:disabled:hover{border-color:var(--border2);background:var(--surface2)}
.settings-option.active{border-color:var(--accent);background:rgba(59,130,246,.08);box-shadow:inset 0 0 0 1px rgba(59,130,246,.18)}
.settings-danger-option:hover{border-color:var(--danger);background:rgba(239,68,68,.08)}
.settings-danger-option .settings-option-label{color:var(--danger)}
.settings-option-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.settings-option-label{font-size:14px;font-weight:600;color:var(--text)}
.settings-option-help{font-size:12px;line-height:1.45;color:var(--muted)}
.settings-option-check{width:20px;height:20px;border-radius:999px;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:12px;color:transparent;flex-shrink:0;transition:all .12s}
.settings-option.active .settings-option-check{border-color:var(--accent);background:var(--accent);color:#fff}
.settings-toggle{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);cursor:pointer}
.settings-toggle input{accent-color:var(--accent)}
.settings-current{font-size:12px;color:var(--muted)}
/* Light-mode overrides for hardcoded color badges */
:root[data-theme="light"] .s-todo{background:#f1f5f9;color:#475569;border-color:#cbd5e1}
:root[data-theme="light"] .s-in_progress{background:#eff6ff;color:#2563eb;border-color:rgba(37,99,235,.25)}
:root[data-theme="light"] .s-review{background:#fff7ed;color:#c2410c;border-color:rgba(194,65,12,.25)}
:root[data-theme="light"] .s-tested{background:#f7fee7;color:#4d7c0f;border-color:rgba(77,124,15,.25)}
:root[data-theme="light"] .s-resolved{background:#f5f3ff;color:#7c3aed;border-color:rgba(124,58,237,.25)}
:root[data-theme="light"] .s-done{background:var(--low-bg);color:var(--low-text);border-color:rgba(22,163,74,.25)}
:root[data-theme="light"] .task-title-accomplished{color:#1a231e}
:root[data-theme="light"] .filter-bubble.fb-status-open,
:root[data-theme="light"] .filter-chip-btn.fb-status-open{background:rgba(100,116,139,.08);color:#334155;border-color:rgba(100,116,139,.22)}
:root[data-theme="light"] .filter-bubble.fb-status-closed,
:root[data-theme="light"] .filter-chip-btn.fb-status-closed{background:#f5f3ff;color:#7c3aed;border-color:rgba(124,58,237,.25)}
:root[data-theme="light"] .filter-bubble.fb-status-todo,
:root[data-theme="light"] .filter-chip-btn.fb-status-todo{background:#f1f5f9;color:#475569;border-color:#cbd5e1}
:root[data-theme="light"] .filter-bubble.fb-status-in_progress,
:root[data-theme="light"] .filter-chip-btn.fb-status-in_progress{background:#eff6ff;color:#2563eb;border-color:rgba(37,99,235,.25)}
:root[data-theme="light"] .filter-bubble.fb-status-pause,
:root[data-theme="light"] .filter-chip-btn.fb-status-pause{background:#fffbeb;color:#b45309;border-color:rgba(180,83,9,.2)}
:root[data-theme="light"] .filter-bubble.fb-status-review,
:root[data-theme="light"] .filter-chip-btn.fb-status-review{background:#fff7ed;color:#c2410c;border-color:rgba(194,65,12,.25)}
:root[data-theme="light"] .filter-bubble.fb-status-tested,
:root[data-theme="light"] .filter-chip-btn.fb-status-tested{background:#f7fee7;color:#4d7c0f;border-color:rgba(77,124,15,.25)}
:root[data-theme="light"] .filter-bubble.fb-status-resolved,
:root[data-theme="light"] .filter-chip-btn.fb-status-resolved{background:#f5f3ff;color:#7c3aed;border-color:rgba(124,58,237,.25)}
:root[data-theme="light"] .filter-bubble.fb-status-done,
:root[data-theme="light"] .filter-chip-btn.fb-status-done{background:var(--low-bg);color:var(--low-text);border-color:rgba(22,163,74,.25)}
:root[data-theme="light"] .filter-bubble.fb-status-deleted,
:root[data-theme="light"] .filter-chip-btn.fb-status-deleted{background:#f8fafc;color:#64748b;border-color:#cbd5e1}
:root[data-theme="light"] .filter-bubble.fb-creator,
:root[data-theme="light"] .filter-chip-btn.fb-creator{background:#ecfeff;color:#0f766e;border-color:rgba(15,118,110,.2)}
:root[data-theme="light"] .filter-bubble.fb-customer,
:root[data-theme="light"] .filter-chip-btn.fb-customer{background:#fdf2f8;color:#be185d;border-color:rgba(190,24,93,.2)}
:root[data-theme="light"] .s-pause{background:#fffbeb;color:#b45309;border-color:rgba(180,83,9,.2)}
:root[data-theme="light"] .mention-chip.me{background:rgba(37,99,235,.12);border-color:rgba(37,99,235,.3);color:#1d4ed8}
:root[data-theme="light"] .linked-task-chip{background:#ecfdf3;border-color:rgba(22,163,74,.24);color:#166534}
:root[data-theme="light"] .linked-task-chip:hover{background:#dcfce7;border-color:rgba(22,163,74,.34);color:#14532d}
:root[data-theme="light"] .tp-proj{background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.25);color:#1d4ed8}
:root[data-theme="light"] .tp-dev{background:rgba(109,40,217,.08);border-color:rgba(109,40,217,.25);color:#6d28d9}
:root[data-theme="light"] .settings-option.active{background:rgba(37,99,235,.08);box-shadow:inset 0 0 0 1px rgba(37,99,235,.14)}
:root[data-theme="light"] .summary-range-custom{background:rgba(15,23,42,.02)}
:root[data-theme="light"] .summary-range-custom-hint.valid{color:#15803d}
/* Topbar home button */
.topbar-home-btn{width:32px;height:32px;border-radius:7px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;line-height:1;flex-shrink:0}
.topbar-home-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--accent)}
