﻿:root {
  --bg:#f5f4f0;--surface:#ffffff;--surface2:#f0efe9;
  --border:rgba(0,0,0,0.09);--border2:rgba(0,0,0,0.17);
  --text:#1a1a18;--text2:#6b6b65;--text3:#a8a8a0;
  --info-bg:#e6f1fb;--info:#0c447c;--danger:#a32d2d;
  --radius:8px;--radius-lg:12px;--panel-w:310px;
}
@media(prefers-color-scheme:dark){
  :root{
    --bg:#18181a;--surface:#242428;--surface2:#1e1e22;
    --border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.15);
    --text:#f0f0ec;--text2:#9a9a94;--text3:#5a5a56;
    --info-bg:#0d2540;--info:#85b7eb;--danger:#f09595;
  }
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);overflow:hidden;}
#app{display:flex;flex-direction:column;height:100vh;}

.nav-tab{display:flex;align-items:center;gap:5px;font-size:12px;padding:5px 10px;border-radius:var(--radius);color:var(--text2);cursor:pointer;transition:all .12s;white-space:nowrap;}
.nav-tab:hover{background:var(--surface2);color:var(--text);}
.nav-tab.active{background:var(--surface2);color:var(--text);font-weight:500;}
/* topbar */
.topbar{display:flex;align-items:center;padding:0 20px;height:46px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;user-select:none;gap:0;}
.logo{font-size:15px;font-weight:700;letter-spacing:-.02em;color:var(--text);flex-shrink:0;cursor:pointer;}
.logo span{color:var(--info);}
.logo:hover{opacity:.8;}
.topbar-nav{display:flex;align-items:center;gap:3px;margin-left:10px;padding-left:10px;border-left:1px solid var(--border);flex-shrink:0;}
.top-icon-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text2);border-radius:var(--radius);cursor:pointer;font-size:15px;transition:background .12s,color .12s,opacity .12s;}
.top-icon-btn:hover:not(:disabled){background:var(--surface2);color:var(--text);}
.top-icon-btn:disabled{opacity:.28;cursor:default;}
.topbar-center{flex:1;display:flex;align-items:center;gap:5px;overflow:hidden;padding:0 16px;}
.bc-item{font-size:12px;color:var(--text2);cursor:pointer;white-space:nowrap;padding:3px 7px;border-radius:var(--radius);transition:background .12s;}
.bc-item:hover{background:var(--surface2);color:var(--text);}
.bc-item.active{color:var(--text);font-weight:500;cursor:default;}
.bc-item.active:hover{background:transparent;}
.bc-sep{font-size:12px;color:var(--text3);}
.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0;}
.tb-btn{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text2);background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);padding:5px 11px;cursor:pointer;transition:all .12s;white-space:nowrap;}
.tb-btn:hover{color:var(--text);background:var(--surface);}
.tb-btn.primary{background:var(--text);color:var(--surface);border-color:transparent;}
.tb-btn.primary:hover{opacity:.85;}
.tb-btn.icon-only{min-width:36px;padding:5px 11px;justify-content:center;font-size:14px;}
.tb-btn.disabled{opacity:.35;cursor:default;pointer-events:none;}
.sync-btn{min-width:118px;justify-content:center;}
.sync-btn i{font-size:14px;}
.sync-btn:has(.ti-loader-2) i{animation:sync-spin .8s linear infinite;}
.sync-btn.syncing i{animation:sync-spin .8s linear infinite;}
.sync-btn.offline{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 45%,var(--border2));background:transparent;}
.sync-btn.pending{color:var(--info);border-color:var(--info);background:var(--info-bg);}
@keyframes sync-spin{to{transform:rotate(360deg);}}
#hydration-indicator{position:fixed;inset:46px 0 auto 0;display:none;justify-content:center;pointer-events:none;z-index:500;}
#hydration-indicator.open{display:flex;}
.hydration-box{margin-top:10px;display:flex;align-items:center;gap:8px;padding:9px 13px;border:1px solid var(--border2);border-radius:999px;background:var(--surface);box-shadow:0 8px 24px rgba(0,0,0,.14);color:var(--text2);font-size:12px;}
.hydration-box i{font-size:15px;color:var(--info);animation:sync-spin .8s linear infinite;}
.server-status-body{display:flex;flex-direction:column;gap:12px;}
.server-status-grid{display:grid;grid-template-columns:1fr;gap:6px;}
.server-status-row{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 10px;font-size:12px;}
.server-status-row span{color:var(--text2);}
.server-status-row strong{color:var(--text);font-weight:650;}
.server-status-loading,.server-status-error{font-size:13px;color:var(--text2);line-height:1.45;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;}
.server-status-error{color:var(--danger);}
.server-status-error span{font-size:11px;color:var(--text3);}
.server-last-mutation{display:flex;flex-direction:column;gap:5px;font-size:11px;color:var(--text3);}
.server-last-mutation code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:11px;color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px;overflow:hidden;text-overflow:ellipsis;}
.filter-btn{position:relative;}
.filter-btn.active-filter{color:var(--info);border-color:var(--info);background:var(--info-bg);}
.filter-count{display:none;position:absolute;right:4px;top:3px;min-width:6px;height:6px;border-radius:999px;background:var(--info);color:transparent;font-size:0;line-height:1;}
.filter-btn.active-filter .filter-count{display:block;}
.notification-btn{position:relative;}
.notification-count{display:none;position:absolute;right:-4px;top:-5px;min-width:17px;height:17px;padding:1px 4px;border-radius:999px;background:var(--danger);color:#fff;font-size:10px;line-height:15px;text-align:center;font-weight:700;}
.notification-btn.has-unread .notification-count{display:block;}
.notification-list{display:flex;flex-direction:column;gap:7px;max-height:390px;overflow:auto;}
.notification-row{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--border);background:var(--surface);padding:10px;border-radius:var(--radius);font:inherit;text-align:left;color:var(--text);cursor:pointer;}
.notification-row.unread{background:var(--info-bg);border-color:var(--info);}
.notification-content{display:flex;flex-direction:column;gap:4px;min-width:0;}
.notification-text{font-size:12px;line-height:1.4;}
.notification-meta{font-size:11px;color:var(--text2);}
.split-action{position:relative;display:flex;align-items:center;}
.split-action .tb-btn{border-radius:0;}
.split-action .split-main{border-radius:var(--radius) 0 0 var(--radius);}
.split-action .split-more{border-left:1px solid rgba(255,255,255,.22);border-radius:0 var(--radius) var(--radius) 0;min-width:30px;padding:5px 8px;}
.split-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:190px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.12);padding:4px;display:none;z-index:50;}
.split-action.open .split-menu{display:flex;flex-direction:column;}
.split-menu button{display:flex;align-items:center;gap:8px;width:100%;border:0;background:transparent;color:var(--text);font-family:inherit;font-size:12px;text-align:left;padding:8px 10px;border-radius:6px;cursor:pointer;}
.split-menu button:hover{background:var(--surface2);}
.user-btn{padding-left:7px;}
.user-avatar,.owner-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:#fff;font-weight:700;letter-spacing:0;font-size:9px;}
.user-avatar{width:20px;height:20px;}
.presence-btn{gap:0;min-width:54px;justify-content:center;padding-left:8px;padding-right:8px;}
.presence-btn.empty{opacity:.55;}
.presence-avatar{display:inline-flex;align-items:center;justify-content:center;width:21px;height:21px;border-radius:999px;border:2px solid var(--surface2);color:#fff;font-size:9px;font-weight:750;letter-spacing:0;margin-left:-6px;box-shadow:0 0 0 1px var(--border);}
.presence-avatar:first-child{margin-left:0;}
.presence-avatar.large{width:30px;height:30px;margin-left:0;border-color:var(--surface);font-size:11px;flex-shrink:0;}
.presence-more{display:inline-flex;align-items:center;justify-content:center;width:21px;height:21px;border-radius:999px;background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-size:10px;font-weight:650;margin-left:-6px;}
.presence-label{font-size:11px;color:var(--text2);font-weight:650;margin-left:6px;}
.presence-list{display:flex;flex-direction:column;gap:8px;}
.presence-row{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px;}
.presence-info{min-width:0;}
.presence-name{font-size:13px;font-weight:650;color:var(--text);line-height:1.25;}
.presence-meta{font-size:11px;color:var(--text2);line-height:1.35;}
.presence-empty{font-size:13px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;line-height:1.4;}
.profile-summary{display:flex;align-items:center;gap:12px;}
.profile-avatar{width:34px;height:34px;font-size:13px;flex-shrink:0;}
.profile-info{min-width:0;}
.profile-name{font-size:14px;font-weight:650;color:var(--text);line-height:1.3;}
.profile-email{font-size:12px;color:var(--text2);line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.assignee-list{display:flex;flex-direction:column;gap:6px;border:1px solid var(--border);border-radius:var(--radius);padding:7px;}
.assignee-choice{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;font-size:12px;color:var(--text);cursor:pointer;}
.assignee-choice:hover{background:var(--surface2);}
.assignee-choice input{accent-color:var(--info);}
.p-readonly{font-size:12px;color:var(--text2);padding:8px 0;}
.inline-field-action{display:inline-flex;align-items:center;gap:5px;border:0;background:transparent;color:var(--info);font:inherit;font-size:11px;cursor:pointer;margin-top:6px;}
.inline-clear{font-size:11px;color:var(--text3);cursor:pointer;align-items:center;gap:3px;margin-top:4px;}
.due-time{margin-top:6px;}

/* ── Projects page ── */
#page-projects{flex:1;overflow-y:auto;padding:32px 28px;flex-direction:column;}
#page-projects::-webkit-scrollbar{width:5px;}
#page-projects::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
.proj-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;}
.proj-header h1{font-size:22px;font-weight:600;}
.proj-header p{font-size:13px;color:var(--text2);margin-top:3px;}
#projects-main{display:flex;gap:18px;min-height:0;align-items:flex-start;}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;}
.projects-grid{flex:1;min-width:0;}
#projects-grid{display:flex;flex-direction:column;gap:24px;}
.project-section{display:flex;flex-direction:column;gap:10px;}
.project-section-head{display:flex;align-items:center;gap:8px;}
.project-section-title{font-size:13px;font-weight:650;color:var(--text);letter-spacing:.01em;}
.project-section-count{font-size:11px;color:var(--text3);border:1px solid var(--border);border-radius:999px;padding:1px 7px;}
.project-section-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;flex:none;}
.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:border-color .15s,transform .12s,box-shadow .12s;user-select:none;}
.proj-card:hover{border-color:var(--border2);transform:translateY(-2px);}
.proj-card.active{border-color:var(--info);box-shadow:0 0 0 2px var(--info-bg);}
.proj-card.new-card{border-style:dashed;border-color:var(--border2);align-items:center;justify-content:center;min-height:148px;gap:8px;color:var(--text3);font-size:13px;}
.proj-card.new-card:hover{border-color:var(--info);color:var(--info);transform:translateY(-2px);}
.proj-card.new-card i{font-size:24px;}
.proj-band{height:5px;flex-shrink:0;}
.proj-body{padding:16px 16px 14px;flex:1;display:flex;flex-direction:column;gap:6px;}
.proj-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;}
.proj-desc{font-size:12px;color:var(--text2);line-height:1.45;flex:1;}
.proj-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border);flex-shrink:0;}
.proj-date{font-size:11px;color:var(--text3);}
.proj-actions{display:flex;gap:6px;opacity:0;transition:opacity .15s;}
.proj-card:hover .proj-actions{opacity:1;}
.proj-icon-btn{font-size:14px;color:var(--text3);cursor:pointer;padding:3px 4px;border-radius:5px;}
.proj-icon-btn:hover{color:var(--text);background:var(--surface2);}
.proj-icon-btn.favorite.active{color:#e5aa28;}
.proj-icon-btn.del:hover{color:var(--danger);}
#project-panel{width:320px;overflow:hidden;background:var(--surface);border:1px solid transparent;border-radius:var(--radius-lg);display:flex;flex-direction:column;transition:opacity .16s ease,border-color .16s;flex-shrink:0;position:sticky;top:0;max-height:calc(100vh - 112px);opacity:0;visibility:hidden;pointer-events:none;user-select:text;}
#project-panel.open{border-color:var(--border);opacity:1;visibility:visible;pointer-events:auto;}
.project-panel-title{font-size:16px;font-weight:600;color:var(--text);line-height:1.3;}
.project-panel-desc{font-size:12px;color:var(--text2);line-height:1.5;white-space:pre-wrap;}
.project-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.project-stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 10px;}
.project-stat.clickable{cursor:pointer;transition:border-color .12s,background .12s;}
.project-stat.clickable:hover{border-color:var(--info);background:var(--info-bg);}
.project-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:4px;}
.project-stat-value{font-size:13px;color:var(--text);font-weight:600;line-height:1.3;}
.collaborator-list{border-top:1px solid var(--border);padding-top:10px;}
.project-panel-actions{display:flex;gap:8px;}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .15s;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal-box{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border2);width:420px;padding:24px;display:flex;flex-direction:column;gap:16px;transform:scale(.96);transition:transform .15s;}
.modal-overlay.open .modal-box{transform:scale(1);}
.modal-box h2{font-size:16px;font-weight:600;}
.modal-box.settings-box{width:min(680px,calc(100vw - 32px));}
.modal-message{font-size:13px;color:var(--text2);line-height:1.45;white-space:pre-line;}
.modal-field{display:flex;flex-direction:column;gap:5px;}
.modal-field label{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);}
.modal-field input,.modal-field textarea,.modal-field select{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 11px;font-size:13px;color:var(--text);font-family:inherit;outline:none;resize:none;transition:border-color .12s;}
.modal-field input:focus,.modal-field textarea:focus,.modal-field select:focus{border-color:var(--info);}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px;}
.modal-icon-action{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-family:inherit;cursor:pointer;background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius);padding:0;}
.modal-icon-action:hover{background:var(--surface2);color:var(--text);}
.modal-icon-action.danger-text:hover{color:var(--danger);}
.modal-cancel{padding:7px 14px;font-size:13px;font-family:inherit;cursor:pointer;background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius);}
.modal-cancel.danger-text{color:var(--danger);}
.modal-confirm{padding:7px 16px;font-size:13px;font-family:inherit;cursor:pointer;background:var(--text);color:var(--surface);border:none;border-radius:var(--radius);}
.modal-confirm.danger{background:#d85a30;color:#fff;}
.modal-confirm:hover{opacity:.85;}
.modal-note{font-size:13px;color:var(--text2);line-height:1.45;}
.modal-section-title{font-size:13px;font-weight:600;margin-top:7px;color:var(--text);}
.perf-list{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow:auto;padding-right:2px;}
.perf-row{display:grid;grid-template-columns:1fr auto;gap:3px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;}
.perf-label{font-size:12px;font-weight:600;color:var(--text);}
.perf-time{font-size:12px;font-weight:700;color:var(--info);}
.perf-meta{grid-column:1 / -1;font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.color-picker{display:flex;gap:8px;flex-wrap:wrap;}
.color-swatch{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .1s;}
.color-swatch:hover{transform:scale(1.15);}
.color-swatch.sel{border-color:var(--text);transform:scale(1.15);}


.cfg-inp{flex:1;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:5px 8px;font-size:12px;color:var(--text);font-family:inherit;outline:none;}
.cfg-inp:focus{border-color:var(--info);}
.cfg-del{width:26px;height:26px;font-size:14px;color:var(--text3);cursor:pointer;border:0;background:transparent;padding:0;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;border-radius:6px;flex-shrink:0;position:relative;z-index:1;}
.cfg-del i{pointer-events:none;}
.cfg-del:hover{background:var(--surface);color:var(--danger);}
.status-list{display:flex;flex-direction:column;gap:8px;}
.status-row{display:flex;align-items:center;gap:8px;padding:8px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);}
.tag-row{grid-template-columns:auto auto 1fr auto;}
.status-color{width:28px!important;height:28px!important;border:0!important;background:transparent!important;padding:0!important;flex-shrink:0;cursor:pointer;}
.status-color:disabled{opacity:.35;cursor:default;}
.settings-shell{display:grid;grid-template-columns:150px minmax(0,1fr);gap:18px;min-height:300px;}
.settings-nav{display:flex;flex-direction:column;gap:4px;border-right:1px solid var(--border);padding-right:10px;}
.settings-nav button{display:flex;align-items:center;gap:8px;width:100%;border:0;background:transparent;color:var(--text2);font:inherit;font-size:12px;text-align:left;padding:8px 10px;border-radius:var(--radius);cursor:pointer;}
.settings-nav button:hover{background:var(--surface2);color:var(--text);}
.settings-nav button.active{background:var(--info-bg);color:var(--info);font-weight:600;}
.settings-content{display:flex;flex-direction:column;gap:12px;min-width:0;}
.settings-add-btn{align-self:flex-start;}
.modal-box.share-box{width:min(760px,calc(100vw - 32px));}
.share-shell{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:18px;min-height:310px;}
.share-form,.share-list-wrap{display:flex;flex-direction:column;gap:12px;min-width:0;}
.share-section-title{font-size:12px;font-weight:700;color:var(--text);letter-spacing:.01em;}
.share-add-row{display:flex;justify-content:flex-end;}
.share-list{display:flex;flex-direction:column;gap:8px;min-width:0;}
.share-row{display:grid;grid-template-columns:auto minmax(0,1fr) 132px 34px;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:9px;}
.share-avatar{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:var(--text3);font-size:10px;font-weight:750;letter-spacing:0;flex-shrink:0;}
.share-info{min-width:0;}
.share-name{font-size:13px;font-weight:650;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.share-meta{font-size:11px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.share-role{width:100%;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:7px 8px;color:var(--text);font:inherit;font-size:12px;}
.share-delete{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border2);border-radius:var(--radius);background:var(--surface);color:var(--danger);cursor:pointer;}
.share-delete:hover{background:var(--surface2);}
.share-empty{font-size:12px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;line-height:1.4;}
.share-empty.error{color:var(--danger);}
.my-cards-filters{display:flex;gap:8px;flex-wrap:wrap;}
.my-cards-filters .active{background:var(--info-bg);border-color:var(--info);color:var(--info);}
.my-cards-list{display:flex;flex-direction:column;gap:8px;max-height:420px;overflow:auto;padding-right:2px;}
.my-card-row{display:flex;flex-direction:column;gap:4px;text-align:left;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;color:inherit;font:inherit;cursor:pointer;}
.my-card-row:hover{border-color:var(--info);background:var(--info-bg);}
.my-card-title{font-size:13px;font-weight:700;color:var(--text);line-height:1.3;}
.my-card-meta{font-size:11px;color:var(--text2);line-height:1.35;}
.modal-box.calendar-box{width:min(1180px,calc(100vw - 36px));height:min(760px,calc(100vh - 42px));padding:18px;gap:14px;}
.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.calendar-nav,.calendar-modes{display:flex;align-items:center;gap:6px;}
.calendar-nav button,.calendar-modes button{height:32px;border:1px solid var(--border2);background:var(--surface);border-radius:var(--radius);padding:0 11px;color:var(--text2);font:inherit;font-size:12px;cursor:pointer;}
.calendar-nav button:hover,.calendar-modes button:hover{background:var(--surface2);color:var(--text);}
.calendar-nav button:first-child,.calendar-nav button:nth-child(3){width:32px;padding:0;font-size:15px;}
.calendar-range{font-size:14px;font-weight:650;color:var(--text);margin-left:8px;}
.calendar-modes button.active{border-color:var(--info);background:var(--info-bg);color:var(--info);font-weight:650;}
.calendar-shell{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:14px;flex:1;min-height:0;}
.calendar-main{min-width:0;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);}
.calendar-grid{height:100%;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-template-rows:32px repeat(6,minmax(0,1fr));background:var(--border);gap:1px;}
.calendar-grid.week{grid-template-rows:32px minmax(0,1fr);}
.calendar-weekday{display:flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--text2);font-size:11px;font-weight:650;text-transform:capitalize;}
.calendar-day{background:var(--surface);padding:7px 6px;min-width:0;display:flex;flex-direction:column;gap:5px;overflow:hidden;}
.calendar-day.outside{background:color-mix(in srgb,var(--surface2) 55%,var(--surface));color:var(--text3);}
.calendar-day.today{box-shadow:inset 0 0 0 1px var(--info);background:color-mix(in srgb,var(--info-bg) 48%,var(--surface));}
.calendar-day-number{display:flex;align-items:center;justify-content:center;align-self:flex-start;width:24px;height:24px;border-radius:999px;color:var(--text2);font-size:12px;}
.calendar-day.today .calendar-day-number{background:var(--info);color:var(--surface);font-weight:700;}
.calendar-day-cards{display:flex;flex-direction:column;gap:4px;overflow:auto;min-height:0;}
.calendar-day-cards::-webkit-scrollbar{width:3px;}
.calendar-day-cards::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.calendar-card{display:block;width:100%;min-height:25px;border:1px solid var(--border);border-radius:6px;background:var(--surface2);padding:5px 6px;color:var(--text);font:inherit;font-size:11px;font-weight:550;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;user-select:none;}
.calendar-card:hover,.calendar-card.active{border-color:var(--info);background:var(--info-bg);}
.calendar-loading{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;background:var(--surface);color:var(--text2);font-size:13px;}
.calendar-loading.error{color:var(--danger);}
.calendar-inspector{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:15px;display:flex;flex-direction:column;gap:12px;overflow:auto;user-select:text;}
.calendar-inspector-empty{margin:auto 0;color:var(--text3);font-size:12px;line-height:1.45;text-align:center;}
.calendar-inspector-title{font-size:15px;line-height:1.35;font-weight:650;}
.calendar-inspector-project{font-size:12px;color:var(--text2);}
.calendar-inspector-fields{display:flex;flex-direction:column;gap:7px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:11px 0;}
.calendar-inspector-field{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:12px;}
.calendar-inspector-field span{color:var(--text3);}
.calendar-inspector-field strong{font-weight:550;color:var(--text);text-align:right;}
.calendar-inspector-desc{font-size:12px;color:var(--text2);line-height:1.45;white-space:pre-wrap;}
.calendar-inspector-tags{display:flex;flex-wrap:wrap;gap:5px;}
.calendar-inspector-tags span{border-radius:4px;padding:3px 7px;font-size:11px;font-weight:650;}
.calendar-inspector-actions{display:flex;margin-top:auto;}
.calendar-inspector-actions button{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;}
@media(max-width:820px){
  .modal-box.calendar-box{height:min(840px,calc(100vh - 20px));padding:12px;}
  .calendar-shell{display:flex;flex-direction:column;}
  .calendar-main{min-height:360px;}
  .calendar-inspector{max-height:230px;}
}
.card-comments{display:flex;flex-direction:column;gap:10px;}
.card-comments-list{display:flex;flex-direction:column;gap:9px;max-height:260px;overflow:auto;padding-right:2px;}
.card-comments-empty{font-size:12px;color:var(--text3);padding:8px 0;}
.card-comment{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;}
.card-comment-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:10px;font-weight:700;flex-shrink:0;}
.card-comment-body{min-width:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;}
.card-comment-meta{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:4px;}
.card-comment-meta strong{font-size:12px;color:var(--text);}
.card-comment-meta span{font-size:10px;color:var(--text3);white-space:nowrap;}
.card-comment-text{font-size:12px;color:var(--text2);line-height:1.45;white-space:pre-wrap;user-select:text;}
.card-comment-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:end;}
.card-comment-input{min-height:58px;}
.card-comment-send{width:38px;height:38px;border-radius:var(--radius);border:1px solid var(--info);background:var(--info-bg);color:var(--info);display:flex;align-items:center;justify-content:center;cursor:pointer;}
.card-comment-send:hover{background:var(--info);color:white;}
@media(max-width:720px){.share-shell{grid-template-columns:1fr;}.share-row{grid-template-columns:auto minmax(0,1fr);}.share-role,.share-delete{grid-column:2;}.share-delete{justify-self:start;}}
/* ── Kanban page ── */
#page-kanban{flex:1;display:flex;flex-direction:column;overflow:hidden;}
#kanban-main{display:flex;flex:1;overflow:hidden;}
#board-wrap{flex:1;overflow:hidden;position:relative;display:flex;min-width:0;}
#parent-context{width:0;overflow:hidden;background:var(--surface);border-right:1px solid var(--border);transition:width .2s ease;flex-shrink:0;}
#parent-context.open{width:240px;padding:14px;overflow-y:auto;}
.parent-kicker{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-bottom:10px;}
.parent-card{display:flex;flex-direction:column;gap:8px;}
.parent-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35;}
.parent-desc,.parent-notes{font-size:12px;color:var(--text2);line-height:1.45;white-space:pre-wrap;}
.parent-meta{display:flex;flex-wrap:wrap;gap:5px;}
#board{position:relative;flex:1;min-width:0;display:flex;gap:12px;padding:16px;height:100%;overflow-x:auto;overflow-y:hidden;align-items:flex-start;cursor:grab;}
#board.filtered-board{padding-top:44px;}
#board.simple-board{padding-right:96px;}
#board.simple-board{flex-direction:column;overflow-y:auto;overflow-x:hidden;}
#board.grabbing{cursor:grabbing;user-select:none;}
#board::-webkit-scrollbar{height:5px;}
#board::-webkit-scrollbar-track{background:transparent;}
#board::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
.col{flex-shrink:0;width:220px;background:var(--surface2);border-radius:var(--radius-lg);border:1px solid var(--border);display:flex;flex-direction:column;max-height:100%;overflow:hidden;transition:border-color .12s;user-select:none;}
.col.simple-col{width:min(920px,100%);background:transparent;border:none;border-radius:0;max-height:100%;}
.col.drag-over{border-color:var(--info);background:var(--info-bg);}
.col-head{display:flex;align-items:center;gap:6px;padding:10px 10px 8px;border-bottom:1px solid var(--border);flex-shrink:0;}
.col-title{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text2);cursor:pointer;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.col-title:hover{color:var(--text);}
.col-title-inp{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;background:transparent;border:none;border-bottom:1.5px solid var(--info);outline:none;color:var(--text);width:100%;font-family:inherit;padding:0;}
.col-cnt{font-size:11px;color:var(--text3);flex-shrink:0;}
.col-del,.col-settings,.col-move{font-size:14px;color:var(--text3);cursor:pointer;flex-shrink:0;opacity:0;transition:opacity .12s;}
.col-head:hover .col-del,.col-head:hover .col-settings,.col-head:hover .col-move{opacity:1;}
.col-del:hover{color:var(--danger);}
.col-settings:hover{color:var(--info);}
.col-move:hover{color:var(--text);}
.cards{display:flex;flex-direction:column;gap:8px;padding:8px;overflow-y:auto;flex:1;min-height:32px;}
.cards.simple-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-content:start;gap:10px;padding:0;overflow-y:auto;}
.cards::-webkit-scrollbar{width:3px;}
.cards::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.empty-col{text-align:center;padding:20px 8px;font-size:11px;color:var(--text3);}
.simple-empty{grid-column:1 / -1;}
.filter-notice{position:absolute;left:16px;top:10px;z-index:20;display:inline-flex;align-items:center;gap:6px;max-width:min(520px,calc(100vw - 80px));padding:6px 9px;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--surface) 88%,transparent);box-shadow:0 8px 20px rgba(0,0,0,.06);color:var(--text2);font-size:11px;backdrop-filter:blur(8px);pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.filter-notice i{color:var(--info);font-size:13px;flex-shrink:0;}
.filter-notice span{overflow:hidden;text-overflow:ellipsis;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:11px 10px 8px;cursor:pointer;position:relative;overflow:hidden;transition:border-color .12s,opacity .15s,transform .1s;flex:0 0 auto;user-select:none;}
.card.has-status::before{content:'';position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--status-color),var(--surface));opacity:.75;pointer-events:none;}
.card:hover{border-color:var(--border2);transform:translateY(-1px);}
.card.active{border-color:var(--info);box-shadow:0 0 0 2px var(--info-bg);}
.card.done{opacity:.72;}
.card.dragging{opacity:.3;transform:scale(.97);}
.card.drag-over-card{border-color:var(--info);border-style:dashed;}
.card.reparent-arming{border-color:var(--info);box-shadow:0 0 0 1px var(--info-bg);}
.reparent-progress{display:none;position:absolute;right:9px;bottom:8px;width:18px;height:18px;border:1px solid var(--info);border-radius:999px;overflow:hidden;background:var(--surface);pointer-events:none;}
.reparent-progress::after{content:'';position:absolute;inset:auto 0 0 0;height:100%;background:var(--info);transform:scaleY(0);transform-origin:bottom;animation:reparent-fill .75s linear forwards;}
.card.reparent-arming .reparent-progress{display:block;}
.card.drag-over-child{border-color:var(--info);box-shadow:0 0 0 2px var(--info-bg),inset 0 0 0 1px var(--info);transform:translateY(-1px);}
.card.drag-over-child::after{content:'Attacher comme enfant';position:absolute;right:8px;bottom:7px;background:var(--info);color:var(--surface);border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700;pointer-events:none;}
@keyframes reparent-fill{to{transform:scaleY(1);}}
.card-chevron{position:absolute;top:9px;right:8px;font-size:13px;color:var(--info);opacity:0;transition:opacity .12s;}
.card.has-children .card-chevron{opacity:.55;}
.card.has-children:hover .card-chevron{opacity:1;}
.card.has-children .card-title-row{padding-right:22px;}
.card-title-row{display:flex;align-items:flex-start;gap:7px;min-width:0;}
.card-done{width:14px;height:14px;margin-top:2px;accent-color:var(--info);flex-shrink:0;cursor:pointer;}
.card-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.35;}
.card.done .card-title{text-decoration:line-through;color:var(--text2);}
.card-desc{font-size:11px;color:var(--text2);margin-top:3px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.status-flair{display:inline-flex;align-self:flex-start;margin-top:6px;border-radius:3px;padding:2px 6px;font-size:9px;font-weight:700;line-height:1.2;color:#1a1a18;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.owner-pill{width:19px;height:19px;margin-top:7px;box-shadow:0 0 0 2px var(--surface);}
.tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:6px;}
.tag{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600;}
.card-meta{display:flex;align-items:center;gap:8px;margin-top:5px;}
.card-workload{font-size:10px;color:var(--text3);display:flex;align-items:center;gap:3px;}
.subtask-list{display:flex;flex-direction:column;gap:4px;margin-top:8px;padding-top:7px;border-top:1px solid var(--border);}
.subtask-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text2);line-height:1.25;cursor:default;min-width:0;}
.subtask-item input{width:12px;height:12px;accent-color:var(--info);flex-shrink:0;}
.subtask-item input:disabled{cursor:default;opacity:.75;}
.subtask-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.subtask-item.done span{text-decoration:line-through;color:var(--text3);}
/* Due date badges */
.due{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;}
.due.ok{background:#e1f5ee;color:#085041;}
.due.soon{background:#faeeda;color:#633806;}
.due.late{background:#fcebeb;color:#791f1f;}
@media(prefers-color-scheme:dark){
  .due.ok{background:#0a2e1f;color:#5ecb9e;}
  .due.soon{background:#2e1f00;color:#e8a84a;}
  .due.late{background:#2e0a0a;color:#f09595;}
}
/* Urgency bar on proj-card */
.proj-urgency{display:flex;align-items:center;gap:5px;margin-top:8px;flex-wrap:wrap;}
.proj-urg-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;display:inline-flex;align-items:center;gap:3px;}
.proj-urg-badge.late{background:#fcebeb;color:#791f1f;}
.proj-urg-badge.soon{background:#faeeda;color:#633806;}
@media(prefers-color-scheme:dark){
  .proj-urg-badge.late{background:#2e0a0a;color:#f09595;}
  .proj-urg-badge.soon{background:#2e1f00;color:#e8a84a;}
}
.add-card-btn{display:flex;align-items:center;justify-content:center;gap:6px;margin:4px 8px 10px;padding:9px 10px;font-size:12px;color:var(--text3);cursor:pointer;border-radius:var(--radius);border:1px dashed var(--border);transition:all .12s;flex-shrink:0;}
.add-card-btn:hover{background:var(--surface);color:var(--text2);border-color:var(--border2);}
.simple-add-card{width:100%;margin:0 0 10px;min-height:42px;background:var(--surface);border-color:var(--border2);}
.done-drawer{width:min(920px,100%);border-top:1px solid var(--border);padding-top:12px;margin-top:4px;}
.done-drawer summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;color:var(--text2);font-size:12px;font-weight:600;list-style:none;padding:8px 0;}
.done-drawer summary::-webkit-details-marker{display:none;}
.done-drawer summary span:last-child{font-size:11px;color:var(--text3);font-weight:500;}
.done-cards{padding-top:8px!important;}
.col-new{flex-shrink:0;width:220px;border:1.5px dashed var(--border2);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--text3);cursor:pointer;min-height:60px;align-self:flex-start;transition:all .12s;}
.col-new:hover{border-color:var(--info);color:var(--info);}
.col-head,.col-title,.cards,.subtask-list,.search-result,.my-card-row{user-select:none;}
@media(max-width:900px){
  #projects-main{flex-direction:column;}
  #project-panel,#project-panel.open{width:100%;position:static;max-height:none;}
  .col.simple-col{width:100%;}
  .done-drawer{width:100%;}
  .cards.simple-cards{grid-template-columns:1fr;}
}

/* Panel */
#panel{width:0;overflow:hidden;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transition:width .2s ease;flex-shrink:0;user-select:text;}
#panel.open{width:var(--panel-w);}
.panel-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0;}
.panel-close{font-size:16px;color:var(--text3);cursor:pointer;flex-shrink:0;}
.panel-close:hover{color:var(--text);}
.panel-head-title{font-size:13px;font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.panel-drill-btn{display:none;align-items:center;gap:4px;font-size:11px;color:var(--info);cursor:pointer;padding:4px 8px;border-radius:var(--radius);border:1px solid var(--info);flex-shrink:0;white-space:nowrap;}
.panel-drill-btn:hover{background:var(--info-bg);}
.panel-body{flex:1;overflow-y:auto;padding:14px 14px 24px;display:flex;flex-direction:column;gap:14px;}
.panel-body::-webkit-scrollbar{width:3px;}
.panel-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.p-field{display:flex;flex-direction:column;gap:5px;}
.p-field label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);}
.p-inp{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;font-size:12px;color:var(--text);font-family:inherit;outline:none;resize:vertical;transition:border-color .12s;}
.p-inp:focus{border-color:var(--info);}
.p-check{display:flex!important;align-items:center;gap:8px;font-size:12px;color:var(--text2);font-weight:400!important;letter-spacing:0!important;text-transform:none!important;cursor:pointer;}
.p-check input{width:14px;height:14px;accent-color:var(--info);}
.tag-picker{display:flex;flex-wrap:wrap;gap:5px;}
.tag-opt{font-size:11px;padding:3px 9px;border-radius:4px;cursor:pointer;border:1.5px solid transparent;font-weight:600;}
.tag-opt.sel{border-color:currentColor;}
.panel-tags{display:flex;align-items:center;gap:5px;flex-wrap:wrap;}
.panel-tag{border:1px solid transparent;border-radius:4px;padding:3px 7px;font:inherit;font-size:11px;font-weight:650;cursor:pointer;line-height:1.2;}
.panel-tag:hover{box-shadow:0 0 0 1px currentColor;}
.panel-add-tag-wrap{display:inline-flex;}
.panel-add-tag{display:inline-flex;align-items:center;gap:4px;border:1px dashed var(--border2);background:transparent;color:var(--text2);border-radius:4px;padding:3px 7px;font:inherit;font-size:11px;cursor:pointer;}
.panel-add-tag:hover{color:var(--info);border-color:var(--info);}
.tag-choice-list{display:flex;flex-wrap:wrap;gap:8px;}
.tag-choice{border:1px solid transparent;border-radius:5px;padding:6px 10px;font:inherit;font-size:12px;font-weight:650;cursor:pointer;}
.tag-choice:hover{box-shadow:0 0 0 1px currentColor;}
.panel-del-btn{width:100%;padding:7px;font-size:12px;font-family:inherit;cursor:pointer;background:transparent;color:var(--text2);border:1px solid var(--border);border-radius:var(--radius);transition:all .12s;}
.panel-del-btn:hover{color:var(--danger);border-color:var(--danger);}
.panel-sub-btn{width:100%;padding:7px;font-size:12px;font-family:inherit;cursor:pointer;background:var(--surface2);color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .12s;}
.panel-sub-btn:hover{color:var(--info);border-color:var(--info);}
#search-panel,#filters-panel{position:fixed;right:0;top:46px;bottom:0;width:0;overflow:hidden;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transition:width .2s ease;z-index:220;box-shadow:-12px 0 24px rgba(0,0,0,.08);}
#search-panel.open,#filters-panel.open{width:min(360px,100vw);}
.search-body{flex:1;display:flex;flex-direction:column;gap:12px;padding:14px;overflow:hidden;}
.search-field{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 10px;flex-shrink:0;}
.search-field i{font-size:15px;color:var(--text3);}
.search-field input{flex:1;min-width:0;border:0;background:transparent;outline:none;color:var(--text);font:inherit;font-size:13px;}
.search-results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:2px;}
.search-results::-webkit-scrollbar{width:3px;}
.search-results::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.search-empty{font-size:12px;color:var(--text3);line-height:1.45;padding:10px 2px;}
.search-result{border:1px solid var(--border);background:var(--surface2);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:7px;cursor:pointer;transition:border-color .12s,background .12s;}
.search-result:hover{border-color:var(--info);background:var(--surface);}
.search-result-title{font-size:13px;font-weight:650;color:var(--text);line-height:1.3;}
.search-result-desc{font-size:11px;color:var(--text2);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.search-result-path{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.search-result-actions{display:flex;align-items:center;gap:6px;}
.search-result-actions button{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);border-radius:6px;padding:4px 7px;font-family:inherit;font-size:11px;cursor:pointer;}
.search-result-actions button:hover{color:var(--info);border-color:var(--info);}
.filters-body{flex:1;display:flex;flex-direction:column;gap:14px;padding:14px;overflow-y:auto;}
.filters-body::-webkit-scrollbar{width:3px;}
.filters-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.filter-field{display:flex;flex-direction:column;gap:5px;}
.filter-field label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);}
.filter-field select,.filter-check-with-input input[type="number"]{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 10px;font:inherit;font-size:13px;color:var(--text);outline:none;}
.filter-field select:focus,.filter-check-with-input input[type="number"]:focus{border-color:var(--info);}
.filter-section{display:flex;flex-direction:column;gap:10px;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);}
.filter-check{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);line-height:1.35;}
.filter-check input[type="checkbox"]{width:14px;height:14px;accent-color:var(--info);flex-shrink:0;}
.filter-check-with-input{flex-wrap:wrap;}
.filter-check-with-input input[type="number"]{width:64px;padding:6px 8px;}
.filter-summary{font-size:12px;color:var(--text3);padding-top:2px;}
.filter-actions{display:flex;justify-content:flex-end;margin-top:auto;padding-top:6px;}
.filter-actions button{padding:7px 12px;border:1px solid var(--border2);border-radius:var(--radius);background:transparent;color:var(--text2);font:inherit;font-size:12px;cursor:pointer;}
.filter-actions button:hover:not(:disabled){color:var(--text);background:var(--surface2);}
.filter-actions button:disabled{opacity:.35;cursor:default;}
.history-list{display:flex;flex-direction:column;gap:8px;max-height:min(520px,62vh);overflow-y:auto;padding-right:3px;}
.history-list::-webkit-scrollbar{width:3px;}
.history-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.history-row{display:flex;gap:10px;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);}
.history-avatar{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:750;flex-shrink:0;}
.history-body{min-width:0;display:flex;flex-direction:column;gap:4px;}
.history-title{font-size:12px;color:var(--text);line-height:1.35;}
.history-target{color:var(--text2);}
.history-meta{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* Ctx */
#ctx{position:fixed;z-index:9999;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:4px 0;min-width:190px;box-shadow:0 4px 16px rgba(0,0,0,.1);display:none;}
.ctx-item{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:12px;color:var(--text);cursor:pointer;transition:background .1s;}
.ctx-item:hover{background:var(--surface2);}
.ctx-item i{font-size:14px;color:var(--text2);}
.ctx-item.dis{opacity:.35;pointer-events:none;}
.ctx-item.danger{color:var(--danger);}
.ctx-item.danger i{color:var(--danger);}
.ctx-sep{height:1px;background:var(--border);margin:3px 0;}

/* Tree view */
#tree-inner{position:relative;padding:0!important;overflow:hidden!important;}
.tree-toolbar-title{font-size:14px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:7px;}
.tree-toolbar-title i{font-size:16px;color:var(--text2);}
.tree-depth-indicator{font-size:11px;color:var(--text3);margin-left:auto;}
.tree-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text2);}
.tree-legend-item span{width:12px;height:12px;border-radius:4px;display:inline-block;flex-shrink:0;border:1px solid var(--border2);background:var(--surface);}
.tree-legend-root{border-color:var(--text)!important;}
.tree-legend-card{background:var(--surface)!important;}
.tree-legend-status{border:0!important;background:linear-gradient(90deg,#f5c451,var(--surface))!important;}
.tree-legend-count{border-radius:999px!important;background:var(--info)!important;border-color:var(--info)!important;}
.tree-empty{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:13px;}
.tree-viewport{position:relative;width:100%;height:100%;overflow:hidden;cursor:grab;background:radial-gradient(circle at center,rgba(55,138,221,.06),transparent 28%),var(--bg);user-select:none;}
.tree-viewport.dragging{cursor:grabbing;}
.tree-stage{position:absolute;left:0;top:0;width:1px;height:1px;transform-origin:0 0;transition:transform .08s ease-out;}
.tree-stage.tree-camera-animating{transition:transform .74s cubic-bezier(.18,.9,.2,1);}
.tree-nodes,.tree-edges{position:absolute;left:0;top:0;width:1px;height:1px;overflow:visible;}
.tree-edge{position:absolute;height:1px;background:var(--border2);transform-origin:0 50%;opacity:.8;transition:opacity .22s,background .22s;}
.tree-node{position:absolute;user-select:none;transition:opacity .18s ease,border-color .12s;background:var(--surface);border:1px solid var(--border);}
#tree-panel{user-select:text;}
.tree-root-node{width:210px;height:96px;border-radius:10px;border-color:var(--text);padding:15px 16px;display:flex;flex-direction:column;justify-content:center;gap:4px;z-index:2;position:absolute;overflow:hidden;}
.tree-focus-node{width:250px;height:112px;border-radius:18px;}
.tree-focus-card{border-color:var(--info);}
.tree-focus-card .tree-status-flair{display:block;}
.tree-focus-growing{transform-origin:center center;transition:transform .74s cubic-bezier(.18,.9,.2,1),box-shadow .3s ease;}
.tree-child-settling{transform-origin:center center;transition:transform .74s cubic-bezier(.18,.9,.2,1),border-color .3s ease;}
.tree-child-settling .tree-card-desc{opacity:.25;transition:opacity .28s ease;}
.tree-root-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:700;}
.tree-root-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tree-root-meta{font-size:11px;color:var(--text2);}
.tree-card-node{width:142px;min-height:62px;border-radius:var(--radius-lg);padding:13px 16px 9px;overflow:hidden;cursor:pointer;position:absolute;}
.tree-focus-child{width:150px;min-height:68px;display:flex;flex-direction:column;justify-content:center;transition:width .18s ease,min-height .18s ease,border-radius .18s ease,border-color .12s;}
.tree-card-node:hover{border-color:var(--info);box-shadow:0 0 0 2px var(--info-bg);}
.tree-status-flair{position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--tree-status-color),var(--surface));opacity:.8;border-radius:inherit;border-bottom-left-radius:0;border-bottom-right-radius:0;max-width:100%;pointer-events:none;}
.tree-card-title{font-size:11px;font-weight:650;color:var(--text);line-height:1.25;padding-right:20px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.tree-card-desc{font-size:10px;color:var(--text2);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tree-child-count{position:absolute;right:8px;top:7px;min-width:18px;height:18px;border-radius:999px;background:var(--info);color:var(--surface);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;padding:0 5px;box-shadow:0 0 0 2px var(--surface);z-index:4;}
.tree-panel-summary{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 10px;}
.tree-panel-status{width:10px;height:10px;border-radius:999px;border:1px solid var(--border2);flex-shrink:0;}
.tree-more-node{width:136px;height:54px;border-radius:var(--radius-lg);background:var(--surface2);border-style:dashed;color:var(--text2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;}
.tree-more-node strong{font-size:15px;color:var(--text);}
.tree-more-node span{font-size:10px;color:var(--text3);}
.focus-edge{opacity:.65;}
.tree-mini-node{width:68px;height:26px;border-radius:7px;background:var(--surface);border-color:var(--border2);display:flex;align-items:center;justify-content:center;padding:0 8px;font-size:8px;font-weight:700;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;}
.tree-mini-node::before{content:'';position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--tree-status-color),var(--surface));opacity:.75;border-radius:7px 7px 0 0;}
.tree-mini-node:hover{border-color:var(--info);color:var(--info);}
.tree-ancestor-node{width:150px;height:34px;border-radius:999px;background:var(--surface2);border-color:var(--border2);display:flex;align-items:center;padding:0 12px;font-size:10px;font-weight:650;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;z-index:3;}
.tree-ancestor-node:hover{border-color:var(--info);color:var(--info);background:var(--info-bg);}

.level-in{animation:fIn .18s ease-out;}
@keyframes fIn{from{opacity:0;transform:translateX(6px);}to{opacity:1;transform:translateX(0);}}
.page-in{animation:pgIn .2s ease-out;}
@keyframes pgIn{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);}}



