/* ── RESET ── */
*{margin:0;padding:0;box-sizing:border-box}

/* ── DESIGN TOKENS ── */
:root{
  --bg-base:#F5F6FA;
  --bg-surface:#FFFFFF;
  --bg-elevated:#F9FAFB;
  --bg-card:#FFFFFF;
  --bg-hover:#F0F4F9;
  --border:#E5E7EB;
  --border-light:#E4E8F0;
  --text-primary:#111827;
  --text-secondary:#6B7280;
  --text-muted:#9CA3AF;
  --blue:#197AC6;
  --blue-dim:rgba(25,122,198,0.10);
  --blue-mid:rgba(25,122,198,0.20);
  --blue-glow:rgba(25,122,198,0.06);
  --accent:#F5A300;
  --accent-dim:rgba(245,163,0,0.10);
  --accent-mid:rgba(245,163,0,0.20);
  --high:#DC2626;
  --high-dim:rgba(220,38,38,0.10);
  --medium:#F97316;
  --medium-dim:rgba(249,115,22,0.10);
  --low:#059669;
  --low-dim:rgba(5,150,105,0.10);
  --sidebar-w:264px;
  --row-logo-h:88px;  /* logo block / greeting row — top horizontal line */
  --row-user-h:68px;  /* profile block / stats row — second horizontal line */
  --radius:10px;
  --radius-lg:14px;
  --radius-sm:6px;
  --font-num:'Figtree',sans-serif;
  --shadow-sm:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 4px 12px rgba(0,0,0,0.10),0 2px 4px rgba(0,0,0,0.05);
  --shadow-lg:0 20px 60px rgba(0,0,0,0.14),0 4px 16px rgba(0,0,0,0.06);
}

html,body{height:100%;font-family:'Figtree',sans-serif;background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.5}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#9CA3AF}

/* ── LOGIN ── */
#login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);position:relative;overflow:hidden}
#login-page::before{content:'';position:absolute;width:700px;height:700px;background:radial-gradient(circle,rgba(25,122,198,0.07) 0%,transparent 65%);top:-150px;right:-150px;pointer-events:none}
#login-page::after{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(245,163,0,0.05) 0%,transparent 65%);bottom:-80px;left:-80px;pointer-events:none}
.login-box{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:44px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:var(--shadow-lg)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo-img{max-width:140px;height:auto;margin-bottom:10px}
.wordmark{display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.brand-logo-svg{color:#111827}
.tagline{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}
.login-title{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px}
.login-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:24px}
.login-error{display:none;background:var(--high-dim);border:1px solid rgba(220,38,38,0.2);color:var(--high);font-size:12px;font-weight:500;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:16px}

/* ── DEMO CHIPS ── */
.demo-box{margin-top:20px;border-top:1px solid var(--border);padding-top:16px}
.demo-box-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.demo-chip{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;transition:all .15s}
.demo-chip:hover{border-color:var(--blue);background:var(--blue-dim)}
.demo-chip-name{font-size:12px;font-weight:600;color:var(--text-primary)}
.demo-chip-role{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:1px}

/* ── APP SHELL ── */
#app{display:none;height:100vh;overflow:hidden}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:#fff;border-right:1px solid var(--border-light);display:flex;flex-direction:column;height:100vh;overflow-y:auto;position:relative}
.main-content{flex:1;overflow-y:auto;min-width:0}

/* ── SIDEBAR HEADER ── */
.sidebar-header{height:var(--row-logo-h);padding:0 20px;display:flex;align-items:center;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-logo-wrap{display:flex;align-items:center;gap:10px}
.sidebar-logo-img{width:36px;height:36px;border-radius:8px;object-fit:cover}
.sidebar-logo-text{min-width:0}
.sidebar-logo{line-height:1}
.sidebar-logo .brand-logo-svg{color:var(--text-primary)}
.sidebar-logo-sub{font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}

/* ── SIDEBAR USER ── */
.sidebar-user{height:var(--row-user-h);padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}
.sb-av-wrap{position:relative;flex-shrink:0}
.sb-av-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.35);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;color:#fff}
.sb-av-wrap:hover .sb-av-overlay{opacity:1}
.user-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;letter-spacing:.02em;flex-shrink:0;overflow:hidden}
.user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.has-tip{position:relative;overflow:visible}
.has-tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%) scale(.96);transform-origin:bottom center;background:#1f2937;color:#fff;font-size:11px;font-weight:600;letter-spacing:.01em;line-height:1;white-space:nowrap;padding:6px 9px;border-radius:6px;box-shadow:0 4px 14px rgba(0,0,0,.18);opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:9999}
.has-tip::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1f2937;opacity:0;pointer-events:none;transition:opacity .12s ease;z-index:9999}
.has-tip:hover::after{opacity:1;transform:translateX(-50%) scale(1)}
.has-tip:hover::before{opacity:1}
.mycolor-swatch{width:36px;height:36px;border-radius:50%;border:3px solid transparent;cursor:pointer;padding:0;transition:transform .1s ease,box-shadow .1s ease}
.mycolor-swatch:hover{transform:scale(1.08)}
.mycolor-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--text-primary)}
.sb-presence-dot{position:absolute;bottom:1px;right:1px;width:9px;height:9px;border-radius:50%;border:2px solid #fff;background:#22c55e}
.user-info{min-width:0;flex:1}
.user-name{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:1px}

/* ── SIDEBAR NAV ── */
.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-section-label{font-size:9px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;padding:8px 8px 4px;margin-top:4px}
.nav-section-label:first-child{margin-top:0}
.nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s;user-select:none}
.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}
.nav-item.active{background:var(--blue-dim);color:var(--blue);font-weight:600}
.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.7}
.nav-item.active .nav-icon{opacity:1}
.nav-badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border);padding:1px 6px;border-radius:9999px;font-family:var(--font-num);flex-shrink:0}
.nav-badge-unread{background:var(--blue-dim);color:var(--blue);border-color:var(--blue-mid)}

/* ── SIDEBAR ACTION BUTTONS ── */
.sb-action-btns{display:flex;flex-direction:column;gap:8px;padding:10px 0 4px}
.sb-nav-items{flex:1}
.sb-log-time-btn{display:flex;align-items:center;gap:8px;margin:0 10px;padding:9px 14px;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);font-family:'Figtree',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;letter-spacing:.01em;width:calc(100% - 20px)}
.sb-log-time-btn:hover{background:#1568AA}
.sb-log-time-btn svg{flex-shrink:0}
.sb-new-task-btn{display:flex;align-items:center;gap:8px;margin:0 10px;padding:7px 14px;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius);font-family:'Figtree',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;width:calc(100% - 20px)}
.sb-new-task-btn:hover{background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}
.sb-new-task-btn svg{flex-shrink:0}

/* ── SIDEBAR FOOTER ── */
.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}
.sidebar-clock{margin-bottom:10px}
.sidebar-clock-time{font-size:28px;font-weight:700;font-family:var(--font-num);color:var(--text-primary);line-height:1.1;letter-spacing:-.01em}
.sidebar-clock-date{font-size:12px;color:var(--text-secondary);margin-top:2px;font-weight:500}
.logout-btn{display:flex;align-items:center;gap:8px;padding:7px 12px;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-family:'Figtree',sans-serif;font-size:13px;font-weight:500;width:100%;transition:all .2s}
.logout-btn:hover{border-color:rgba(220,38,38,0.3);color:#DC2626;background:rgba(220,38,38,0.05)}

/* ── PRESENCE ── */
.presence-dot{display:inline-block;width:8px;height:8px;border-radius:50%;border:2px solid #fff;background:#9CA3AF;flex-shrink:0}
.presence-dot.online{background:#22c55e}
.presence-dot.offline{background:#9CA3AF}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-group:last-child{margin-bottom:0}
.form-label{font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.01em}
.form-input,.form-select,.form-textarea{width:100%;background:#F3F4F6;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;font-family:'Figtree',sans-serif;font-size:13px;color:var(--text-primary);outline:none;transition:border-color .2s,background .2s,box-shadow .2s;appearance:none;-webkit-appearance:none}
.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;background-color:#F3F4F6}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px var(--blue-dim)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-textarea{resize:vertical;min-height:80px;line-height:1.5}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.assignee-grid{display:flex;flex-wrap:wrap;gap:6px}
.assignee-chip{display:flex;align-items:center;gap:6px;padding:5px 10px 5px 6px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg-elevated);cursor:pointer;transition:all .15s;user-select:none}
.assignee-chip:hover{border-color:var(--blue);background:var(--blue-dim)}
.assignee-chip.selected{border-color:var(--blue);background:var(--blue-dim)}
.assignee-chip-name{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 20px;height:40px;border-radius:9999px;font-family:'Figtree',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;letter-spacing:.01em;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:#1568AA}
.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}
.btn-danger{background:var(--high-dim);color:var(--high);border:1px solid rgba(220,38,38,0.2)}
.btn-danger:hover{background:var(--high);color:#fff}
.btn-sm{height:34px;padding:0 14px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s;flex-shrink:0}
.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(17,24,39,0.45);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:var(--radius-lg);max-width:540px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border);animation:modalSlideUp .2s ease}
@keyframes modalSlideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#197AC6;flex-shrink:0}
.modal-title{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.01em}
.modal-close{background:rgba(255,255,255,0.15);border:none;cursor:pointer;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;transition:background .15s;flex-shrink:0}
.modal-close:hover{background:rgba(255,255,255,0.3)}
.modal-body{padding:20px;overflow-y:auto;flex:1;background:#fff}
.modal-footer{padding:14px 20px;display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0;background:#197AC6}
.modal-footer .btn-secondary{background:rgba(255,255,255,0.15);color:#fff;border-color:rgba(255,255,255,0.3)}
.modal-footer .btn-secondary:hover{background:rgba(255,255,255,0.25)}
.modal-footer .btn-danger{background:rgba(220,38,38,0.3);color:#fff;border-color:rgba(220,38,38,0.4)}
.modal-footer .btn-danger:hover{background:rgba(220,38,38,0.5)}
.modal-footer .btn-primary{background:#fff;color:#197AC6}
.modal-footer .btn-primary:hover{background:#F0F4F9;color:#1568AA}

/* ── PAGE STRUCTURE ── */
.page-header{height:var(--row-logo-h);display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid var(--border);gap:16px;flex-wrap:wrap;background:#fff;flex-shrink:0}
.page-title{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}
.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}
.header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.content-area{padding:24px 28px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}

/* ── TASKS HERO ── */
.tasks-hero{padding:0 28px;background:#fff}
.tasks-hero-top{height:var(--row-logo-h);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.tasks-greeting{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.tasks-name{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1.1}
.tasks-name em{font-style:normal;color:var(--text-muted);font-weight:400}
.tasks-hero-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border:2px solid;flex-shrink:0;overflow:hidden}
.tasks-hero-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.stat-row-v2{display:grid;grid-template-columns:repeat(4,1fr);gap:0;height:var(--row-user-h);border-bottom:1px solid var(--border)}

/* ── STAT CARDS ── */
.stat-v2{padding:0 20px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--border);min-width:0}
.stat-v2:last-child{border-right:none}
.stat-v2-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.stat-v2-num{font-size:24px;font-weight:800;font-family:var(--font-num);line-height:1;margin-bottom:1px}
.s-blue .stat-v2-num{color:var(--blue)}
.s-red .stat-v2-num{color:var(--high)}
.s-amber .stat-v2-num{color:var(--accent)}
.s-green .stat-v2-num{color:var(--low)}
.stat-v2-sub{font-size:10px;color:var(--text-muted)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;height:var(--row-user-h);border-bottom:1px solid var(--border)}
.stat-card{background:#fff;padding:0 20px;display:flex;flex-direction:column;justify-content:center;position:relative;border-right:1px solid var(--border);min-width:0}
.stat-card:last-child{border-right:none}
.stat-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.stat-value{font-size:24px;font-weight:800;font-family:var(--font-num);line-height:1;color:var(--text-primary);margin-bottom:1px}
.stat-sub{font-size:10px;color:var(--text-muted)}
.stat-accent{display:none}

/* ── VIEW CONTROLS ── */
.view-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.view-toggle{display:flex;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden}
.view-btn{padding:6px 14px;font-family:'Figtree',sans-serif;font-size:12px;font-weight:600;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .13s}
.view-btn:hover{color:var(--text-primary);background:var(--bg-hover)}
.view-btn.active{background:#fff;color:var(--blue);box-shadow:var(--shadow-sm)}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap}
.filter-select{padding:5px 28px 5px 10px;background:#F3F4F6;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:'Figtree',sans-serif;font-size:12px;color:var(--text-secondary);cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-color:#F3F4F6;transition:border-color .15s}
.filter-select:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px var(--blue-dim)}

/* ── TASK LIST ── */
.task-list-v2{display:flex;flex-direction:column;gap:2px}
.task-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .15s;position:relative}
.task-item:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm)}
.task-item.status-done{opacity:.65}
.task-item-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-light);flex-shrink:0;margin-top:2px;transition:all .15s;cursor:pointer}
.task-item-check:hover{border-color:var(--blue)}
.task-item-check.checked{background:var(--low);border-color:var(--low)}
.task-item-check.checked::after{content:'';display:block;width:6px;height:3px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translate(3px,2px)}
.task-item-body{flex:1;min-width:0}
.task-item-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.35}
.task-item-desc{font-size:12px;color:var(--text-muted);margin-top:3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.task-item-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-top:6px}
.task-item-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}
.task-list{display:flex;flex-direction:column;gap:6px}
.task-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;gap:10px;align-items:flex-start;transition:all .15s;box-shadow:var(--shadow-sm)}
.task-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}
.task-check{width:16px;height:16px;border-radius:50%;border:2px solid var(--border-light);flex-shrink:0;margin-top:2px;cursor:pointer;transition:all .15s}
.task-check:hover{border-color:var(--blue)}
.task-check.checked{background:var(--low);border-color:var(--low)}
.task-main{flex:1;min-width:0;cursor:pointer}
.task-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.35;margin-bottom:3px}
.task-desc{font-size:11px;color:var(--text-muted);line-height:1.4;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.task-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.task-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 7px;border-radius:9999px;white-space:nowrap;letter-spacing:.02em}
.badge-priority-high{background:var(--high-dim);color:var(--high)}
.badge-priority-medium{background:var(--medium-dim);color:var(--medium)}
.badge-priority-low{background:var(--low-dim);color:var(--low)}
.badge-status-todo{background:#F3F4F6;color:#6B7280}
.badge-status-inprogress{background:rgba(25,122,198,0.10);color:#197AC6}
.badge-status-inreview{background:rgba(124,58,237,0.10);color:#7C3AED}
.badge-status-done{background:rgba(5,150,105,0.10);color:#059669}
.badge-client{background:var(--accent-dim);color:var(--accent)}
.badge-age-fresh{background:rgba(5,150,105,0.09);color:#059669}
.badge-age-recent{background:rgba(25,122,198,0.09);color:#197AC6}
.badge-age-aging{background:rgba(245,163,0,0.10);color:var(--accent)}
.badge-age-old{background:var(--high-dim);color:var(--high)}
.badge-due-overdue{background:var(--high-dim);color:var(--high)}
.badge-due-soon{background:rgba(245,163,0,0.10);color:var(--accent)}
.badge-due-ok{background:#F3F4F6;color:var(--text-muted)}
.avatar-stack{display:flex;margin-left:2px}
.avatar-stack .user-avatar{width:18px;height:18px;font-size:8px;margin-left:-5px;border:1px solid #fff}

/* ── KANBAN (4 columns) ── */
.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:start;padding:2px 2px 16px}
.kanban-col{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s}
.kanban-col.drag-over{border-color:var(--blue);background:var(--blue-dim)}
.kanban-col-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);background:#fff}
.kanban-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.kanban-col-count{font-size:11px;font-weight:700;font-family:var(--font-num);color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);padding:1px 7px;border-radius:9999px}
.kanban-col-body{padding:10px 8px;display:flex;flex-direction:column;gap:6px;min-height:60px}
.kanban-task{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;cursor:grab;transition:all .15s;user-select:none;box-shadow:var(--shadow-sm)}
.kanban-task:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}
.kanban-task.dragging{opacity:.4;border-style:dashed}
.kanban-task-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.35;margin-bottom:5px}
.kanban-task-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.kanban-empty-hint{border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;color:var(--text-muted);font-size:12px}

/* ── TEAM GRID ── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.team-member-col{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.team-member-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);background:#fff}
.team-member-info{flex:1;min-width:0}
.team-member-name{font-size:13px;font-weight:700;color:var(--text-primary)}
.team-member-stats{font-size:11px;color:var(--text-muted);margin-top:1px}
.team-member-tasks{padding:8px}
.team-task-card{background:#F9FAFB;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:5px;cursor:pointer;transition:all .15s}
.team-task-card:hover{border-color:var(--border-light);background:#fff}
.team-task-card.status-done{opacity:.6}
.team-task-title{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.3}
.team-task-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:5px}

/* ── JOB BAGS ── */
.jb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:22px 28px}
.jb-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.jb-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#2381A9,#269CCD)}
.jb-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.jb-card-client{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.jb-card-name{font-size:16px;font-weight:800;letter-spacing:-.01em;color:var(--text-primary);margin-bottom:8px}
.jb-card-desc{font-size:12px;color:var(--text-secondary);margin-bottom:12px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.jb-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}
.jb-card-stats{display:flex;gap:12px;margin-bottom:12px}
.jb-card-stat{font-size:11px;color:var(--text-muted)}
.jb-card-stat strong{color:var(--text-secondary);font-size:13px;display:block}

/* ── CLIENTS ── */
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:22px 28px}
.client-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:all .2s;box-shadow:var(--shadow-sm)}
.client-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}
.client-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.client-card-icon{width:40px;height:40px;border-radius:10px;background:var(--blue-dim);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--blue)}
.client-card-kebab-wrap{display:flex;gap:2px;opacity:0;transition:opacity .15s}
.client-card:hover .client-card-kebab-wrap{opacity:1}
.client-card-name{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:8px}
.client-card-contact{font-size:12px;color:var(--text-muted);margin-bottom:10px}
.client-card-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-secondary);margin-bottom:5px;min-width:0}
.client-card-row a{color:var(--blue);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-card-row a:hover{text-decoration:underline}
.cli-ico{color:var(--text-muted);flex-shrink:0;display:inline-flex}
.client-card-notes{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-top:8px;padding:8px 10px;background:#F9FAFB;border:1px solid var(--border);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word}
.client-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);flex-wrap:wrap}
.client-card-jbs{font-size:11px;color:var(--text-secondary)}
.client-card-cta{display:flex;gap:6px;flex-wrap:wrap}
.client-card-actions{display:flex;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* ── USERS PAGE ── */
.users-grid{display:flex;flex-direction:column;gap:6px}
.user-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px;transition:all .15s;box-shadow:var(--shadow-sm)}
.user-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}
.user-card-info{flex:1;min-width:0}
.user-card-name{font-size:14px;font-weight:700;color:var(--text-primary)}
.user-card-username{font-size:12px;color:var(--text-muted);margin-top:1px}
.user-card-tasks{font-size:22px;font-weight:800;font-family:var(--font-num);color:var(--text-primary)}
.user-card-tasks-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.role-badge{display:inline-block;font-size:9px;font-weight:800;padding:2px 8px;border-radius:9999px;text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.role-admin{background:rgba(245,163,0,0.12);color:var(--accent)}
.role-member{background:var(--blue-dim);color:var(--blue)}

/* ── JOB BAG DETAIL ── */
.jb-detail-header{padding:22px 28px 0;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}
.jb-detail-breadcrumb{font-size:12px;color:var(--text-muted);margin-bottom:8px;display:flex;align-items:center;gap:6px;cursor:pointer}
.jb-detail-breadcrumb:hover span{color:var(--blue)}
.jb-detail-title{font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:4px}
.jb-detail-client{font-size:12px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.jb-detail-meta{display:flex;align-items:center;gap:12px;margin-bottom:0;flex-wrap:wrap}
.jb-billing-refs{display:flex;align-items:center;gap:6px;margin-top:10px;flex-wrap:wrap}
.jb-ref-chip{display:inline-flex;align-items:center;gap:5px;background:#F9FAFB;border:1px solid var(--border);border-radius:6px;padding:3px 10px 3px 6px;font-size:11px}
.jb-ref-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:#F3F4F6;border-radius:3px;padding:1px 5px}
.jb-ref-val{font-family:var(--font-num);font-weight:600;color:var(--text-primary);font-size:12px}
.jb-tabs{display:flex;gap:0;margin-top:16px}
.jb-tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px}
.jb-tab:hover{color:var(--text-primary)}
.jb-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.jb-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;background:var(--bg-hover);color:var(--text-secondary);border-radius:9999px;margin-left:4px;font-family:var(--font-num)}
.jb-tab.active .jb-tab-count{background:var(--blue-dim);color:var(--blue)}
.jb-tab-content{padding:24px 28px}

/* ── JOB BAG FILES LIST ── */
.jbf-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.jbf-row{display:flex;align-items:center;gap:14px;padding:12px 14px;border-bottom:1px solid var(--border);transition:background .12s}
.jbf-row:last-child{border-bottom:none}
.jbf-row:hover{background:var(--bg-hover)}
.jbf-thumb{width:44px;height:44px;border-radius:8px;flex-shrink:0;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer}
.jbf-thumb img{width:100%;height:100%;object-fit:cover}
.jbf-ext{font-size:10px;font-weight:800;color:var(--blue);letter-spacing:.03em}
.jbf-info{flex:1;min-width:0;cursor:pointer}
.jbf-name{font-size:13.5px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jbf-name:hover{color:var(--blue)}
.jbf-meta{font-size:11.5px;color:var(--text-muted);margin-top:2px;font-family:var(--font-num)}
.jbf-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
.jbf-del:hover{color:#DC2626;background:rgba(220,38,38,.08)}

/* ── TASK ACTION MENU ── */
.task-action-menu{position:absolute;right:0;top:32px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);min-width:140px;z-index:200;padding:4px;animation:fadeIn .12s ease}
@keyframes fadeIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
.tam-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .12s}
.tam-item:hover{background:var(--bg-hover)}
.tam-danger{color:var(--high)}
.tam-danger:hover{background:var(--high-dim)}
.tam-sep{height:1px;background:var(--border);margin:3px 6px}

/* ── JOB BAG PROGRESS ── */
.jb-progress-wrap{background:#F9FAFB;border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:16px}
.jb-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.jb-progress-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}
.jb-progress-stats{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--text-secondary)}
.jb-progress-track{height:8px;background:var(--border);border-radius:100px;overflow:hidden}
.jb-progress-fill{height:100%;border-radius:100px;transition:width .5s ease}

/* ── TIMESHEET ── */
.ts-table{width:100%;border-collapse:collapse;font-size:13px}
.ts-table th{text-align:left;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:8px 12px;border-bottom:1px solid var(--border);white-space:nowrap;background:#F9FAFB}
.ts-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.ts-table tr:last-child td{border-bottom:none}
.ts-task-row td{background:#fff}
.ts-task-row:hover td{background:var(--bg-hover)!important}
.ts-log-row td{background:#F9FAFB}
.ts-log-row:hover td{background:#ECEDF0!important}
.btn-log{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--blue-dim);border:1px solid var(--blue-mid);color:var(--blue);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;letter-spacing:.03em}
.btn-log:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.ts-table .ts-task-title{color:var(--text-primary);font-weight:500}
.ts-table .ts-hours{font-family:var(--font-num);color:var(--blue);font-weight:600}
.ts-table .ts-billable{font-family:var(--font-num);color:var(--text-muted);font-size:11px}
.ts-summary{display:flex;gap:16px;padding:16px;background:#F9FAFB;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;flex-wrap:wrap}
.ts-summary-item{flex:1;min-width:80px}
.ts-summary-val{font-size:20px;font-weight:700;font-family:var(--font-num);color:var(--text-primary)}
.ts-summary-lbl{font-size:11px;color:var(--text-muted)}

/* ── TIMESHEET — grouped task blocks ── */
.tsv-wrap{display:flex;flex-direction:column;gap:18px}
.tsv-block{border:1px solid var(--border);border-radius:10px;overflow:visible;background:#fff;box-shadow:var(--shadow-sm)}
.tsv-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 96px 86px 86px 92px 70px 150px;
  align-items:center;column-gap:8px;
  padding:10px 16px;
}
.tsv-head{
  background:#EAEBEE;border-radius:10px 10px 0 0;
  font-size:10px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.08em;padding:9px 16px;
}
.tsv-head .tsv-c,.tsv-head .tsv-c-task{justify-self:center;text-align:center}
.tsv-head .tsv-c-task{justify-self:start;text-align:left}
.tsv-c{justify-self:center;text-align:center;min-width:0}
.tsv-c-task{justify-self:start;min-width:0;width:100%}
.tsv-task-row{border-top:1px solid var(--border);background:#fff}
.tsv-task-title{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.45;word-break:break-word;cursor:pointer}
.tsv-task-title:hover{color:var(--blue)}
.tsv-task-ctx{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);margin-top:4px}
.tsv-task-ctx svg{flex-shrink:0;opacity:.7}
.tsv-task-ctx em{font-style:italic;opacity:.8}
.tsv-prio{font-size:9px;margin-top:6px;display:inline-block;text-transform:capitalize}
.tsv-done{opacity:.62}
.tsv-done .tsv-task-title{text-decoration:line-through;text-decoration-color:var(--text-muted)}
.tsv-num{font-family:var(--font-num);font-weight:700;font-size:14px;color:var(--text-primary);white-space:nowrap}
.tsv-status-ico{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto}
.tsv-tm{display:flex;gap:3px;justify-content:center;align-items:center;flex-wrap:wrap}
.tsv-invoice{position:relative;display:flex;align-items:center;justify-content:center;gap:4px}
.tsv-invoice-ref{font-family:var(--font-num);font-weight:600;font-size:13px;color:var(--text-primary);white-space:nowrap}
.tsv-action{position:relative;display:flex;align-items:center;justify-content:center;gap:6px}
.tsv-edit-btn{width:30px;height:30px;border:1px solid var(--border);background:#fff;color:var(--text-secondary);border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
.tsv-edit-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}
.tsv-log-btn{display:flex;align-items:center;gap:5px;height:30px;padding:0 12px;border:1px solid var(--border);background:#fff;color:var(--text-secondary);border-radius:7px;font-family:inherit;font-size:11px;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:all .12s;flex-shrink:0}
.tsv-log-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.tsv-log-btn svg{flex-shrink:0}
.tam-active{font-weight:700;color:var(--blue)}
.tsv-dash{color:var(--text-muted)}
.tsv-kebab{width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:all .12s}
.tsv-task-row:hover .tsv-kebab,.tsv-log-row:hover .tsv-kebab{opacity:1}
.tsv-kebab:hover{background:var(--bg-hover);color:var(--text-primary)}
.tsv-log-row{border-top:1px solid #EEF0F2;background:#FAFCEB}
.tsv-log-row:hover{background:#F4F8DC}
.tsv-log-row:last-child{border-radius:0 0 10px 10px}
.tsv-log-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;word-break:break-word}
.tsv-date{font-family:var(--font-num);font-size:13px;color:var(--text-secondary);white-space:nowrap}
.tsv-log-row .tsv-num{font-weight:600}
.tsv-log-empty{border-top:1px solid #EEF0F2;background:#FAFCEB;border-radius:0 0 10px 10px}
.tsv-log-empty .tsv-c-task{font-size:12px;color:var(--text-muted)}
.tsv-loglink{color:var(--blue);font-weight:600;cursor:pointer}
.tsv-loglink:hover{text-decoration:underline}
@media(max-width:880px){
  .tsv-wrap{overflow-x:auto}
  .tsv-block{min-width:760px}
}
.copy-cell{transition:background .15s;border-radius:4px;padding:2px 4px;cursor:pointer}
.copy-cell:hover{background:var(--bg-hover)}
.exp-wrap{cursor:pointer;border-radius:5px;padding:3px 5px;transition:background .15s}
.exp-wrap:hover{background:var(--bg-hover)}
.exp-txt{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:12px;color:var(--text-secondary);line-height:1.55;word-break:break-word}
.exp-bar{display:none;align-items:center;margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}
.exp-copy-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--blue-dim);border:1px solid var(--blue-mid);color:var(--blue);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}
.exp-copy-btn:hover{background:var(--blue);color:#fff}
.exp-wrap.exp-open .exp-txt{-webkit-line-clamp:unset;overflow:visible;display:block}

/* ── JOB BAG TASK CARDS ── */
.jb-task-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;transition:border-color .15s;box-shadow:var(--shadow-sm)}
.jb-task-card:hover{border-color:var(--blue-mid)}
.jb-task-card.is-done{opacity:.65}
.jb-task-card.drag-over-task{border-color:var(--blue);background:var(--blue-dim)}
.jb-task-card.dragging{opacity:.4;border-style:dashed}
.jb-task-card-head{display:flex;align-items:center;gap:10px;padding:12px 14px 10px;cursor:pointer}
.jb-drag-handle{flex-shrink:0;color:var(--text-muted);cursor:grab;padding:2px 0;opacity:.4;transition:opacity .15s}
.jb-drag-handle:hover,.jb-task-card-head:hover .jb-drag-handle{opacity:.8}
.jb-task-title{font-size:13px;font-weight:600;color:var(--text-primary);flex:1;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jb-task-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap;padding:0 14px 6px 38px}
.jb-task-progress{padding:0 14px 10px 38px}
.jb-task-progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:5px}
.jb-task-progress-fill{height:100%;border-radius:2px;transition:width .3s}
.jb-task-progress-label{font-size:10px;color:var(--text-muted);font-family:var(--font-num);display:flex;justify-content:space-between;margin-top:3px}
.jb-log-entries{border-top:1px solid var(--border);background:#F9FAFB}
.jb-log-row{display:grid;grid-template-columns:1fr auto auto auto auto;align-items:center;gap:10px;padding:8px 14px 8px 38px;border-bottom:1px solid var(--border);font-size:12px}
.jb-log-row:last-child{border-bottom:none}
.jb-log-who{display:flex;align-items:center;gap:5px;color:var(--text-secondary);min-width:0}
.jb-log-notes{color:var(--text-muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.jb-log-date{color:var(--text-muted);font-family:var(--font-num);font-size:10px;white-space:nowrap}
.jb-log-h{font-family:var(--font-num);font-weight:600;font-size:12px;white-space:nowrap}
.jb-log-actions{display:flex;gap:2px;flex-shrink:0}
.btn-log-time{display:inline-flex;align-items:center;gap:4px;height:26px;padding:0 10px;background:var(--blue-dim);border:1px solid var(--blue-mid);color:var(--blue);border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.btn-log-time:hover{background:var(--blue);color:#fff}
.ce-field-wrap{display:none}
.ce-field-wrap.visible{display:block}
.jb-tasks-wrap{padding:20px 0}
.jb-task-list{display:flex;flex-direction:column}

/* ── INVOICE / LOCK ── */
.lock-badge{display:inline-flex;align-items:center;gap:5px;background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;letter-spacing:.04em;text-transform:uppercase}
.billable-locked{opacity:.55;pointer-events:none}
.billable-locked-msg{display:flex;align-items:center;gap:6px;background:var(--accent-dim);border:1px solid var(--accent-mid);border-radius:6px;padding:8px 12px;font-size:11px;color:var(--accent);margin-top:4px}

/* ── QUOTE STATUS ── */
.qs-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;letter-spacing:.03em;text-transform:uppercase}
.qs-quote_requested{background:rgba(156,163,175,.15);color:#6B7280}
.qs-email_approval{background:var(--blue-dim);color:var(--blue)}
.qs-whatsapp_approval{background:var(--low-dim);color:var(--low)}
.qs-verbal{background:var(--medium-dim);color:var(--medium)}
.qs-official_ce{background:var(--accent-dim);color:var(--accent)}

/* ── MONTHLY LOGS ── */
.ml-chart-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:0 28px 16px;padding:20px 24px}
.ml-chart-svg{display:block;width:100%;overflow:visible}
.ml-chart-svg .bar{cursor:pointer;transition:opacity .12s}
.ml-chart-svg .bar-fill{transition:opacity .12s}
.ml-daily-avg{font-size:12px;color:var(--text-muted);padding:10px 0 0}
.ml-daily-avg strong{color:var(--text-primary);font-family:var(--font-num)}
.ml-table-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:0 28px 16px;overflow:hidden}
.ml-table{margin-top:0}
.ml-day-row{cursor:pointer;user-select:none}
.ml-day-row td{background:#fff;transition:background .1s}
.ml-day-row:hover td{background:var(--bg-hover)!important}
.ml-weekend td{background:#FFFBF0}
.ml-weekend:hover td{background:#FFF3D0!important}
.ml-entry-row td{background:#F9FAFB}
.ml-zero{opacity:.5}
.ml-zero:hover{opacity:1}
.ml-date-label{font-size:13px;color:var(--text-primary)}
.ml-date-label.weekend-label{color:var(--accent)}
.ml-logged{font-family:var(--font-num);color:var(--text-primary);font-size:13px;font-weight:600}
.ml-billable{font-family:var(--font-num);color:var(--text-secondary);font-size:13px}
.ml-variance{font-family:var(--font-num);font-size:13px;font-weight:700}
.ml-chevron{transition:transform .15s;flex-shrink:0;color:var(--text-muted)}
.ml-entry-row td{padding-top:6px;padding-bottom:6px;font-size:12px}
.ml-entry-row td:first-child{padding-left:42px;color:var(--text-muted)}
.ml-totals{display:flex;justify-content:center;gap:80px;padding:28px 0;border-top:2px solid var(--border)}
.ml-total-item{text-align:center}
.ml-total-val{font-size:30px;font-weight:700;font-family:var(--font-num);margin-bottom:4px;line-height:1}
.ml-total-lbl{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.ml-member-tabs{display:flex;gap:6px;flex-wrap:wrap;padding:0 28px 16px}
.ml-member-tab{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:#F9FAFB;color:var(--text-secondary);transition:all .15s}
.ml-member-tab:hover{border-color:var(--border-light);color:var(--text-primary)}
.ml-member-tab.active{background:var(--blue-dim);border-color:var(--blue-mid);color:var(--blue)}

/* ── TARGET PROGRESS ── */
.prog-wrap{background:var(--border);border-radius:100px;height:7px;overflow:hidden;flex:1;min-width:0}
.prog-fill{height:100%;border-radius:100px;transition:width .4s ease}
.prog-over{background:var(--high)!important}
.target-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;padding:16px 28px 0}
.target-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:all .15s;box-shadow:var(--shadow-sm);cursor:pointer}
.target-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}
.target-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.target-card-info{flex:1;min-width:0}
.target-card-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.target-card-sub{font-size:11px;color:var(--text-muted);margin-top:1px;font-family:var(--font-num)}
.target-bar-row{display:flex;align-items:center;gap:8px}
.target-pct{font-size:11px;font-weight:700;font-family:var(--font-num);white-space:nowrap;min-width:38px;text-align:right}
.target-solo{padding:16px 28px 0}
.target-solo-row{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow-sm)}
.target-solo-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:12px;flex-wrap:wrap}
.target-solo-label{font-size:13px;font-weight:600;color:var(--text-primary)}
.target-solo-nums{font-size:13px;font-family:var(--font-num);color:var(--text-secondary)}

/* ── DATE PICKER ── */
.dp-wrap{position:relative;width:100%}
.dp-trigger{display:flex;align-items:center;gap:9px;background:#F3F4F6;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 13px;cursor:pointer;transition:all .2s;min-height:40px;user-select:none}
.dp-trigger:hover{border-color:var(--blue)}
.dp-trigger.open{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px var(--blue-dim)}
.dp-trigger-ico{color:var(--text-muted);flex-shrink:0;display:flex}
.dp-trigger-lbl{flex:1;font-size:13px;color:var(--text-primary)}
.dp-trigger-lbl.ph{color:var(--text-muted)}
.dp-trigger-clr{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px 4px;border-radius:4px;display:flex;align-items:center;line-height:1;transition:color .15s}
.dp-trigger-clr:hover{color:var(--high)}
.dp-popup{position:fixed;z-index:600;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 28px rgba(0,0,0,.13);min-width:272px;overflow:hidden;display:none}
.dp-popup.open{display:block;animation:fadeUp .14s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.dp-hd{display:flex;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border)}
.dp-nav{background:none;border:none;cursor:pointer;color:var(--text-secondary);width:28px;height:28px;border-radius:6px;font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .13s;flex-shrink:0}
.dp-nav:hover{background:var(--bg-hover);color:var(--text-primary)}
.dp-my{flex:1;text-align:center;font-size:13px;font-weight:700;color:var(--text-primary)}
.dp-dow{display:grid;grid-template-columns:repeat(7,1fr);padding:10px 12px 4px}
.dp-dow span{text-align:center;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:2px 0}
.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);padding:4px 12px 10px;gap:1px}
.dp-cell{text-align:center;padding:0;font-size:12px;font-weight:500;border-radius:7px;cursor:pointer;color:var(--text-secondary);transition:all .1s;aspect-ratio:1;display:flex;align-items:center;justify-content:center}
.dp-cell:not(.dp-empty):hover{background:var(--bg-hover);color:var(--text-primary)}
.dp-empty{cursor:default}
.dp-today{color:var(--blue);font-weight:700;position:relative}
.dp-today::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:3px;height:3px;border-radius:50%;background:var(--blue)}
.dp-selected{background:var(--blue)!important;color:#fff!important;font-weight:700}
.dp-selected.dp-today::after{background:#fff}
.dp-past{opacity:.45}
.dp-ft{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-top:1px solid var(--border)}
.dp-ft-btn{background:none;border:none;cursor:pointer;font-size:12px;font-weight:600;font-family:'Figtree',sans-serif;padding:5px 10px;border-radius:6px;transition:all .13s}
.dp-ft-btn.today-btn{color:var(--blue)}
.dp-ft-btn.today-btn:hover{background:var(--blue-dim)}
.dp-ft-btn.clear-btn{color:var(--text-muted)}
.dp-ft-btn.clear-btn:hover{background:var(--bg-hover);color:var(--high)}

/* ── RICH TEXT EDITOR ── */
.rte-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.rte-toolbar{display:flex;gap:2px;padding:8px 10px;background:#F9FAFB;border-bottom:1px solid var(--border);flex-wrap:wrap}
.rte-btn{padding:5px 9px;background:transparent;border:none;border-radius:5px;cursor:pointer;color:var(--text-secondary);font-size:12px;font-weight:600;font-family:'Figtree',sans-serif;transition:all .13s;display:inline-flex;align-items:center;justify-content:center}
.rte-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.rte-btn.active{background:var(--blue-dim);color:var(--blue)}
.rte-sep{width:1px;background:var(--border);margin:4px 4px;align-self:stretch}
.rte-editor{min-height:200px;padding:16px;outline:none;color:var(--text-primary);font-family:'Figtree',sans-serif;font-size:14px;line-height:1.7;background:#fff}
.rte-editor:empty::before{content:attr(data-placeholder);color:var(--text-muted)}
.rte-editor h1{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}
.rte-editor h2{font-size:18px;font-weight:700;margin:0 0 6px}
.rte-editor p{margin:0 0 8px}
.rte-editor ul,.rte-editor ol{padding-left:20px;margin:0 0 8px}
.rte-editor strong{font-weight:700}
.rte-editor em{font-style:italic}

/* ── FILE GRID ── */
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-top:12px}
.file-thumb{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:1;background:#F9FAFB;cursor:pointer;transition:all .15s}
.file-thumb:hover{border-color:var(--blue)}
.file-thumb img{width:100%;height:100%;object-fit:cover}
.file-thumb-doc{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:10px;color:var(--text-muted);font-weight:600}
.file-thumb-name{font-size:10px;padding:4px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.5);color:#fff}
.file-remove{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.5);border:none;border-radius:4px;cursor:pointer;padding:2px 5px;color:#fff;font-size:11px;display:none}
.file-thumb:hover .file-remove{display:block}

/* ── CHAT ── */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 260px);min-height:400px}
.chat-messages{flex:1;overflow-y:auto;padding:16px 0;display:flex;flex-direction:column;gap:12px}
.chat-msg{display:flex;gap:10px;align-items:flex-start}
.chat-msg.mine{flex-direction:row-reverse}
.chat-bubble{max-width:70%;background:#F9FAFB;border:1px solid var(--border);border-radius:12px 12px 12px 4px;padding:10px 14px;font-size:13px;color:var(--text-primary);line-height:1.5}
.chat-msg.mine .chat-bubble{background:var(--blue-dim);border-color:var(--blue-mid);border-radius:12px 12px 4px 12px}
.chat-meta{font-size:10px;color:var(--text-muted);margin-top:4px;display:flex;gap:6px;align-items:center}
.chat-msg.mine .chat-meta{justify-content:flex-end}
.chat-name{font-weight:600;color:var(--text-secondary)}
.chat-msg-inner{position:relative}
.chat-del-btn{position:absolute;top:-8px;right:-8px;background:#fff;border:1px solid var(--border);border-radius:50%;width:22px;height:22px;display:none;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);padding:0;transition:all .15s;z-index:2}
.chat-msg:hover .chat-del-btn{display:flex}
.chat-del-btn:hover{background:var(--high-dim);color:var(--high);border-color:var(--high)}
.tc-del-btn{position:absolute;top:-8px;left:-8px;background:#fff;border:1px solid var(--border);border-radius:50%;width:22px;height:22px;display:none;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);padding:0;transition:all .15s;z-index:2}
.tc-msg-wrap.mine .tc-del-btn{left:auto;right:-8px}
.tc-msg-wrap:hover .tc-del-btn{display:flex}
.tc-del-btn:hover{background:var(--high-dim);color:var(--high);border-color:var(--high)}
.typing-indicator{display:none;align-items:center;padding:4px 0 6px;min-height:28px}
.typing-indicator.visible{display:flex}
.typing-bubble{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#F9FAFB;border:1px solid var(--border);border-radius:12px 12px 12px 4px;font-size:11px;color:var(--text-muted)}
.typing-dots{display:flex;gap:3px;align-items:center}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.3s infinite ease-in-out}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}
.emoji-picker-wrap{position:relative;flex-shrink:0}
.emoji-picker{display:none;position:absolute;bottom:40px;left:0;background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px;width:280px;max-height:220px;overflow-y:auto;box-shadow:var(--shadow-md);z-index:50}
.emoji-picker.open{display:block}
.emoji-picker-cat{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:4px 4px 2px;margin-top:4px}
.emoji-picker-grid{display:flex;flex-wrap:wrap;gap:2px}
.emoji-btn{width:32px;height:32px;border:none;background:none;font-size:18px;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .1s}
.emoji-btn:hover{background:var(--bg-hover)}
.chat-input-row{display:flex;gap:10px;align-items:flex-end;padding:12px 0;border-top:1px solid var(--border);margin-top:8px}
.chat-input{flex:1;background:#F9FAFB;border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;color:var(--text-primary);font-family:'Figtree',sans-serif;font-size:13px;outline:none;resize:none;min-height:42px;max-height:120px;transition:border-color .2s}
.chat-input:focus{border-color:var(--blue);background:#fff}
.chat-file-chip{background:#F9FAFB;border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;text-decoration:none;transition:all .15s;cursor:pointer;max-width:240px}
.chat-file-chip:hover{border-color:var(--blue);background:var(--blue-dim)}
.chat-file-chip-icon{width:28px;height:28px;border-radius:6px;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted)}
.chat-file-chip-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-file-chip-size{font-size:10px;color:var(--text-muted);margin-top:1px}
.chat-img-wrap{position:relative;display:inline-block;margin-top:6px}
.chat-img-preview{max-width:220px;max-height:200px;border-radius:10px;display:block;cursor:pointer;transition:opacity .15s}
.chat-img-preview:hover{opacity:.9}
.chat-img-dl{position:absolute;bottom:6px;right:6px;width:28px;height:28px;border-radius:6px;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;opacity:0;transition:opacity .15s}
.chat-img-wrap:hover .chat-img-dl{opacity:1}
.chat-date-sep{text-align:center;font-size:11px;color:var(--text-muted);padding:8px 0;display:flex;align-items:center;gap:8px}
.chat-date-sep::before,.chat-date-sep::after{content:'';flex:1;height:1px;background:var(--border)}
.chat-file-preview{display:flex;gap:8px;flex-wrap:wrap;padding:8px 0;border-top:1px solid var(--border)}
.tc-layout{display:flex;height:100%;background:#F5F6FA}
.tc-main{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff}
.tc-top-bar{padding:14px 20px;border-bottom:1px solid var(--border);background:#fff}
.tc-input-area{padding:12px 16px;background:#fff;border-top:1px solid var(--border)}
.tc-input-row{display:flex;align-items:flex-end;gap:8px;background:#F9FAFB;border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px}
.tc-roster{width:220px;flex-shrink:0;background:#F9FAFB;border-left:1px solid var(--border);overflow-y:auto}
.tc-roster-head{padding:14px 16px;border-bottom:1px solid var(--border)}
.tc-roster-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.tc-roster-list{padding:8px}
.tc-roster-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm);transition:background .13s}
.tc-roster-item:hover{background:var(--bg-hover)}
.tc-roster-av-wrap{position:relative;flex-shrink:0}
.tc-roster-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:1.5px solid;flex-shrink:0;overflow:hidden}
.tc-roster-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.tc-roster-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-roster-role{font-size:10px;color:var(--text-muted);margin-top:1px}
.tc-messages-area{flex:1;overflow-y:auto;padding:16px}
.tc-msg-wrap{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px;position:relative}
.tc-msg-wrap.mine{flex-direction:row-reverse}
.tc-bubble{max-width:70%;background:#F9FAFB;border:1px solid var(--border);border-radius:12px 12px 12px 4px;padding:10px 14px;font-size:13px;color:var(--text-primary);line-height:1.5}
.tc-msg-wrap.mine .tc-bubble{background:var(--blue-dim);border-color:var(--blue-mid);border-radius:12px 12px 4px 12px}
.tc-meta{font-size:10px;color:var(--text-muted);margin-top:4px;display:flex;gap:6px}
.tc-msg-wrap.mine .tc-meta{justify-content:flex-end}

/* ── TOGGLE SWITCH ── */
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:11px;cursor:pointer;transition:all .2s}
.toggle-slider::before{content:'';position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.toggle-switch input:checked+.toggle-slider{background:var(--blue)}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(18px)}

/* ── NOTIFICATIONS ── */
.notif-empty{padding:40px 28px;text-align:center;color:var(--text-muted);font-size:13px;line-height:1.6}
.notif-list{padding:4px 0}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 28px;cursor:pointer;transition:background .13s;border-bottom:1px solid var(--border)}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--bg-hover)}
.notif-item.unread{background:var(--blue-dim)}
.notif-item.unread:hover{background:var(--blue-mid)}
.notif-item-icon{width:32px;height:32px;border-radius:50%;background:var(--blue-dim);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-item-body{flex:1;min-width:0}
.notif-item-title{font-size:13px;color:var(--text-primary);line-height:1.4}
.notif-item-meta{font-size:11px;color:var(--text-muted);margin-top:3px}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--text-primary);color:#fff;padding:10px 18px;border-radius:var(--radius);font-size:13px;font-weight:500;z-index:1000;transform:translateY(20px);opacity:0;transition:all .25s;pointer-events:none;box-shadow:var(--shadow-md)}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{background:var(--high)}
.toast.warn{background:var(--accent);color:var(--text-primary)}

/* ── COLOR DOTS ── */
.color-dot{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s;flex-shrink:0}
.color-dot:hover{transform:scale(1.15)}
.color-dot.selected{border-color:#fff;box-shadow:0 0 0 2px currentColor}

/* ── EMPTY STATE ── */
.empty-state{padding:60px 20px;text-align:center}
.empty-icon{font-size:32px;color:var(--border-light);margin-bottom:12px}
.empty-text{font-size:16px;font-weight:700;color:var(--text-secondary);margin-bottom:6px}
.empty-sub{font-size:13px;color:var(--text-muted)}

/* ── PORTAL ── */
.portal-body{min-height:100vh;background:#F5F6FA;font-family:'Figtree',sans-serif;color:#111827}
.portal-nav{background:#197AC6;padding:0 24px;height:56px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100}
.portal-nav-brand{color:#fff;font-weight:800;font-size:16px;letter-spacing:-.02em}
.portal-nav-sep{color:rgba(255,255,255,0.45);font-size:13px;margin:0 2px}
.portal-nav-title{color:rgba(255,255,255,0.9);font-size:13px;font-weight:500}
.portal-content{max-width:1060px;margin:0 auto;padding:32px 24px}
.portal-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}
.portal-card-header{padding:18px 24px;border-bottom:1px solid #E5E7EB;display:flex;align-items:center;justify-content:space-between;gap:12px}
.portal-stats-row{display:flex;border-bottom:1px solid #F3F4F6}
.portal-stat{flex:1;padding:18px 24px;text-align:center;border-right:1px solid #F3F4F6}
.portal-stat:last-child{border-right:none}
.portal-stat-val{font-size:22px;font-weight:800;color:#111827;line-height:1.1;font-family:var(--font-num)}
.portal-stat-label{font-size:10px;font-weight:700;color:#9CA3AF;text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.portal-task-list{padding:0}
.portal-task-row{display:flex;align-items:flex-start;gap:12px;padding:14px 24px;border-bottom:1px solid #F3F4F6;transition:background .13s}
.portal-task-row:last-child{border-bottom:none}
.portal-task-row:hover{background:#FAFBFC}
.portal-task-check{width:18px;height:18px;border-radius:50%;border:2px solid #D1D5DB;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center}
.portal-task-check.done{background:#059669;border-color:#059669}
.portal-task-check.done::after{content:'✓';font-size:9px;color:#fff;font-weight:800}
.portal-task-check.inprogress{border-color:#197AC6;background:rgba(25,122,198,0.1)}
.portal-task-name{font-size:13px;color:#111827;font-weight:500;line-height:1.4}
.portal-task-name.done{text-decoration:line-through;color:#9CA3AF}
.portal-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:9999px;white-space:nowrap;flex-shrink:0}
.portal-badge.todo{background:#F3F4F6;color:#6B7280}
.portal-badge.inprogress{background:rgba(25,122,198,0.09);color:#197AC6}
.portal-badge.inreview{background:rgba(124,58,237,0.09);color:#7C3AED}
.portal-badge.done{background:rgba(5,150,105,0.09);color:#059669}
.portal-badge.high{background:rgba(220,38,38,0.08);color:#DC2626}
.portal-badge.medium{background:rgba(249,115,22,0.08);color:#F97316}
.portal-badge.low{background:rgba(5,150,105,0.08);color:#059669}
.portal-jb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:8px}
.portal-jb-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;box-shadow:var(--shadow-sm);padding:20px;cursor:pointer;transition:all .18s;text-decoration:none;display:block;color:inherit}
.portal-jb-card:hover{box-shadow:var(--shadow-md);border-color:#D1D5DB;transform:translateY(-1px)}
.portal-jb-card-name{font-size:15px;font-weight:700;color:#111827;margin-bottom:8px}
.portal-status-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:9999px}
.portal-status-pill.active{background:rgba(5,150,105,0.1);color:#059669}
.portal-status-pill.inactive{background:#F3F4F6;color:#9CA3AF}
.portal-jb-progress{height:6px;background:#F3F4F6;border-radius:3px;overflow:hidden;margin:12px 0 8px}
.portal-jb-progress-fill{height:100%;border-radius:3px}
.portal-section-title{font-size:11px;font-weight:700;color:#9CA3AF;text-transform:uppercase;letter-spacing:.1em;margin:28px 0 12px}
.portal-footer{text-align:center;padding:28px 0 16px;font-size:11px;color:#D1D5DB}
.portal-progress-wrap{padding:16px 24px}
.portal-progress-bar-bg{height:8px;background:#F3F4F6;border-radius:4px;overflow:hidden;margin-top:8px}
.portal-progress-bar{height:100%;border-radius:4px;transition:width .5s ease}
.portal-time-rows{background:#F9FAFB;border-top:1px solid #F3F4F6}
.portal-time-row{display:flex;align-items:center;gap:12px;padding:9px 24px 9px 54px;border-top:1px solid #F3F4F6;font-size:12px;color:#6B7280}
.portal-time-date{color:#9CA3AF;min-width:90px;font-size:11px}
.portal-time-hrs{font-weight:700;color:#374151;min-width:50px;font-family:var(--font-num)}
.portal-time-note{flex:1;color:#6B7280}

/* ── CALENDAR ── */
.cal-controls{height:var(--row-user-h);display:flex;align-items:center;gap:12px;padding:0 24px;border-bottom:1px solid var(--border);background:#fff;flex-shrink:0}
.cal-nav-btn{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#F9FAFB;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.cal-nav-btn:hover{background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}
.cal-month-label{font-size:18px;font-weight:800;color:var(--text-primary);letter-spacing:-.01em;flex:1}
.cal-today-btn{padding:6px 16px;background:var(--blue-dim);border:1px solid var(--blue-mid);color:var(--blue);border-radius:var(--radius-sm);font-family:'Figtree',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.cal-today-btn:hover{background:var(--blue);color:#fff}
.cal-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:#fff}
/* View toggle (Month / Day) */
.cal-view-toggle{display:inline-flex;background:#F3F4F6;border:1px solid var(--border);border-radius:9999px;padding:3px;gap:2px}
.cal-vt{border:none;background:transparent;cursor:pointer;font-family:'Figtree',sans-serif;font-size:12px;font-weight:600;color:var(--text-secondary);padding:6px 16px;border-radius:9999px;transition:all .15s}
.cal-vt.active{background:#fff;color:var(--blue);box-shadow:var(--shadow-sm)}
.cal-vt:hover:not(.active){color:var(--text-primary)}
/* Day view — Apple-style hourly timeline */
.cal-day-scroll{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow-y:auto;height:calc(100vh - 232px);min-height:320px}
.cal-day-grid{position:relative;width:100%}
.cal-day-hour{position:absolute;left:0;right:0;border-top:1px solid var(--border);cursor:pointer;transition:background .1s}
.cal-day-hour:hover{background:var(--bg-hover)}
.cal-day-hour-label{position:absolute;left:10px;top:-8px;font-size:10px;font-weight:600;color:var(--text-muted);font-family:var(--font-num);background:#fff;padding:0 4px}
.cal-day-events{position:absolute;left:64px;right:14px;top:0;bottom:0;pointer-events:none}
.cal-day-event{position:absolute;pointer-events:auto;background:var(--blue);color:#fff;border-radius:7px;padding:4px 8px;overflow:hidden;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.12);border-left:3px solid rgba(255,255,255,.5);transition:filter .12s}
.cal-day-event:hover{filter:brightness(1.06)}
.cal-day-event.my-event{background:var(--low)}
.cal-day-event-time{font-size:10px;font-weight:600;opacity:.92;font-family:var(--font-num);line-height:1.2}
.cal-day-event-title{font-size:12px;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-day-now{position:absolute;left:54px;right:14px;height:0;border-top:2px solid #DC2626;z-index:3;pointer-events:none}
.cal-day-now-dot{position:absolute;left:-5px;top:-5px;width:10px;height:10px;border-radius:50%;background:#DC2626}
/* Week view */
.cal-week-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 232px);min-height:340px}
.cal-week-head{display:grid;grid-template-columns:64px repeat(7,1fr);border-bottom:1px solid var(--border);background:#F9FAFB;flex-shrink:0}
.cal-week-gutter-sp{border-right:1px solid var(--border)}
.cal-week-dayhead{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:8px 0;cursor:pointer;border-right:1px solid var(--border);transition:background .12s}
.cal-week-dayhead:last-child{border-right:none}
.cal-week-dayhead:hover{background:var(--bg-hover)}
.cal-week-dow{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.cal-week-dnum{font-size:16px;font-weight:700;color:var(--text-primary);font-family:var(--font-num);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.cal-week-dayhead.today .cal-week-dnum{background:var(--blue);color:#fff}
.cal-week-dayhead.today .cal-week-dow{color:var(--blue)}
.cal-week-scroll,.cal-week-wrap .cal-day-scroll{flex:1;overflow-y:auto;border:none;border-radius:0;box-shadow:none}
.cal-week-grid{position:relative;width:100%}
.cal-week-hour{position:absolute;left:0;right:0;border-top:1px solid var(--border)}
.cal-week-hour-label{position:absolute;left:10px;top:-8px;font-size:10px;font-weight:600;color:var(--text-muted);font-family:var(--font-num);background:#fff;padding:0 4px}
.cal-week-cols{position:absolute;left:64px;right:0;top:0;bottom:0;display:grid;grid-template-columns:repeat(7,1fr)}
.cal-week-col{position:relative;border-left:1px solid var(--border);cursor:pointer}
.cal-week-col:first-child{border-left:none}
.cal-week-col.today{background:rgba(25,122,198,.04)}
.cal-week-event{padding:2px 5px;border-radius:5px;border-left-width:2px}
.cal-week-event .cal-day-event-time{font-size:9px}
.cal-week-event .cal-day-event-title{font-size:10.5px}
.cal-week-now{left:0;right:0}
.cal-header{display:grid;grid-template-columns:repeat(7,1fr);background:#F9FAFB;border-bottom:1px solid var(--border)}
.cal-dow{padding:10px 0;text-align:center;font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;border-right:1px solid var(--border)}
.cal-dow:last-child{border-right:none}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:110px;padding:8px 6px;cursor:pointer;transition:background .13s;background:#fff;overflow:hidden}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell:hover{background:var(--bg-hover)}
.cal-cell.other-month{background:#FAFAFA;cursor:default}
.cal-cell.other-month .cal-day-num{color:var(--text-muted);opacity:.4}
.cal-cell.today{background:var(--blue-dim)}
.cal-cell.today .cal-day-num{color:#fff;font-weight:800;background:var(--blue);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}
.cal-cell.has-events .cal-day-num{color:var(--text-primary);font-weight:700}
.cal-day-num{font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:4px;line-height:1.6;padding:0 2px}
.cal-event{font-size:10px;font-weight:600;background:var(--blue-dim);color:var(--blue);border-left:2px solid var(--blue);padding:2px 5px;border-radius:2px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:background .1s;display:flex;align-items:center;gap:2px}
.cal-event:hover{background:var(--blue-mid)}
.cal-event.my-event{background:var(--low-dim);color:var(--low);border-left-color:var(--low)}
.cal-event.my-event:hover{background:rgba(5,150,105,0.18)}
.cal-event-time{font-size:9px;font-family:var(--font-num);opacity:.8;letter-spacing:.02em;flex-shrink:0}
.cal-more{font-size:10px;color:var(--text-muted);font-weight:600;padding:1px 4px;cursor:pointer}
.cal-more:hover{color:var(--blue)}

/* ── MEETING VIEW MODAL ── */
.mt-view-datetime{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px;padding:14px;background:var(--blue-dim);border-radius:var(--radius-sm);border:1px solid var(--blue-mid)}
.mt-view-date{font-size:14px;font-weight:600;color:var(--text-primary)}
.mt-view-time{font-size:14px;color:var(--blue);font-family:var(--font-num);margin-top:3px;font-weight:700}
.mt-view-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;margin-bottom:18px;padding:12px 14px;background:#F9FAFB;border-radius:var(--radius-sm);border:1px solid var(--border)}
.mt-view-people-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;margin-top:4px}
.mt-view-people{display:flex;flex-direction:column;gap:10px}
.mt-view-person{display:flex;align-items:center;gap:10px}
.mt-view-person-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.mt-view-person-role{font-size:11px;color:var(--text-muted)}

/* Start time pill row — horizontally scrollable */
.mt-time-scroll{overflow-x:auto;flex-wrap:nowrap!important;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.mt-time-scroll::-webkit-scrollbar{display:none}
.mt-time-scroll .pill{flex-shrink:0}

/* ── BACKUPS ── */
.bk-note{display:flex;gap:10px;padding:14px 16px;background:var(--blue-dim);border:1px solid var(--blue-mid);border-radius:var(--radius);color:var(--text-secondary);font-size:12.5px;line-height:1.55;margin-bottom:20px;color:#1568AA}
.bk-note svg{color:var(--blue)}
.bk-note strong{color:var(--text-primary)}
.bk-loading{padding:30px;text-align:center;color:var(--text-muted);font-size:13px}
.bk-table{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.bk-row{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}
.bk-row:last-child{border-bottom:none}
.bk-head{background:#EAEBEE;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:9px 16px}
.bk-head .bk-c,.bk-head .bk-c-act{text-align:left}
.bk-info{display:flex;align-items:center;gap:12px;min-width:0}
.bk-icon{width:36px;height:36px;border-radius:8px;background:var(--blue-dim);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bk-date{font-size:13px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.bk-file{font-size:11px;color:var(--text-muted);font-family:var(--font-num);margin-top:2px}
.bk-latest{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--low-dim);color:var(--low);padding:2px 7px;border-radius:9999px}
.bk-today{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--blue-dim);color:var(--blue);padding:2px 7px;border-radius:9999px}
.bk-size{font-family:var(--font-num);font-size:12px;color:var(--text-secondary);font-weight:600}
.bk-c-act{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.bk-confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.bk-confirm-txt{font-size:12px;color:var(--high);font-weight:600}
@media(max-width:820px){
  .bk-row{grid-template-columns:1fr;gap:8px}
  .bk-c-act,.bk-confirm{justify-content:flex-start}
}

/* Simple Add-Task (job bag) subtitle */
.atjb-sub{font-size:12px;color:var(--text-muted);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.atjb-sub strong{color:var(--text-primary)}

/* ── SETTINGS ── */
.settings-card{max-width:680px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px 24px}
.settings-card-title{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em}
.settings-hint{font-size:11px;color:var(--text-muted);margin-top:4px}
.settings-input-prefix{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:#F3F4F6;overflow:hidden}
.settings-input-prefix span{padding:0 10px;font-weight:700;color:var(--text-secondary);font-family:var(--font-num);border-right:1px solid var(--border);align-self:stretch;display:flex;align-items:center;background:#EAEBEE}
.settings-input-prefix .form-input{border:none;background:transparent;border-radius:0}
.settings-preview{margin-top:18px;padding:12px 14px;background:var(--blue-dim);border:1px solid var(--blue-mid);border-radius:var(--radius-sm);font-size:13px;color:#1568AA;line-height:1.6}
.settings-preview strong{font-family:var(--font-num);color:var(--blue)}

/* ── QUOTES LIST ── */
.q-table{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.q-row{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1.1fr) 120px 140px 250px;align-items:center;gap:16px;padding:14px 18px;border-bottom:1px solid var(--border)}
.q-row:last-child{border-bottom:none}
.q-head{background:#EAEBEE;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:10px 18px}
.q-ref{font-size:13px;font-weight:700;color:var(--text-primary);font-family:var(--font-num)}
.q-title{font-size:13px;color:var(--text-primary);margin-top:1px}
.q-target{font-size:11px;color:var(--text-muted);margin-top:2px}
.q-client{font-size:13px;color:var(--text-primary);min-width:0}
.q-email{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* column alignment — header + data share these classes */
.q-c-total{text-align:left;min-width:0}
.q-c-status{text-align:left;min-width:0}
.q-total{font-family:var(--font-num);font-weight:700;font-size:14px;color:var(--text-primary);white-space:nowrap}
.q-when{font-size:10px;color:var(--text-muted);margin-top:3px}
.q-c-act{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.q-badge{display:inline-block;font-size:10px;font-weight:700;padding:3px 9px;border-radius:9999px;text-transform:uppercase;letter-spacing:.04em}
.q-accepted-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:9999px;background:rgba(5,150,105,.12);color:#059669}
@media(max-width:880px){.q-row{grid-template-columns:1fr;gap:6px}.q-c-act{justify-content:flex-start}}

/* ── QUOTE MODAL ── */
.q-line{display:grid;grid-template-columns:minmax(0,1fr) 70px 80px 30px;gap:8px;align-items:center;margin-bottom:8px}
.q-line .form-input{padding:8px 10px}
.q-line-amt{font-family:var(--font-num);font-weight:700;font-size:13px;color:var(--text-primary);text-align:right;white-space:nowrap}
.q-line-del{width:28px;height:28px}
.q-totals{margin-top:14px;padding:14px;background:#F9FAFB;border:1px solid var(--border);border-radius:var(--radius-sm)}
.q-tot-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-secondary);padding:3px 0}
.q-tot-row strong{font-family:var(--font-num);color:var(--text-primary)}
.q-tot-total{border-top:1px solid var(--border);margin-top:6px;padding-top:10px;font-size:15px;color:var(--text-primary);font-weight:700}
.q-tot-total strong{font-size:18px;color:var(--blue)}
.q-rate-note{margin-top:14px;font-size:12px;color:var(--text-secondary)}
.q-rate-note strong{font-family:var(--font-num);color:var(--text-primary)}

/* ── PASSWORDS VAULT ── */
.pw-acc{display:flex;flex-direction:column;gap:8px;max-width:780px}
.pw-client{border:1px solid var(--border);border-radius:10px;background:#fff;box-shadow:var(--shadow-sm);overflow:hidden}
.pw-client.open{border-color:var(--blue-mid)}
.pw-client-head{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;user-select:none;transition:background .12s}
.pw-client-head:hover{background:var(--bg-hover)}
.pw-chev{color:var(--text-muted);transition:transform .15s;flex-shrink:0}
.pw-client.open .pw-chev{transform:rotate(90deg)}
.pw-client-name{font-size:14px;font-weight:600;color:var(--text-primary);flex:1}
.pw-count{font-size:11px;font-weight:700;color:var(--low);background:var(--low-dim);padding:3px 9px;border-radius:9999px}
.pw-count-empty{color:var(--text-muted);background:#F3F4F6}
.pw-client-body{padding:6px 16px 16px;border-top:1px solid var(--border)}
.pw-member{padding:14px 0;border-bottom:1px dashed var(--border)}
.pw-member:last-child{border-bottom:none}
.pw-member-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.pw-member-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.pw-shared{font-size:10px;font-weight:700;color:var(--low);margin-left:2px}
.pw-textarea{width:100%;min-height:64px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#F9FAFB;padding:10px 12px;font-family:'Figtree',sans-serif;font-size:13px;line-height:1.5;color:var(--text-primary);outline:none;resize:vertical}
.pw-textarea:focus{border-color:var(--blue);background:#fff}
.pw-member-actions{display:flex;align-items:center;gap:10px;margin-top:8px}
.pw-md-hint{font-size:10.5px;color:var(--text-muted)}
.pw-doc{font-size:13.5px;color:var(--text-primary);line-height:1.7;word-break:break-word}
.pw-doc code{background:#F3F4F6;border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:#B91C1C}
.pw-doc a{color:var(--blue);font-weight:600}
.pw-doc strong{color:var(--text-primary)}

/* ── ACTIONS TIMELINE ── */
.act-timeline{max-width:720px;padding:4px 0}
.act-row{display:flex;gap:14px;position:relative;padding:0 0 22px 0}
.act-row:not(:last-child)::before{content:'';position:absolute;left:15px;top:32px;bottom:0;width:2px;background:var(--border)}
.act-icon{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#F3F4F6;color:var(--text-secondary);z-index:1}
.act-icon-created{background:var(--blue-dim);color:var(--blue)}
.act-icon-task{background:rgba(124,58,237,.1);color:#7C3AED}
.act-icon-log{background:var(--blue-dim);color:var(--blue)}
.act-icon-quote{background:rgba(5,150,105,.12);color:#059669}
.act-hot .act-icon-quote{box-shadow:0 0 0 4px rgba(5,150,105,.12)}
.act-body{flex:1;min-width:0;padding-top:5px}
.act-title{font-size:13.5px;font-weight:600;color:var(--text-primary);line-height:1.4}
.act-hot .act-title{color:#059669}
.act-sub{font-size:12.5px;color:var(--text-secondary);margin-top:2px;line-height:1.5;word-break:break-word}
.act-meta{font-size:11px;color:var(--text-muted);margin-top:4px;font-family:var(--font-num)}

/* Hour / minute selector pills */
.mt-hour-pill{
  min-width:48px;justify-content:center;padding:9px 10px;
  font-size:14px;font-weight:700;font-family:var(--font-num);
}
.mt-min-pill{
  min-width:56px;justify-content:center;padding:9px 14px;
  font-size:14px;font-weight:700;font-family:var(--font-num);
  letter-spacing:.02em;
}

/* ── MENTION POPUP ── */
.mention-popup{position:absolute;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:4px;min-width:180px;z-index:600}
.mention-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:4px;cursor:pointer;transition:background .1s}
.mention-item:hover,.mention-item.active{background:var(--blue-dim)}
.mention-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.mention-role{font-size:10px;color:var(--text-muted)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.task-card,.kanban-task,.team-task-card{animation:fadeUp .18s ease both}
.stat-card,.stat-v2{animation:fadeUp .2s ease both}
.stat-card:nth-child(2),.stat-v2:nth-child(2){animation-delay:.05s}
.stat-card:nth-child(3),.stat-v2:nth-child(3){animation-delay:.1s}
.stat-card:nth-child(4),.stat-v2:nth-child(4){animation-delay:.15s}

/* ────────────────────────────────────────────────
   APP-STYLE SHEET MODALS — Add Task & Log Time
   ──────────────────────────────────────────────── */

/* Hero title input — no border, large, autofocus visual */
.sheet-title-input{
  width:100%;border:none;background:transparent;outline:none;
  font-family:'Figtree',sans-serif;font-size:22px;font-weight:600;
  color:var(--text-primary);padding:4px 0 14px;margin-bottom:6px;
  border-bottom:1px solid var(--border);transition:border-color .2s;
}
.sheet-title-input::placeholder{color:#C7CBD1;font-weight:500}
.sheet-title-input:focus{border-bottom-color:var(--blue)}

/* Inline description */
.sheet-desc{
  width:100%;border:none;background:transparent;outline:none;resize:none;
  font-family:'Figtree',sans-serif;font-size:14px;font-weight:400;
  color:var(--text-secondary);padding:6px 0;line-height:1.5;
  min-height:36px;margin-bottom:8px;
  overflow-y:hidden;overflow-x:hidden;
}
.sheet-desc::placeholder{color:#C7CBD1}

/* Section label (small uppercase) */
.sheet-label{
  font-size:10px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.08em;margin:18px 0 8px;
  display:block;
}

/* Pill rows */
.pill-row{display:flex;flex-wrap:wrap;gap:6px}
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:9999px;
  background:#F3F4F6;border:1px solid transparent;
  color:var(--text-secondary);font-size:13px;font-weight:500;
  cursor:pointer;user-select:none;transition:all .15s;
  font-family:'Figtree',sans-serif;line-height:1;
}
.pill:hover{background:#E8EAEE;color:var(--text-primary)}
.pill.selected{
  background:var(--blue);color:#fff;
  box-shadow:0 1px 3px rgba(25,122,198,0.3);
}
.pill.selected:hover{background:#1568AA}

/* Priority pills — colored when selected */
.pill-priority[data-p="high"].selected{background:#DC2626;box-shadow:0 1px 3px rgba(220,38,38,0.3)}
.pill-priority[data-p="medium"].selected{background:#D97706;box-shadow:0 1px 3px rgba(217,119,6,0.3)}
.pill-priority[data-p="low"].selected{background:#059669;box-shadow:0 1px 3px rgba(5,150,105,0.3)}

/* Time pills - bigger */
.time-pill{
  min-width:64px;justify-content:center;padding:10px 14px;
  font-size:14px;font-weight:600;font-family:var(--font-num);
}
.time-pill.custom-pill{font-family:'Figtree',sans-serif;font-size:13px;font-weight:500}

/* Date pills */
.date-pill{padding:8px 14px;font-size:13px}
.date-pill .date-pill-sub{font-size:10px;color:inherit;opacity:.7;margin-top:1px;font-weight:400}
.date-pill.selected .date-pill-sub{opacity:.85}

/* Assignee circle picker */
.av-picker{display:flex;flex-wrap:wrap;gap:10px}
.av-pick{
  position:relative;width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;cursor:pointer;
  border:2px solid transparent;transition:all .15s;user-select:none;
}
.av-pick.selected{transform:scale(1.05)}
.av-pick.selected::after{
  content:'';position:absolute;right:-2px;bottom:-2px;
  width:16px;height:16px;border-radius:50%;background:var(--blue);
  border:2px solid #fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='4'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:10px;background-position:center;background-repeat:no-repeat;
}
.av-pick-name{
  font-size:10px;font-weight:500;color:var(--text-secondary);
  margin-top:4px;text-align:center;white-space:nowrap;
}
.av-pick-wrap{display:flex;flex-direction:column;align-items:center;cursor:pointer}
.av-pick-wrap:hover .av-pick:not(.selected){border-color:var(--border-light)}

/* Disclosure (advanced options) */
.sheet-more{
  display:inline-flex;align-items:center;gap:4px;
  font-size:12px;font-weight:600;color:var(--blue);
  cursor:pointer;padding:8px 0;margin-top:6px;
  background:none;border:none;font-family:'Figtree',sans-serif;
}
.sheet-more:hover{text-decoration:underline}
.sheet-more svg{transition:transform .2s}
.sheet-more.open svg{transform:rotate(180deg)}
.sheet-more-content{display:none;margin-top:10px;padding-top:14px;border-top:1px dashed var(--border)}
.sheet-more-content.open{display:block;animation:fadeUp .2s ease both}

/* Compact selects in advanced options */
.sheet-mini-select{
  width:100%;padding:8px 12px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:#F3F4F6;
  font-family:'Figtree',sans-serif;font-size:13px;color:var(--text-primary);
  cursor:pointer;outline:none;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;
}

/* Task badge at top of Log Time sheet */
.sheet-task-chip{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--blue-dim);border:1px solid var(--blue-mid);
  border-radius:var(--radius-sm);margin-bottom:18px;
}
.sheet-task-chip-icon{
  width:28px;height:28px;border-radius:6px;background:#fff;
  display:flex;align-items:center;justify-content:center;color:var(--blue);flex-shrink:0;
}
.sheet-task-chip-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3}
.sheet-task-chip-sub{font-size:11px;color:var(--text-muted);margin-top:1px}

/* Notes expandable */
.sheet-notes-toggle{
  display:inline-flex;align-items:center;gap:4px;
  font-size:12px;font-weight:600;color:var(--blue);
  cursor:pointer;padding:6px 0;background:none;border:none;
  font-family:'Figtree',sans-serif;margin-top:8px;
}
.sheet-notes-wrap{display:none;margin-top:8px}
.sheet-notes-wrap.open{display:block;animation:fadeUp .15s ease both}
.sheet-notes-textarea{
  width:100%;padding:10px 12px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:#F3F4F6;
  font-family:'Figtree',sans-serif;font-size:13px;color:var(--text-primary);
  outline:none;resize:vertical;min-height:60px;line-height:1.5;
}
.sheet-notes-textarea:focus{border-color:var(--blue);background:#fff}

/* Locked / warning banner */
.sheet-warn{
  display:flex;align-items:flex-start;gap:8px;padding:10px 12px;
  background:rgba(217,119,6,0.08);border:1px solid rgba(217,119,6,0.25);
  border-radius:var(--radius-sm);font-size:12px;color:#D97706;
  margin-bottom:14px;line-height:1.4;
}
.sheet-warn svg{flex-shrink:0;margin-top:1px}

/* Primary CTA in modal footer — dynamic label */
.modal-footer .btn-primary.cta{min-width:160px;font-variant-numeric:tabular-nums}

/* ── QUICK LOG TIME — Task Picker ── */
.qlt-search-wrap{position:relative;margin-bottom:18px}
.qlt-search{
  width:100%;padding:11px 14px 11px 38px;
  border-radius:9999px;border:1px solid var(--border);
  background:#F3F4F6;font-family:'Figtree',sans-serif;font-size:14px;
  color:var(--text-primary);outline:none;transition:all .2s;
}
.qlt-search:focus{background:#fff;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim)}
.qlt-search::placeholder{color:var(--text-muted)}
.qlt-search-ico{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--text-muted);pointer-events:none;
}

.qlt-task-list{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto;margin:-2px}
.qlt-task-card{
  display:flex;align-items:center;gap:10px;padding:11px 14px;margin:2px;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);
  cursor:pointer;transition:all .15s;text-align:left;font-family:'Figtree',sans-serif;
}
.qlt-task-card:hover{border-color:var(--blue);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.qlt-task-card-body{flex:1;min-width:0}
.qlt-task-card-meta{
  font-size:10px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.qlt-task-card-title{
  font-size:13px;font-weight:600;color:var(--text-primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.qlt-task-card-arrow{color:var(--text-muted);flex-shrink:0;transition:transform .15s;opacity:.5}
.qlt-task-card:hover .qlt-task-card-arrow{color:var(--blue);transform:translateX(2px);opacity:1}

.qlt-empty{
  text-align:center;padding:30px 20px;color:var(--text-muted);
  font-size:13px;font-style:italic;
}

.qlt-new-task-btn{
  width:100%;display:flex;align-items:center;justify-content:center;gap:6px;
  padding:11px 14px;margin-top:10px;
  background:var(--blue-dim);border:1.5px dashed var(--blue-mid);
  border-radius:var(--radius-sm);color:var(--blue);
  font-family:'Figtree',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .15s;
}
.qlt-new-task-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue);border-style:solid}

.qlt-new-task-form{
  background:#F9FAFB;border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:14px;margin-top:10px;
  animation:fadeUp .18s ease both;
}

/* "Change task" link on the chip */
.sheet-task-chip-action{
  font-size:11px;font-weight:600;color:var(--blue);
  cursor:pointer;background:transparent;border:none;padding:4px 8px;
  border-radius:6px;font-family:'Figtree',sans-serif;flex-shrink:0;
}
.sheet-task-chip-action:hover{background:rgba(25,122,198,0.1)}

/* ════════════════════════════════════════════════
   CHAT — Unified redesign (Team Chat + Job Bag Chat)
   ════════════════════════════════════════════════ */

/* Layout — full-height column for both contexts */
.chat-shell{display:flex;flex-direction:column;height:100%;min-height:0;background:#fff}
.chat-shell-with-roster{display:flex;height:100%;background:#F7F8FB}
.chat-shell-with-roster .chat-shell{flex:1;min-width:0;background:#fff;border-right:1px solid var(--border)}

/* Header — context-aware chat header */
.chat-header{
  height:var(--row-logo-h);padding:0 22px;background:#fff;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;flex-shrink:0;z-index:5;
}
.chat-header-icon{
  width:36px;height:36px;border-radius:10px;background:var(--blue-dim);color:var(--blue);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.chat-header-info{flex:1;min-width:0}
.chat-header-title{font-size:15px;font-weight:700;color:var(--text-primary);line-height:1.2;letter-spacing:-.01em}
.chat-header-sub{font-size:11.5px;color:var(--text-muted);margin-top:2px;display:flex;align-items:center;gap:6px}
.chat-header-online-dot{width:7px;height:7px;border-radius:50%;background:#22C55E;display:inline-block;box-shadow:0 0 0 3px rgba(34,197,94,0.18)}
.chat-header-avatars{display:flex;align-items:center;margin-left:auto}
.chat-header-avatars .chat-stack-av{
  width:28px;height:28px;border-radius:50%;border:2px solid #fff;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;margin-left:-8px;overflow:hidden;flex-shrink:0;
}
.chat-header-avatars .chat-stack-av img{width:100%;height:100%;object-fit:cover}
.chat-header-avatars .chat-stack-more{
  background:#F3F4F6;color:var(--text-muted);font-size:10px;
}

/* Messages area */
.chat-stream{
  flex:1;overflow-y:auto;padding:18px 22px 12px;
  display:flex;flex-direction:column;gap:2px;position:relative;
  scrollbar-gutter:stable;
  background-color:#F0ECE6;
}
.chat-stream::-webkit-scrollbar{width:10px}
.chat-stream::-webkit-scrollbar-track{background:transparent}
.chat-stream::-webkit-scrollbar-thumb{background:transparent;border-radius:5px;border:2px solid #fff}
.chat-stream:hover::-webkit-scrollbar-thumb{background:#D1D5DB}

/* Date separator */
.chat-day-sep{
  display:flex;align-items:center;gap:10px;margin:18px 0 10px;
  font-size:11px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.08em;
}
.chat-day-sep::before,.chat-day-sep::after{
  content:'';flex:1;height:1px;background:linear-gradient(to right,transparent,var(--border),transparent);
}
.chat-day-sep-pill{
  padding:4px 10px;border-radius:9999px;background:#F3F4F6;color:var(--text-secondary);
  font-size:10.5px;font-weight:700;
}

/* Message row */
.chat-row{
  display:flex;gap:10px;align-items:flex-start;position:relative;
  padding:2px 6px;border-radius:8px;transition:background .12s;
  margin:0 -6px;
}
.chat-row:hover{background:rgba(0,0,0,0.02)}
.chat-row.mine{flex-direction:row-reverse}
.chat-row.grouped{margin-top:1px}
.chat-row.grouped .chat-row-av,.chat-row.grouped .chat-row-name{visibility:hidden;height:0;margin:0}
.chat-row.grouped .chat-row-av{height:auto;visibility:hidden}
.chat-row:not(.grouped){margin-top:8px}

.chat-row-av{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;overflow:hidden;
  border:1.5px solid;
}
.chat-row-av img{width:100%;height:100%;object-fit:cover}

.chat-row-col{display:flex;flex-direction:column;max-width:68%;min-width:0;position:relative}
.chat-row.mine .chat-row-col{align-items:flex-end}

.chat-row-name{
  font-size:11.5px;font-weight:700;margin-bottom:2px;padding:0 4px;line-height:1.2;
}
.chat-row.mine .chat-row-name{display:none}

.chat-bubble-new{
  background:#F3F4F6;border-radius:14px;padding:9px 14px;
  font-size:13.5px;color:var(--text-primary);line-height:1.5;
  word-break:break-word;font-family:'Figtree',sans-serif;
  border:none;position:relative;
}
/* Preserve user line-breaks only in the actual text div, not the container
   (container had pre-wrap which rendered template-literal indentation as ~100px of blank space) */
.chat-bubble-new > div:first-child{white-space:pre-wrap;word-break:break-word}
.chat-row.mine .chat-bubble-new{
  background:#197AC6;color:#fff;
}
.chat-row.mine .chat-bubble-new a{color:#fff;text-decoration:underline}
.chat-bubble-new + .chat-bubble-new{margin-top:2px}

/* First/last bubble in a group — tail */
.chat-row:not(.grouped):not(.mine) .chat-bubble-new{border-top-left-radius:4px}
.chat-row:not(.grouped).mine .chat-bubble-new{border-top-right-radius:4px}

/* Timestamp under last message in a group */
.chat-row-time{
  font-size:10.5px;color:var(--text-muted);margin-top:3px;padding:0 4px;
  font-family:'Figtree',sans-serif;font-weight:500;
  display:flex;align-items:center;gap:4px;
}
.chat-row-time-edited{font-style:italic;opacity:.7}

/* Hover action toolbar */
.chat-actions{
  position:absolute;top:-12px;right:8px;
  background:#fff;border:1px solid var(--border);border-radius:8px;
  box-shadow:var(--shadow-md);padding:2px;display:none;gap:1px;z-index:3;
}
.chat-row.mine .chat-actions{right:auto;left:8px}
.chat-row:hover .chat-actions{display:flex}
.chat-action{
  width:28px;height:28px;border:none;background:transparent;cursor:pointer;
  border-radius:6px;display:flex;align-items:center;justify-content:center;
  color:var(--text-secondary);transition:all .1s;padding:0;
}
.chat-action:hover{background:#F3F4F6;color:var(--text-primary)}
.chat-action.danger:hover{background:rgba(220,38,38,0.1);color:#DC2626}

/* Mention pill in messages */
.chat-mention{
  background:rgba(25,122,198,0.12);color:var(--blue);
  font-weight:600;padding:1px 5px;border-radius:4px;
}
.chat-row.mine .chat-mention{background:rgba(255,255,255,0.18);color:#fff}

/* Input area */
.chat-composer{
  padding:12px 16px 16px;background:#fff;border-top:1px solid var(--border);
  flex-shrink:0;
}
.chat-composer-inner{
  display:flex;align-items:flex-end;gap:6px;
  background:#F3F4F6;border:1px solid var(--border);border-radius:18px;
  padding:6px 8px 6px 12px;transition:all .15s;
}
.chat-composer-inner:focus-within{
  background:#fff;border-color:var(--blue);
  box-shadow:0 0 0 3px var(--blue-dim);
}
.chat-tool-btn{
  width:32px;height:32px;border:none;background:transparent;cursor:pointer;
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:all .12s;padding:0;font-size:17px;
  flex-shrink:0;
}
.chat-tool-btn:hover{background:rgba(0,0,0,0.05);color:var(--text-primary)}
.chat-composer-input{
  flex:1;background:transparent;border:none;outline:none;resize:none;
  font-family:'Figtree',sans-serif;font-size:14px;color:var(--text-primary);
  line-height:1.5;padding:6px 0;min-height:24px;
  overflow-y:hidden;overflow-x:hidden;
}
.chat-composer-input::placeholder{color:var(--text-muted)}
.chat-send{
  width:36px;height:36px;border:none;border-radius:50%;cursor:pointer;
  background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;align-self:flex-end;
}
.chat-send:hover:not(:disabled){background:#1568AA;transform:scale(1.05)}
.chat-send:disabled{background:#D1D5DB;cursor:default;color:#9CA3AF}

/* Floating "jump to latest" button */
.chat-jump-btn{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%) translateY(0);
  background:#fff;border:1px solid var(--border);border-radius:9999px;
  padding:8px 16px;font-size:12px;font-weight:600;color:var(--blue);
  box-shadow:var(--shadow-md);cursor:pointer;
  display:none;align-items:center;gap:6px;z-index:10;
  font-family:'Figtree',sans-serif;transition:all .2s;
}
.chat-jump-btn.visible{display:inline-flex;animation:fadeUp .2s ease both}
.chat-jump-btn:hover{transform:translateX(-50%) translateY(-2px);box-shadow:var(--shadow-lg)}
.chat-jump-btn .jump-count{
  background:var(--blue);color:#fff;border-radius:9999px;
  padding:1px 8px;font-size:11px;font-family:var(--font-num);
}

/* Empty state */
.chat-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 20px;color:var(--text-muted);text-align:center;
}
.chat-empty-icon{
  width:72px;height:72px;border-radius:50%;background:var(--blue-dim);color:var(--blue);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.chat-empty-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:6px}
.chat-empty-sub{font-size:13px;color:var(--text-muted);max-width:280px;line-height:1.5}

/* Roster (Team Chat sidebar) — modern */
.chat-roster{
  width:260px;flex-shrink:0;background:#fff;
  display:flex;flex-direction:column;overflow:hidden;
}
.chat-roster-head{
  height:var(--row-logo-h);padding:0 18px;border-bottom:1px solid var(--border);flex-shrink:0;
  display:flex;flex-direction:column;justify-content:center;
}
.chat-roster-head-title{
  font-size:10.5px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.08em;
}
.chat-roster-search{
  margin-top:10px;width:100%;padding:7px 12px;border-radius:9999px;
  border:1px solid var(--border);background:#F3F4F6;
  font-size:12px;font-family:'Figtree',sans-serif;outline:none;
}
.chat-roster-search:focus{background:#fff;border-color:var(--blue)}
.chat-roster-list-new{flex:1;overflow-y:auto;padding:8px 6px}
.chat-roster-row{
  display:flex;align-items:center;gap:10px;padding:8px 12px;
  border-radius:8px;transition:background .12s;cursor:default;
}
.chat-roster-row:hover{background:#F3F4F6}
.chat-roster-av-new{
  position:relative;width:34px;height:34px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;overflow:hidden;border:1.5px solid;
}
.chat-roster-av-new img{width:100%;height:100%;object-fit:cover}
.chat-roster-dot{
  position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;
  border:2px solid #fff;
}
.chat-roster-dot.on{background:#22C55E}
.chat-roster-dot.off{background:#D1D5DB}
.chat-roster-info{flex:1;min-width:0}
.chat-roster-row-name{
  font-size:13px;font-weight:600;color:var(--text-primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.chat-roster-row-name .you-tag{
  color:var(--text-muted);font-size:11px;font-weight:500;margin-left:4px;
}
.chat-roster-row-status{
  font-size:11px;color:var(--text-muted);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.chat-roster-row-status.online-status{color:#22C55E;font-weight:600}

/* Inline file/image previews in messages */
.chat-bubble-new .chat-img-preview{margin-top:6px;border-radius:10px;max-width:260px}
.chat-row.mine .chat-bubble-new .chat-file-chip{
  background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.2);color:#fff;
}
.chat-row.mine .chat-bubble-new .chat-file-chip-name{color:#fff}
.chat-row.mine .chat-bubble-new .chat-file-chip-size{color:rgba(255,255,255,0.7)}
.chat-row.mine .chat-bubble-new .chat-file-chip-icon{background:rgba(255,255,255,0.2);color:#fff}

/* Files preview row above input */
.chat-files-preview{
  display:flex;gap:8px;flex-wrap:wrap;padding:10px 16px;
  border-top:1px solid var(--border);background:#F9FAFB;
}
.chat-files-preview-item{
  background:#fff;border:1px solid var(--border);border-radius:8px;
  padding:6px 10px;font-size:12px;display:flex;align-items:center;gap:8px;
  position:relative;
}
.chat-files-preview-item .file-remove-btn{
  width:18px;height:18px;border-radius:50%;border:none;
  background:rgba(0,0,0,0.5);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;padding:0;margin-left:4px;
}
.chat-files-preview-item .file-remove-btn:hover{background:#DC2626}

/* Typing indicator (refreshed) */
.chat-typing{padding:0 22px 6px;min-height:0}
.chat-typing.visible{min-height:22px}
.chat-typing-bubble{
  display:inline-flex;align-items:center;gap:6px;padding:6px 12px;
  background:#F3F4F6;border-radius:14px;font-size:11px;color:var(--text-muted);
}
.chat-typing-dots{display:flex;gap:3px}
.chat-typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.3s infinite ease-in-out}
.chat-typing-dots span:nth-child(2){animation-delay:.2s}
.chat-typing-dots span:nth-child(3){animation-delay:.4s}

