:root{--bg:#f5f7fb;--panel:#fff;--text:#111827;--muted:#6b7280;--line:#e5e7eb;--blue:#2563eb;--green:#16a34a;--red:#ef4444;--orange:#f59e0b;--sidebar:#0f172a;--shadow:0 8px 25px rgba(15,23,42,.06)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.sidebar{position:fixed;left:0;top:0;bottom:0;width:250px;background:linear-gradient(180deg,#0f172a,#111827);color:#fff;padding:18px;display:flex;flex-direction:column;gap:22px}.brand{display:flex;align-items:center;gap:10px;font-size:18px}.brand-icon{width:30px;height:30px;border-radius:10px;background:#1d4ed8;display:grid;place-items:center}nav{display:flex;flex-direction:column;gap:6px}nav a{padding:12px;border-radius:10px;color:#cbd5e1}nav a:hover,nav a.active{background:#1d4ed8;color:#fff}.userbox{margin-top:auto;display:flex;gap:10px;align-items:center;padding:12px;border-radius:14px;background:rgba(255,255,255,.08)}.avatar{width:36px;height:36px;border-radius:50%;background:#334155;display:grid;place-items:center}.userbox small{display:block;color:#cbd5e1}.main{margin-left:250px;padding:24px}.auth-main{min-height:100vh;display:grid;place-items:center;padding:20px}.topbar{display:flex;gap:16px;align-items:center;justify-content:space-between;margin-bottom:22px}.topbar h1{margin:0;font-size:26px}.search{max-width:360px;width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:12px;background:#fff}.btn{border:0;border-radius:12px;padding:11px 14px;background:var(--blue);color:#fff;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.btn.secondary{background:#e5e7eb;color:#111827}.btn.danger{background:var(--red)}.grid{display:grid;gap:16px}.stats{grid-template-columns:repeat(5,minmax(0,1fr))}.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px}.stat{display:flex;gap:14px;align-items:center}.stat .icon{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#eff6ff;color:var(--blue);font-size:22px}.stat b{font-size:26px}.stat span{display:block;color:var(--muted);font-size:13px}.table-card{overflow:auto;padding:0}.table-title{padding:18px 20px;border-bottom:1px solid var(--line);font-weight:800}table{border-collapse:collapse;width:100%;background:#fff}th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);font-size:14px}th{color:#374151;font-size:13px;background:#fbfdff}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:26px;padding:4px 8px;border-radius:8px;font-size:12px;font-weight:800}.badge.green{background:#dcfce7;color:#166534}.badge.blue{background:#dbeafe;color:#1e40af}.badge.orange{background:#ffedd5;color:#9a3412}.badge.red{background:#fee2e2;color:#991b1b}.badge.gray{background:#f3f4f6;color:#374151}.badge.slate{background:#e2e8f0;color:#334155}.progress{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden;min-width:120px}.progress div{height:100%;background:var(--green)}.progress.red div{background:var(--red)}.cards3{grid-template-columns:1fr 1fr 1fr}.mini-list{display:grid;gap:12px}.mini-item{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center}.muted{color:var(--muted)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:grid;gap:6px}.field.full{grid-column:1/-1}.field span{font-weight:700;font-size:13px;color:#374151}input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;font:inherit}.actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.alert{padding:12px 14px;border-radius:12px;margin-bottom:16px;background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert.error{background:#fee2e2;color:#991b1b;border-color:#fecaca}.kanban{display:grid;grid-template-columns:repeat(4,minmax(230px,1fr)) 300px;gap:14px}.column{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:12px;min-height:320px}.column h3{margin:0 0 12px;font-size:15px}.task-card{background:#fff;border:1px solid var(--line);border-radius:13px;padding:12px;margin-bottom:10px;box-shadow:0 4px 16px rgba(15,23,42,.04)}.task-card b{display:block;margin-bottom:7px}.task-meta{display:flex;justify-content:space-between;gap:10px;color:#6b7280;font-size:12px}.tabs{display:flex;gap:8px;border-bottom:1px solid var(--line);margin:16px 0}.tabs a{padding:12px 10px;color:#64748b}.tabs a.active{color:#1d4ed8;border-bottom:2px solid #1d4ed8}.login-card{width:100%;max-width:420px}.login-card h1{margin-top:0}.empty{padding:25px;text-align:center;color:#64748b}.mobile-only{display:none}@media(max-width:900px){.sidebar{position:static;width:auto;min-height:auto}.sidebar nav{display:grid;grid-template-columns:repeat(2,1fr)}.userbox{display:none}.main{margin-left:0;padding:14px}.stats,.cards3,.form-grid,.kanban{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column}.search{max-width:none}.desktop-wide{display:none}.mobile-only{display:block}th,td{padding:10px}.card{padding:14px}}

/* Project overview / task tree view */
.project-hero h1{font-size:30px;margin-bottom:8px}.project-pills{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;color:#374151}.deadline{color:#ef4444}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.project-overview{display:grid;gap:16px}.overview-main{display:grid;gap:16px}.project-summary-grid{grid-template-columns:1.25fr .85fr}.project-info-card h3,.progress-card h3,.people-card h3{margin-top:0}.progress-row{display:flex;gap:10px;align-items:center}.big-progress{display:flex;align-items:flex-end;gap:12px;margin:12px 0}.big-progress b{font-size:40px;line-height:1}.big-progress span{color:var(--muted);padding-bottom:7px}.status-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}.status-strip span{padding:10px;border:1px solid var(--line);border-radius:12px;background:#fbfdff;color:#475569}.danger-text{color:#b91c1c!important}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-head h2,.section-head h3{margin:0}.people-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.person-chip{display:inline-flex;align-items:center;padding:8px 11px;background:#eef2ff;color:#3730a3;border-radius:999px;font-weight:800;font-size:13px}.task-tree-head{margin-top:4px}.task-tree{display:grid;gap:12px}.task-node{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.task-node summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 16px}.task-node summary::-webkit-details-marker{display:none}.task-title-block{display:flex;align-items:center;gap:12px;min-width:0}.task-title-block b{display:block;font-size:16px}.task-title-block small{display:block;color:var(--muted);margin-top:3px}.chev{width:28px;height:28px;display:grid;place-items:center;border-radius:10px;background:#eff6ff;color:#1d4ed8;font-weight:900;flex:0 0 auto}.task-node:not([open]) .chev{transform:rotate(-90deg)}.task-summary-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.task-date,.subtask-date{color:#64748b;font-size:13px;white-space:nowrap}.edit-link{font-weight:800;color:#1d4ed8;padding:4px 2px}.task-node-body{border-top:1px solid var(--line);padding:14px 16px 16px;background:#fbfdff}.task-details-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;color:#475569;font-size:14px;margin-bottom:10px}.task-comment{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;color:#475569}.progress.compact{min-width:0;margin:8px 0 12px}.subtasks{display:grid;gap:8px}.subtask-row{display:grid;grid-template-columns:28px 1fr 120px 120px 80px;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}.subtask-row:hover{border-color:#bfdbfe;background:#f8fbff}.check{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:#f1f5f9;color:#64748b;font-weight:900}.check.done{background:#dcfce7;color:#166534}.subtask-title{font-weight:700}.subtask-actions{margin-top:12px}.empty.inline{padding:12px;text-align:left;background:#fff;border:1px dashed var(--line);border-radius:12px}
@media(max-width:900px){.project-summary-grid{grid-template-columns:1fr}.status-strip{grid-template-columns:1fr}.section-head{align-items:flex-start;flex-direction:column}.task-node summary{align-items:flex-start;flex-direction:column}.task-summary-meta{justify-content:flex-start}.task-details-grid{grid-template-columns:1fr}.subtask-row{grid-template-columns:28px 1fr;align-items:start}.subtask-row .badge,.subtask-row .subtask-date,.subtask-row .muted{grid-column:2}.big-progress{align-items:flex-start;flex-direction:column}.project-pills{display:grid;gap:8px}.hero-actions{width:100%}.hero-actions .btn{flex:1;justify-content:center}}

/* Sortable tables */
.sortable-th {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  position: relative;
}
.sortable-th::after {
  content: "↕";
  opacity: .35;
  font-size: 12px;
  margin-left: 6px;
}
.sortable-th.sort-asc::after {
  content: "↑";
  opacity: .9;
}
.sortable-th.sort-desc::after {
  content: "↓";
  opacity: .9;
}
.sortable-th:focus {
  outline: 2px solid rgba(37, 99, 235, .35);
  outline-offset: 2px;
}
.form-grid.single{grid-template-columns:1fr}
.checkbox-field label{font-weight:600;color:#334155;display:flex;gap:8px;align-items:center}
.link-danger{background:none;border:0;color:#dc2626;font-weight:800;cursor:pointer;padding:0;margin-left:10px}
.link-danger:hover{text-decoration:underline}
@media (max-width: 900px){section.grid[style]{grid-template-columns:1fr!important}}

/* Collapsible sidebar */
.sidebar-toggle{margin-left:auto;border:0;background:rgba(255,255,255,.1);color:#fff;border-radius:10px;width:34px;height:34px;display:grid;place-items:center;cursor:pointer;font-size:16px}.sidebar-toggle:hover{background:rgba(255,255,255,.18)}.nav-icon{width:24px;display:inline-grid;place-items:center;font-size:18px;flex:0 0 24px}.sidebar nav a{display:flex;align-items:center;gap:10px}.sidebar,.main{transition:width .2s ease,margin-left .2s ease,padding .2s ease}.sidebar-collapsed .sidebar{width:82px;padding:18px 12px;align-items:center}.sidebar-collapsed .main{margin-left:82px}.sidebar-collapsed .brand{width:100%;justify-content:center}.sidebar-collapsed .brand-icon{margin:0}.sidebar-collapsed .sidebar-toggle{position:absolute;right:-17px;top:19px;background:#1d4ed8;box-shadow:0 8px 20px rgba(15,23,42,.2)}.sidebar-collapsed .nav-text{display:none}.sidebar-collapsed .sidebar nav{width:100%;align-items:center}.sidebar-collapsed .sidebar nav a{justify-content:center;width:46px;height:46px;padding:0}.sidebar-collapsed .userbox{justify-content:center;width:46px;padding:8px}.sidebar-collapsed .avatar{width:34px;height:34px}.sidebar-collapsed .brand strong{display:none}
@media(max-width:900px){.sidebar-toggle{display:none}.sidebar-collapsed .sidebar{width:auto;padding:18px;align-items:stretch}.sidebar-collapsed .main{margin-left:0}.sidebar-collapsed .nav-text{display:inline}.sidebar-collapsed .sidebar nav a{justify-content:flex-start;width:auto;height:auto;padding:12px}.sidebar-collapsed .userbox{display:none}}

/* Task detail page and comments */
.link-blue{color:#1d4ed8;font-weight:800}.task-title-link{color:#1d4ed8;font-weight:800}.task-title-link:hover{text-decoration:underline}.task-view-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;align-items:start}.task-view-main{display:grid;gap:16px}.task-view-side{display:grid;gap:16px}.task-passport h3,.comments-card h3{margin-top:0}.task-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}.task-info-grid>div{border:1px solid var(--line);background:#fbfdff;border-radius:12px;padding:12px}.task-info-grid .full{grid-column:1/-1}.task-info-grid span{display:block;font-size:12px;margin-bottom:4px}.task-info-grid b{font-size:14px}.task-description-box{margin-top:14px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px}.task-description-box p{margin:6px 0}.chat-list{display:grid;gap:10px;margin:14px 0;max-height:520px;overflow:auto;padding-right:4px}.chat-message{display:flex;justify-content:flex-start}.chat-message.mine{justify-content:flex-end}.chat-bubble{max-width:78%;background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:10px 12px}.chat-message.mine .chat-bubble{background:#eff6ff;border-color:#bfdbfe}.chat-meta{display:flex;gap:10px;justify-content:space-between;color:#64748b;font-size:12px;margin-bottom:6px}.chat-meta b{color:#111827}.chat-text{white-space:normal;line-height:1.45}.chat-form{border-top:1px solid var(--line);padding-top:14px}.side-subtasks{display:grid;gap:10px;margin-top:12px}.side-subtask{border:1px solid var(--line);border-radius:12px;padding:10px;background:#fbfdff}.side-subtask-title{display:block;font-weight:800;color:#1d4ed8;margin-bottom:7px}.subtask-row{grid-template-columns:28px 1fr 120px 120px 80px 44px}.subtask-row .edit-link{text-align:right}
@media(max-width:900px){.task-view-grid{grid-template-columns:1fr}.task-info-grid{grid-template-columns:1fr}.chat-bubble{max-width:100%}.task-view-topbar .hero-actions{width:100%}.task-view-topbar .btn{flex:1;justify-content:center}.subtask-row{grid-template-columns:28px 1fr}.subtask-row .edit-link{grid-column:2;text-align:left}.subtask-row .badge,.subtask-row .subtask-date,.subtask-row .muted{grid-column:2}}


.task-title-link + .chat-indicator,
.side-subtask-title + .chat-indicator,
.subtask-title + .chat-indicator { margin-left: 6px; }
.chat-indicator {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  vertical-align: middle;
  opacity: .55;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
}
.chat-indicator.unread {
  opacity: 1;
  color: #dc2626;
  font-weight: 800;
}
.chat-indicator.unread span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: #dc2626;
  color: #fff;
  font-size: 11px;
  box-shadow: 0 8px 18px rgba(220,38,38,.25);
}
.task-heading-with-chat {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* User profile and avatars */
.profile-link{color:#fff}.profile-link:hover{background:rgba(255,255,255,.14)}
.avatar{overflow:hidden;font-weight:900;color:#fff;text-transform:uppercase;flex:0 0 auto}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar.has-photo{background:transparent}.avatar.mini{width:28px;height:28px;font-size:11px;display:inline-grid;vertical-align:middle;margin-right:7px}.avatar.xl{width:92px;height:92px;font-size:28px}.avatar.chat-avatar{width:34px;height:34px;margin-top:4px;background:#475569}.user-chip{display:inline-flex;align-items:center;gap:7px;vertical-align:middle;min-width:0}.user-chip .avatar{margin-right:0}.user-chip.compact{font-size:13px;gap:5px}.user-chip.compact .avatar{width:24px;height:24px;font-size:10px}.person-chip.user-chip{gap:7px;padding:6px 10px}.person-chip.user-chip .avatar{background:#3730a3}.profile-grid{display:grid;grid-template-columns:360px minmax(0,1fr);gap:16px;align-items:start}.profile-avatar-preview{display:flex;gap:16px;align-items:center}.profile-avatar-preview h3{margin:0 0 4px}.profile-avatar-preview p{margin:0}.chat-message{gap:8px;align-items:flex-start}.chat-message.mine{flex-direction:row-reverse}.chat-message.mine .chat-avatar{display:none}
td .user-chip{white-space:nowrap}.mini-item .user-chip{justify-content:flex-end}.sidebar-collapsed .profile-link{padding:8px}.sidebar-collapsed .profile-link .avatar{margin:0}
@media(max-width:900px){.profile-grid{grid-template-columns:1fr}.profile-avatar-preview{align-items:flex-start}.mini-item .user-chip{justify-content:flex-start}}

/* Password reset */
.auth-links{margin:14px 0 0;text-align:center}.auth-links a{color:#1d4ed8;font-weight:800}.auth-links a:hover{text-decoration:underline}.debug-box{margin-top:14px;background:#0f172a;color:#dbeafe;border-radius:12px;padding:12px;white-space:pre-wrap;overflow:auto;font-size:12px;max-height:260px}


/* Attendance */
.attendance-form-card .table-title{margin-bottom:14px}.attendance-form{grid-template-columns:260px 180px 150px 1fr auto;align-items:end}.readonly-box{min-height:42px;border:1px solid var(--line);border-radius:12px;background:#f8fafc;padding:9px 12px;display:flex;align-items:center}.attendance-scroll{overflow:auto;border:1px solid var(--line);border-radius:14px}.attendance-calendar{min-width:980px;border-collapse:separate;border-spacing:0}.attendance-calendar th,.attendance-calendar td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);padding:7px;text-align:center}.attendance-calendar th:last-child,.attendance-calendar td:last-child{border-right:0}.attendance-calendar tr:last-child td{border-bottom:0}.attendance-calendar .employee-col{position:sticky;left:0;background:#fff;z-index:2;text-align:left;min-width:190px}.attendance-calendar thead .employee-col{z-index:3;background:#f8fafc}.attendance-calendar thead th{background:#f8fafc;font-size:12px;color:#475569}.attendance-calendar .day-col{min-width:46px}.attendance-calendar .day-col span{display:block;font-weight:900;color:#111827}.attendance-calendar .day-col small{display:block;color:#64748b;font-size:10px}.attendance-calendar .weekend{background:#fff7ed}.attendance-calendar .day-cell{height:42px;color:#94a3b8}.attendance-calendar .day-cell.has-hours{background:#eff6ff;color:#1d4ed8;font-weight:900}.attendance-calendar .day-cell.weekend.has-hours{background:#ffedd5;color:#c2410c}.attendance-calendar .cell-note{color:#f97316;margin-left:2px}.attendance-calendar .total-cell{background:#f0fdf4;color:#166534;font-size:15px}.attendance-form .field.full{grid-column:span 2}.attendance-form .field.full:last-child{grid-column:auto}.hero-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:1100px){.attendance-form{grid-template-columns:1fr 1fr}.attendance-form .field.full,.attendance-form .field.full:last-child{grid-column:1/-1}}@media(max-width:700px){.attendance-form{grid-template-columns:1fr}.attendance-calendar{min-width:860px}.attendance-calendar .employee-col{min-width:150px}.topbar .hero-actions{width:100%;justify-content:stretch}.topbar .hero-actions .btn{flex:1;justify-content:center}}

.attendance-limit-note{margin:-6px 0 14px;font-size:13px}
.attendance-calendar .day-cell.editable-day{cursor:pointer;position:relative}
.attendance-calendar .day-cell.editable-day:hover{outline:2px solid #2563eb;outline-offset:-2px;background:#dbeafe}
.attendance-calendar .day-cell.locked-day{background:#f8fafc;color:#cbd5e1;cursor:not-allowed;opacity:.75}
.attendance-calendar .day-cell.locked-day.has-hours{background:#f1f5f9;color:#64748b}
.attendance-calendar .day-cell.weekend.locked-day{background:#f8fafc;color:#cbd5e1}
.attendance-calendar .day-cell.weekend.locked-day.has-hours{background:#f1f5f9;color:#64748b}
.attendance-calendar .add-hours-mark{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;border:1px dashed #94a3b8;color:#64748b;font-weight:900}

/* v0.3.7 Attendance period selector */
.attendance-period-card { margin-bottom: 16px; }
.period-form { display: flex; gap: 12px; align-items: end; flex-wrap: wrap; }
.period-form .field { min-width: 160px; margin: 0; }
.period-form .period-submit { min-width: auto; }
.attendance-topbar { gap: 12px; }
@media (max-width: 720px) {
  .period-form { display: grid; grid-template-columns: 1fr 1fr; }
  .period-form .period-submit { grid-column: 1 / -1; }
  .period-form .period-submit .btn { width: 100%; }
  .attendance-actions { width: 100%; display: grid; grid-template-columns: 1fr; }
}
.attendance-calendar-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.attendance-title-period-form{display:inline-flex;align-items:center;gap:8px;margin:0}
.attendance-title-period-form select{height:34px;border:1px solid var(--line);border-radius:10px;background:#fff;padding:0 10px;font-weight:800;color:#111827}
.attendance-title-period-form .btn.small{height:34px;padding:0 12px}
@media(max-width:700px){.attendance-calendar-title{align-items:flex-start;flex-direction:column}.attendance-title-period-form,.attendance-title-period-form select{width:100%}}

/* v0.4.1 Live search for Projects and Tasks */
.list-topbar{align-items:center}.title-with-search{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.title-with-search h1{white-space:nowrap}.live-search-wrap{position:relative;min-width:260px;max-width:420px;width:100%}.live-search-wrap .search{padding-right:40px;max-width:none}.search-clear{display:none;position:absolute;right:7px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:0;border-radius:999px;background:#e5e7eb;color:#475569;font-size:20px;line-height:1;cursor:pointer}.live-search-wrap.has-value .search-clear{display:grid;place-items:center}.search-clear:hover{background:#cbd5e1;color:#111827}.live-search-empty-row td{background:#fff}
@media(max-width:900px){.list-topbar{align-items:stretch}.title-with-search{width:100%;align-items:stretch;flex-direction:column}.live-search-wrap{max-width:none;width:100%}}

/* v0.4.2 Comment attachments */
.comment-upload-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:10px 0 0}.file-upload-label{display:inline-flex;align-items:center;gap:8px;border:1px dashed var(--line);border-radius:12px;padding:9px 12px;background:#f8fafc;color:#334155;font-weight:800;cursor:pointer}.file-upload-label:hover{background:#eef2ff;border-color:#c7d2fe}.file-upload-label input{display:none}.comment-attachments{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}.comment-image-link{display:block;width:120px;height:86px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#f8fafc}.comment-image-link img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .15s ease}.comment-image-link:hover img{transform:scale(1.04)}.comment-file-link{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:9px 11px;color:#1d4ed8;font-weight:800;max-width:260px}.comment-file-link span:nth-child(2){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-file-link small{color:#64748b;font-weight:700}.file-icon{font-size:18px}.image-lightbox{position:fixed;inset:0;background:rgba(15,23,42,.86);display:none;align-items:center;justify-content:center;z-index:9999;padding:24px}.image-lightbox.open{display:flex}.image-lightbox img{max-width:min(1100px,96vw);max-height:90vh;border-radius:16px;box-shadow:0 20px 70px rgba(0,0,0,.4);background:#fff}.image-lightbox button{position:absolute;right:20px;top:16px;border:0;background:rgba(255,255,255,.15);color:#fff;width:42px;height:42px;border-radius:999px;font-size:28px;line-height:1;cursor:pointer}.image-lightbox button:hover{background:rgba(255,255,255,.25)}
@media(max-width:700px){.comment-image-link{width:96px;height:74px}.comment-file-link{max-width:100%}.comment-upload-row{align-items:flex-start;flex-direction:column}}

/* v0.5.0 filters, quick status, files, history, archive */
.filters-card{margin-bottom:16px}.filters-grid{display:grid;grid-template-columns:1.2fr repeat(5,minmax(140px,1fr)) auto;gap:12px;align-items:end}.filters-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:800;color:#475569}.filters-grid input,.filters-grid select,.quick-status-select{border:1px solid var(--line);border-radius:11px;background:#fff;min-height:38px;padding:0 10px;color:#111827}.check-filter{flex-direction:row!important;align-items:center!important;gap:8px!important}.check-filter input{min-height:auto}.filter-actions{display:flex;gap:8px;align-items:center}.quick-status-form{margin:0}.quick-status-select{font-weight:800;min-width:145px}.archived-row{opacity:.65;background:#f8fafc}.checkbox-field .checkline{display:flex;align-items:center;gap:8px;min-height:42px;border:1px solid var(--line);border-radius:12px;background:#f8fafc;padding:0 12px}.inline-upload-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:8px 0 12px}.task-files-list{margin-top:12px}.task-history-card .history-list{display:grid;gap:10px}.history-item{border:1px solid var(--line);border-radius:12px;padding:10px;background:#f8fafc}.history-item small{display:block;color:#64748b;margin-top:2px}.task-files-card,.project-files-card{margin-top:16px}.link-blue{color:#1d4ed8;font-weight:800}@media(max-width:1200px){.filters-grid{grid-template-columns:1fr 1fr 1fr}.filter-actions{grid-column:1/-1}}@media(max-width:720px){.filters-grid{grid-template-columns:1fr}.filter-actions{display:grid}.filter-actions .btn{width:100%}.quick-status-select{width:100%}}

/* v0.5.1 */
.multi-select { min-height: 150px; }
.assignee-chips { display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.mention { background:#dbeafe; color:#1d4ed8; padding:1px 5px; border-radius:999px; font-weight:700; }
.mention-hint { margin-top:6px; font-size:12px; color:#64748b; }


/* v0.5.2 AppRox-inspired clean dashboard redesign */
:root{
  --bg:#f7f9fc;
  --panel:#ffffff;
  --text:#202938;
  --muted:#7c8798;
  --line:#edf1f7;
  --blue:#3156ff;
  --blue2:#6d3df5;
  --green:#16b28b;
  --red:#ff4d67;
  --orange:#ffb84d;
  --sidebar:#111827;
  --shadow:0 18px 45px rgba(16,24,40,.05);
}
body{background:var(--bg);color:var(--text);font-size:14px;}
.sidebar{width:236px;background:#111827;padding:20px 16px;gap:26px;box-shadow:14px 0 40px rgba(15,23,42,.08)}
.brand{height:34px;font-size:17px;letter-spacing:.1px}.brand-icon{width:12px;height:12px;border-radius:999px;background:linear-gradient(135deg,#ff4d67,#3156ff);font-size:0}.brand-icon::after{content:'';display:block;width:4px;height:4px;border-radius:50%;background:#fff;opacity:.8}.sidebar-toggle{background:rgba(255,255,255,.06);color:#cbd5e1}.sidebar-toggle:hover{background:rgba(255,255,255,.12);color:#fff}
.sidebar nav{gap:5px}.sidebar nav::before{content:'MAIN';font-size:10px;font-weight:900;letter-spacing:.18em;color:#6b7280;margin:10px 8px 8px}.sidebar nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:#aeb8c9;font-weight:650;font-size:13px}.sidebar nav a:hover,.sidebar nav a.active{background:#1d2740;color:#fff}.nav-icon{width:20px;text-align:center;opacity:.9}.userbox{background:#162033;border:1px solid rgba(255,255,255,.05);border-radius:16px}.avatar{background:linear-gradient(135deg,#6376ff,#2dd4bf);color:#fff;font-weight:900;overflow:hidden}.avatar.mini{width:30px;height:30px;font-size:12px}.main{margin-left:236px;padding:0 22px 28px}.app-header{height:58px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 -22px 18px;padding:0 22px;background:#fff;border-bottom:1px solid #eef2f7;position:sticky;top:0;z-index:20}.app-header-left{display:flex;align-items:center;gap:14px}.app-menu-btn{width:34px;height:34px;border:0;background:#fff;color:#7c8798;border-radius:10px;font-size:20px;cursor:pointer}.app-menu-btn:hover{background:#f1f5f9;color:#111827}.app-global-search{display:flex;align-items:center;gap:8px;min-width:260px;max-width:360px;width:30vw;background:#fff;border:1px solid #edf1f7;border-radius:999px;height:36px;padding:0 14px;color:#9aa4b5}.app-global-search input{height:32px;border:0;padding:0;background:transparent;color:#94a3b8}.app-global-search input:disabled{opacity:1}.app-header-user{display:flex;align-items:center;gap:9px;color:#334155;font-weight:800}.topbar{margin:4px 0 20px}.topbar h1{font-size:21px;font-weight:900;letter-spacing:-.02em}.card,.table-card,.column,.task-node{border:0;border-radius:8px;box-shadow:0 12px 28px rgba(15,23,42,.035);background:#fff}.card{padding:20px}.table-title{padding:17px 20px;font-size:15px;border-bottom:1px solid #eef2f7;background:#fff}.btn{background:#3156ff;border-radius:8px;box-shadow:0 8px 20px rgba(49,86,255,.16);min-height:38px}.btn:hover{filter:brightness(.98);transform:translateY(-1px)}.btn.secondary{background:#f3f6fb;color:#475569;box-shadow:none}.btn.danger{background:#ff4d67}.stats{gap:14px}.stat{min-height:88px}.stat .icon{width:42px;height:42px;border-radius:12px;background:#eef2ff;color:#3156ff}.stat b{font-size:25px;color:#222b3a}.stat span{font-size:12px;text-transform:none;color:#7c8798}table{background:#fff}th{background:#f8fafc;color:#667085;text-transform:none;font-size:12px;font-weight:900}td{color:#344054}th,td{border-bottom:1px solid #edf1f7}.table-card tr:hover td{background:#fbfdff}.badge{border-radius:999px;min-width:28px;font-weight:900}.badge.green{background:#e8f8f3;color:#0f8f71}.badge.blue{background:#eef4ff;color:#3156ff}.badge.orange{background:#fff4df;color:#b76b00}.badge.red{background:#ffe9ee;color:#d92d4a}.badge.gray{background:#f3f5f8;color:#667085}.progress{height:7px;background:#edf1f7}.progress div{background:#16b28b}.tabs{border:0;background:#fff;border-radius:12px;padding:6px;box-shadow:0 10px 25px rgba(15,23,42,.035)}.tabs a{border-radius:9px;padding:10px 14px;font-weight:800}.tabs a.active{border:0;background:#eef2ff;color:#3156ff}.search,input,select,textarea{border-color:#edf1f7;border-radius:10px}.search:focus,input:focus,select:focus,textarea:focus{outline:3px solid rgba(49,86,255,.12);border-color:#bdcaff}.dashboard-hero{display:grid;grid-template-columns:minmax(360px,1.2fr) minmax(260px,.85fr) minmax(220px,.55fr);gap:16px;margin-bottom:16px}.hero-banner{position:relative;overflow:hidden;min-height:158px;border-radius:8px;background:radial-gradient(circle at 85% 15%,rgba(255,255,255,.24),transparent 26%),linear-gradient(135deg,#2b22d8,#6d3df5);color:#fff;padding:28px 30px;box-shadow:0 20px 45px rgba(49,38,216,.18)}.hero-banner:after{content:'';position:absolute;right:-30px;bottom:-45px;width:180px;height:180px;border:1px solid rgba(255,255,255,.18);border-radius:50%}.hero-eyebrow{display:block;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;opacity:.82}.hero-banner h2{margin:9px 0 8px;font-size:24px;line-height:1.15}.hero-banner p{margin:0 0 16px;color:rgba(255,255,255,.82);max-width:520px}.hero-btn{background:#ff4d67;box-shadow:none}.hero-balance-card{background:#fff;border-radius:8px;padding:22px;box-shadow:var(--shadow);min-height:158px;position:relative;overflow:hidden}.hero-balance-card:after{content:'';position:absolute;right:-42px;top:-42px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,#fff2f7,#fff 70%)}.hero-balance-card span,.hero-mini-grid span{display:block;color:#7c8798;font-size:12px;font-weight:900;text-transform:uppercase}.hero-balance-card b{display:block;margin:14px 0 6px;font-size:30px}.hero-balance-card small{color:#16b28b;font-weight:800}.hero-mini-grid{display:grid;gap:14px}.hero-mini-grid div{background:#fff;border-radius:8px;padding:18px 20px;box-shadow:var(--shadow);min-height:72px}.hero-mini-grid b{font-size:24px;display:block;margin-top:8px}.task-card{border:0;border-radius:8px;box-shadow:0 10px 24px rgba(15,23,42,.04)}.column{background:#f8fafc}.task-node summary{border-radius:8px}.people-list .person-chip,.user-chip{border-radius:999px;background:#f4f7ff}.comment-bubble,.history-item,.task-comment{border-color:#edf1f7}.sidebar-collapsed .sidebar{width:76px}.sidebar-collapsed .main{margin-left:76px}.sidebar-collapsed .brand{justify-content:center}.sidebar-collapsed .sidebar nav a{justify-content:center}.sidebar-collapsed .sidebar nav::before,.sidebar-collapsed .nav-text{display:none}.sidebar-collapsed .sidebar-toggle{margin-left:0}.sidebar-collapsed .userbox{justify-content:center}.sidebar-collapsed .app-header{margin-left:-22px}
@media(max-width:1180px){.dashboard-hero{grid-template-columns:1fr 1fr}.hero-mini-grid{grid-column:1/-1;grid-template-columns:1fr 1fr}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.sidebar{position:static;width:auto;box-shadow:none;border-radius:0}.sidebar nav::before{display:none}.main{margin-left:0;padding:0 14px 18px}.app-header{margin:0 -14px 14px;padding:0 14px}.app-global-search{display:none}.dashboard-hero,.hero-mini-grid{grid-template-columns:1fr}.sidebar-collapsed .main{margin-left:0}.sidebar-collapsed .nav-text{display:inline}.sidebar-collapsed .sidebar{width:auto}.sidebar-collapsed .sidebar nav a{justify-content:flex-start}}


/* v0.5.3 interface fixes */
body{font-size:15.5px}.topbar h1{font-size:23px}th,td{font-size:15px}.table-title{font-size:16px}.sidebar nav a{font-size:14px}.field span{font-size:14px}.btn{font-size:14px}.badge{font-size:13px}.muted,small{font-size:13px}.app-global-search{display:none!important}.brand .sidebar-toggle{display:none!important}.app-header-left{min-width:44px}.app-menu-btn{display:inline-grid;place-items:center}.dashboard-hero{display:none!important}.sidebar-collapsed .brand{justify-content:center}.sidebar-collapsed .sidebar-toggle{display:none!important}.sidebar-collapsed .app-header{margin-left:-22px}
@media(max-width:900px){
  body{font-size:15px;overflow-x:hidden}.app-header{height:56px;position:sticky;top:0;z-index:60}.app-header-user span{display:none}.app-menu-btn{background:#f8fafc;border:1px solid #edf1f7;color:#111827}.sidebar{position:fixed!important;left:0;top:0;bottom:0;width:270px!important;max-width:86vw;z-index:80;transform:translateX(-105%);transition:transform .22s ease;box-shadow:18px 0 45px rgba(15,23,42,.25);padding:18px!important;align-items:stretch!important}.sidebar nav{display:flex!important;grid-template-columns:none!important}.sidebar .nav-text{display:inline!important}.sidebar nav a{justify-content:flex-start!important;width:auto!important;height:auto!important;padding:12px!important}.sidebar .userbox{display:flex!important}.sidebar-collapsed .sidebar{transform:translateX(-105%);width:270px!important}.mobile-menu-open .sidebar{transform:translateX(0)!important}.mobile-menu-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:70}.mobile-menu-open .mobile-menu-backdrop{display:block}.main{margin-left:0!important;padding:0 14px 18px!important}.sidebar-collapsed .main{margin-left:0!important}.stats{grid-template-columns:1fr!important}.cards3{grid-template-columns:1fr!important}.table-card{overflow:auto}.sidebar-collapsed .nav-text{display:inline!important}.sidebar-collapsed .sidebar nav::before{display:none!important}
}

/* v0.5.5 attendance salary-hour summaries */
.attendance-summary-grid{grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px}
.attendance-summary-card{display:flex;flex-direction:column;gap:6px}
.attendance-summary-card span{font-size:13px;color:#64748b;font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.attendance-summary-card b{font-size:28px;line-height:1;color:#111827}
.attendance-summary-card small{color:#64748b;font-size:12px}
.attendance-summary-card.overtime b{color:#b91c1c}
.attendance-summary-card.sunday b{color:#c2410c}
.attendance-calendar .regular-cell{background:#f8fafc;color:#334155;font-size:14px}
.attendance-calendar .overtime-cell{background:#fef2f2;color:#b91c1c;font-size:14px}
.attendance-calendar .sunday-cell{background:#ffedd5;color:#c2410c;font-size:14px}
.badge.regular-badge{background:#e2e8f0;color:#334155}
.badge.overtime-badge{background:#fee2e2;color:#991b1b}
.badge.sunday-badge{background:#ffedd5;color:#9a3412}
@media(max-width:900px){.attendance-summary-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.attendance-summary-grid{grid-template-columns:1fr}}

/* v0.5.7 attendance planned hours in total card */
.attendance-total-card .summary-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.attendance-total-card .summary-card-head span:first-child{margin-top:1px}
.attendance-total-card .planned-hours{font-size:12px!important;line-height:1.2;color:#64748b;font-weight:800;text-transform:none;letter-spacing:0;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:5px 9px;white-space:nowrap}
@media(max-width:560px){.attendance-total-card .summary-card-head{flex-direction:column;gap:6px}.attendance-total-card .planned-hours{align-self:flex-start}}

/* v0.5.14 Mention autocomplete in task comments */
.mention-input-wrap{position:relative;width:100%}
.mention-input-wrap textarea{width:100%}
.mention-suggestions{position:absolute;left:0;right:0;bottom:calc(100% + 8px);z-index:40;background:#fff;border:1px solid rgba(17,24,39,.12);border-radius:14px;box-shadow:0 18px 45px rgba(15,23,42,.18);padding:6px;max-height:280px;overflow:auto}
.mention-suggestion-item{width:100%;display:flex;align-items:center;gap:10px;border:0;background:transparent;text-align:left;border-radius:11px;padding:9px 10px;cursor:pointer;color:var(--text,#111827)}
.mention-suggestion-item:hover,.mention-suggestion-item.active{background:rgba(37,99,235,.08)}
.mention-suggestion-avatar{width:34px;height:34px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;flex:0 0 34px;background:linear-gradient(135deg,#e0e7ff,#f1f5f9);font-weight:800;color:#334155;font-size:13px}
.mention-suggestion-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.mention-suggestion-main{display:flex;flex-direction:column;min-width:0;line-height:1.15}
.mention-suggestion-main b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mention-suggestion-main small{font-size:12px;color:var(--muted,#64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}
@media (max-width:700px){.mention-suggestions{bottom:auto;top:calc(100% + 8px);max-height:230px}}

.app-header-right{display:flex;align-items:center;gap:12px;margin-left:auto}.notif-wrap{position:relative}.notif-btn{width:38px;height:38px;border:1px solid #edf1f7;background:#fff;border-radius:12px;color:#334155;font-size:18px;display:inline-grid;place-items:center;cursor:pointer;position:relative}.notif-btn:hover{background:#f8fafc}.notif-badge{position:absolute;right:-5px;top:-6px;min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:#ff4d67;color:#fff;font-size:11px;font-weight:900;display:grid;place-items:center;box-shadow:0 6px 14px rgba(255,77,103,.25)}.notif-menu{position:absolute;right:0;top:48px;width:360px;max-width:calc(100vw - 28px);background:#fff;border:1px solid #eef2f7;border-radius:16px;box-shadow:0 24px 60px rgba(15,23,42,.16);z-index:100;overflow:hidden}.notif-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #eef2f7}.notif-head b{font-size:15px}.notif-head a{font-size:12px;font-weight:800;color:#3156ff}.notif-list{max-height:410px;overflow:auto}.notif-item{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid #f1f5f9;color:#334155}.notif-item:hover{background:#f8fafc}.notif-item.unread{background:#f5f7ff}.notif-item.unread:hover{background:#eef2ff}.notif-item span{min-width:0;display:block}.notif-item b{display:block;font-size:13px;color:#111827;margin-bottom:4px}.notif-item small{display:block;color:#64748b;line-height:1.3;max-height:38px;overflow:hidden}.notif-item em{display:block;margin-top:5px;color:#94a3b8;font-size:11px;font-style:normal}.notif-empty{padding:22px;color:#94a3b8;text-align:center;font-weight:700}
@media(max-width:900px){.app-header-right{gap:8px}.notif-menu{right:-54px;width:330px}.notif-btn{width:36px;height:36px}}

.remember-row{
  display:flex;
  align-items:center;
  gap:8px;
  margin:10px 0 14px;
  font-size:.95rem;
  color:#475569;
}
.remember-row input{width:16px;height:16px;}
