*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #00173D;--primary-l: #002560;--secondary: #01568D;--secondary-l: #0170b9;--accent: #50B395;--accent-l: #6fcbb0;--bg: #eef1f6;--white: #ffffff;--text: #111827;--text-s: #374151;--text-m: #6b7280;--text-l: #9ca3af;--border: #e5e7eb;--urgent: #ef4444;--urgent-bg: #fef2f2;--warn: #f59e0b;--warn-bg: #fffbeb;--ok: #10b981;--ok-bg: #ecfdf5;--info: #3b82f6;--info-bg: #eff6ff;--r: 10px;--r-s: 6px;--r-l: 16px;--sh: 0 1px 3px rgba(0,23,61,.08), 0 1px 2px rgba(0,23,61,.04);--sh-m: 0 4px 12px rgba(0,23,61,.1);--sh-l: 0 10px 24px rgba(0,23,61,.12);--t: .18s ease}body{font-family:Raleway,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit}:root{--sidebar-w: 240px}.app-shell{display:flex;min-height:100vh}.app-shell>aside{transition:width .3s ease}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.page-content{flex:1;overflow-y:auto;padding:28px 32px}.sidebar{width:240px;min-height:100vh;background:var(--primary);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo .logo-mark{display:flex;align-items:center;gap:10px}.logo-box{width:36px;height:36px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:var(--primary)}.logo-text{color:#fff;font-size:13px;font-weight:700;line-height:1.2}.logo-sub{color:#ffffff80;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.06em}.sidebar-nav{flex:1;padding:16px 12px}.nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;padding:0 8px;margin:16px 0 6px}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-s);color:#ffffffa6;font-size:13.5px;font-weight:500;transition:var(--t);margin-bottom:2px}.nav-link:hover{background:#ffffff12;color:#fff}.nav-link.active{background:var(--secondary);color:#fff}.nav-link svg{flex-shrink:0}.nav-unread-badge{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;font-size:10px;font-weight:800;border-radius:10px;min-width:18px;height:18px;padding:0 5px;animation:pulse-badge 1.8s ease-in-out infinite;box-shadow:0 0 0 2px #ef44444d}.sidebar-user{padding:16px 12px;margin:0 0 8px;border-top:1px solid rgba(255,255,255,.08)}.user-chip{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r);background:#ffffff0f;cursor:pointer;transition:var(--t)}.user-chip:hover{background:#ffffff1a}.avatar{width:34px;height:34px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.user-info{flex:1;min-width:0}.user-name{color:#fff;font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:#ffffff73;font-size:11px}.top-header{background:var(--white);border-bottom:1px solid var(--border);padding:0 32px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.page-title{font-size:16px;font-weight:700;color:var(--primary)}.header-actions{display:flex;align-items:center;gap:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--r-s);font-size:13.5px;font-weight:600;transition:var(--t);white-space:nowrap}.btn-primary{background:var(--secondary);color:#fff}.btn-primary:hover{background:var(--secondary-l)}.btn-accent{background:var(--accent);color:var(--primary)}.btn-accent:hover{background:var(--accent-l)}.btn-ghost{background:transparent;color:var(--text-s);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg)}.btn-danger{background:var(--urgent);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-icon{padding:8px;border-radius:var(--r-s)}.btn:disabled{opacity:.5;pointer-events:none}.card{background:var(--white);border-radius:var(--r-l);box-shadow:var(--sh);padding:24px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:15px;font-weight:700;color:var(--primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--white);border-radius:var(--r-l);padding:20px;box-shadow:var(--sh);display:flex;align-items:flex-start;gap:14px}.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-value{font-size:26px;font-weight:800;color:var(--primary);line-height:1}.stat-label{font-size:12px;color:var(--text-m);font-weight:500;margin-top:3px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:700;white-space:nowrap}.badge-urgent{background:var(--urgent-bg);color:var(--urgent)}.badge-high{background:var(--warn-bg);color:#b45309}.badge-medium{background:#eff6ff;color:#1d4ed8}.badge-low{background:var(--ok-bg);color:#059669}.badge-pending{background:#f3f4f6;color:#4b5563}.badge-in_progress{background:#eff6ff;color:#2563eb}.badge-review{background:#faf5ff;color:#7c3aed}.badge-completed{background:var(--ok-bg);color:#059669}.badge-pending_approval{background:#faf5ff;color:#7c3aed;border:1px solid #ddd6fe}.badge-premium{background:#fef9c3;color:#a16207}.badge-admin{background:#ede9fe;color:#6d28d9}.badge-collaborador{background:#f0fdf4;color:#15803d}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;background:#01568d1a;color:var(--secondary);font-size:11.5px;font-weight:600}.task-card{background:var(--white);border-radius:var(--r-l);box-shadow:var(--sh);padding:18px 20px;border-left:3px solid transparent;transition:var(--t);cursor:pointer;display:block}.task-card:hover{box-shadow:var(--sh-m);transform:translateY(-1px)}.task-card.urgent{border-left-color:var(--urgent)}.task-card.high{border-left-color:var(--warn)}.task-card.completed-card{opacity:.65}.task-card.pending-approval-card{border-left:3px solid #7c3aed!important;background:#faf5ff}.task-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.task-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.4;flex:1}.task-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}.task-meta-item{display:flex;align-items:center;gap:4px;color:var(--text-m);font-size:12px}.task-assignees{display:flex;gap:-4px}.task-assignees .avatar{width:24px;height:24px;font-size:10px;border:2px solid #fff;margin-left:-4px}.task-assignees .avatar:first-child{margin-left:0}.task-points{display:flex;align-items:center;gap:4px;color:#a16207;font-weight:700;font-size:12px}.tasks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}.filter-select,.search-input{height:38px;padding:0 12px;border-radius:var(--r-s);border:1px solid var(--border);background:var(--white);font-family:inherit;font-size:13.5px;color:var(--text);outline:none;transition:var(--t)}.filter-select:focus,.search-input:focus{border-color:var(--secondary)}.search-input{width:220px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-s);margin-bottom:6px}.form-control{width:100%;padding:9px 12px;border-radius:var(--r-s);border:1px solid var(--border);font-family:inherit;font-size:13.5px;color:var(--text);outline:none;transition:var(--t);background:var(--white)}.form-control:focus{border-color:var(--secondary);box-shadow:0 0 0 3px #01568d1a}textarea.form-control{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-check{display:flex;align-items:center;gap:8px;cursor:pointer}.form-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--secondary);cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00173d73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--white);border-radius:var(--r-l);box-shadow:var(--sh-l);width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--white);z-index:1}.modal-title{font-size:16px;font-weight:700;color:var(--primary)}.modal-body{padding:24px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--white);z-index:1}.login-page{min-height:100vh;background:var(--primary);display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:var(--white);border-radius:var(--r-l);box-shadow:var(--sh-l);width:100%;max-width:420px;overflow:hidden}.login-header{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);padding:36px 32px;text-align:center}.login-logo-box{width:60px;height:60px;border-radius:16px;background:var(--accent);margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:24px;color:var(--primary)}.login-company{color:#fff;font-size:20px;font-weight:800}.login-sub{color:#fff9;font-size:12px;margin-top:4px}.login-body{padding:32px}.login-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:24px}.login-tab{flex:1;padding:10px;text-align:center;font-size:13.5px;font-weight:600;color:var(--text-m);border-bottom:2px solid transparent;transition:var(--t);cursor:pointer}.login-tab.active{color:var(--secondary);border-bottom-color:var(--secondary)}.login-error{background:var(--urgent-bg);color:var(--urgent);padding:10px 14px;border-radius:var(--r-s);font-size:13px;margin-bottom:16px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-m);padding:10px 14px;text-align:left;background:var(--bg)}td{padding:13px 14px;border-bottom:1px solid var(--border);font-size:13.5px;color:var(--text-s);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg)}.rank-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.rank-row:last-child{border-bottom:none}.rank-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;flex-shrink:0}.rank-1{background:#fef9c3;color:#a16207}.rank-2{background:#f3f4f6;color:#4b5563}.rank-3{background:#fff7ed;color:#c2410c}.rank-other{background:var(--bg);color:var(--text-m)}.rank-name{flex:1;font-weight:600;font-size:13.5px}.rank-pts{font-weight:800;color:var(--accent);font-size:14px}.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.detail-section{margin-bottom:24px}.detail-section-title{font-size:13px;font-weight:700;color:var(--text-m);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.checklist-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-light)}.checklist-item:last-child{border-bottom:none}.checklist-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--secondary);cursor:pointer;flex-shrink:0}.checklist-label{flex:1;font-size:13.5px;color:var(--text-s)}.checklist-label.done{text-decoration:line-through;color:var(--text-l)}.attachment-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-s);margin-bottom:8px}.attachment-name{flex:1;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-size{font-size:11px;color:var(--text-m)}.profile-photo-ring{width:100px;height:100px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:36px;margin:0 auto 16px;position:relative;overflow:hidden;cursor:pointer}.profile-photo-ring img{width:100%;height:100%;object-fit:cover}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00173d99;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--t)}.profile-photo-ring:hover .photo-overlay{opacity:1}.progress-bar{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease}.tag-input-wrap{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:40px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--r-s);background:var(--white);cursor:text}.tag-input-wrap:focus-within{border-color:var(--secondary);box-shadow:0 0 0 3px #01568d1a}.tag-input{border:none;outline:none;font-family:inherit;font-size:13.5px;min-width:80px;flex:1}.tag-remove{background:none;border:none;cursor:pointer;color:var(--text-m);font-size:14px;line-height:1;padding:0 2px}.user-select-list{border:1px solid var(--border);border-radius:var(--r-s);max-height:160px;overflow-y:auto}.user-select-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;transition:var(--t)}.user-select-item:hover{background:var(--bg)}.user-select-item.selected{background:#01568d0f}.empty-state{text-align:center;padding:48px 20px;color:var(--text-m)}.empty-state svg{opacity:.3;margin-bottom:12px}.empty-title{font-size:15px;font-weight:600;margin-bottom:6px}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--secondary);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.text-sm{font-size:12.5px}.text-muted{color:var(--text-m)}.font-bold{font-weight:700}.w-full{width:100%}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cal-month-label{font-size:17px;font-weight:800;color:var(--primary);text-transform:capitalize}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh)}.cal-weekday{background:var(--primary);color:#ffffffa6;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:10px 0}.cal-day{background:var(--white);min-height:110px;padding:8px;cursor:pointer;transition:background var(--t);position:relative}.cal-day:hover{background:#f4f7fb}.cal-day.other-month{background:var(--bg)}.cal-day.other-month .cal-day-num{color:var(--text-l)}.cal-day.today{background:#50b3950f}.cal-day.today .cal-day-num{background:var(--accent);color:var(--primary);border-radius:50%;font-weight:800}.cal-day-num{font-size:12px;font-weight:600;color:var(--text-s);margin-bottom:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.cal-event-chip{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px;margin-bottom:2px;cursor:pointer;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--t)}.cal-event-chip:hover{opacity:.82}.cal-more{font-size:10.5px;color:var(--text-m);font-weight:600;margin-top:2px}.cal-event-chip.unavail{font-weight:700;font-size:10.5px}.cal-person-picker{display:flex;align-items:center;gap:7px;padding:6px 12px 6px 6px;border-radius:99px;border:1.5px solid var(--border);background:var(--white);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;color:var(--text);transition:border-color var(--t),box-shadow var(--t);min-width:150px}.cal-person-picker:hover{border-color:var(--secondary)}.cal-person-av{width:26px;height:26px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;overflow:hidden;flex-shrink:0}.cal-person-av img{width:100%;height:100%;object-fit:cover}.cal-person-drop{position:absolute;top:calc(100% + 6px);right:0;background:var(--white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-m);z-index:50;min-width:220px;max-height:280px;overflow-y:auto}.cal-person-drop-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text);transition:background var(--t)}.cal-person-drop-item:hover{background:var(--bg)}.cal-person-drop-item.active{background:var(--info-bg);color:var(--secondary);font-weight:700}.event-modal-body{display:flex;flex-direction:column;gap:0}.event-type-bar{margin:-20px -24px 0;padding:14px 20px 12px;border-radius:var(--r) var(--r) 0 0;transition:background .3s ease}.event-type-bar-inner{display:flex;gap:6px;flex-wrap:wrap}.event-type-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:99px;background:#ffffff2e;color:#fffc;border:1.5px solid rgba(255,255,255,.25);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--t)}.event-type-pill:hover{background:#ffffff47;color:#fff}.event-type-pill.active{background:#fffffff2;color:var(--text);border-color:transparent;box-shadow:0 2px 8px #00000026}.event-type-pill:disabled{opacity:.6;cursor:default}.event-modal-fields{display:flex;flex-direction:column;gap:4px;padding-top:20px}.event-title-input{width:100%;border:none;outline:none;font-family:inherit;font-size:20px;font-weight:800;color:var(--primary);background:transparent;padding:4px 0 8px;border-bottom:2px solid var(--border);transition:border-color var(--t);margin-bottom:4px}.event-title-input::placeholder{color:var(--text-l);font-weight:600}.event-title-input:focus{border-bottom-color:var(--secondary)}.event-title-input:disabled{opacity:.7}.event-field-row{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border)}.event-field-row:last-child{border-bottom:none}.event-field-icon{color:var(--text-m);flex-shrink:0}.event-field-content{flex:1;min-width:0}.event-datetime-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.event-input-compact{border:1px solid var(--border);border-radius:var(--r-s);padding:6px 10px;font-family:inherit;font-size:13px;outline:none;background:var(--bg);color:var(--text);transition:border-color var(--t)}.event-input-compact:focus{border-color:var(--secondary);background:#fff}.event-input-compact:disabled{opacity:.7}.event-time-group{display:flex;align-items:center;gap:6px}.event-participants-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.event-participant-tag{display:inline-flex;align-items:center;gap:5px;background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:3px 8px 3px 3px;font-size:12px;font-weight:600;color:var(--text-s)}.event-participant-av{width:22px;height:22px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;overflow:hidden;flex-shrink:0}.event-participant-av img{width:100%;height:100%;object-fit:cover}.event-participant-rm{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:none;border:none;cursor:pointer;color:var(--text-m);transition:color var(--t)}.event-participant-rm:hover{color:var(--urgent)}.event-add-participant-wrap{position:relative}.event-add-participant-input{border:none;outline:none;background:transparent;font-family:inherit;font-size:13px;color:var(--secondary);cursor:pointer;padding:3px 4px;min-width:160px}.event-add-participant-input::placeholder{color:var(--secondary);opacity:.7;font-weight:600}.event-textarea{width:100%;border:none;outline:none;resize:none;font-family:inherit;font-size:13.5px;line-height:1.6;color:var(--text);background:transparent;padding:4px 0}.event-textarea::placeholder{color:var(--text-l)}.event-color-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.event-color-dot{width:22px;height:22px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform var(--t),border-color var(--t)}.event-color-dot:hover{transform:scale(1.2)}.event-color-dot.active{border-color:var(--primary);transform:scale(1.25);box-shadow:0 0 0 2px #00173d26}.chat-wrapper{display:flex;flex-direction:row;height:calc(100vh - 60px);margin:-28px -32px;background:var(--white);overflow:hidden}.conv-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--white)}.conv-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border)}.conv-list{flex:1;overflow-y:auto}.conv-item{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;transition:background var(--t);border-bottom:1px solid var(--border)}.conv-item:hover{background:var(--bg)}.conv-item.selected{background:#01568d12}.conv-avatar{width:42px;height:42px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;overflow:hidden}.conv-avatar img{width:100%;height:100%;object-fit:cover}.conv-avatar-group{display:flex;align-items:center;justify-content:center}.conv-info{flex:1;min-width:0}.conv-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.conv-name{font-weight:500;font-size:13.5px;color:var(--text-s);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-time{font-size:10.5px;color:var(--text-l);flex-shrink:0;margin-left:6px}.conv-preview{font-size:12.5px;color:var(--text-m);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-preview-bold{color:var(--text);font-weight:600}.conv-name.bold{color:var(--primary);font-weight:700}.conv-time.unread-time{color:var(--secondary);font-weight:700}.conv-item.unread{background:#01568d0a}.conv-unread-dot{position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-radius:50%;background:var(--urgent);border:2px solid var(--white);animation:pulse-badge 1.8s ease-in-out infinite}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f7f9fc}.chat-conv-header{display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--sh)}.chat-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:2px;scroll-behavior:smooth}.chat-date-sep{text-align:center;margin:14px 0 8px;font-size:11.5px;font-weight:600;color:var(--text-m);display:flex;align-items:center;gap:10px}.chat-date-sep:before,.chat-date-sep:after{content:"";flex:1;height:1px;background:var(--border)}.msg-group{margin-bottom:8px}.msg-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:2px}.msg-row.own{flex-direction:row-reverse}.msg-avatar{width:30px;height:30px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;overflow:hidden}.msg-avatar img{width:100%;height:100%;object-fit:cover}.msg-avatar.ghost{visibility:hidden}.msg-content{max-width:62%}.msg-sender-name{font-size:11px;font-weight:700;color:var(--secondary);margin-bottom:3px;padding-left:6px}.msg-bubble-wrap{position:relative}.msg-bubble{position:relative;padding:9px 14px;border-radius:18px;font-size:13.5px;line-height:1.55;word-break:break-word;box-shadow:var(--sh)}.msg-bubble.other{background:var(--white);color:var(--text);border-bottom-left-radius:4px}.msg-bubble.own{background:var(--secondary);color:#fff;border-bottom-right-radius:4px}.msg-meta{display:flex;align-items:center;gap:4px;margin-top:3px;padding:0 6px}.msg-row.own .msg-meta{justify-content:flex-end}.msg-time{font-size:10px;color:var(--text-l)}.msg-seen-icon{display:flex;align-items:center}.msg-reactions{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px;padding:0 4px}.reaction-badge{display:inline-flex;align-items:center;gap:3px;background:var(--white);border:1px solid var(--border);border-radius:99px;padding:2px 8px;font-size:12px;cursor:pointer;transition:background var(--t);-webkit-user-select:none;user-select:none;box-shadow:var(--sh)}.reaction-badge:hover{background:var(--bg)}.reaction-badge.reacted{background:#01568d1a;border-color:var(--secondary)}.reaction-count{font-size:11px;font-weight:600;color:var(--text-s)}.msg-actions{position:absolute;top:-32px;right:6px;display:none;gap:2px;background:var(--white);border:1px solid var(--border);border-radius:8px;padding:3px 5px;box-shadow:var(--sh-m);z-index:10}.msg-row.own .msg-actions{right:auto;left:6px}.msg-bubble-wrap:hover .msg-actions{display:flex}.msg-action-btn{font-size:15px;padding:2px 5px;border-radius:4px;cursor:pointer;transition:background var(--t);background:none;border:none;line-height:1}.msg-action-btn:hover{background:var(--bg)}.reaction-picker{position:absolute;top:-46px;left:0;background:var(--white);border:1px solid var(--border);border-radius:10px;padding:6px 10px;display:flex;gap:4px;box-shadow:var(--sh-m);z-index:20}.msg-row.own .reaction-picker{left:auto;right:0}.reaction-picker button{font-size:18px;background:none;border:none;cursor:pointer;border-radius:4px;padding:3px 4px;transition:background var(--t),transform var(--t)}.reaction-picker button:hover{background:var(--bg);transform:scale(1.2)}.chat-input-area{border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:flex-end;gap:10px;background:var(--white)}.chat-textarea{flex:1;resize:none;border:1px solid var(--border);border-radius:22px;padding:10px 16px;font-family:inherit;font-size:13.5px;line-height:1.5;outline:none;transition:border-color var(--t),box-shadow var(--t);max-height:120px;overflow-y:auto;background:var(--bg)}.chat-textarea:focus{border-color:var(--secondary);background:var(--white);box-shadow:0 0 0 3px #01568d1a}.chat-send-btn{width:40px;height:40px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--t)}.chat-send-btn:hover{background:var(--secondary-l)}.chat-send-btn:disabled{opacity:.45;pointer-events:none}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-m);padding:40px}.chat-empty svg{opacity:.3}.participant-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.participant-chip{display:inline-flex;align-items:center;gap:6px;background:var(--info-bg);border:1px solid rgba(59,130,246,.25);border-radius:99px;padding:3px 10px 3px 4px;font-size:12.5px;font-weight:600;color:var(--secondary)}.participant-chip-avatar{width:22px;height:22px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;overflow:hidden}.participant-chip-avatar img{width:100%;height:100%;object-fit:cover}.participant-chip-remove{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#01568d26;color:var(--secondary);border:none;cursor:pointer;transition:background var(--t);padding:0}.participant-chip-remove:hover{background:#01568d4d}.user-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:220px;background:var(--white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-m);z-index:50;max-height:280px;overflow-y:auto}.user-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background var(--t)}.user-dropdown-item:hover{background:var(--bg)}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-s);color:var(--primary);background:none;border:none;cursor:pointer;flex-shrink:0}.sidebar-overlay{display:none}@media (max-width: 768px){.mobile-menu-btn{display:flex}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:190;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.sidebar{position:fixed;top:0;left:0;width:260px;height:100dvh;z-index:200;transform:translate(-100%);transition:transform .25s ease}.sidebar.mobile-open{transform:translate(0)}.app-shell{display:block}.main-area{width:100%;min-height:100dvh}.top-header{padding:env(safe-area-inset-top) 14px 0;height:calc(54px + env(safe-area-inset-top));gap:10px;align-items:flex-end;padding-bottom:8px}.page-title{font-size:15px}.page-content{padding:14px 14px calc(80px + env(safe-area-inset-bottom))}.detail-grid,.form-row{grid-template-columns:1fr!important}.stats-grid{grid-template-columns:1fr 1fr!important}.dash-grid{grid-template-columns:1fr!important}.kanban-board{overflow-x:auto;padding-bottom:12px}.kanban-col{min-width:260px}.filter-bar{overflow-x:auto;flex-wrap:nowrap!important;padding-bottom:4px;-webkit-overflow-scrolling:touch}.filter-bar>*{flex-shrink:0}.chat-wrapper{flex-direction:column;height:auto;min-height:calc(100dvh - 54px)}.conv-sidebar{width:100%!important;height:auto;max-height:220px;border-right:none;border-bottom:1px solid var(--border)}.chat-main{flex:1;min-height:0}.chat-messages{padding:12px}.cal-grid{font-size:11px}.cal-day{min-height:60px;padding:4px}.cal-day-num{font-size:11px}.cal-event-chip{font-size:10px;padding:2px 5px}.modal-overlay{align-items:flex-end;padding:0}.modal-box{width:100%!important;max-width:100%!important;max-height:92dvh;border-radius:20px 20px 0 0;margin:0}.table-wrap,table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.btn{padding:8px 14px;font-size:13px}.btn-sm{padding:6px 10px;font-size:12px}.task-card{padding:12px}.docs-grid{grid-template-columns:1fr!important}.notif-panel{position:fixed!important;left:0!important;right:0!important;bottom:0!important;top:auto!important;width:100%!important;max-height:70vh;border-radius:20px 20px 0 0!important}.notif-toast{width:calc(100% - 24px);left:12px;right:12px}.notif-enable-btn{font-size:12px;padding:5px 8px}}.notif-bell-wrapper{position:relative}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--bg);color:var(--text-s);transition:var(--t)}.notif-bell-btn:hover{background:var(--border);color:var(--primary)}.notif-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;border-radius:8px;background:var(--urgent);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid #fff}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-l);box-shadow:var(--sh-l);display:flex;flex-direction:column;z-index:200;overflow:hidden}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px;color:var(--text)}.notif-mark-all{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--secondary);font-weight:600;padding:4px 8px;border-radius:var(--r-s);transition:var(--t)}.notif-mark-all:hover{background:var(--info-bg)}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--text-m);font-size:13px}.notif-list{list-style:none;overflow-y:auto;flex:1}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;cursor:pointer;transition:var(--t);border-bottom:1px solid var(--border);position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg)}.notif-item.notif-unread{background:var(--info-bg)}.notif-item.notif-unread:hover{background:#dbeafe}.notif-item-icon{width:32px;height:32px;border-radius:50%;background:var(--bg);color:var(--secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.notif-item.notif-unread .notif-item-icon{background:var(--secondary);color:#fff}.notif-item-content{flex:1;min-width:0}.notif-item-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-body{font-size:12px;color:var(--text-m);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-item-time{font-size:11px;color:var(--text-l);margin-top:4px;display:block}.notif-item-check{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;color:var(--text-m);flex-shrink:0;margin-top:4px;transition:var(--t)}.notif-item-check:hover{background:var(--ok-bg);color:var(--ok)}.notif-toast{position:fixed;bottom:24px;right:24px;max-width:360px;z-index:9999;background:var(--primary);color:#fff;border-radius:var(--r-l);padding:14px 16px;display:flex;align-items:flex-start;gap:12px;box-shadow:var(--sh-l);cursor:pointer;animation:slideUpToast .3s ease}@keyframes slideUpToast{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.notif-toast-icon{width:32px;height:32px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-toast-text{flex:1;min-width:0}.notif-toast-text strong{font-size:13px;display:block}.notif-toast-text p{font-size:12px;opacity:.8;margin-top:2px}.notif-toast-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;color:#fff9;flex-shrink:0;transition:var(--t)}.notif-toast-close:hover{background:#ffffff26;color:#fff}.notif-enable-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--r-s);background:var(--warn-bg);color:#92400e;font-size:12.5px;font-weight:600;border:1px solid #fcd34d;transition:var(--t)}.notif-enable-btn:hover{background:#fef3c7}div:hover>.drag-handle{opacity:1!important}.drag-handle:active{cursor:grabbing!important}
