.app{min-height:100vh;background:#f5f7fa}.app.with-sidebar{display:flex}.app.with-sidebar .main-content{flex:1;min-height:100vh;display:flex;flex-direction:column;transition:margin-left .25s ease;overflow-x:hidden}.app.with-sidebar.sidebar-open .main-content{margin-left:220px}.app.with-sidebar.sidebar-closed .main-content{margin-left:64px}@media (max-width: 1024px){.app.with-sidebar.sidebar-open .main-content,.app.with-sidebar.sidebar-closed .main-content{margin-left:0}}.login-page{min-height:100vh;display:flex;background:#f8fafc}.login-branding{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;padding:60px;position:relative;overflow:hidden}.login-branding:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.login-branding:after{content:"";position:absolute;bottom:-30%;left:-30%;width:80%;height:80%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 60%);pointer-events:none}.branding-content{position:relative;z-index:1;max-width:480px}.branding-logo{width:80px;height:80px;margin-bottom:24px}.branding-logo svg{width:100%;height:100%}.branding-title{font-size:42px;font-weight:800;color:#fff;margin:0 0 8px;letter-spacing:-.5px}.branding-tagline{font-size:20px;color:#ffffffd9;margin:0 0 48px;font-weight:400}.branding-features{display:flex;flex-direction:column;gap:24px}.feature-item{display:flex;align-items:flex-start;gap:16px}.feature-icon{width:44px;height:44px;background:#ffffff26;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon svg{width:22px;height:22px;color:#fff}.feature-text{display:flex;flex-direction:column;gap:2px}.feature-text strong{font-size:16px;font-weight:600;color:#fff}.feature-text span{font-size:14px;color:#ffffffb3}.branding-footer{position:absolute;bottom:40px;left:60px;z-index:1}.branding-footer p{margin:0;font-size:13px;color:#ffffff80}.login-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.login-form-container{width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:40px}.login-welcome{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.welcome-wave{font-size:32px;animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}.login-welcome h2{font-size:32px;font-weight:700;color:#1a1a2e;margin:0}.login-subtitle{font-size:16px;color:#64748b;margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.login-error{display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #fca5a5;border-radius:12px;color:#dc2626;font-size:14px;font-weight:500}.login-error svg{flex-shrink:0}.form-group label{font-size:14px;font-weight:600;color:#1e293b}.input-wrapper{position:relative;display:flex;align-items:center}.form-group input{width:100%;padding:16px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:inherit;color:#1e293b;transition:all .2s ease;background:#f8fafc}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.form-group input::placeholder{color:#94a3b8}.form-group input:disabled{opacity:.6;cursor:not-allowed}.password-toggle{position:absolute;right:16px;background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.password-toggle svg{width:20px;height:20px;color:#94a3b8;transition:color .2s}.password-toggle:hover svg{color:#667eea}.btn-login{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px;position:relative;overflow:hidden}.btn-login:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-login:hover:before{left:100%}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-help{text-align:center;margin-top:32px;padding-top:24px;border-top:1px solid #e2e8f0}.login-help p{margin:0;font-size:14px;color:#64748b}@media (max-width: 1024px){.login-branding{padding:40px}.branding-title{font-size:36px}.branding-footer{left:40px;bottom:30px}}@media (max-width: 768px){.login-page{flex-direction:column}.login-branding{padding:40px 24px;min-height:auto}.branding-content{max-width:100%}.branding-title{font-size:28px}.branding-tagline{font-size:16px;margin-bottom:32px}.branding-features,.branding-footer{display:none}.login-form-section{padding:40px 24px}.login-welcome h2{font-size:26px}.login-header{margin-bottom:32px}}@media (max-width: 480px){.login-branding{padding:32px 20px}.branding-logo{width:60px;height:60px}.branding-title{font-size:24px}.branding-tagline{font-size:14px}.login-form-section{padding:32px 20px}.login-welcome h2{font-size:22px}.welcome-wave{font-size:26px}.form-group input{padding:14px 14px 14px 46px;font-size:14px}.btn-login{padding:14px 20px;font-size:15px}}.app-header{height:60px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:12px}.menu-toggle{width:40px;height:40px;border:none;background:#f9fafb;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s}.menu-toggle:hover{background:#f3f4f6;color:#374151}.menu-toggle svg{width:22px;height:22px}.header-right{display:flex;align-items:center;gap:8px}.user-menu{position:relative}.user-btn{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:50px;cursor:pointer;transition:all .2s}.user-btn:hover{background:#f3f4f6;border-color:#d1d5db}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{font-size:14px;font-weight:500;color:#374151}.chevron{width:16px;height:16px;color:#9ca3af}.dropdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #0000001f;z-index:101;overflow:hidden}.dropdown-header{display:flex;align-items:center;gap:12px;padding:16px;background:#f9fafb}.dropdown-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;overflow:hidden}.dropdown-avatar img{width:100%;height:100%;object-fit:cover}.dropdown-info{flex:1;min-width:0}.dropdown-name{font-size:15px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-role{font-size:13px;color:#6b7280}.dropdown-divider{height:1px;background:#e5e7eb}.dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;color:#374151;cursor:pointer;text-decoration:none;transition:background .15s}.dropdown-item:hover{background:#f9fafb}.dropdown-item svg{width:18px;height:18px;color:#6b7280}.dropdown-item.logout{color:#dc2626}.dropdown-item.logout svg{color:#dc2626}.dropdown-item.logout:hover{background:#fef2f2}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.logout-modal{background:#fff;border-radius:16px;padding:32px;text-align:center;max-width:340px;width:100%;animation:modalIn .2s ease}.modal-icon{width:56px;height:56px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.modal-icon svg{width:28px;height:28px;color:#dc2626}.logout-modal h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.logout-modal p{font-size:14px;color:#6b7280;margin:0 0 24px}.modal-actions{display:flex;gap:12px}.btn-cancel,.btn-confirm{flex:1;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background:#f3f4f6;border:none;color:#374151}.btn-confirm{background:#dc2626;border:none;color:#fff}.btn-confirm:hover{background:#b91c1c}@media (max-width: 640px){.app-header{padding:0 12px;height:56px}.user-name{display:none}.user-btn{padding:4px;background:transparent;border:none}.chevron{display:none}.user-dropdown{width:calc(100vw - 24px);right:-6px}}.notification-wrapper{position:relative}.notification-btn{position:relative;background:#f5f7fa;border:none;border-radius:8px;padding:8px;cursor:pointer;transition:all .3s ease;color:#666;display:flex;align-items:center;justify-content:center}.notification-btn:hover{background:#e8ecf0;color:#333}.notification-badge{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;border:2px solid white;box-shadow:0 2px 4px #0003}.notification-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;width:380px;max-height:500px;overflow:hidden;z-index:1002;animation:slideDown .3s ease}.notification-header{padding:16px;border-bottom:1px solid #e8ecf0;display:flex;justify-content:space-between;align-items:center}.notification-header h3{font-size:18px;font-weight:700;color:#1a1a1a;margin:0}.mark-all-read{background:none;border:none;color:#667eea;font-size:12px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s ease}.mark-all-read:hover{background:#f5f7fa}.notification-list{max-height:400px;overflow-y:auto}.notification-item{display:flex;gap:12px;padding:12px 16px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f5f7fa}.notification-item:hover{background:#f8f9fa}.notification-item.unread{background:#f0f4ff}.notification-item.unread:hover{background:#e8edff}.notification-icon{font-size:24px;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f7fa;border-radius:50%}.notification-item.unread .notification-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.notification-content{flex:1;min-width:0}.notification-title{font-size:14px;font-weight:600;color:#1a1a1a;margin:0 0 4px}.notification-item.unread .notification-title{color:#667eea}.notification-message{font-size:13px;color:#666;margin:0 0 6px;line-height:1.4}.notification-time{font-size:11px;color:#999}.notification-empty{padding:40px 20px;text-align:center;color:#999}.empty-icon{font-size:48px;display:block;margin-bottom:12px;opacity:.5}.notification-empty p{margin:0;font-size:14px}.notification-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1001;background:transparent}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 480px){.notification-dropdown{width:calc(100vw - 30px);right:-10px}}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{background:#fff;border-radius:16px;width:90%;max-width:480px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e8ecf0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.settings-header h2{margin:0;font-size:20px;font-weight:700}.settings-close{background:#fff3;border:none;width:36px;height:36px;border-radius:50%;font-size:24px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.settings-close:hover{background:#ffffff4d;transform:rotate(90deg)}.settings-tabs{display:flex;border-bottom:1px solid #e8ecf0}.settings-tab{flex:1;padding:14px 20px;background:none;border:none;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease;border-bottom:3px solid transparent}.settings-tab:hover{background:#f5f7fa;color:#333}.settings-tab.active{color:#667eea;border-bottom-color:#667eea;background:#f0f4ff}.settings-content{padding:24px;max-height:60vh;overflow-y:auto}.settings-message{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;font-weight:500}.settings-message.success{background:#dcfce7;color:#16a34a;border:1px solid #86efac}.settings-message.error{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}.settings-avatar-section{text-align:center}.avatar-preview-container{margin-bottom:24px}.avatar-preview{width:150px;height:150px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;overflow:hidden;border:4px solid white;box-shadow:0 8px 24px #667eea4d}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-preview .avatar-initial{font-size:60px;font-weight:700;color:#fff}.avatar-hint{font-size:13px;color:#888;margin:0}.avatar-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}.btn-upload,.btn-save,.btn-remove{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-upload{background:#f0f4ff;color:#667eea}.btn-upload:hover{background:#e0e7ff}.btn-save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-remove{background:#fee2e2;color:#dc2626}.btn-remove:hover{background:#fecaca}.btn-upload:disabled,.btn-save:disabled,.btn-remove:disabled{opacity:.6;cursor:not-allowed}.avatar-info{font-size:12px;color:#999;margin:0}.settings-password-section{display:flex;flex-direction:column;gap:16px}.settings-password-section .form-group{text-align:left}.settings-password-section label{display:block;font-size:13px;font-weight:600;color:#333;margin-bottom:6px}.settings-password-section input{width:100%;padding:12px 14px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;transition:all .3s ease}.settings-password-section input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.settings-password-section input:disabled{background:#f5f7fa;cursor:not-allowed}.btn-change-password{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px}.btn-change-password:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-change-password:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 480px){.settings-modal{width:95%;margin:10px}.settings-content{padding:16px}.avatar-preview{width:120px;height:120px}.avatar-preview .avatar-initial{font-size:48px}.avatar-actions{flex-direction:column}.btn-upload,.btn-save,.btn-remove{width:100%}}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:998;opacity:0;animation:fadeIn .2s ease forwards}@keyframes fadeIn{to{opacity:1}}.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;background:#fff;border-right:1px solid #e5e7eb;z-index:999;display:flex;flex-direction:column;transition:width .25s ease;overflow:hidden}.sidebar.open{width:220px}.sidebar.closed{width:64px}.sidebar-header{padding:16px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px;border-radius:10px;transition:background .2s}.sidebar-brand:hover{background:#f9fafb}.brand-icon{width:32px;height:32px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.brand-icon svg{width:18px;height:18px;color:#fff}.brand-text{font-size:18px;font-weight:700;color:#1f2937;letter-spacing:-.5px}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto;overflow-x:hidden}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .15s ease;margin-bottom:2px;color:#6b7280}.sidebar-item:hover{background:#f3f4f6;color:#374151}.sidebar-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sidebar-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.closed .sidebar-item{justify-content:center;padding:12px}.sidebar.closed .sidebar-label{display:none}.sidebar-footer{padding:12px;border-top:1px solid #f3f4f6;flex-shrink:0}.sidebar-collapse-btn{width:100%;padding:10px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s}.sidebar-collapse-btn:hover{background:#f3f4f6;color:#374151}.sidebar-collapse-btn svg{width:18px;height:18px}.sidebar.closed .sidebar-collapse-btn{padding:10px 8px}@media (min-width: 1025px){.sidebar-overlay{display:none}}@media (max-width: 1024px){.sidebar{transform:translate(-100%);width:260px!important;box-shadow:4px 0 20px #0000001a}.sidebar.open{transform:translate(0)}.sidebar.closed{transform:translate(-100%)}}.online-users-section{position:relative;margin-bottom:10px}.online-users-btn{width:100%;padding:10px 12px;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s ease}.online-users-btn:hover{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#6ee7b7}.online-indicator{width:10px;height:10px;background:#10b981;border-radius:50%;animation:pulse-green 2s infinite;flex-shrink:0}@keyframes pulse-green{0%,to{opacity:1;box-shadow:0 0 #10b98166}50%{opacity:.8;box-shadow:0 0 0 6px #10b98100}}.online-count{font-size:16px;font-weight:700;color:#059669}.online-text{font-size:13px;font-weight:600;color:#047857}.sidebar.closed .online-users-btn{justify-content:center;padding:10px}.online-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000}.online-panel{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;background:#fff;border-radius:14px;box-shadow:0 10px 40px #00000026;border:1px solid #e5e7eb;z-index:1001;max-height:400px;display:flex;flex-direction:column;overflow:hidden;min-width:260px}.sidebar.closed .online-panel{left:8px;right:auto;width:280px}.online-panel-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #f3f4f6;background:linear-gradient(135deg,#f8fafc,#fff)}.online-panel-header h4{font-size:15px;font-weight:700;color:#1f2937;margin:0}.close-panel-btn{width:28px;height:28px;background:#f3f4f6;border:none;border-radius:8px;font-size:20px;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-panel-btn:hover{background:#e5e7eb;color:#374151}.online-panel-content{padding:12px;overflow-y:auto;max-height:320px}.online-group{margin-bottom:16px}.online-group:last-child{margin-bottom:0}.group-label{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;padding:0 4px}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.online{background:#10b981}.status-dot.offline{background:#9ca3af}.online-user-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;transition:background .2s;cursor:default}.online-user-item:hover{background:#f9fafb}.online-user-item.offline{opacity:.7}.user-avatar-mini{position:relative;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;flex-shrink:0;overflow:hidden}.user-avatar-mini img{width:100%;height:100%;object-fit:cover}.avatar-status{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid white}.avatar-status.online{background:#10b981}.user-info-mini{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.user-name-mini{font-size:13px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-mini{font-size:11px;color:#10b981;font-weight:500}.user-lastseen{font-size:11px;color:#9ca3af}.more-users{text-align:center;font-size:12px;color:#6b7280;padding:8px;font-style:italic}.no-users{text-align:center;padding:20px;color:#9ca3af;font-size:13px}.dashboard{flex:1;padding:24px;overflow-x:hidden}.dashboard-container{max-width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}.dashboard-header-left{display:flex;align-items:center;gap:16px}.dashboard-title{font-size:24px;font-weight:700;color:#1f2937;margin:0}.dashboard-header-right{display:flex;align-items:center;gap:12px}.view-toggle{display:flex;background:#f3f4f6;border-radius:8px;padding:4px}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:32px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s}.view-toggle-btn:hover{color:#374151}.view-toggle-btn.active{background:#fff;color:#667eea;box-shadow:0 1px 3px #0000001a}.view-toggle-btn svg{width:18px;height:18px}.btn-export-excel{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #10b9814d}.btn-export-excel:hover{transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.btn-export-excel:active{transform:translateY(0)}.btn-export-excel svg{width:18px;height:18px}.btn-add-project{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.btn-add-project:hover{transform:translateY(-1px);box-shadow:0 6px 16px #667eea66}.btn-add-project:active{transform:translateY(0)}.btn-icon{font-size:18px;line-height:1}.no-results{background:#fff;border-radius:12px;padding:48px 24px;text-align:center;border:1px solid #e5e7eb}.no-results-icon{font-size:48px;margin-bottom:16px;opacity:.5}.no-results h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.no-results p{font-size:14px;color:#6b7280;margin:0}@media (max-width: 768px){.dashboard{padding:16px}.dashboard-header{flex-direction:column;align-items:stretch;gap:12px}.dashboard-title{font-size:20px}.btn-add-project{width:100%;justify-content:center}}.status-nav{width:100%;background:#fff;border-radius:12px;padding:8px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;overflow-x:auto}.status-nav-container{display:flex;gap:4px;min-width:fit-content}.status-nav-item{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-size:14px;font-weight:500;color:#666;position:relative;min-width:fit-content}.status-nav-item:hover{background:#f5f7fa;color:#333}.status-nav-item.active{color:#667eea;font-weight:600}.status-nav-item.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px 3px 0 0}.status-icon{font-size:18px;line-height:1}.status-label{flex:1}.status-count{background:#e8ecf0;color:#666;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600;min-width:24px;text-align:center}.status-nav-item.active .status-count{background:#667eea;color:#fff}@media (max-width: 768px){.status-nav{margin-bottom:15px;padding:6px}.status-nav-item{padding:10px 12px;font-size:12px;gap:6px}.status-icon{font-size:16px}.status-count{font-size:11px;padding:2px 6px;min-width:20px}}@media (max-width: 480px){.status-nav-item{padding:8px 10px;font-size:11px}.status-label{display:none}.status-nav-item{flex-direction:column;gap:4px}}.filter-bar{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;display:flex;gap:20px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:200px}.filter-group label{font-size:13px;font-weight:600;color:#333}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;font-size:16px;pointer-events:none;z-index:1}.search-input{width:100%;padding:12px 12px 12px 40px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea}.clear-search{position:absolute;right:10px;background:#e8ecf0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:#666;transition:all .2s ease;z-index:1}.clear-search:hover{background:#d1d9e0;color:#333}.filter-select{padding:12px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-family:inherit;background:#fff;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:#667eea}.filter-reset{display:flex;align-items:center}.btn-reset{padding:12px 20px;background:#e8ecf0;color:#666;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-reset:hover{background:#d1d9e0;color:#333}@media (max-width: 768px){.filter-bar{flex-direction:column;align-items:stretch}.filter-group{min-width:100%}.filter-reset{justify-content:flex-start}.btn-reset{width:100%}}.project-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;margin-top:20px}.project-table{width:100%;border-collapse:collapse;font-size:14px}.project-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.project-table th{padding:14px 12px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.project-table tbody tr{border-bottom:1px solid #e8ecf0;transition:all .2s ease}.project-table tbody tr:hover{background:#f8f9fa}.project-table td{padding:12px;vertical-align:top;color:#333}.table-number{text-align:center;color:#999;font-weight:600;width:50px}.table-name{font-weight:600;color:#1a1a1a;min-width:150px}.project-name-link{color:#667eea;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block}.project-name-link:hover{color:#764ba2;text-decoration:underline;transform:translate(2px)}.type-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.status-ql-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:700;white-space:nowrap;border:1px solid transparent}.status-ql-badge.not-started{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.status-ql-badge.in-progress{background:#e0f2fe;color:#0369a1;border-color:#7dd3fc}.status-ql-badge.review{background:#fff7ed;color:#9a3412;border-color:#fdba74}.status-ql-badge.diundur{background:#fee2e2;color:#991b1b;border-color:#fecaca}.table-nilai-penawaran{white-space:nowrap}.nilai-penawaran-badge{display:inline-block;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600;background:linear-gradient(135deg,#10b981,#059669);color:#fff;letter-spacing:.3px}.lead-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.lead-badge.belum-dikerjakan{background:#f3f4f6;color:#4b5563;border:1px solid #9ca3af}.lead-badge.sedang-dikerjakan{background:#dbeafe;color:#1d4ed8;border:1px solid #3b82f6}.lead-badge.review{background:#fef3c7;color:#b45309;border:1px solid #f59e0b}.lead-badge.tidak-deal{background:#fee2e2;color:#dc2626;border:1px solid #ef4444}.lead-badge.deal{background:#dcfce7;color:#16a34a;border:1px solid #22c55e}.table-description{max-width:280px}.description-text{white-space:pre-line;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;color:#374151}.table-client{max-width:220px}.client-name{display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1f2937}.pic-list{display:flex;flex-wrap:wrap;gap:4px}.pic-tag{display:inline-block;background:#e8edff;color:#667eea;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:600;white-space:nowrap}.table-actions{white-space:nowrap}.action-buttons{display:flex;gap:6px;align-items:center}.btn-action{background:none;border:1px solid #e8ecf0;border-radius:6px;padding:6px 10px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;gap:4px}.btn-action.btn-move{padding:8px 12px;min-width:40px;height:40px;font-weight:700;display:flex;align-items:center;justify-content:center}.btn-move-icon{font-size:20px;font-weight:700;line-height:1;color:inherit}.btn-move.btn-prev{background:#6c757d;color:#fff;border:none}.btn-move.btn-prev:hover{background:#5a6268;border-color:transparent;transform:translateY(-1px);box-shadow:0 2px 8px #6c757d4d}.btn-move.btn-next{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.btn-move.btn-next:hover{background:linear-gradient(135deg,#5568d3,#653a8f);border-color:transparent;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-upload{background:#f0f4ff;border:1px solid #667eea;color:#667eea;font-size:18px}.btn-upload:hover{background:#667eea;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.btn-documentation{background:#f0f9ff;border:1px solid #10b981;color:#10b981;font-size:18px}.btn-documentation:hover{background:#10b981;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #10b9814d}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1118278c;display:flex;align-items:center;justify-content:center;z-index:2500;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-container{background:#fff;border-radius:16px;width:100%;max-width:720px;max-height:92vh;overflow:hidden;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;animation:slideUp .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 22px;background:linear-gradient(135deg,#eef2ff,#f5f3ff);border-bottom:1px solid #e5e7eb}.modal-close-btn{background:#eef2ff;border:none;border-radius:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#4f46e5;cursor:pointer;transition:all .2s ease}.modal-close-btn:hover{background:#e0e7ff;transform:rotate(90deg)}.modal-content{padding:20px 22px}.modal-edit-scrollable{max-height:90vh}.modal-edit-scrollable .modal-content-scrollable{max-height:calc(90vh - 140px);overflow-y:auto;padding:20px 22px}.modal-edit-scrollable .modal-content-scrollable::-webkit-scrollbar{width:6px}.modal-edit-scrollable .modal-content-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.modal-edit-scrollable .modal-content-scrollable::-webkit-scrollbar-thumb{background:#c4c4c4;border-radius:3px}.modal-edit-scrollable .modal-content-scrollable::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 22px;border-top:1px solid #e5e7eb;background:#fafafa}.btn-primary{background:linear-gradient(135deg,#6366f1,#7c3aed);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 18px #6366f140}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c)!important;box-shadow:0 8px 18px #ef44444d}.btn-danger:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280)!important;opacity:.6;cursor:not-allowed}.delete-warning{padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;margin-bottom:20px}.warning-text{margin:0 0 8px;font-size:15px;font-weight:600;color:#991b1b}.warning-text strong{color:#dc2626}.warning-subtext{margin:0;font-size:13px;color:#7f1d1d;line-height:1.5}.btn-secondary{background:#f3f4f6;color:#111827;border:1px solid #e5e7eb;border-radius:10px;padding:10px 16px;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease}.btn-secondary:hover{background:#e5e7eb;transform:translateY(-1px)}@media (max-width: 640px){.modal-container{max-width:100%;border-radius:12px}.modal-header,.modal-content{padding:16px}.modal-footer{padding:14px 16px}}.modal-title{font-size:20px;font-weight:800;margin:0}.modal-subtitle{margin:6px 0 18px;color:#6b7280;font-size:13px}.modal-project-header{display:flex;align-items:center;gap:10px;margin:4px 0 18px;flex-wrap:wrap}.project-name-chip{max-width:100%;display:inline-block;padding:8px 12px;border-radius:10px;background:#f3f4f6;color:#111827;font-weight:700;font-size:14px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-ql-chip{display:inline-block;padding:6px 10px;border-radius:999px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:800;font-size:12px}@media (max-width: 640px){.project-name-chip{width:100%}}.input-group{position:relative;display:flex;align-items:center}.input-group.has-icon .form-input{padding-left:38px}.input-icon{position:absolute;left:12px;color:#667eea;font-size:16px}.form-group{margin-bottom:18px}.form-group:last-child{margin-bottom:0}.document-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.required-mark{color:#ef4444;margin-left:2px}.form-input{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#111827;background:#fff;transition:all .2s ease;font-family:inherit}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input::placeholder{color:#9ca3af}.form-input[type=select],.form-input select{cursor:pointer}.form-input textarea{resize:vertical;min-height:80px}.pagination{display:flex;justify-content:space-between;align-items:center;padding:20px;border-top:1px solid #e8ecf0;flex-wrap:wrap;gap:10px}.pagination-pages{display:flex;gap:6px;align-items:center}.pagination-btn{padding:8px 12px;border:1px solid #e8ecf0;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .2s ease;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:#f5f7fa;border-color:#667eea;color:#667eea}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.pagination-ellipsis{padding:0 4px;color:#999}.table-info{padding:12px 20px;background:#f8f9fa;border-top:1px solid #e8ecf0;font-size:13px;color:#666;text-align:center}@media (max-width: 1200px){.project-table{font-size:13px}.project-table th,.project-table td{padding:10px 8px}}@media (max-width: 768px){.project-table-container{border-radius:8px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.project-table{min-width:1000px;font-size:12px}.project-table th,.project-table td{padding:8px 6px;font-size:12px}.project-table th{font-size:11px;padding:10px 6px}.action-buttons{flex-direction:column;gap:6px}.btn-action{min-width:28px;height:28px;padding:4px 6px;font-size:12px}.btn-action.btn-move{width:100%;justify-content:center;padding:8px 12px;min-width:36px;height:36px}.btn-move-icon{font-size:18px}.pagination{justify-content:center;padding:15px}.pagination-pages{order:1;width:100%;justify-content:center;margin:10px 0;flex-wrap:wrap}.pagination-btn{min-width:32px;height:32px;padding:6px 10px;font-size:12px}.pagination-btn:first-child,.pagination-btn:last-child{order:0}.table-info{font-size:11px;padding:10px 15px}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2500;padding:20px;animation:fadeIn .3s ease}.confirm-modal-container{background:#fff;border-radius:16px;width:100%;max-width:480px;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease;overflow:hidden}.confirm-modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px;text-align:center}.confirm-icon{font-size:48px;margin-bottom:10px}.confirm-modal-header h2{font-size:22px;font-weight:700;margin:0}.confirm-modal-content{padding:30px 25px}.confirm-message{text-align:center;font-size:16px;color:#666;margin:0 0 25px}.status-flow{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:20px;padding:20px;background:#f8f9fa;border-radius:12px}.status-item{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.status-dot{width:16px;height:16px;border-radius:50%;display:block}.status-item.current .status-dot{background:#6c757d;box-shadow:0 0 0 4px #6c757d33}.status-item.next .status-dot{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 0 0 4px #667eea33;animation:pulse 2s infinite}.status-label{font-size:13px;font-weight:600;color:#333;text-align:center}.status-item.current .status-label{color:#6c757d}.status-item.next .status-label{color:#667eea}.status-arrow{font-size:24px;color:#667eea;font-weight:700}.project-name-display{text-align:center;padding:15px;background:#f0f4ff;border-radius:8px;border-left:4px solid #667eea}.project-name-display strong{font-size:16px;color:#1a1a1a}.confirm-modal-actions{display:flex;gap:12px;padding:20px 25px;background:#f8f9fa;border-top:1px solid #e8ecf0}.btn-confirm-cancel,.btn-confirm-ok{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-confirm-cancel{background:#fff;color:#666;border:2px solid #e8ecf0}.btn-confirm-cancel:hover{background:#f5f7fa;border-color:#d1d9e0}.btn-confirm-ok{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-confirm-ok:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@keyframes pulse{0%,to{box-shadow:0 0 0 4px #667eea33}50%{box-shadow:0 0 0 8px #667eea1a}}@media (max-width: 480px){.confirm-modal-container{max-width:100%}.status-flow{flex-direction:column;gap:10px}.status-arrow{transform:rotate(90deg)}}.upload-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2600;padding:20px;animation:fadeIn .3s ease}.upload-modal-container{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease}.upload-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e8ecf0;position:sticky;top:0;background:#fff;z-index:1}.upload-modal-header h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0}.upload-modal-content{padding:24px}.upload-info{margin-bottom:25px;padding:15px;background:#f0f4ff;border-radius:8px;border-left:4px solid #667eea}.upload-info p{margin:5px 0;font-size:14px;color:#333}.upload-hint{font-size:12px;color:#666!important;margin-top:8px!important}.upload-progress-container{margin-bottom:20px;padding:16px;background:#f0f4ff;border-radius:12px;border:1px solid #c7d2fe}.upload-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.upload-progress-text{font-size:14px;font-weight:600;color:#4f46e5;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:12px}.upload-progress-percentage{font-size:14px;font-weight:700;color:#6366f1;min-width:45px;text-align:right}.upload-progress-bar-wrapper{width:100%;height:8px;background:#e0e7ff;border-radius:10px;overflow:hidden;position:relative}.upload-progress-bar{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6,#a855f7);border-radius:10px;transition:width .3s ease;position:relative;animation:progressPulse 1.5s ease-in-out infinite}.upload-progress-bar:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.document-upload-list{display:flex;flex-direction:column;gap:20px}.document-item{border:2px solid #e8ecf0;border-radius:12px;padding:18px;transition:all .3s ease}.document-item.required{border-color:#ffc107;background:#fffbf0}.document-item.optional{border-color:#e8ecf0;background:#fafafa}.document-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.document-label{font-size:15px;font-weight:600;color:#333;cursor:pointer}.required-mark{color:#dc3545;font-weight:700}.optional-mark{color:#999;font-size:13px;font-weight:400}.document-status{font-size:12px;padding:4px 10px;border-radius:12px;font-weight:600}.document-status.uploaded{background:#d4edda;color:#155724}.file-input-wrapper{position:relative}.file-input{position:absolute;width:0;height:0;opacity:0;overflow:hidden;z-index:-1}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px;border:2px dashed #667eea;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;gap:8px;text-align:center}.file-upload-label:hover{background:#f8f9ff;border-color:#5568d3}.upload-icon{font-size:32px}.file-upload-label span:not(.upload-icon){font-size:14px;color:#667eea;font-weight:500}.file-name-display{display:flex;align-items:center;gap:10px;padding:12px;background:#e8edff;border:1px solid #667eea;border-radius:8px}.file-icon{font-size:20px}.file-name{flex:1;font-size:14px;color:#333;font-weight:500;word-break:break-all;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.file-status-badge{font-size:11px;color:#28a745;font-weight:600;padding:2px 6px;background:#d4edda;border-radius:4px;white-space:nowrap}.file-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.file-remove{background:#dc3545;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;font-weight:700;line-height:1;transition:all .2s ease;flex-shrink:0}.file-remove:hover{background:#c82333;transform:scale(1.1)}.file-reupload-btn{background:#667eea;color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:inline-block}.file-reupload-btn:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 6px #667eea4d}.mom-input-wrapper{display:flex;flex-direction:column;gap:8px}.mom-textarea{width:100%;padding:12px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-family:inherit;line-height:1.6;resize:vertical;min-height:150px;transition:all .3s ease}.mom-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.mom-textarea::placeholder{color:#999;font-style:italic}.mom-info{padding-top:4px}.mom-info small{font-size:11px;color:#667eea;font-style:italic}.upload-modal-actions{display:flex;gap:12px;padding:20px 24px;background:#f8f9fa;border-top:1px solid #e8ecf0;position:sticky;bottom:0}.btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280)}@media (max-width: 768px){.upload-modal-container{max-width:100%;max-height:95vh}.upload-modal-header,.upload-modal-content,.file-upload-label{padding:20px}}.project-detail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2700;padding:20px;animation:fadeIn .3s ease}.project-detail-modal-container{background:#fff;border-radius:16px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease;display:flex;flex-direction:column}.project-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px;border-bottom:1px solid #e8ecf0;position:sticky;top:0;background:#fff;z-index:1}.project-detail-title-section{display:flex;flex-direction:column;gap:12px;flex:1}.project-detail-title-section h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0}.project-status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;width:fit-content}.project-status-badge.status-leads-masuk{background:#e3f2fd;color:#1976d2}.project-status-badge.status-proses-ql{background:#fff3e0;color:#f57c00}.project-status-badge.status-deal-running{background:#e8f5e9;color:#388e3c}.project-status-badge.status-finish-penagihan{background:#f3e5f5;color:#7b1fa2}.project-status-badge.status-done-full-payment{background:#e0f2f1;color:#00796b}.modal-close-btn{background:#f5f7fa;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .3s ease;flex-shrink:0}.modal-close-btn:hover{background:#e8ecf0;color:#333}.project-detail-content{padding:24px;flex:1}.detail-section{margin-bottom:28px}.detail-section:last-child{margin-bottom:0}.detail-section-title{font-size:18px;font-weight:700;color:#1a1a1a;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #f0f4ff}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:14px;color:#333;font-weight:500}.detail-description{padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea;font-size:14px;color:#333;line-height:1.6;white-space:pre-wrap}.detail-item.full-width{grid-column:1 / -1}.pic-list-detail{display:flex;flex-wrap:wrap;gap:8px}.pic-badge-detail{display:inline-block;padding:8px 14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:13px;font-weight:600}.detail-empty{color:#999;font-style:italic;font-size:14px}.documents-list{display:flex;flex-direction:column;gap:20px}.document-type-section{background:#f8f9fa;border-radius:12px;border:1px solid #e8ecf0;padding:16px;transition:all .2s ease}.document-type-section:hover{box-shadow:0 2px 8px #0000000d}.documents-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:16px;flex-wrap:wrap}.btn-download-all{padding:10px 18px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn-download-all:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.document-type-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid #e8ecf0;gap:12px}.document-header-actions{display:flex;align-items:center;gap:10px}.document-type-label{font-size:16px;font-weight:700;color:#1a1a1a;text-transform:uppercase;letter-spacing:.5px;flex:1}.btn-download-file{padding:6px 12px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:4px}.btn-download-file:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 6px #667eea4d}.document-type-status{font-size:12px;padding:4px 10px;border-radius:12px;font-weight:600}.document-type-status.uploaded{background:#d4edda;color:#155724}.document-type-status.not-uploaded{background:#fff3cd;color:#856404}.document-file-item{display:flex;align-items:flex-start;gap:12px;padding:10px;background:#fff;border-radius:8px;border:1px solid #e8ecf0}.document-file-item.document-file-empty{background:#f8f9fa;border:1px dashed #dee2e6;opacity:.8}.document-file-item.document-file-empty .document-file-name{color:#6c757d;font-style:italic}.document-file-icon{font-size:24px;flex-shrink:0;margin-top:2px}.document-file-info{flex:1;display:flex;flex-direction:column;gap:6px}.document-file-name{font-size:14px;font-weight:600;color:#333;word-break:break-all;line-height:1.4}.document-file-name.document-file-clickable{color:#667eea;cursor:pointer;transition:all .2s ease;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}.document-file-name.document-file-clickable:hover{color:#764ba2;text-decoration-style:solid}.document-file-uploader{font-size:12px;color:#666;display:flex;align-items:center;gap:4px;flex-wrap:wrap}.document-uploader strong{color:#667eea;font-weight:600}.uploader-link,.creator-link{color:#667eea;text-decoration:none;font-weight:600;transition:all .2s ease}.uploader-link:hover,.creator-link:hover{color:#764ba2;text-decoration:underline}.uploader-link strong{color:inherit}.documents-summary{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:10px;text-align:center;margin-top:20px;font-size:15px;box-shadow:0 4px 12px #667eea33}.documents-summary strong{font-weight:600;letter-spacing:.5px}.documents-empty{text-align:center;padding:20px;color:#999;font-style:italic;font-size:14px}.mom-display{margin-top:12px;padding:10px;background:#fff;border-radius:8px;border:1px solid #e8ecf0}.mom-content{font-size:13px;line-height:1.8;color:#333;white-space:pre-wrap;word-wrap:break-word;font-family:inherit;margin:0;padding:0;background:transparent;border:none;max-height:400px;overflow-y:auto}.mom-updated-at{color:#999;font-size:11px;font-style:italic}.lead-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.project-detail-footer{padding:20px 24px;border-top:1px solid #e8ecf0;display:flex;justify-content:flex-end;position:sticky;bottom:0;background:#fff}.btn-close-detail{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-close-detail:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.assign-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.assign-modal-container{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow:hidden;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column}.assign-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e8ecf0}.assign-modal-header h3{margin:0;font-size:20px;color:#1a1a1a}.assign-modal-close{background:none;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.assign-modal-close:hover{background:#f0f0f0}.assign-modal-content{padding:20px;flex:1;overflow-y:auto}.assign-modal-content p{margin:0 0 15px;color:#555;font-size:14px}.assign-employee-select{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.assign-employee-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.assign-modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px;border-top:1px solid #e8ecf0}.btn-cancel{padding:10px 20px;background:#f5f5f5;color:#333;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-cancel:hover{background:#e0e0e0}.btn-assign{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-assign:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.btn-assign:disabled{opacity:.5;cursor:not-allowed}.btn-assign-document{padding:6px 12px;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:4px}.btn-assign-document:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 2px 6px #f59e0b4d}.document-assignment-info{display:block;margin-top:8px;font-size:13px;color:#666}.assignment-assigned-by{color:#999;font-style:italic}@media (max-width: 768px){.project-detail-modal-container{max-width:100%;max-height:95vh}.project-detail-header,.project-detail-content,.project-detail-footer{padding:20px}.detail-grid{grid-template-columns:1fr}.project-detail-title-section h2{font-size:20px}}.comment-section{border-top:1px solid #e5e7eb;padding-top:16px;margin-top:16px}.comment-header{margin-bottom:16px}.comment-header h4{margin:0;font-size:16px;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:8px}.comment-loading{text-align:center;padding:24px;color:#6b7280}.comment-list{max-height:400px;overflow-y:auto;padding-right:8px;margin-bottom:16px}.comment-empty{text-align:center;padding:32px 16px;color:#9ca3af;font-size:14px;background:#f9fafb;border-radius:8px}.comment-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid #f3f4f6}.comment-item:last-of-type{border-bottom:none}.comment-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.comment-avatar img{width:100%;height:100%;object-fit:cover}.comment-avatar span{color:#fff;font-size:12px;font-weight:600}.comment-avatar-clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.comment-avatar-clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.comment-content{flex:1;min-width:0}.comment-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.comment-author{font-weight:600;font-size:14px;color:#1f2937}.comment-author-clickable{cursor:pointer;transition:color .2s}.comment-author-clickable:hover{color:#3b82f6;text-decoration:underline}.comment-time{font-size:12px;color:#9ca3af}.comment-edited{font-size:11px;color:#9ca3af;font-style:italic}.comment-text{font-size:14px;color:#374151;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.comment-mention{color:#3b82f6;font-weight:500;background:#eff6ff;padding:1px 4px;border-radius:4px}.comment-mention-link{cursor:pointer;transition:all .2s}.comment-mention-link:hover{background:#dbeafe;text-decoration:underline}.comment-item.comment-highlighted{background:#fef3c7;animation:highlight-fade 3s ease-out}@keyframes highlight-fade{0%{background:#fef3c7}to{background:transparent}}.comment-actions{display:flex;gap:12px;margin-top:6px}.comment-action-btn{background:none;border:none;padding:0;font-size:12px;color:#6b7280;cursor:pointer;transition:color .2s}.comment-action-btn:hover{color:#3b82f6}.comment-action-delete:hover{color:#ef4444}.comment-edit-form{margin-top:8px}.comment-edit-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;resize:none;font-family:inherit;min-height:60px}.comment-edit-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.comment-edit-actions{display:flex;gap:8px;margin-top:8px}.comment-btn-save,.comment-btn-cancel{padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.comment-btn-save{background:#3b82f6;color:#fff;border:none}.comment-btn-save:hover{background:#2563eb}.comment-btn-cancel{background:#fff;color:#6b7280;border:1px solid #d1d5db}.comment-btn-cancel:hover{background:#f3f4f6}.comment-form{display:flex;gap:12px;align-items:flex-end;padding-top:12px;border-top:1px solid #e5e7eb}.comment-input-wrapper{flex:1;position:relative}.comment-input{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;resize:none;font-family:inherit;transition:border-color .2s,box-shadow .2s}.comment-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.comment-input:disabled{background:#f9fafb;cursor:not-allowed}.comment-input::placeholder{color:#9ca3af}.comment-submit-btn{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.comment-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.comment-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.mention-dropdown{position:absolute;bottom:100%;left:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 16px #0000001f;max-height:200px;overflow-y:auto;z-index:100;min-width:200px;margin-bottom:4px}.mention-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s}.mention-item:hover{background:#f3f4f6}.mention-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;overflow:hidden}.mention-avatar img{width:100%;height:100%;object-fit:cover}.mention-avatar span{color:#fff;font-size:10px;font-weight:600}.mention-name{font-size:14px;color:#374151}@media (max-width: 640px){.comment-form{flex-direction:column;align-items:stretch}.comment-submit-btn{width:100%}.comment-list{max-height:300px}}.comment-thread{margin-bottom:8px}.comment-reply{margin-left:48px;border-left:2px solid #e5e7eb;padding:10px 0 10px 16px}.comment-reply .comment-avatar{width:28px;height:28px}.comment-reply .comment-avatar span{font-size:10px}.replies-toggle{display:flex;align-items:center;gap:6px;margin-left:48px;padding:8px 12px;background:none;border:none;color:#667eea;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.replies-toggle:hover{color:#764ba2;background:#f3f4f6;border-radius:6px}.replies-list{margin-top:4px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.reply-form{margin-left:48px;margin-top:8px;padding:12px;background:#f9fafb;border-radius:10px;animation:slideDown .2s ease}.reply-input-wrapper{display:flex;gap:10px;margin-bottom:10px}.reply-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.reply-avatar img{width:100%;height:100%;object-fit:cover}.reply-avatar span{color:#fff;font-size:10px;font-weight:600}.reply-input{flex:1;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;resize:none;transition:all .2s}.reply-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.reply-actions{display:flex;justify-content:flex-end;gap:8px}.reply-cancel-btn,.reply-submit-btn{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.reply-cancel-btn{background:#fff;border:1px solid #e5e7eb;color:#6b7280}.reply-cancel-btn:hover{background:#f3f4f6}.reply-submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.reply-submit-btn:hover:not(:disabled){opacity:.9}.reply-submit-btn:disabled{opacity:.5;cursor:not-allowed}.comment-action-reply{display:flex;align-items:center;gap:4px}.comment-action-reply svg{flex-shrink:0}@media (max-width: 640px){.comment-reply{margin-left:24px;padding-left:12px}.replies-toggle{margin-left:24px}.reply-form{margin-left:24px;padding:10px}.reply-avatar{display:none}}.kanban-board{width:100%;overflow-x:auto;padding-bottom:20px}.kanban-columns{display:flex;gap:16px;min-width:max-content;padding:4px}.kanban-column{width:300px;min-width:300px;background:#f9fafb;border-radius:12px;display:flex;flex-direction:column;max-height:calc(100vh - 280px);transition:all .2s ease}.kanban-column.drag-over{background:#eff6ff;box-shadow:inset 0 0 0 2px #3b82f6}.column-header{padding:16px;border-bottom:2px solid var(--column-color, #667eea);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.column-title{display:flex;align-items:center;gap:8px}.column-icon{font-size:18px}.column-name{font-size:14px;font-weight:600;color:#1f2937}.column-count{background:#e5e7eb;color:#4b5563;padding:4px 10px;border-radius:20px;font-size:13px;font-weight:600}.column-content{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.column-empty{display:flex;align-items:center;justify-content:center;height:100px;color:#9ca3af;font-size:13px;border:2px dashed #e5e7eb;border-radius:8px}.kanban-card{background:#fff;border-radius:10px;padding:14px;cursor:grab;border:1px solid #e5e7eb;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.kanban-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.kanban-card.dragging{opacity:.5;cursor:grabbing;transform:rotate(3deg)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.card-type{font-size:11px;font-weight:600;text-transform:uppercase;color:#6b7280;background:#f3f4f6;padding:3px 8px;border-radius:4px}.card-ql{font-size:11px;font-weight:600;color:#7c3aed;background:#ede9fe;padding:3px 8px;border-radius:4px}.card-title{font-size:14px;font-weight:600;color:#1f2937;margin:0 0 10px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-client{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280;margin-bottom:12px}.card-client svg{width:14px;height:14px;flex-shrink:0}.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid #f3f4f6}.card-pics{display:flex;align-items:center}.pic-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;margin-right:-8px;border:2px solid white;overflow:hidden}.pic-avatar img{width:100%;height:100%;object-fit:cover}.pic-more{width:28px;height:28px;border-radius:50%;background:#e5e7eb;color:#6b7280;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;border:2px solid white}.card-value{font-size:12px;font-weight:600;color:#059669}.column-content::-webkit-scrollbar{width:6px}.column-content::-webkit-scrollbar-track{background:transparent}.column-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.column-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 768px){.kanban-column{width:280px;min-width:280px;max-height:calc(100vh - 240px)}.column-header{padding:12px}.column-name{font-size:13px}.kanban-card{padding:12px}.card-title{font-size:13px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.ql-status-modal{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:400px;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ql-status-modal h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.ql-status-modal p{font-size:14px;color:#6b7280;margin:0 0 20px}.ql-status-modal .form-group{margin-bottom:16px}.ql-status-modal label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.ql-status-modal input,.ql-status-modal select{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s}.ql-status-modal input:focus,.ql-status-modal select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.ql-status-modal .modal-actions{display:flex;gap:12px;margin-top:24px}.ql-status-modal .btn-cancel,.ql-status-modal .btn-confirm{flex:1;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.ql-status-modal .btn-cancel{background:#f3f4f6;border:none;color:#374151}.ql-status-modal .btn-cancel:hover{background:#e5e7eb}.ql-status-modal .btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.ql-status-modal .btn-confirm:hover{opacity:.9}.ql-auto-note{background:#dbeafe;color:#1e40af;padding:8px 12px;border-radius:6px;font-size:12px;margin:0 0 16px}.ql-status-modal .form-hint{display:block;font-size:11px;color:#6b7280;margin-top:4px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}.modal-container{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e8ecf0;position:sticky;top:0;background:#fff;z-index:1;border-radius:16px 16px 0 0}.modal-header h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0}.modal-close{background:#f5f7fa;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .3s ease}.modal-close:hover{background:#e8ecf0;color:#333}.modal-form{padding:24px;display:flex;flex-direction:column;gap:24px;flex:1;overflow-y:auto;min-height:0}.form-section{padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e8ecf0}.section-title{font-size:16px;font-weight:700;color:#333;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #667eea}.form-group input,.form-group textarea,.form-group select{padding:12px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-hint{font-size:12px;color:#999;margin-top:-4px}.pic-project-selector{display:flex;flex-direction:column;gap:12px}.pic-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.pic-option{display:flex;align-items:center;gap:8px;padding:10px 12px;border:2px solid #e8ecf0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.pic-option:hover{border-color:#667eea;background:#f8f9ff}.pic-option.selected{border-color:#667eea;background:#f0f4ff}.pic-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.pic-option-label{font-size:14px;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none}.selected-pics{padding-top:8px;border-top:1px solid #e8ecf0}.info-icon{margin-left:8px;cursor:help;font-size:14px;opacity:.7}.lead-info{margin-top:10px;padding:12px;border-radius:8px;font-size:13px;line-height:1.6}.lead-info.cold-prospect{background:#fff3cd;border:1px solid #ffc107;color:#856404}.lead-info.hot-prospect{background:#d4edda;border:1px solid #28a745;color:#155724}.lead-info strong{display:block;margin-bottom:6px;font-size:14px}.lead-info p{margin:0;font-size:12px}.lead-info-help{margin-top:8px;padding:10px;background:#f8f9fa;border-radius:6px;font-size:12px;color:#666;line-height:1.6}.lead-info-help p{margin:4px 0}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding:12px 24px;border-top:1px solid #e8ecf0;background:#fff;position:sticky;bottom:0;z-index:1}@media (max-width: 768px){.modal-overlay{padding:10px}.modal-container{max-height:95vh}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-form{padding:20px}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.btn{width:100%}}.client-search-group,.client-search-wrapper{position:relative}.new-client-badge{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:11px;padding:4px 8px;border-radius:4px;font-weight:600}.client-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:100;max-height:200px;overflow-y:auto;margin-top:4px}.client-dropdown-item{padding:12px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;border-bottom:1px solid #f3f4f6;transition:background .2s}.client-dropdown-item:last-child{border-bottom:none}.client-dropdown-item:hover{background:#f3f4f6}.client-dropdown-item .client-name{font-weight:600;color:#1f2937;flex:1}.client-dropdown-item .client-industry{font-size:11px;background:#e0e7ff;color:#4f46e5;padding:2px 6px;border-radius:4px}.client-dropdown-item .client-projects{font-size:11px;color:#6b7280}.contact-options{display:flex;flex-direction:column;gap:8px}.contact-option{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s}.contact-option:hover{background:#f3f4f6}.contact-option.selected{background:#eff6ff;border-color:#3b82f6}.contact-option input[type=radio]{width:18px;height:18px;accent-color:#3b82f6}.contact-info{display:flex;flex-wrap:wrap;align-items:center;gap:8px;flex:1}.contact-info .contact-name{font-weight:600;color:#1f2937}.contact-info .contact-position{font-size:12px;color:#6b7280}.contact-info .contact-phone{font-size:12px;color:#667eea}.contact-info .primary-tag{font-size:10px;background:#10b981;color:#fff;padding:2px 6px;border-radius:4px;font-weight:600}.contact-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.contact-header label{margin:0}.btn-add-new-contact{background:#e0e7ff;color:#4f46e5;border:none;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s}.btn-add-new-contact:hover{background:#c7d2fe}.new-contact-form{background:#f9fafb;padding:12px;border-radius:8px;margin-bottom:12px}.new-contact-form .contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.new-contact-form input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:13px}.new-contact-form input:focus{outline:none;border-color:#667eea}.btn-save-contact{width:100%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:10px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-save-contact:hover:not(:disabled){opacity:.9}.btn-save-contact:disabled{opacity:.5;cursor:not-allowed}.pic-search-wrapper{margin-bottom:12px}.pic-search-input{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px}.pic-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.pic-option.current-user{background:#eff6ff;border:1px solid #3b82f6}.pic-option.current-user input:disabled{cursor:not-allowed}.you-badge{background:#3b82f6;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;margin-left:6px;font-weight:600}@media (max-width: 768px){.new-contact-form .contact-form-row{grid-template-columns:1fr}.contact-header{flex-direction:column;align-items:flex-start;gap:8px}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-state-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state-title{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 10px}.empty-state-description{font-size:16px;color:#999;margin:0}.reports-container{padding:30px;max-width:1400px;margin:0 auto;flex:1;width:100%}.reports-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:20px}.reports-header h1{font-size:28px;font-weight:700;color:#1a1a1a;margin:0}.header-actions{display:flex;align-items:center;gap:12px}.export-csv-btn,.export-excel-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.export-csv-btn{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d}.export-csv-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;background:linear-gradient(135deg,#5568d3,#6a3d8f)}.export-csv-btn:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.export-excel-btn{background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 2px 8px #28a7454d}.export-excel-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a74566;background:linear-gradient(135deg,#218838,#1aa179)}.export-excel-btn:active{transform:translateY(0);box-shadow:0 2px 8px #28a7454d}.export-icon{font-size:18px;line-height:1}.export-text{white-space:nowrap}.filter-section{display:flex;align-items:flex-start;gap:12px}.date-filter-container{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;background:#fff;padding:16px 20px;border-radius:12px;box-shadow:0 2px 8px #00000014}.date-filter-group{display:flex;flex-direction:column;gap:8px}.date-filter-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#555}.date-icon{font-size:16px}.date-filter-input{padding:10px 14px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-weight:500;background:#fff;color:#333;cursor:pointer;transition:all .3s ease;min-width:160px;font-family:inherit}.date-filter-input:hover{border-color:#cbd5e0}.date-filter-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-filter-separator{display:flex;align-items:center;padding-bottom:8px;color:#667eea;font-size:20px;font-weight:700}.quick-range-buttons{display:flex;gap:6px;align-items:center;padding-bottom:2px}.quick-range-btn{padding:8px 14px;background:#f5f7fa;border:1px solid #e8ecf0;border-radius:6px;font-size:12px;font-weight:600;color:#666;cursor:pointer;transition:all .2s ease;white-space:nowrap}.quick-range-btn:hover{background:#e8ecf0;color:#667eea;border-color:#667eea;transform:translateY(-1px)}.quick-range-btn:active{transform:translateY(0)}.reports-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid #e8ecf0}.tab-button{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease;position:relative;bottom:-2px}.tab-button:hover{color:#667eea;background:#f8f9ff}.tab-button.active{color:#667eea;border-bottom-color:#667eea}.reports-content{display:flex;flex-direction:column;gap:30px}.sales-content{display:flex;flex-direction:column;gap:20px}.sales-header-info{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:30px;flex-wrap:wrap}.sales-header-info p{margin:0;font-size:14px;color:#666}.sales-header-info strong{color:#1a1a1a}.date-range-info{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:30px;flex-wrap:wrap}.date-range-info p{margin:0;font-size:14px;color:#666}.date-range-info strong{color:#1a1a1a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.stat-header h3{font-size:16px;font-weight:600;color:#333;margin:0}.stat-count{font-size:32px;font-weight:700;color:#667eea}.stat-bar-container{background:#f5f7fa;height:8px;border-radius:4px;overflow:hidden;margin-bottom:10px}.stat-bar{height:100%;border-radius:4px;transition:width .5s ease}.stat-percentage{font-size:12px;color:#999;text-align:right}.chart-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #00000014}.chart-section h2{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 25px}.chart-container{width:100%}.bar-chart{display:flex;justify-content:space-around;align-items:flex-end;height:300px;gap:15px;padding:20px 0}.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.bar-wrapper{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.bar{width:80%;max-width:100px;border-radius:8px 8px 0 0;transition:height .5s ease;display:flex;align-items:flex-start;justify-content:center;padding-top:10px;position:relative;min-height:30px}.bar-value{color:#fff;font-weight:700;font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.bar-label{margin-top:10px;font-size:12px;font-weight:600;color:#666;text-align:center;word-wrap:break-word;max-width:100px}.table-summary{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #00000014}.table-summary h2{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 20px}.summary-table{width:100%;border-collapse:collapse}.summary-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.summary-table th{padding:12px;text-align:left;font-weight:600;font-size:14px}.summary-table tbody tr{border-bottom:1px solid #e8ecf0}.summary-table tbody tr:hover{background:#f8f9fa}.summary-table td{padding:12px;color:#333}.text-center{text-align:center}.total-row{background:#f8f9fa;font-weight:600}.total-row td{padding-top:15px;padding-bottom:15px}.prospect-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #00000014}.prospect-section h2{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 25px}.prospect-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:20px}.prospect-card{background:#f8f9fa;padding:20px;border-radius:12px;border:2px solid transparent}.prospect-card.cold{border-color:#ffc107}.prospect-card.hot{border-color:#28a745}.prospect-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.prospect-header h3{font-size:18px;font-weight:700;color:#333;margin:0}.prospect-count{font-size:36px;font-weight:700}.prospect-card.cold .prospect-count{color:#856404}.prospect-card.hot .prospect-count{color:#155724}.prospect-bar-container{background:#fff;height:10px;border-radius:5px;overflow:hidden;margin-bottom:10px}.prospect-bar{height:100%;border-radius:5px;transition:width .5s ease}.prospect-percentage{font-size:13px;color:#666;text-align:right}.prospect-summary{background:#f8f9fa;padding:20px;border-radius:8px;margin-top:20px}.prospect-summary p{margin:8px 0;font-size:14px;color:#333}.lead-source-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-top:24px}.lead-source-section h2{margin:0 0 20px;font-size:18px;color:#1a1a1a}.lead-source-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.lead-source-card{background:#f8fafc;padding:16px;border-radius:10px;border:1px solid #e2e8f0}.lead-source-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.lead-source-header h4{margin:0;font-size:14px;color:#334155;font-weight:600}.lead-source-count{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 10px;border-radius:20px;font-size:14px;font-weight:700}.lead-source-bar-container{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden;margin-bottom:8px}.lead-source-bar{height:100%;border-radius:4px;transition:width .5s ease}.lead-source-percentage{font-size:12px;color:#64748b}.lead-source-table{margin-top:16px}.empty-section{text-align:center;padding:40px 20px;color:#94a3b8}.sales-table-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.sales-table{width:100%;border-collapse:collapse}.sales-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sales-table th{padding:14px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.sales-table tbody tr{border-bottom:1px solid #e8ecf0;transition:all .2s ease}.sales-table tbody tr:hover{background:#f8f9fa}.sales-table td{padding:14px;color:#333;vertical-align:middle}.employee-link,.employee-username-link{color:#667eea;text-decoration:none;transition:all .2s ease;display:inline-block}.employee-link:hover,.employee-username-link:hover{color:#764ba2;text-decoration:underline;transform:translate(2px)}.employee-link strong{color:inherit}.count-badge{display:inline-block;padding:6px 12px;border-radius:8px;font-weight:700;font-size:14px}.count-badge.leads{background:#e8edff;color:#667eea}.count-badge.ql{background:#fff3cd;color:#856404}.count-badge.deal{background:#d4edda;color:#155724}.count-badge.finish{background:#cff4fc;color:#0c5460}.count-badge.done{background:#d1e7dd;color:#0f5132}.total-badge{font-size:18px;color:#667eea}.username-small{display:block;font-size:11px;color:#94a3b8;font-weight:400;margin-top:2px}.empty-sales{background:#fff;padding:60px 20px;border-radius:12px;box-shadow:0 2px 8px #00000014;text-align:center;color:#999}.empty-sales p{margin:0;font-size:16px}@media (max-width: 768px){.reports-container{padding:20px 15px}.reports-header{flex-direction:column;align-items:flex-start;gap:15px}.header-actions{width:100%;justify-content:flex-start;flex-direction:column;gap:10px}.export-csv-btn,.export-excel-btn{width:100%;justify-content:center;padding:12px 20px}.export-text{font-size:15px}.date-filter-container{width:100%;flex-direction:column;align-items:stretch;padding:14px}.date-filter-group{width:100%}.date-filter-input{width:100%;min-width:unset}.date-filter-separator{transform:rotate(90deg);padding:0;margin:4px 0;align-self:center}.quick-range-buttons{width:100%;justify-content:center;flex-wrap:wrap;padding-top:8px}.quick-range-btn{flex:1;min-width:60px;max-width:80px}.reports-tabs{overflow-x:auto;margin-bottom:20px}.tab-button{padding:10px 16px;font-size:14px;white-space:nowrap}.stats-grid,.prospect-grid{grid-template-columns:1fr}.bar-chart{height:250px;gap:10px}.bar-label{font-size:11px;max-width:80px}.chart-section,.table-summary,.prospect-section{padding:20px}.sales-table{font-size:12px}.sales-table th,.sales-table td{padding:10px 8px}}.employees-container{padding:30px;max-width:1400px;margin:0 auto;flex:1;width:100%}.employees-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.employees-header h1{font-size:28px;font-weight:700;color:#1a1a1a;margin:0}.btn-add-employee{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-add-employee:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-add-employee span{font-size:20px;font-weight:300}.employee-form-card{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:30px}.employee-form-card h2{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 20px}.employee-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#333}.form-group label span{font-weight:400;color:#999;font-size:12px}.form-group input,.form-group select{padding:12px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f5f7fa;cursor:not-allowed}.form-group small{font-size:12px;color:#999}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-secondary{background:#e8ecf0;color:#666}.btn-secondary:hover{background:#d1d9e0}.employees-table-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.table-header{padding:20px 30px;border-bottom:1px solid #e8ecf0}.table-header h2{font-size:18px;font-weight:700;color:#1a1a1a;margin:0}.table-wrapper{overflow-x:auto}.employees-table{width:100%;border-collapse:collapse}.employees-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employees-table th{padding:14px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.employees-table tbody tr{border-bottom:1px solid #e8ecf0;transition:all .2s ease}.employees-table tbody tr:hover{background:#f8f9fa}.employees-table td{padding:14px;color:#333;vertical-align:middle}.employee-name-link,.employee-username-link{color:#667eea;text-decoration:none;transition:all .2s ease;display:inline-block}.employee-name-link:hover,.employee-username-link:hover{color:#764ba2;text-decoration:underline;transform:translate(2px)}.employee-name-link strong{color:inherit}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.role-badge.admin{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.role-badge.employee{background:#e8edff;color:#667eea}.action-buttons{display:flex;gap:8px}.btn-action{background:none;border:1px solid #e8ecf0;border-radius:6px;padding:6px 10px;cursor:pointer;font-size:14px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.btn-action:hover{background:#f5f7fa;border-color:#667eea;transform:translateY(-1px)}.btn-edit:hover{background:#fff3cd;border-color:#ffc107}.btn-delete:hover{background:#fee;border-color:#dc3545}.table-empty{text-align:center;padding:40px!important;color:#999;font-style:italic}.online-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.online-status-badge.online{background:#dcfce7;color:#16a34a}.online-status-badge.offline{background:#f3f4f6;color:#6b7280}.online-status-badge .status-dot{width:8px;height:8px;border-radius:50%}.online-status-badge.online .status-dot{background:#4ade80;animation:pulse-dot 2s infinite}.online-status-badge.offline .status-dot{background:#9ca3af}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.employees-container{padding:20px 15px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn{width:100%}.employee-form-card{padding:20px}}.employee-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2500;padding:20px;animation:fadeIn .3s ease}.employee-modal-container{background:#fff;border-radius:16px;width:100%;max-width:600px;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease;display:flex;flex-direction:column;max-height:90vh;overflow-y:auto}.employee-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e8ecf0;position:sticky;top:0;background:#fff;z-index:1}.employee-modal-header h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0}.employee-modal-close{background:#f5f7fa;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .3s ease}.employee-modal-close:hover{background:#e8ecf0;color:#333}.employee-modal-form{padding:24px;display:flex;flex-direction:column;gap:20px}.employee-form-error{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;font-weight:500}.employee-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.employee-form-group{display:flex;flex-direction:column;gap:8px}.employee-form-group label{font-size:14px;font-weight:600;color:#333}.optional-hint{font-weight:400;color:#999;font-size:12px}.employee-form-group input,.employee-form-group select{padding:12px;border:2px solid #e8ecf0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .3s ease}.employee-form-group input:focus,.employee-form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.employee-form-group input:disabled{background:#f5f7fa;cursor:not-allowed}.employee-form-group input.error{border-color:#dc3545}.employee-form-group input.error:focus{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.error-message{font-size:12px;color:#dc3545;font-weight:500}.employee-form-group small{font-size:11px;color:#999;font-style:italic}.employee-modal-actions{display:flex;gap:12px;padding-top:12px;border-top:1px solid #e8ecf0}.employee-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.employee-btn:disabled{opacity:.6;cursor:not-allowed}.employee-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employee-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.employee-btn-secondary{background:#e8ecf0;color:#666}.employee-btn-secondary:hover:not(:disabled){background:#d1d9e0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.employee-modal-container{max-width:100%;max-height:95vh}.employee-modal-header,.employee-modal-form{padding:20px}.employee-form-row{grid-template-columns:1fr}}.profile-container{width:100%;min-height:100vh;background:#f5f7fa;flex:1}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #e8ecf0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.profile-cover{height:200px;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.cover-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.15) 0%,transparent 40%),radial-gradient(circle at 40% 80%,rgba(255,255,255,.1) 0%,transparent 40%)}.profile-header{background:#fff;border-radius:16px;padding:30px;box-shadow:0 4px 20px #0000001a;display:flex;align-items:center;gap:24px;margin:-80px 30px 0;position:relative;z-index:10}.profile-avatar{flex-shrink:0;position:relative}.avatar-circle{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;color:#fff;box-shadow:0 8px 24px #667eea66;border:4px solid white;overflow:hidden}.avatar-circle .avatar-image{width:100%;height:100%;object-fit:cover}.avatar-status{position:absolute;bottom:8px;right:8px;width:20px;height:20px;border-radius:50%;border:3px solid white}.avatar-status.online{background:#4ade80;box-shadow:0 0 0 2px #4ade804d}.avatar-status.offline{background:#9ca3af}.profile-online-status{display:flex;align-items:center;gap:8px;margin-bottom:12px}.profile-online-status .status-dot{width:10px;height:10px;border-radius:50%}.profile-online-status .status-dot.online{background:#4ade80;box-shadow:0 0 0 3px #4ade8033;animation:pulse-online 2s infinite}.profile-online-status .status-dot.offline{background:#9ca3af}.profile-online-status .status-text{font-size:14px;color:#666}.profile-online-status .status-text.online{color:#16a34a;font-weight:600}@keyframes pulse-online{0%,to{box-shadow:0 0 0 3px #4ade8033}50%{box-shadow:0 0 0 6px #4ade801a}}.profile-info{flex:1}.profile-name{font-size:32px;font-weight:800;color:#1a1a1a;margin:0 0 6px}.profile-username{font-size:18px;color:#667eea;font-weight:600;margin:0 0 12px}.profile-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.profile-role{font-size:14px;color:#666;background:#f0f4ff;padding:4px 12px;border-radius:20px}.profile-joined{font-size:13px;color:#888}.btn-close-profile{position:absolute;top:20px;right:20px;background:#f5f7fa;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;font-size:18px;transition:all .3s ease}.btn-close-profile:hover{background:#e8ecf0;color:#333}.profile-quick-stats{display:flex;justify-content:center;gap:40px;padding:25px 30px;margin:20px 30px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.quick-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.quick-stat-value{font-size:28px;font-weight:800;color:#1a1a1a}.quick-stat-label{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px}.profile-badges{margin:0 30px 20px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.badges-title{font-size:16px;font-weight:700;color:#333;margin:0 0 15px}.badges-list{display:flex;flex-wrap:wrap;gap:10px}.badge-item{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#f0f4ff,#e8ecf8);border-radius:20px;cursor:default;transition:all .3s ease}.badge-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.badge-icon{font-size:18px}.badge-label{font-size:13px;font-weight:600;color:#667eea}.profile-tabs{display:flex;gap:8px;margin:0 30px 20px;padding:8px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.tab-btn{flex:1;padding:12px 20px;background:transparent;border:none;border-radius:8px;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease}.tab-btn:hover{background:#f5f7fa;color:#333}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.profile-content{display:flex;flex-direction:column;gap:20px;padding:0 30px 30px}.profile-progress-section{background:#fff;border-radius:16px;padding:25px;box-shadow:0 2px 8px #0000000f}.progress-container{display:flex;flex-direction:column;gap:12px}.progress-bar-wrapper{display:flex;align-items:center;gap:16px}.progress-bar{flex:1;height:12px;background:#e8ecf0;border-radius:6px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:6px;transition:width .5s ease}.progress-text{font-size:14px;font-weight:700;color:#667eea;white-space:nowrap}.progress-details{font-size:13px;color:#888}.profile-activity-section{background:#fff;border-radius:16px;padding:25px;box-shadow:0 2px 8px #0000000f}.profile-activity-section.full{min-height:400px}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;gap:14px;padding:14px;background:#f8f9fa;border-radius:10px;transition:all .3s ease}.activity-item:hover{background:#f0f4ff}.activity-icon{font-size:24px;flex-shrink:0}.activity-content{flex:1}.activity-message{font-size:14px;color:#333;margin:0 0 4px;line-height:1.4}.activity-time{font-size:12px;color:#888}.projects-empty .empty-icon,.profile-not-found .not-found-icon{font-size:60px;margin-bottom:16px}.profile-stats-section{background:#fff;border-radius:16px;padding:30px;box-shadow:0 2px 8px #00000014}.section-title{font-size:22px;font-weight:700;color:#1a1a1a;margin:0 0 24px;padding-bottom:12px;border-bottom:2px solid #f0f4ff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px}.stat-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;border:2px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001a}.stat-leads{border-color:#2196f3;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.stat-proses{border-color:#ff9800;background:linear-gradient(135deg,#fff3e0,#ffe0b2)}.stat-deal{border-color:#4caf50;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.stat-finish{border-color:#9c27b0;background:linear-gradient(135deg,#f3e5f5,#e1bee7)}.stat-done{border-color:#00bcd4;background:linear-gradient(135deg,#e0f2f1,#b2dfdb)}.stat-total{border-color:#667eea;background:linear-gradient(135deg,#ede7f6,#d1c4e9)}.stat-total .stat-value,.stat-total .stat-label{color:#4a4a4a}.stat-icon{font-size:32px;flex-shrink:0}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;color:#1a1a1a;line-height:1;margin-bottom:4px}.stat-label{font-size:13px;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.profile-projects-section{background:#fff;border-radius:16px;padding:30px;box-shadow:0 2px 8px #00000014}.projects-empty{text-align:center;padding:60px 20px;color:#999}.projects-empty p{font-size:16px}.projects-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.project-card-profile{background:#f8f9fa;border-radius:12px;padding:20px;border:1px solid #e8ecf0;transition:all .3s ease;cursor:pointer}.project-card-profile:hover{box-shadow:0 4px 12px #667eea33;transform:translateY(-2px);border-color:#667eea}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.project-card-name{font-size:16px;font-weight:700;color:#1a1a1a;margin:0;flex:1}.project-card-status{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.project-card-status.status-leads-masuk{background:#e3f2fd;color:#1976d2}.project-card-status.status-proses-ql{background:#fff3e0;color:#f57c00}.project-card-status.status-deal-running{background:#e8f5e9;color:#388e3c}.project-card-status.status-finish-penagihan{background:#f3e5f5;color:#7b1fa2}.project-card-status.status-done-full-payment{background:#e0f2f1;color:#00796b}.project-card-details{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.project-card-item{display:flex;justify-content:space-between;font-size:13px}.project-card-label{color:#666;font-weight:600}.project-card-value{color:#333}.project-card-description{font-size:13px;color:#666;line-height:1.5;padding-top:12px;border-top:1px solid #e8ecf0}.profile-not-found{text-align:center;padding:60px 20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014}.profile-not-found h2{font-size:24px;color:#1a1a1a;margin-bottom:12px}.profile-not-found p{color:#666;margin-bottom:24px}.btn-back{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-back:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}@media (max-width: 768px){.profile-cover{height:150px}.profile-header{flex-direction:column;text-align:center;padding:24px;margin:-60px 15px 0}.avatar-circle{width:100px;height:100px;font-size:40px}.profile-name{font-size:24px}.profile-meta{justify-content:center}.btn-close-profile{position:static;margin-top:16px}.profile-quick-stats{flex-wrap:wrap;gap:20px;margin:15px;padding:20px}.quick-stat{flex-basis:45%}.quick-stat-value{font-size:22px}.profile-badges{margin:0 15px 15px}.profile-tabs{margin:0 15px 15px;flex-wrap:wrap}.tab-btn{flex-basis:48%;padding:10px 16px;font-size:13px}.profile-content{padding:0 15px 20px}.stats-grid{grid-template-columns:repeat(2,1fr)}.projects-list{grid-template-columns:1fr}.profile-stats-section,.profile-projects-section,.profile-progress-section,.profile-activity-section{padding:20px}}.activities-page{min-height:calc(100vh - 140px);padding:30px 20px;background:#f5f7fa}.activities-container{max-width:1000px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;padding:30px}.activities-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e8ecf0;flex-wrap:wrap;gap:15px}.activities-header-title{flex:1}.activities-header h1{font-size:32px;font-weight:700;color:#1a1a1a;margin:0}.activities-subtitle{font-size:14px;color:#666;margin:5px 0 0}.activities-header-actions{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.activities-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:#28a745;font-weight:600}.indicator-dot{width:8px;height:8px;background:#28a745;border-radius:50%;animation:pulse 2s infinite}.activities-loading{text-align:center;padding:60px 20px}.loading-spinner{width:40px;height:40px;border:4px solid #e8ecf0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.activities-error{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:15px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.activities-error button{background:#ffc107;color:#333;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s ease}.activities-error button:hover{background:#ffb300}.activities-empty{text-align:center;padding:60px 20px}.activities-empty p{font-size:18px;font-weight:600;color:#333;margin:0 0 8px}.activities-empty span{font-size:14px;color:#666}.activities-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;gap:16px;padding:20px;background:#f8f9fa;border-radius:12px;border-left:4px solid #667eea;transition:all .3s ease;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.activity-item:hover{background:#e8ecf0;box-shadow:0 2px 8px #0000000d}.activity-icon{font-size:32px;flex-shrink:0;line-height:1}.activity-content{flex:1;min-width:0}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}.activity-type{font-size:14px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px}.activity-time{font-size:12px;color:#999;white-space:nowrap}.activity-message{font-size:15px;color:#333;line-height:1.6;margin-bottom:8px}.activity-user{font-size:13px;color:#666;margin-top:4px}.activity-user-link{color:#667eea;text-decoration:none;transition:all .2s ease}.activity-user-link:hover{color:#764ba2;text-decoration:underline}.activity-metadata{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.metadata-tag{display:inline-block;font-size:11px;padding:4px 8px;background:#e8edff;color:#667eea;border-radius:4px;font-weight:600}.btn-clear-all{padding:10px 18px;background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #dc354533}.btn-clear-all:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #dc35454d;background:linear-gradient(135deg,#c82333,#bd2130)}.btn-clear-all:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.activities-page{padding:20px 15px}.activities-container{padding:20px;border-radius:12px}.activities-header{flex-direction:column;align-items:flex-start;margin-bottom:20px;padding-bottom:15px}.activities-header h1{font-size:24px}.activities-subtitle{font-size:13px}.activity-item{padding:16px}.activity-icon{font-size:28px}.activity-message{font-size:14px}.activity-header{flex-direction:column;align-items:flex-start}.activity-time{font-size:11px}}@media (max-width: 480px){.activities-container{padding:16px}.activities-header h1{font-size:20px}.activity-item{padding:12px;gap:12px}.activity-icon{font-size:24px}.activity-message{font-size:13px}}.events-page{padding:30px;max-width:1400px;margin:0 auto;width:100%}.events-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:20px}.header-left h1{font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 6px}.header-subtitle{font-size:14px;color:#6b7280;margin:0}.btn-add-event{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.btn-add-event:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-add-event span{font-size:18px;font-weight:700}.events-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 12px #0000000f;transition:all .3s ease;border-left:4px solid}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0000001a}.stat-today{border-left-color:#ef4444}.stat-week{border-left-color:#3b82f6}.stat-upcoming{border-left-color:#667eea}.stat-completed{border-left-color:#10b981}.stat-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:12px}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:28px;font-weight:700;color:#1a1a1a}.stat-label{font-size:13px;color:#6b7280;margin-top:2px}.events-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.filter-group{display:flex;align-items:center;gap:12px}.filter-group label{font-size:14px;font-weight:600;color:#374151}.filter-select{padding:10px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;background:#fff;cursor:pointer;min-width:180px;transition:all .2s ease}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.view-toggle{display:flex;background:#f3f4f6;border-radius:10px;padding:4px}.toggle-btn{padding:10px 20px;border:none;background:transparent;font-size:13px;font-weight:600;color:#6b7280;cursor:pointer;border-radius:8px;transition:all .2s ease}.toggle-btn.active{background:#fff;color:#667eea;box-shadow:0 2px 8px #00000014}.toggle-btn:hover:not(.active){color:#374151}.loading-state{text-align:center;padding:80px 20px}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.today-highlight{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:2px solid #fca5a5;border-radius:16px;padding:20px;margin-bottom:30px}.today-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.today-pulse{width:12px;height:12px;background:#ef4444;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.today-header h3{font-size:18px;font-weight:700;color:#991b1b;margin:0}.today-events-list{display:flex;flex-direction:column;gap:10px}.today-event-item{display:flex;align-items:center;gap:16px;background:#fff;padding:16px;border-radius:12px;cursor:pointer;transition:all .2s ease}.today-event-item:hover{transform:translate(4px);box-shadow:0 4px 12px #0000001a}.today-event-color{width:6px;height:40px;border-radius:3px}.today-event-info{flex:1;display:flex;flex-direction:column;gap:4px}.today-event-info strong{font-size:15px;color:#1a1a1a}.today-event-type{font-size:12px;color:#6b7280}.btn-view-detail{padding:8px 16px;background:#f3f4f6;border:none;border-radius:8px;font-size:13px;font-weight:600;color:#374151;cursor:pointer;transition:all .2s ease}.btn-view-detail:hover{background:#e5e7eb;color:#667eea}.timeline-container{display:flex;flex-direction:column;gap:40px}.timeline-section-title{font-size:18px;font-weight:700;color:#374151;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.past-section .timeline-section-title{color:#6b7280}.timeline{position:relative;display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:20px;position:relative}.timeline-marker{display:flex;flex-direction:column;align-items:center;width:40px;flex-shrink:0}.marker-icon{width:40px;height:40px;background:#fff;border:3px solid #e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;z-index:1;transition:all .3s ease}.timeline-item.status-today .marker-icon{border-color:#ef4444;background:#fef2f2}.timeline-item.status-tomorrow .marker-icon{border-color:#f97316;background:#fff7ed}.timeline-item.status-soon .marker-icon{border-color:#eab308;background:#fefce8}.timeline-item.status-week .marker-icon{border-color:#3b82f6;background:#eff6ff}.timeline-item.status-completed .marker-icon{border-color:#10b981;background:#ecfdf5}.timeline-line{width:3px;flex:1;min-height:20px;background:#e5e7eb;margin-top:4px}.timeline-item:last-child .timeline-line{display:none}.timeline-content{flex:1;padding-bottom:24px}.timeline-date{display:flex;align-items:center;gap:8px;margin-bottom:8px}.date-day{font-size:14px;font-weight:700;color:#667eea}.date-range{font-size:13px;color:#6b7280}.timeline-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 12px #0000000f;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.timeline-card:hover{transform:translate(4px);box-shadow:0 8px 25px #0000001a;border-color:#667eea}.timeline-card.past-card{opacity:.7}.timeline-card.past-card:hover{opacity:1}.timeline-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.timeline-card-header h4{font-size:16px;font-weight:700;color:#1a1a1a;margin:0}.status-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;white-space:nowrap}.status-badge.status-today{background:#fef2f2;color:#dc2626}.status-badge.status-tomorrow{background:#fff7ed;color:#ea580c}.status-badge.status-soon{background:#fefce8;color:#ca8a04}.status-badge.status-week{background:#eff6ff;color:#2563eb}.status-badge.status-upcoming{background:#f3f4f6;color:#6b7280}.status-badge.status-completed{background:#ecfdf5;color:#059669}.project-type-tag{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:#fff;margin-bottom:10px}.timeline-description{font-size:14px;color:#6b7280;line-height:1.5;margin:0 0 12px}.timeline-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #f3f4f6}.created-by{font-size:13px;color:#6b7280}.timeline-actions{display:flex;gap:8px}.btn-action{padding:6px 10px;background:#f3f4f6;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease;opacity:.7}.btn-action:hover{background:#e5e7eb;opacity:1}.btn-action.btn-delete:hover{background:#fee2e2}.show-more-past{text-align:center;padding:16px;color:#6b7280;font-size:14px;font-style:italic}.events-table-container{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;overflow:hidden;overflow-x:auto}.events-table{width:100%;border-collapse:collapse}.events-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.events-table th{padding:16px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.events-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background .2s ease}.events-table tbody tr:hover{background:#fafbfc}.events-table tbody tr.past-event{opacity:.6}.events-table td{padding:16px;font-size:14px;color:#374151}.events-table .text-center{text-align:center}.event-name-cell strong{color:#1a1a1a}.project-type-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:#fff}.actions-cell{display:flex;gap:8px}.events-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.event-card-new{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000f;cursor:pointer;transition:all .3s ease}.event-card-new:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000001f}.card-status-bar{height:6px}.card-content{padding:20px}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.card-header h4{font-size:16px;font-weight:700;color:#1a1a1a;margin:0}.card-date{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280;margin:12px 0}.card-description{font-size:13px;color:#6b7280;line-height:1.5;margin:0 0 16px}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid #f3f4f6}.card-actions{display:flex;gap:8px}.empty-state{text-align:center;padding:80px 20px;background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 8px}.empty-state p{font-size:14px;color:#6b7280;margin:0 0 24px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{background:#fff;border-radius:20px;max-width:520px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 60px #0000004d}.modal-container.detail-modal{max-width:600px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid #f3f4f6;background:linear-gradient(135deg,#f8fafc,#fff)}.modal-header h3{font-size:20px;font-weight:700;color:#1a1a1a;margin:0}.modal-header.detail-header{flex-direction:column;align-items:flex-start;gap:12px}.detail-title-section{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.detail-project-type{padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;color:#fff}.modal-close-btn{position:absolute;top:20px;right:20px;background:#f3f4f6;border:none;width:36px;height:36px;border-radius:10px;font-size:24px;cursor:pointer;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:#e5e7eb;color:#374151}.modal-body{padding:28px;overflow-y:auto;flex:1}.modal-body.detail-body{padding:0}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:inherit;transition:all .2s ease;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-grid{display:grid;gap:0}.detail-item{display:flex;align-items:flex-start;gap:16px;padding:20px 28px;border-bottom:1px solid #f3f4f6}.detail-item:last-child{border-bottom:none}.detail-icon{font-size:24px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:12px}.detail-info{flex:1;display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:15px;font-weight:500;color:#1a1a1a}.detail-description-section{padding:20px 28px;border-top:1px solid #f3f4f6}.detail-description-section h4{font-size:14px;font-weight:700;color:#374151;margin:0 0 12px}.description-box{background:#f8fafc;border-radius:12px;padding:16px;border:1px solid #e5e7eb}.description-box p{font-size:14px;line-height:1.6;color:#374151;margin:0;white-space:pre-wrap}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 28px;border-top:1px solid #f3f4f6;background:#fafbfc}.btn-cancel{padding:12px 24px;background:#f3f4f6;color:#374151;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:#e5e7eb;border-color:#d1d5db}.btn-submit{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (max-width: 1024px){.events-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.events-page{padding:20px 16px}.events-page-header{flex-direction:column;align-items:stretch}.btn-add-event{width:100%;justify-content:center}.events-stats{grid-template-columns:1fr 1fr;gap:12px}.stat-card{padding:16px}.stat-icon{font-size:24px;width:44px;height:44px}.stat-number{font-size:22px}.events-toolbar,.filter-group{flex-direction:column;align-items:stretch}.filter-select{min-width:auto}.view-toggle{justify-content:center}.toggle-btn{padding:8px 14px;font-size:12px}.events-cards-grid,.form-row{grid-template-columns:1fr}.modal-container{margin:10px;max-width:calc(100% - 20px)}.modal-footer{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%;justify-content:center}.timeline-item{gap:12px}.timeline-marker{width:32px}.marker-icon{width:32px;height:32px;font-size:14px}}@media (max-width: 480px){.events-stats{grid-template-columns:1fr}.header-left h1{font-size:22px}.today-event-item{flex-wrap:wrap}.btn-view-detail{width:100%;margin-top:8px;text-align:center}}.detail-modal-pro{max-width:680px;width:95vw;background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 25px 80px #00000059}.detail-modal-header{background:linear-gradient(135deg,#f8fafc,#fff);padding:28px;border-top:5px solid #667eea;position:relative}.detail-header-content{display:flex;flex-direction:column;gap:12px}.detail-header-top{display:flex;justify-content:space-between;align-items:center}.status-badge-lg{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:700}.status-badge-lg.status-today{background:#fef2f2;color:#dc2626}.status-badge-lg.status-tomorrow{background:#fff7ed;color:#ea580c}.status-badge-lg.status-soon{background:#fefce8;color:#ca8a04}.status-badge-lg.status-week{background:#eff6ff;color:#2563eb}.status-badge-lg.status-upcoming{background:#f3f4f6;color:#6b7280}.status-badge-lg.status-completed{background:#ecfdf5;color:#059669}.modal-close-btn-pro{width:40px;height:40px;background:#f3f4f6;border:none;border-radius:10px;font-size:28px;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn-pro:hover{background:#e5e7eb;color:#1a1a1a}.detail-event-title{font-size:26px;font-weight:800;color:#1a1a1a;margin:0;line-height:1.3}.detail-type-badge{display:inline-block;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:700;color:#fff;width:fit-content}.detail-modal-body{padding:0;max-height:50vh;overflow-y:auto}.detail-section{padding:24px 28px;border-bottom:1px solid #f0f0f0}.detail-section:last-child{border-bottom:none}.section-title{font-size:14px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px}.date-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}.date-card{display:flex;align-items:center;gap:14px;background:#f8fafc;border-radius:12px;padding:16px;border:1px solid #e5e7eb}.date-card-icon{font-size:24px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px}.date-card-icon.start{background:#ecfdf5}.date-card-icon.end{background:#fef2f2}.date-card-content{flex:1;display:flex;flex-direction:column;gap:4px}.date-card-label{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.date-card-value{font-size:14px;font-weight:600;color:#1a1a1a;line-height:1.4}.duration-info{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:10px;border:1px solid #667eea30}.duration-icon{font-size:20px}.duration-text{font-size:14px;color:#374151}.duration-text strong{color:#667eea}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.info-item{display:flex;align-items:center;gap:12px;padding:14px;background:#fafbfc;border-radius:10px;border:1px solid #f0f0f0}.info-icon{font-size:20px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000000d}.info-content{flex:1;display:flex;flex-direction:column;gap:2px}.info-label{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.3px}.info-value{font-size:14px;font-weight:600;color:#1a1a1a}.description-card{background:#f8fafc;border-radius:12px;padding:20px;border:1px solid #e5e7eb}.description-card p{font-size:14px;line-height:1.7;color:#374151;margin:0;white-space:pre-wrap}.detail-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 28px;background:#f8fafc;border-top:1px solid #e5e7eb}.btn-secondary-pro{padding:12px 28px;background:#fff;color:#374151;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary-pro:hover{background:#f3f4f6;border-color:#d1d5db}.btn-primary-pro{padding:12px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.btn-primary-pro:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (max-width: 768px){.detail-modal-pro{width:calc(100% - 20px);max-width:calc(100% - 20px)}.detail-modal-header{padding:20px}.detail-event-title{font-size:20px}.detail-section{padding:20px}.date-cards,.info-grid{grid-template-columns:1fr}.detail-modal-footer{flex-direction:column-reverse;padding:16px 20px}.btn-secondary-pro,.btn-primary-pro{width:100%;text-align:center;justify-content:center}}.clients-page{padding:1.5rem 2rem;max-width:1400px;margin:0 auto;min-height:calc(100vh - 80px)}.clients-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#6b7280}.loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.clients-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-left h1{margin:0;font-size:1.75rem;font-weight:700;color:#111827}.header-subtitle{margin:.25rem 0 0;color:#6b7280;font-size:.9rem}.header-right{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.search-box{position:relative;display:flex;align-items:center}.search-box .search-icon{position:absolute;left:12px;width:18px;height:18px;color:#9ca3af;pointer-events:none}.search-box input{padding:.6rem 1rem .6rem 2.5rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.9rem;width:320px;background:#fff;transition:all .2s}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.view-toggle{display:flex;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.view-toggle button{padding:.5rem .75rem;background:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s}.view-toggle button:not(:last-child){border-right:1px solid #e5e7eb}.view-toggle button:hover{background:#f9fafb}.view-toggle button.active{background:#667eea;color:#fff}.view-toggle button svg{width:18px;height:18px}.clients-page .btn-primary{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.clients-page .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.clients-page .btn-primary svg{width:18px;height:18px}.clients-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#f9fafb;border-radius:16px;border:2px dashed #e5e7eb;text-align:center}.clients-empty svg{width:64px;height:64px;color:#9ca3af;margin-bottom:1rem}.clients-empty h3{margin:0 0 .5rem;color:#374151;font-size:1.1rem}.clients-empty p{margin:0;color:#6b7280;font-size:.9rem}.clients-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.clients-table{width:100%;border-collapse:collapse}.clients-table th{text-align:left;padding:1rem;background:#f9fafb;color:#374151;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5e7eb}.clients-table td{padding:1rem;border-bottom:1px solid #f3f4f6;vertical-align:middle}.clients-table tbody tr:hover{background:#f9fafb}.clients-table tbody tr:last-child td{border-bottom:none}.company-cell{display:flex;align-items:center;gap:.75rem}.company-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.company-avatar.large{width:48px;height:48px;font-size:1.25rem}.company-info{display:flex;flex-direction:column}.company-name{font-weight:600;color:#111827}.company-address{font-size:.8rem;color:#6b7280;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.industry-badge{display:inline-block;padding:.25rem .6rem;background:#e0e7ff;color:#4f46e5;border-radius:6px;font-size:.75rem;font-weight:500}.contact-cell{display:flex;flex-direction:column}.contact-cell .contact-name{font-weight:500;color:#111827}.contact-cell .contact-position{font-size:.8rem;color:#6b7280}.text-muted{color:#9ca3af}.phone-link{color:#667eea;text-decoration:none;font-size:.9rem}.phone-link:hover{text-decoration:underline}.contact-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 .5rem;background:#f3f4f6;color:#374151;border-radius:6px;font-size:.85rem;font-weight:500}.project-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 .5rem;background:#f3f4f6;color:#6b7280;border-radius:6px;font-size:.85rem;font-weight:500}.project-badge.has-projects{background:#dcfce7;color:#166534}.action-buttons{display:flex;gap:.5rem}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.btn-icon svg{width:16px;height:16px}.btn-icon.btn-add-contact{background:#dbeafe;color:#2563eb}.btn-icon.btn-add-contact:hover{background:#bfdbfe}.btn-icon.btn-edit{background:#e0e7ff;color:#4f46e5}.btn-icon.btn-edit:hover{background:#c7d2fe}.btn-icon.btn-delete{background:#fee2e2;color:#dc2626}.btn-icon.btn-delete:hover:not(:disabled){background:#fecaca}.btn-icon.btn-delete:disabled{opacity:.4;cursor:not-allowed}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}.client-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #0000001a;transition:all .2s;display:flex;flex-direction:column}.client-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.card-header-info{flex:1;min-width:0}.card-header-info h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.client-address{margin:0 0 1rem;color:#6b7280;font-size:.85rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-contacts{flex:1;border-top:1px solid #f3f4f6;padding-top:.75rem}.card-contacts .contacts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.card-contacts .contacts-header span{font-size:.8rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.btn-add-contact-small{background:none;border:none;color:#667eea;font-size:.8rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:4px}.btn-add-contact-small:hover{background:#e0e7ff}.contacts-list{display:flex;flex-direction:column;gap:.5rem}.contact-item{display:flex;align-items:center;gap:.6rem;padding:.5rem;background:#f9fafb;border-radius:8px}.contact-item.primary{background:#fef3c7;border:1px solid #fcd34d}.contact-avatar{width:32px;height:32px;border-radius:50%;background:#e0e7ff;color:#4f46e5;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;flex-shrink:0}.contact-item .contact-info{flex:1;min-width:0;display:flex;flex-direction:column}.contact-item .contact-info .name{font-weight:500;color:#111827;font-size:.85rem}.contact-item .contact-info .position,.contact-item .contact-info .phone{font-size:.75rem;color:#6b7280}.primary-tag{padding:.15rem .4rem;background:#10b981;color:#fff;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase}.more-contacts{text-align:center;color:#6b7280;font-size:.8rem;padding:.25rem}.no-contacts{color:#9ca3af;font-size:.85rem;text-align:center;padding:.5rem;margin:0}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid #f3f4f6}.card-footer .project-count{display:flex;align-items:center;gap:.4rem;color:#6b7280;font-size:.85rem}.card-footer .project-count svg{width:16px;height:16px}.card-actions{display:flex;gap:.5rem}.card-actions .btn-edit,.card-actions .btn-delete{padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;border:none;transition:all .2s}.card-actions .btn-edit{background:#e0e7ff;color:#4f46e5}.card-actions .btn-edit:hover{background:#c7d2fe}.card-actions .btn-delete{background:#fee2e2;color:#dc2626}.card-actions .btn-delete:hover:not(:disabled){background:#fecaca}.card-actions .btn-delete:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.client-modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.client-modal.small{max-width:480px}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.modal-subtitle{margin:.25rem 0 0;color:#6b7280;font-size:.9rem}.btn-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;border-radius:6px;transition:all .2s}.btn-close:hover{background:#f3f4f6;color:#111827}.client-modal form{padding:1.5rem}.form-section{margin-bottom:1.5rem}.form-section h4{margin:0 0 1rem;font-size:.9rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h4{margin:0}.btn-add-contact-inline{background:#e0e7ff;color:#4f46e5;border:none;padding:.4rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-add-contact-inline:hover{background:#c7d2fe}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.4rem;font-weight:500;color:#374151;font-size:.875rem}.form-group input,.form-group textarea{width:100%;padding:.65rem .85rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;box-sizing:border-box;transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.contact-form-card{background:#f9fafb;padding:1rem;border-radius:10px;margin-bottom:1rem;border:1px solid #e5e7eb}.contact-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.contact-form-header span{font-weight:600;color:#374151;font-size:.85rem}.btn-remove{background:none;border:none;color:#dc2626;font-size:.8rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px}.btn-remove:hover{background:#fee2e2}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;color:#4b5563;margin-top:.5rem}.checkbox-label input{width:auto;accent-color:#667eea}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1.25rem;border-top:1px solid #e5e7eb;margin-top:1rem}.btn-secondary{padding:.65rem 1.25rem;background:#f3f4f6;color:#374151;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#e5e7eb}.modal-footer .btn-primary{padding:.65rem 1.25rem}@media (max-width: 768px){.clients-page{padding:1rem}.clients-header,.header-right{flex-direction:column;align-items:stretch}.search-box input{width:100%}.view-toggle{align-self:flex-start}.clients-page .btn-primary{width:100%;justify-content:center}.clients-grid{grid-template-columns:1fr}.clients-table-wrapper{overflow-x:auto}.clients-table{min-width:800px}.form-row{grid-template-columns:1fr}.client-modal{max-height:95vh;margin:.5rem}}.clients-list{display:flex;flex-direction:column;gap:.75rem}.client-card-new{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:all .2s}.client-card-new:hover{box-shadow:0 4px 12px #0000001a}.client-main{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;cursor:pointer;transition:background .2s}.client-main:hover{background:#f9fafb}.client-avatar{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;flex-shrink:0}.client-info{flex:1;min-width:0}.client-info h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#111827}.client-pic{margin:0;display:flex;align-items:center;gap:.4rem;color:#6b7280;font-size:.85rem}.client-pic svg{flex-shrink:0}.pic-contact{color:#9ca3af}.client-stats{display:flex;align-items:center;gap:.75rem}.client-stats .project-count{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#f3f4f6;color:#374151;border-radius:8px;font-size:.85rem;font-weight:500}.client-stats .btn-icon{width:36px;height:36px;background:#e0e7ff;color:#4f46e5}.client-stats .btn-icon:hover{background:#c7d2fe}.expand-icon{color:#9ca3af;transition:transform .2s}.expand-icon.expanded{transform:rotate(180deg)}.client-projects{padding:1rem 1.25rem;background:#f9fafb;border-top:1px solid #e5e7eb}.client-projects h4{margin:0 0 .75rem;font-size:.8rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.projects-list{display:flex;flex-direction:column;gap:.5rem}.project-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.project-item .project-name{font-size:.9rem;color:#111827;font-weight:500}.project-item .project-status{padding:.25rem .6rem;border-radius:6px;font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase}@media (max-width: 768px){.client-main{flex-wrap:wrap}.client-stats{width:100%;justify-content:flex-end;margin-top:.5rem;padding-top:.75rem;border-top:1px solid #f3f4f6}}.input-with-suggestions{position:relative}.input-with-suggestions input{width:100%;padding-right:80px}.existing-badge{position:absolute;right:10px;top:50%;transform:translateY(-50%);padding:.2rem .5rem;background:#dcfce7;color:#166534;font-size:.7rem;font-weight:600;border-radius:4px;text-transform:uppercase}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #0000001a;z-index:10;max-height:200px;overflow-y:auto}.suggestion-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background .15s;border-bottom:1px solid #f3f4f6}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#f3f4f6}.suggestion-name{font-weight:500;color:#111827}.suggestion-projects{font-size:.75rem;color:#6b7280;background:#f3f4f6;padding:.2rem .5rem;border-radius:4px}.form-hint{display:block;margin-top:.35rem;color:#f59e0b;font-size:.8rem}.workload-page{padding:2rem;max-width:1400px;margin:0 auto;min-height:100vh;background:#f8fafc;display:flex;align-items:center;justify-content:center}.coming-soon-container{text-align:center;padding:4rem 2rem;max-width:500px}.coming-soon-icon{width:120px;height:120px;margin:0 auto 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 40px #667eea4d}.coming-soon-icon svg{width:60px;height:60px;stroke:#fff}.coming-soon-title{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.coming-soon-subtitle{font-size:1.1rem;color:#6b7280;line-height:1.8;margin:0 0 2rem}.coming-soon-badge{display:inline-block;padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:.9rem;border-radius:50px;text-transform:uppercase;letter-spacing:1px}.workload-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#6b7280}.loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.workload-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.header-content h1{margin:0;font-size:2rem;font-weight:700;color:#1f2937;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{margin:.5rem 0 0;color:#6b7280;font-size:1rem}.header-search{position:relative;min-width:300px}.header-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#9ca3af}.header-search input{width:100%;padding:12px 16px 12px 44px;border:2px solid #e5e7eb;border-radius:12px;font-size:.95rem;background:#fff;transition:all .2s}.header-search input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #00000014;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:28px;height:28px}.stat-icon.blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.stat-icon.green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.stat-icon.purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}.stat-icon.orange{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;color:#1f2937;line-height:1}.stat-label{font-size:.85rem;color:#6b7280;margin-top:4px}.distribution-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #00000014}.distribution-section h3{margin:0 0 1rem;font-size:1rem;color:#374151;font-weight:600}.distribution-bar{display:flex;height:24px;border-radius:12px;overflow:hidden;background:#f3f4f6}.distribution-segment{height:100%;min-width:4px;transition:opacity .2s}.distribution-segment:hover{opacity:.8}.distribution-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem}.legend-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#4b5563}.legend-color{width:12px;height:12px;border-radius:3px}.legend-more{font-size:.85rem;color:#9ca3af}.employee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.workload-empty{text-align:center;padding:4rem;color:#6b7280;background:#fff;border-radius:16px;font-size:1.1rem}.employee-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #00000014;transition:transform .2s,box-shadow .2s}.employee-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.employee-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.employee-avatar{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;overflow:hidden;flex-shrink:0}.employee-avatar img{width:100%;height:100%;object-fit:cover}.employee-info{flex:1;min-width:0}.employee-info h3{margin:0;font-size:1.1rem;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-username{font-size:.85rem;color:#9ca3af}.workload-badge{display:flex;flex-direction:column;align-items:center;padding:8px 14px;border-radius:12px;color:#fff;min-width:60px}.badge-number{font-size:1.25rem;font-weight:700;line-height:1}.badge-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;opacity:.9}.status-bar-row{display:flex;align-items:center;gap:10px}.status-bar-row .status-label{font-size:.8rem;color:#6b7280;width:90px;flex-shrink:0}.status-bar-container{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.status-bar-fill{height:100%;border-radius:4px;transition:width .3s ease;min-width:4px}.status-bar-row .status-count{font-size:.85rem;font-weight:600;color:#374151;min-width:24px;text-align:right}.recent-projects{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid #f3f4f6}.recent-projects h4{margin:0 0 .75rem;font-size:.8rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.project-list{display:flex;flex-direction:column;gap:6px}.project-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f9fafb;border-radius:8px;cursor:pointer;transition:background .2s}.project-item:hover{background:#f3f4f6}.project-item .project-name{font-size:.9rem;color:#1f2937;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.project-item .project-company{font-size:.8rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pending-badge{display:flex;align-items:center;gap:8px;margin-top:1rem;padding:10px 14px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:10px;color:#92400e;font-size:.85rem;font-weight:500}.pending-badge svg{width:18px;height:18px;flex-shrink:0}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.workload-page{padding:1rem}.workload-header{flex-direction:column}.header-search{width:100%;min-width:unset}.stats-grid{grid-template-columns:1fr 1fr;gap:1rem}.stat-card{padding:1rem}.stat-icon{width:44px;height:44px}.stat-icon svg{width:22px;height:22px}.stat-value{font-size:1.5rem}.employee-grid{grid-template-columns:1fr}.distribution-legend{gap:.75rem}.legend-item{font-size:.75rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.header-content h1{font-size:1.5rem}}.admin-panel{flex:1;padding:24px;overflow-x:hidden}.admin-container{max-width:1200px;margin:0 auto}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:16px;color:#6b7280}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:20px;height:20px;border-width:2px}.admin-header{display:flex;align-items:center;gap:16px;margin-bottom:32px}.admin-header-icon{width:56px;height:56px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;display:flex;align-items:center;justify-content:center}.admin-header-icon svg{width:28px;height:28px;color:#fff}.admin-header h1{font-size:28px;font-weight:700;color:#1f2937;margin:0}.admin-header p{font-size:14px;color:#6b7280;margin:4px 0 0}.admin-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.admin-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;overflow:hidden}.admin-card .card-header{display:flex;align-items:center;gap:14px;padding:20px;border-bottom:1px solid #f3f4f6}.card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-icon svg{width:24px;height:24px}.card-icon.maintenance{background:#fef3c7;color:#d97706}.card-icon.backup{background:#dbeafe;color:#2563eb}.card-icon.info{background:#e0e7ff;color:#4f46e5}.card-title-section{flex:1}.card-title-section h2{font-size:16px;font-weight:600;color:#1f2937;margin:0}.card-title-section p{font-size:13px;color:#6b7280;margin:2px 0 0}.toggle-switch{position:relative;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:#e5e7eb;border-radius:14px;transition:.3s}.toggle-slider:before{content:"";position:absolute;width:22px;height:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 2px 4px #0000001a}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#667eea,#764ba2)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:disabled+.toggle-slider{opacity:.6;cursor:not-allowed}.card-body{padding:20px}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:20px}.status-badge.active{background:#fef3c7;color:#b45309}.status-badge.inactive{background:#d1fae5;color:#047857}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.status-badge.active .status-dot{background:#f59e0b}.status-badge.inactive .status-dot{background:#10b981}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:8px}.form-group textarea{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;resize:vertical;min-height:80px;transition:all .2s}.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-save-message{margin-top:12px;padding:10px 20px;background:#f3f4f6;border:none;border-radius:8px;font-size:13px;font-weight:600;color:#374151;cursor:pointer;transition:all .2s}.btn-save-message:hover{background:#e5e7eb}.btn-save-message:disabled{opacity:.6;cursor:not-allowed}.backup-progress{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f0f9ff;border-radius:10px;margin-bottom:16px;font-size:13px;color:#0369a1}.btn-backup{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-backup.full{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-backup.full:hover{opacity:.9;transform:translateY(-1px)}.btn-backup:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-backup svg{width:20px;height:20px}.backup-divider{display:flex;align-items:center;margin:20px 0;color:#9ca3af;font-size:12px}.backup-divider:before,.backup-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.backup-divider span{padding:0 12px}.backup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.btn-backup-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;font-size:12px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.btn-backup-item:hover{background:#f3f4f6;border-color:#d1d5db}.btn-backup-item:disabled{opacity:.6;cursor:not-allowed}.btn-backup-item svg{width:22px;height:22px;color:#6b7280}.info-list{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f3f4f6}.info-item:last-child{border-bottom:none}.info-label{font-size:13px;color:#6b7280}.info-value{font-size:13px;font-weight:600;color:#1f2937}.info-card{grid-column:span 2}@media (max-width: 1024px){.admin-grid{grid-template-columns:1fr}.info-card{grid-column:span 1}}@media (max-width: 768px){.admin-panel{padding:16px}.admin-header{flex-direction:column;text-align:center}.admin-header h1{font-size:24px}.backup-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.backup-grid{grid-template-columns:1fr}.admin-card .card-header{flex-wrap:wrap}.toggle-switch{order:-1;margin-left:auto}}.card-icon.restore{background:linear-gradient(135deg,#10b981,#059669)}.restore-warning{display:flex;gap:12px;padding:12px;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;margin-bottom:16px}.restore-warning svg{width:24px;height:24px;color:#d97706;flex-shrink:0}.restore-warning strong{color:#92400e;font-size:13px}.restore-warning p{margin:4px 0 0;font-size:12px;color:#92400e}.btn-restore{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-restore:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-restore:disabled{opacity:.6;cursor:not-allowed}.btn-restore svg{width:20px;height:20px}.restore-modal{background:#fff;border-radius:16px;padding:24px;max-width:420px;width:90%;text-align:center;box-shadow:0 25px 50px -12px #00000040}.restore-modal .modal-icon.warning{width:64px;height:64px;margin:0 auto 16px;background:#fef3c7;border-radius:50%;display:flex;align-items:center;justify-content:center}.restore-modal .modal-icon.warning svg{width:32px;height:32px;color:#d97706}.restore-modal h3{margin:0 0 16px;font-size:20px;color:#1f2937}.restore-info{background:#f9fafb;border-radius:8px;padding:12px;margin-bottom:16px;text-align:left}.restore-info .info-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}.restore-info .info-row span{color:#6b7280}.restore-info .info-row strong{color:#1f2937}.warning-text{margin:0 0 20px;font-size:13px;color:#dc2626;line-height:1.5}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-cancel{padding:10px 20px;background:#f3f4f6;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#e5e7eb}.btn-confirm{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:14px;font-weight:500;color:#fff;cursor:pointer;transition:all .2s}.btn-confirm:hover{opacity:.9}.card-icon.stats{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.stat-item{text-align:center;padding:16px 8px;background:#f9fafb;border-radius:12px}.stat-number{display:block;font-size:28px;font-weight:700;color:#1f2937;line-height:1}.stat-label-sm{font-size:12px;color:#6b7280;margin-top:4px;display:block}.status-breakdown{border-top:1px solid #e5e7eb;padding-top:16px}.status-breakdown h4{font-size:13px;font-weight:600;color:#374151;margin:0 0 12px}.status-bars{display:flex;flex-direction:column;gap:10px}.status-bar-item{display:grid;grid-template-columns:120px 1fr 40px;align-items:center;gap:12px}.status-name{font-size:12px;color:#6b7280;text-transform:capitalize}.status-bar-bg{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.status-bar-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.status-count{font-size:13px;font-weight:600;color:#1f2937;text-align:right}.card-icon.types{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-add-type{padding:8px 14px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-add-type:hover{opacity:.9}.types-list{display:flex;flex-direction:column;gap:8px}.type-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border-radius:8px}.type-color{width:24px;height:24px;border-radius:6px;flex-shrink:0}.type-name{flex:1;font-size:14px;font-weight:500;color:#1f2937}.type-actions{display:flex;gap:4px}.type-actions button{padding:6px 8px;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px}.type-actions button:hover{background:#e5e7eb}.type-modal{background:#fff;border-radius:16px;padding:24px;max-width:400px;width:90%;box-shadow:0 25px 50px -12px #00000040}.type-modal h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#1f2937}.type-modal .form-group input[type=text]{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s}.type-modal .form-group input[type=text]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.color-picker-row{display:flex;align-items:center;gap:12px}.color-picker-row input[type=color]{width:48px;height:48px;border:none;border-radius:8px;cursor:pointer;padding:0}.color-value{font-size:14px;color:#6b7280;font-family:monospace}.card-icon.branding{background:linear-gradient(135deg,#ec4899,#db2777);color:#fff}.branding-card .form-group input{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s}.branding-card .form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.logo-preview{margin:16px 0;padding:16px;background:#f9fafb;border-radius:12px;text-align:center}.logo-preview img{max-width:200px;max-height:100px;object-fit:contain}.btn-save-branding{width:100%;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-save-branding:hover{opacity:.9}.card-icon.api{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.btn-refresh-api{padding:8px 14px;background:#f3f4f6;border:none;border-radius:8px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.btn-refresh-api:hover{background:#e5e7eb}.api-list{display:flex;flex-direction:column;gap:12px}.api-item{display:flex;align-items:center;justify-content:space-between;padding:14px;background:#f9fafb;border-radius:10px}.api-info{display:flex;flex-direction:column;gap:2px}.api-name{font-size:14px;font-weight:600;color:#1f2937}.api-desc{font-size:12px;color:#6b7280}.api-status{font-size:13px;font-weight:600;padding:4px 10px;border-radius:12px}.api-status.connected{background:#d1fae5;color:#059669}.api-status.disconnected{background:#fee2e2;color:#dc2626}.stats-card{grid-column:span 2}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.status-bar-item{grid-template-columns:80px 1fr 30px}.stats-card{grid-column:span 1}}.maintenance-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;padding:20px}.maintenance-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.gear{position:absolute;opacity:.1;color:#fff}.gear svg{width:100%;height:100%}.gear-1{width:300px;height:300px;top:-100px;right:-100px;animation:rotate 20s linear infinite}.gear-2{width:200px;height:200px;bottom:-50px;left:-50px;animation:rotate 15s linear infinite reverse}.gear-3{width:150px;height:150px;top:40%;left:10%;animation:rotate 25s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.maintenance-content{background:#fff;border-radius:24px;padding:48px;text-align:center;max-width:500px;width:100%;box-shadow:0 25px 80px #0000004d;position:relative;z-index:1;animation:slideUp .6s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.maintenance-icon{width:80px;height:80px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:bounce 2s ease-in-out infinite}.maintenance-icon svg{width:40px;height:40px;color:#fff}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.maintenance-content h1{font-size:28px;font-weight:700;color:#1f2937;margin:0 0 16px}.maintenance-message{font-size:16px;color:#6b7280;line-height:1.6;margin:0 0 32px}.maintenance-illustration{display:flex;justify-content:center;align-items:flex-end;gap:30px;margin-bottom:32px;height:120px}.worker{position:relative;width:60px;height:100px}.worker-head{width:30px;height:30px;background:#fcd34d;border-radius:50%;position:absolute;top:0;left:50%;transform:translate(-50%)}.worker-head:before{content:"";position:absolute;width:36px;height:15px;background:#f59e0b;border-radius:20px 20px 0 0;top:-5px;left:50%;transform:translate(-50%)}.worker-body{width:40px;height:50px;background:#3b82f6;border-radius:8px;position:absolute;top:35px;left:50%;transform:translate(-50%)}.worker-arm{width:12px;height:40px;background:#fcd34d;border-radius:6px;position:absolute;top:40px}.arm-left{left:0;transform:rotate(-30deg);transform-origin:top center;animation:armMove 1s ease-in-out infinite}.arm-right{right:0;transform:rotate(30deg);transform-origin:top center;animation:armMove 1s ease-in-out infinite .5s}@keyframes armMove{0%,to{transform:rotate(-30deg)}50%{transform:rotate(-60deg)}}.arm-right{animation-name:armMoveRight}@keyframes armMoveRight{0%,to{transform:rotate(30deg)}50%{transform:rotate(60deg)}}.server{width:50px;height:80px;background:#374151;border-radius:8px;position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:15px 0}.server:before{content:"";position:absolute;width:40px;height:4px;background:#4b5563;top:10px;border-radius:2px}.server-light{width:8px;height:8px;border-radius:50%}.light-1{background:#22c55e;animation:blink 1s ease-in-out infinite}.light-2{background:#fbbf24;animation:blink 1.5s ease-in-out infinite .3s}.light-3{background:#ef4444;animation:blink 2s ease-in-out infinite .6s}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.maintenance-footer{margin-top:16px}.progress-bar{width:100%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-bottom:12px}.progress-fill{width:60%;height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;animation:progress 2s ease-in-out infinite}@keyframes progress{0%{width:20%}50%{width:80%}to{width:20%}}.maintenance-footer p{font-size:13px;color:#9ca3af;margin:0}@media (max-width: 480px){.maintenance-content{padding:32px 24px}.maintenance-content h1{font-size:22px}.maintenance-message{font-size:14px}.maintenance-icon{width:64px;height:64px}.maintenance-icon svg{width:32px;height:32px}.gear-1{width:200px;height:200px}.gear-2{width:120px;height:120px}.gear-3{display:none}}.app-footer{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;margin-top:auto;box-shadow:0 -2px 10px #0000001a}.footer-container{max-width:1400px;margin:0 auto}.footer-content{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:24px;margin-bottom:16px}.footer-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.footer-logo{font-size:18px;line-height:1}.footer-text{font-size:13px;font-weight:600;opacity:.95;letter-spacing:.2px;white-space:nowrap}.footer-links{display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap}.footer-separator{color:#ffffff80;font-size:12px;margin:0 4px}.footer-link{color:#fff;text-decoration:none;font-size:13px;font-weight:500;opacity:.9;transition:all .3s ease;padding:6px 12px;border-radius:6px;white-space:nowrap}.footer-link:hover{opacity:1;background:#ffffff26;text-decoration:none}.footer-copyright{text-align:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.2)}.footer-copyright p{margin:4px 0;font-size:12px;opacity:.9;line-height:1.5}.footer-copyright strong{font-weight:700;opacity:1}.footer-created{font-size:11px;opacity:.85;margin-top:4px}.footer-created strong{font-weight:700;letter-spacing:.3px}.footer-server-monitor{display:flex;align-items:center;gap:7px;margin-left:24px;font-size:13px;-webkit-user-select:none;user-select:none;font-weight:500}.server-dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:3px;box-shadow:0 0 8px #00000014;border:2px solid rgba(255,255,255,.25)}.server-status-text{font-size:13px;font-weight:600;opacity:.9;margin-right:2px}.server-last-checked{font-size:11px;opacity:.85;margin-left:4px}@media (max-width: 768px){.app-footer{padding:16px 20px}.footer-content{gap:16px;margin-bottom:12px}.footer-brand,.footer-links{width:100%;justify-content:center}.footer-text{font-size:12px}.footer-link{font-size:12px;padding:5px 10px}.footer-copyright{padding-top:12px}.footer-copyright p{font-size:11px}.footer-created{font-size:10px}}@media (max-width:830px){.footer-server-monitor{margin-left:0;width:100%;justify-content:center;margin-top:6px}}@media (max-width:480px){.footer-server-monitor{font-size:11px;margin-top:7px;gap:5px}.server-last-checked{font-size:10px}}@media (max-width: 480px){.app-footer{padding:14px 15px}.footer-content{flex-direction:column;gap:12px;margin-bottom:12px}.footer-brand{width:100%;justify-content:center}.footer-text{font-size:11px}.footer-logo{font-size:16px}.footer-links{width:100%;justify-content:center}.footer-link{font-size:11px;padding:4px 8px}.footer-copyright{padding-top:10px}.footer-copyright p{font-size:10px;margin:3px 0}.footer-created{font-size:9px;margin-top:3px}}.toast{position:fixed;top:90px;right:20px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:16px 20px;display:flex;align-items:center;gap:12px;min-width:300px;max-width:400px;z-index:3000;animation:slideInRight .3s ease}.toast-success{border-left:4px solid #28a745;background:linear-gradient(135deg,#fff,#f0fdf4)}.toast-error{border-left:4px solid #dc3545;background:linear-gradient(135deg,#fff,#fef2f2)}.toast-warning{border-left:4px solid #f59e0b;background:linear-gradient(135deg,#fff,#fffbeb)}.toast-info{border-left:4px solid #3b82f6;background:linear-gradient(135deg,#fff,#eff6ff)}.toast-icon{font-size:24px;flex-shrink:0}.toast-message{flex:1;font-size:14px;color:#333;font-weight:500}.toast-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.toast-close:hover{background:#f5f7fa;color:#333}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.toast{right:10px;left:10px;min-width:auto;max-width:none}}.terms-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf0);padding:40px 20px;display:flex;justify-content:center;align-items:flex-start}.terms-container{max-width:900px;width:100%;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:60px 80px;animation:fadeInUp .5s ease}.terms-header{text-align:center;margin-bottom:50px;padding-bottom:30px;border-bottom:2px solid #e8ecf0}.terms-header h1{font-size:42px;font-weight:700;color:#1a1a1a;margin:0 0 10px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.terms-subtitle{font-size:16px;color:#666;font-weight:500;margin:0 0 15px;letter-spacing:1px;text-transform:uppercase}.terms-updated{font-size:14px;color:#999;margin:0}.terms-content{line-height:1.8;color:#333}.terms-section{margin-bottom:40px}.terms-section:last-child{margin-bottom:0}.terms-section h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 16px;padding-top:10px;border-top:1px solid #e8ecf0}.terms-section:first-child h2{border-top:none;padding-top:0}.terms-section h3{font-size:18px;font-weight:600;color:#667eea;margin:24px 0 12px}.terms-section p{font-size:16px;color:#555;margin:0 0 16px;text-align:justify}.terms-section ul{margin:16px 0;padding-left:30px;list-style:none}.terms-section ul li{font-size:16px;color:#555;margin-bottom:12px;padding-left:25px;position:relative;text-align:justify}.terms-section ul li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.terms-footer{margin-top:50px;padding-top:30px;border-top:2px solid #e8ecf0;text-align:center}.terms-back-link{display:inline-flex;align-items:center;gap:8px;color:#667eea;text-decoration:none;font-weight:600;font-size:16px;padding:12px 24px;border:2px solid #667eea;border-radius:8px;transition:all .3s ease}.terms-back-link:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}@media (max-width: 768px){.terms-page{padding:20px 15px}.terms-container{padding:40px 30px;border-radius:12px}.terms-header h1{font-size:32px}.terms-subtitle{font-size:14px}.terms-section h2{font-size:20px}.terms-section h3{font-size:16px}.terms-section p,.terms-section ul li{font-size:14px}.terms-content{line-height:1.6}}@media (max-width: 480px){.terms-container{padding:30px 20px}.terms-header{margin-bottom:30px;padding-bottom:20px}.terms-header h1{font-size:28px}.terms-section{margin-bottom:30px}.terms-section ul,.terms-section ul li{padding-left:20px}.terms-footer{margin-top:40px;padding-top:20px}}.privacy-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf0);padding:40px 20px;display:flex;justify-content:center;align-items:flex-start}.privacy-container{max-width:900px;width:100%;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:60px 80px;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.privacy-header{text-align:center;margin-bottom:50px;padding-bottom:30px;border-bottom:2px solid #e8ecf0}.privacy-header h1{font-size:42px;font-weight:700;color:#1a1a1a;margin:0 0 10px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.privacy-subtitle{font-size:16px;color:#666;font-weight:500;margin:0 0 15px;letter-spacing:1px;text-transform:uppercase}.privacy-updated{font-size:14px;color:#999;margin:0}.privacy-content{line-height:1.8;color:#333}.privacy-intro{font-size:17px;color:#444;font-weight:500;text-align:justify;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea;margin-bottom:30px}.privacy-section{margin-bottom:40px}.privacy-section:last-of-type{margin-bottom:0}.privacy-section h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 16px;padding-top:10px;border-top:1px solid #e8ecf0}.privacy-section:first-of-type h2{border-top:none;padding-top:0}.privacy-section h3{font-size:18px;font-weight:600;color:#667eea;margin:24px 0 12px}.privacy-section p{font-size:16px;color:#555;margin:0 0 16px;text-align:justify}.privacy-section ul{margin:16px 0;padding-left:30px;list-style:none}.privacy-section ul li{font-size:16px;color:#555;margin-bottom:12px;padding-left:25px;position:relative;text-align:justify}.privacy-section ul li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.privacy-section ul li strong{color:#333;font-weight:600}.privacy-footer{margin-top:50px;padding-top:30px;border-top:2px solid #e8ecf0;text-align:center}.privacy-back-link{display:inline-flex;align-items:center;gap:8px;color:#667eea;text-decoration:none;font-weight:600;font-size:16px;padding:12px 24px;border:2px solid #667eea;border-radius:8px;transition:all .3s ease}.privacy-back-link:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}@media (max-width: 768px){.privacy-page{padding:20px 15px}.privacy-container{padding:40px 30px;border-radius:12px}.privacy-header h1{font-size:32px}.privacy-subtitle{font-size:14px}.privacy-intro{font-size:15px;padding:15px}.privacy-section h2{font-size:20px}.privacy-section h3{font-size:16px}.privacy-section p,.privacy-section ul li{font-size:14px}.privacy-content{line-height:1.6}}@media (max-width: 480px){.privacy-container{padding:30px 20px}.privacy-header{margin-bottom:30px;padding-bottom:20px}.privacy-header h1{font-size:28px}.privacy-intro{font-size:14px;padding:12px}.privacy-section{margin-bottom:30px}.privacy-section ul,.privacy-section ul li{padding-left:20px}.privacy-footer{margin-top:40px;padding-top:20px}}.project-detail-page{min-height:100vh;background:#f8fafc}.project-detail-nav{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 10px #0000001a}.nav-left{display:flex;align-items:center;gap:16px}.btn-back{display:flex;align-items:center;gap:8px;background:#ffffff26;border:none;color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-back:hover{background:#ffffff40}.nav-title{color:#fff;font-size:18px;font-weight:600;margin:0}.project-id-badge{background:#ffffff26;color:#fffc;padding:4px 10px;border-radius:6px;font-size:11px;font-family:monospace;cursor:pointer;transition:all .2s}.project-id-badge:hover{background:#ffffff40;color:#fff}.nav-right{display:flex;align-items:center;gap:12px}.project-status-pill{background:#fff3;color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600}.project-detail-main{max-width:1400px;margin:0 auto;padding:24px;display:grid;grid-template-columns:350px 1fr;gap:24px}.project-sidebar{display:flex;flex-direction:column;gap:20px}.sidebar-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.sidebar-card-header{background:#f8fafc;padding:16px 20px;border-bottom:1px solid #e2e8f0}.sidebar-card-header h3{margin:0;font-size:14px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.sidebar-card-content{padding:20px}.info-list{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:12px;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.info-value{font-size:14px;color:#1e293b;font-weight:500}.info-value.empty{color:#94a3b8;font-style:italic}.lead-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;width:fit-content}.lead-badge.belum-dikerjakan{background:#f3f4f6;color:#4b5563}.lead-badge.sedang-dikerjakan{background:#dbeafe;color:#1d4ed8}.lead-badge.review{background:#fef3c7;color:#b45309}.lead-badge.tidak-deal{background:#fee2e2;color:#dc2626}.lead-badge.deal{background:#dcfce7;color:#16a34a}.ql-number-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;display:inline-block}.nilai-penawaran{background:linear-gradient(135deg,#10b981,#059669);color:#fff!important;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;display:inline-block}.pic-list{display:flex;flex-wrap:wrap;gap:8px}.pic-badge{background:#f1f5f9;color:#475569;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:500}.description-box{background:#f8fafc;padding:16px;border-radius:8px;font-size:14px;color:#475569;line-height:1.6;white-space:pre-wrap;max-height:200px;overflow-y:auto}.creator-info{display:flex;align-items:center;gap:12px}.creator-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.creator-details{display:flex;flex-direction:column}.creator-name{font-size:14px;font-weight:600;color:#1e293b}.creator-name a{color:#667eea;text-decoration:none}.creator-name a:hover{text-decoration:underline}.creator-date{font-size:12px;color:#94a3b8}.project-content{display:flex;flex-direction:column;gap:24px}.content-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.content-card-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.content-card-header h2{margin:0;font-size:18px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:10px}.content-card-body{padding:24px}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.document-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px;transition:all .2s}.document-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.document-card.has-file{border-color:#86efac;background:#f0fdf4}.document-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.document-type-name{font-size:14px;font-weight:600;color:#1e293b}.document-status{font-size:11px;padding:4px 8px;border-radius:4px;font-weight:600}.document-status.uploaded{background:#dcfce7;color:#16a34a}.document-status.pending{background:#fef3c7;color:#d97706}.document-status.empty{background:#f1f5f9;color:#64748b}.document-card-content{display:flex;flex-direction:column;gap:12px}.document-main{display:flex;align-items:center;gap:12px}.document-icon{font-size:32px;flex-shrink:0}.document-info{flex:1;min-width:0}.document-filename{font-size:13px;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;display:block}.document-filename.clickable{color:#667eea;cursor:pointer}.document-filename.clickable:hover{text-decoration:underline}.document-meta{font-size:11px;color:#94a3b8;display:block}.document-meta a{color:#667eea;text-decoration:none}.document-meta a:hover{text-decoration:underline}.document-actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:8px;border-top:1px solid #f1f5f9}.btn-doc-action{background:#667eea;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.btn-doc-action:hover{background:#5a67d8}.mom-section{background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;padding:16px}.mom-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.mom-title{font-size:14px;font-weight:600;color:#92400e}.mom-content{background:#fff;padding:16px;border-radius:8px;font-size:14px;line-height:1.6;color:#1e293b;white-space:pre-wrap;margin:0;font-family:inherit;max-height:300px;overflow-y:auto}.doc-link-section{background:#f0f9ff;border:1px solid #7dd3fc;border-radius:10px;padding:16px;display:flex;align-items:center;gap:12px}.doc-link-icon{font-size:24px}.doc-link-content{flex:1}.doc-link-label{font-size:12px;color:#0369a1;margin-bottom:4px}.doc-link-url{color:#0284c7;text-decoration:none;font-weight:500;word-break:break-all}.doc-link-url:hover{text-decoration:underline}.discussion-section,.discussion-section .content-card-body{padding:0}.discussion-section .comment-section{border-top:none;margin-top:0;padding-top:0}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px;text-align:center;padding:40px}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container h2{font-size:20px;color:#64748b;margin:0}@media (max-width: 1024px){.project-detail-main{grid-template-columns:1fr}.project-sidebar{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}}@media (max-width: 768px){.project-detail-nav{padding:12px 16px;flex-wrap:wrap;gap:12px}.nav-title{font-size:16px;order:-1;width:100%}.project-detail-main{padding:16px}.project-sidebar,.documents-grid{grid-template-columns:1fr}.content-card-header,.content-card-body{padding:16px}}@media (max-width: 480px){.btn-back span{display:none}.project-status-pill{font-size:11px;padding:6px 12px}}.btn-upload-new{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-upload-new:hover:not(:disabled){background:linear-gradient(135deg,#5a6fd6,#6a4190)}.btn-upload-new:disabled{opacity:.6;cursor:not-allowed}.btn-archive{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.btn-archive:hover{background:#f1f5f9;color:#475569}.document-archive{border-top:1px solid #e2e8f0;padding:12px;background:#f8fafc}.archive-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#64748b;margin-bottom:8px}.archive-empty{font-size:12px;color:#94a3b8;text-align:center;padding:12px}.archive-list{display:flex;flex-direction:column;gap:8px}.archive-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e2e8f0}.archive-item-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.archive-version{background:#e2e8f0;color:#475569;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.archive-filename{font-size:12px;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.archive-date,.archive-uploader{font-size:11px;color:#94a3b8}.btn-archive-download{background:#f1f5f9;color:#475569;padding:4px 10px;border-radius:4px;font-size:11px;border:none;cursor:pointer;transition:all .2s}.btn-archive-download:hover{background:#e2e8f0;color:#334155}@media (max-width: 768px){.archive-item-info{flex-wrap:wrap;gap:6px}.archive-filename{max-width:120px}.archive-date,.archive-uploader{display:none}}.not-found-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);position:relative;overflow:hidden;padding:20px}.not-found-background{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;z-index:0}.floating-shapes{position:absolute;width:100%;height:100%}.shape{position:absolute;border-radius:50%;opacity:.1;animation:float 15s infinite ease-in-out}.shape-1{width:400px;height:400px;background:linear-gradient(135deg,#667eea,#764ba2);top:-100px;left:-100px;animation-delay:0s}.shape-2{width:300px;height:300px;background:linear-gradient(135deg,#f093fb,#f5576c);top:50%;right:-50px;animation-delay:-5s}.shape-3{width:200px;height:200px;background:linear-gradient(135deg,#4facfe,#00f2fe);bottom:10%;left:10%;animation-delay:-10s}.shape-4{width:150px;height:150px;background:linear-gradient(135deg,#43e97b,#38f9d7);top:20%;right:20%;animation-delay:-7s}.shape-5{width:250px;height:250px;background:linear-gradient(135deg,#fa709a,#fee140);bottom:-50px;right:30%;animation-delay:-12s}@keyframes float{0%,to{transform:translate(0) rotate(0) scale(1)}25%{transform:translate(30px,-30px) rotate(90deg) scale(1.1)}50%{transform:translate(-20px,20px) rotate(180deg) scale(.9)}75%{transform:translate(20px,40px) rotate(270deg) scale(1.05)}}.not-found-container{position:relative;z-index:1;text-align:center;max-width:600px}.error-code{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:30px;transition:transform .1s ease-out}.digit{font-size:150px;font-weight:900;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 10px 30px rgba(102,126,234,.3);line-height:1}.digit.zero{position:relative;width:120px;height:150px;background:none;-webkit-text-fill-color:initial;display:flex;align-items:center;justify-content:center}.zero-inner{width:100px;height:100px;border-radius:50%;border:15px solid;border-color:#667eea;background:transparent;animation:pulse-ring 2s infinite ease-in-out;box-shadow:0 0 30px #667eea80,inset 0 0 30px #667eea33}@keyframes pulse-ring{0%,to{transform:scale(1);box-shadow:0 0 30px #667eea80,inset 0 0 30px #667eea33}50%{transform:scale(1.05);box-shadow:0 0 50px #667eeab3,inset 0 0 40px #667eea4d}}.error-content{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0000004d}.error-title{color:#fff;font-size:28px;font-weight:700;margin:0 0 16px}.error-description{color:#ffffffb3;font-size:16px;line-height:1.6;margin:0 0 30px}.error-illustration{margin:30px 0}.illustration-container{display:flex;justify-content:center}.broken-link{display:flex;align-items:center;gap:10px}.link-part{display:flex;align-items:center}.chain-link{width:60px;height:30px;border:4px solid #667eea;border-radius:15px;position:relative}.link-part.left .chain-link{animation:shake-left 2s infinite ease-in-out}.link-part.right .chain-link{animation:shake-right 2s infinite ease-in-out}@keyframes shake-left{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-5px) rotate(-5deg)}75%{transform:translate(3px) rotate(3deg)}}@keyframes shake-right{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(5px) rotate(5deg)}75%{transform:translate(-3px) rotate(-3deg)}}.break-spark{display:flex;flex-direction:column;gap:4px}.break-spark span{width:8px;height:2px;background:#f5576c;border-radius:2px;animation:spark 1s infinite ease-in-out;box-shadow:0 0 10px #f5576c}.break-spark span:nth-child(1){transform:rotate(-30deg);animation-delay:0s}.break-spark span:nth-child(2){animation-delay:.2s}.break-spark span:nth-child(3){transform:rotate(30deg);animation-delay:.4s}@keyframes spark{0%,to{opacity:1;transform:scaleX(1)}50%{opacity:.5;transform:scaleX(1.5)}}.error-actions{display:flex;justify-content:center;gap:16px;margin-bottom:30px;flex-wrap:wrap}.btn-home,.btn-back{display:flex;align-items:center;gap:10px;padding:14px 28px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none}.btn-home{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;box-shadow:0 10px 30px #667eea66}.btn-home:hover{transform:translateY(-3px);box-shadow:0 15px 40px #667eea80}.btn-back{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}.btn-back:hover{background:#ffffff1a;border-color:#ffffff80;transform:translateY(-3px)}.btn-icon{font-size:18px}.error-suggestions{border-top:1px solid rgba(255,255,255,.1);padding-top:25px}.suggestions-title{color:#ffffff80;font-size:14px;margin:0 0 15px}.suggestions-links{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.suggestion-link{display:flex;align-items:center;gap:8px;color:#ffffffb3;text-decoration:none;font-size:14px;padding:8px 16px;border-radius:8px;background:#ffffff0d;transition:all .3s ease}.suggestion-link:hover{background:#ffffff1a;color:#fff;transform:translateY(-2px)}.suggestion-icon{font-size:16px}.not-found-footer{position:absolute;bottom:20px;left:0;right:0;text-align:center;z-index:1}.not-found-footer p{color:#fff6;font-size:13px;margin:0}@media (max-width: 768px){.digit{font-size:100px}.digit.zero{width:80px;height:100px}.zero-inner{width:70px;height:70px;border-width:10px}.error-content{padding:30px 20px}.error-title{font-size:22px}.error-description{font-size:14px}.error-actions{flex-direction:column;align-items:center}.btn-home,.btn-back{width:100%;justify-content:center}.suggestions-links{flex-direction:column;align-items:center}.suggestion-link{width:100%;justify-content:center}}@media (max-width: 480px){.digit{font-size:70px}.digit.zero{width:60px;height:70px}.zero-inner{width:50px;height:50px;border-width:8px}.error-title{font-size:20px}}*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;color:#333;overflow-x:hidden}#root{width:100%;min-height:100vh;overflow-x:hidden}
