body{margin:0}.login-container{align-items:center;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:32px;text-align:center}.logo{background:#1f57c3;border-radius:16px;display:inline-flex;height:80px;margin-bottom:20px;width:80px}.logo-text{font-size:28px;letter-spacing:2px}.login-header h1{color:#212121;font-size:24px;font-weight:600;margin:0 0 8px}.subtitle{color:#757575;font-size:14px;margin:0}.login-content{margin-bottom:32px}.google-signin-button{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:12px;justify-content:center;padding:14px 24px;transition:all .2s ease;width:100%}.google-signin-button:hover:not(:disabled){background:#1a4ba8;box-shadow:0 4px 8px #1f57c34d;transform:translateY(-1px)}.google-signin-button:active:not(:disabled){transform:translateY(0)}.google-signin-button:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#ffebee;border:1px solid #e74c3c;border-radius:6px;color:#c62828;font-size:14px;margin-top:16px;padding:12px;text-align:center}.login-footer{border-top:1px solid #e0e0e0;padding-top:24px;text-align:center}.login-footer p{color:#757575;font-size:13px;line-height:1.5;margin:0}@media (max-width:480px){.login-card{padding:32px 24px}.logo{height:64px;width:64px}.logo-text{font-size:24px}.login-header h1{font-size:20px}}.pending-container{align-items:center;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);display:flex;justify-content:center;min-height:100vh;padding:20px}.pending-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;max-width:500px;padding:48px 40px;text-align:center;width:100%}.pending-icon{align-items:center;background:#fff3e0;border-radius:50%;color:#f2994a;display:inline-flex;height:96px;justify-content:center;margin-bottom:24px;width:96px}.pending-card h1{color:#212121;font-size:24px;font-weight:600;margin:0 0 24px}.pending-message{margin-bottom:32px}.pending-message p{color:#616161;font-size:15px;line-height:1.6;margin:0 0 16px}.pending-message p:last-child{margin-bottom:0}.email-info{border-top:1px solid #e0e0e0;font-size:14px!important;padding-top:16px}.signout-button{background:#e0e0e0;border-radius:8px;color:#424242;display:inline-flex;padding:12px 24px;transition:all .2s ease}.signout-button:hover{background:#d5d5d5}.signout-button:active{transform:translateY(1px)}@media (max-width:480px){.pending-card{padding:40px 24px}.pending-icon{height:80px;width:80px}.pending-card h1{font-size:20px}.pending-message p{font-size:14px}}.pending-approvals{margin:0 auto;max-width:900px;padding:24px}.pending-approvals h2{color:#212121;font-size:24px;font-weight:600;margin:0 0 8px}.pending-approvals .subtitle{color:#757575;font-size:14px;margin:0 0 24px}.no-pending-users,.pending-approvals-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:64px 24px;text-align:center}.no-pending-users svg,.pending-approvals-loading .spinner{color:#757575;margin-bottom:16px}.pending-approvals-loading .spinner{animation:spin 1s linear infinite}.no-pending-users h3{color:#212121;font-size:18px;font-weight:600;margin:0 0 8px}.no-pending-users p{color:#757575;font-size:14px;margin:0}.pending-users-list{display:flex;flex-direction:column;gap:16px}.pending-user-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.user-info{gap:16px;margin-bottom:16px}.user-avatar{height:56px;object-fit:cover;width:56px}.user-details h3{color:#212121;font-size:16px;font-weight:600;margin:0 0 4px}.user-email{color:#616161;font-size:14px;margin:0 0 4px}.user-date{color:#9e9e9e;font-size:13px;margin:0}.user-actions{display:flex;gap:12px}.approve-button-small,.reject-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:10px 16px;transition:all .2s ease}.approve-button-small{background:#14a800;color:#fff}.approve-button-small:hover:not(:disabled){background:#0f8600}.reject-button{background:#ffebee;color:#e74c3c}.reject-button:hover:not(:disabled){background:#ffcdd2}.approve-button-small:disabled,.reject-button:disabled{cursor:not-allowed;opacity:.5}.approval-form{border-top:1px solid #e0e0e0;padding-top:16px}.approval-form h4{color:#212121;font-size:14px;font-weight:600;margin:0 0 16px}.form-group label{color:#424242;display:block}.form-group input[type=text],.form-group select{border:1px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.form-group input[type=text]:focus,.form-group select:focus{border-color:#1f57c3;outline:none}.form-group.checkbox label{align-items:center;cursor:pointer;display:flex;gap:8px}.form-group.checkbox input[type=checkbox]{cursor:pointer;height:18px;width:18px}.form-actions{margin-top:20px}.approve-button,.cancel-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.approve-button{background:#14a800;color:#fff}.approve-button:hover:not(:disabled){background:#0f8600}.approve-button:disabled{cursor:not-allowed;opacity:.6}.cancel-button{background:#e0e0e0;color:#424242}.cancel-button:hover:not(:disabled){background:#d5d5d5}@media (max-width:768px){.pending-approvals{padding:16px}.user-info{align-items:center;text-align:center}.user-actions,.user-info{flex-direction:column}.approve-button-small,.reject-button{justify-content:center;width:100%}}.image-modal-backdrop{align-items:center;animation:fadeIn .2s ease;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.image-modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.image-modal-header{align-items:center;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.image-modal-title{color:#212121;font-size:16px;font-weight:500;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-modal-actions{display:flex;gap:8px}.image-modal-btn{align-items:center;background:none;border:none;border-radius:50%;color:#757575;cursor:pointer;display:flex;padding:8px;transition:all .2s}.image-modal-btn:hover{background:#f5f5f5;color:#1f57c3}.image-modal-body{align-items:center;background:#fafafa;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.image-modal-img{border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:calc(90vh - 80px);max-width:100%;object-fit:contain}@media (max-width:768px){.image-modal-backdrop{padding:0}.image-modal-content{border-radius:0;max-height:100vh;max-width:100vw}.image-modal-img{max-height:calc(100vh - 80px)}}.image-modal-backdrop[data-closeable=true]{cursor:pointer}.chat-window{background:#fff;border-radius:8px;overflow:hidden}.chat-window,.chat-window-loading{display:flex;flex-direction:column;height:100%}.chat-window-loading{align-items:center;color:#757575;gap:12px;justify-content:center}.chat-header{align-items:center;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.chat-header h3{color:#212121;font-size:16px;margin:0}.chat-status{color:#14a800;font-size:12px}.chat-messages{background:#f5f5f5;flex:1 1;gap:12px;overflow-y:auto;padding:20px}.chat-empty,.chat-messages{display:flex;flex-direction:column}.chat-empty{align-items:center;color:#9e9e9e;height:100%;justify-content:center}.chat-empty p{font-size:16px;margin:0}.chat-empty-subtitle{font-size:14px;margin-top:8px}.message-system{align-self:flex-start;margin:4px 0;max-width:90%}.message-system .message-bubble{background:#f5f5f5;border-radius:12px;box-shadow:none;color:#757575;font-size:13px;font-style:italic;line-height:1.3;padding:6px 12px;text-align:left}.message{display:flex;max-width:70%}.message-sent{align-self:flex-end}.message-received{align-self:flex-start}.message-bubble{word-wrap:break-word;border-radius:16px;padding:10px 14px;position:relative}.message-sent .message-bubble{background:#1f57c3;border-bottom-right-radius:4px;color:#fff}.message-received .message-bubble{background:#fff;border-bottom-left-radius:4px;box-shadow:0 1px 2px #0000001a;color:#212121}.message-text-container{align-items:center;display:inline-flex;gap:8px;position:relative}.message-text{flex:1 1;font-size:14px;line-height:1.4;margin:0;white-space:pre-wrap}.delete-message-btn{align-items:center;background:#0000001a;border:none;border-radius:4px;color:currentColor;cursor:pointer;display:flex;flex-shrink:0;opacity:.6;padding:4px;transition:all .2s}.delete-message-btn:hover:not(:disabled){background:#0003;opacity:1}.delete-message-btn:disabled{cursor:not-allowed;opacity:.3}.message-time{display:block;font-size:11px;margin-top:4px;opacity:.7}.message-file{margin-bottom:8px}.message-image-container{display:inline-block;position:relative}.message-image{border-radius:8px;cursor:pointer;display:block;max-height:300px;max-width:300px;transition:opacity .2s}.message-image:hover{opacity:.9}.message-image-error{color:#9e9e9e;font-size:13px;font-style:italic;padding:8px 0}.delete-image-btn{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;opacity:0;padding:8px;position:absolute;right:8px;top:8px;transition:all .2s}.message-image-container:hover .delete-image-btn{opacity:1}.delete-image-btn:hover:not(:disabled){background:#e74c3ce6;transform:scale(1.1)}.delete-image-btn:disabled{cursor:not-allowed;opacity:.5}.message-file-link{align-items:center;background:#ffffff1a;border-radius:8px;color:inherit;display:flex;gap:12px;padding:12px;text-decoration:none;transition:background .2s}.message-received .message-file-link{background:#f5f5f5}.message-file-link:hover{background:#fff3}.message-received .message-file-link:hover{background:#eee}.file-icon{font-size:24px}.file-info{gap:2px;min-width:0}.file-size{opacity:.7}.chat-input-container{background:#fff;border-top:1px solid #e0e0e0;padding:16px}.selected-file-preview{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;font-size:14px;gap:8px;margin-bottom:12px;padding:8px 12px}.selected-file-preview .file-name{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-file-btn{align-items:center;background:none;border:none;border-radius:4px;color:#757575;cursor:pointer;display:flex;padding:4px;transition:background .2s}.remove-file-btn:hover:not(:disabled){background:#e0e0e0}.remove-file-btn:disabled{cursor:not-allowed;opacity:.5}.upload-progress{color:#757575;font-size:14px;margin-bottom:12px}.progress-bar{border-radius:2px;height:4px}.progress-fill{background:#1f57c3;transition:width .3s}.chat-input{align-items:center;display:flex;gap:8px}.attach-btn,.send-btn{align-items:center;background:none;border:none;border-radius:50%;color:#757575;cursor:pointer;display:flex;padding:8px;transition:all .2s}.attach-btn:hover:not(:disabled){background:#f5f5f5;color:#1f57c3}.send-btn:hover:not(:disabled){background:#1f57c3;color:#fff}.attach-btn:disabled,.send-btn:disabled{cursor:not-allowed;opacity:.5}.message-input{border:1px solid #e0e0e0;border-radius:24px;flex:1 1;font-size:14px;outline:none;padding:10px 16px;transition:border-color .2s}.message-input:focus{border-color:#1f57c3}.message-input:disabled{background:#f5f5f5;cursor:not-allowed}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#f5f5f5}.chat-messages::-webkit-scrollbar-thumb{background:#bdbdbd;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#9e9e9e}@media (max-width:768px){.chat-window{border-radius:0;height:100vh}.chat-header{padding:12px 16px}.chat-header h3{font-size:15px}.chat-messages{padding:12px}.message{max-width:85%}.message-bubble{padding:8px 12px}.message-text{font-size:14px}.message-image{max-width:250px}.chat-input-container{padding:12px}.chat-input{gap:6px}.message-input{font-size:15px;padding:10px 14px}.attach-btn,.send-btn{padding:10px}.delete-image-btn{opacity:1;padding:6px;right:6px;top:6px}.delete-message-btn{padding:3px}}.chat-list-container{background:#fff;border-radius:8px;display:flex;height:calc(100vh - 80px);overflow:hidden}.chat-list-loading{align-items:center;color:#757575;gap:12px;height:100%;justify-content:center}.chat-list-loading,.chat-sidebar{display:flex;flex-direction:column}.chat-sidebar{background:#fff;border-right:1px solid #e0e0e0;width:350px}.chat-sidebar-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.chat-sidebar-header h2{color:#212121;font-size:20px;margin:0}.chat-count{background:#e3f2fd;border-radius:12px;color:#1565c0;font-size:12px;font-weight:600;padding:4px 10px}.chat-list{flex:1 1;overflow-y:auto}.chat-list-empty{align-items:center;color:#9e9e9e;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px;text-align:center}.chat-list-empty svg{color:#e0e0e0;margin-bottom:16px}.chat-list-empty p{font-size:16px;margin:8px 0 0}.chat-list-empty-subtitle{color:#bdbdbd;font-size:14px;margin-top:8px}.chat-list-item{align-items:center;border-bottom:1px solid #f5f5f5;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .2s}.chat-list-item:hover{background:#f5f5f5}.chat-list-item.active{background:#e3f2fd}.chat-avatar{align-items:center;background:linear-gradient(135deg,#1f57c3,#2979ff);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:600;height:48px;justify-content:center;width:48px}.chat-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.chat-info-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.chat-name{color:#212121;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-time{color:#757575;flex-shrink:0;font-size:12px}.chat-info-footer{align-items:center;display:flex;gap:8px;justify-content:space-between}.chat-preview{color:#757575;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-unread-badge{background:#1f57c3;border-radius:10px;color:#fff;flex-shrink:0;font-size:11px;font-weight:600;min-width:20px;padding:2px 8px;text-align:center}.chat-main{flex:1 1}.chat-main,.chat-placeholder{display:flex;flex-direction:column}.chat-placeholder{align-items:center;color:#9e9e9e;height:100%;justify-content:center}.chat-placeholder svg{color:#e0e0e0;margin-bottom:16px}.chat-placeholder h3{color:#757575;font-size:20px;margin:0}.chat-placeholder p{color:#bdbdbd;font-size:14px;margin:8px 0 0}.chat-list::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-track{background:#f5f5f5}.chat-list::-webkit-scrollbar-thumb{background:#bdbdbd;border-radius:3px}.chat-list::-webkit-scrollbar-thumb:hover{background:#9e9e9e}@media (max-width:768px){.chat-list-container{flex-direction:column;height:100vh}.chat-sidebar{border-bottom:1px solid #e0e0e0;border-right:none;height:auto;max-height:40vh;width:100%}.chat-sidebar-header{padding:12px 16px}.chat-sidebar-header h2{font-size:18px}.chat-list-item{padding:10px 16px}.chat-avatar{font-size:16px;height:44px;width:44px}.chat-name{font-size:14px}.chat-preview{font-size:13px}.chat-main{flex:1 1;height:auto}.chat-placeholder{padding:24px 16px}.chat-placeholder h3{font-size:18px}.chat-placeholder p{font-size:13px}}@media (max-width:480px){.chat-sidebar{max-height:35vh}.chat-sidebar-header h2{font-size:16px}.chat-list-item{padding:8px 12px}.chat-avatar{font-size:15px;height:40px;width:40px}.chat-name{font-size:13px}.chat-time{font-size:11px}.chat-preview{font-size:12px}}.project-form-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.project-form-container{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.project-form-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.project-form-header h2{color:#212121;font-size:20px;margin:0}.project-form{display:flex;flex-direction:column;gap:20px;padding:24px}@media (max-width:768px){.project-form-overlay{padding:0}.project-form-container{border-radius:0;max-height:100vh;max-width:100%}.project-form{padding:20px 16px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-save{width:100%}}.milestone-card{background:#fff;border-left:4px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:20px;transition:all .3s}.milestone-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.milestone-card.pending{border-left-color:#9e9e9e}.milestone-card.in_progress{border-left-color:#2196f3}.milestone-card.completed{background:#f9fdf9;border-left-color:#4caf50}.milestone-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.milestone-status{align-items:center;display:flex;gap:8px}.urgent-badge{align-items:center;animation:pulse 2s ease-in-out infinite;background:#ff5722;border-radius:12px;color:#fff;display:inline-flex;font-size:11px;font-weight:700;gap:4px;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.status-icon{flex-shrink:0}.status-icon.pending{color:#9e9e9e}.status-icon.in-progress{color:#2196f3}.status-icon.completed{color:#4caf50}.status-text{color:#212121;font-size:14px;font-weight:600}.milestone-order{background:#f5f5f5;border-radius:12px;color:#757575;font-size:13px;font-weight:600;padding:4px 12px}.milestone-body{display:flex;flex-direction:column;gap:12px}.milestone-title{color:#212121;font-size:18px;margin:0}.milestone-description{color:#757575;font-size:14px;line-height:1.5;margin:0}.milestone-deadline{align-items:center;background:#f5f5f5;border-radius:8px;color:#757575;display:flex;font-size:13px;gap:8px;padding:8px 12px;width:-webkit-fit-content;width:fit-content}.milestone-deadline.overdue{background:#ffebee;color:#c62828}.overdue-badge{background:#c62828;border-radius:4px;color:#fff;font-size:11px;font-weight:600;margin-left:8px;padding:2px 8px}.milestone-files{background:#f5f5f5;border-radius:8px;padding:12px}.files-header{align-items:center;color:#757575;display:flex;font-size:13px;font-weight:500;gap:6px;margin-bottom:8px}.files-list{gap:6px}.file-item{background:#fff;border-radius:6px;color:#1f57c3;font-size:13px;gap:8px;padding:6px 10px;text-decoration:none}.file-item:hover{background:#e3f2fd}.file-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.milestone-completed{align-items:center;background:#e8f5e9;border-radius:6px;color:#4caf50;display:flex;font-size:12px;gap:6px;padding:6px 10px;width:-webkit-fit-content;width:fit-content}.milestone-actions{border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding-top:16px}.action-btn{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s}.action-btn:hover{background:#f5f5f5}.action-btn.complete{background:#4caf50;border-color:#4caf50;color:#fff}.action-btn.complete:hover{background:#45a049}.action-btn.reopen{background:#2196f3;border-color:#2196f3;color:#fff}.action-btn.reopen:hover{background:#1976d2}.action-btn.edit{border-color:#1f57c3;color:#1f57c3}.action-btn.edit:hover{background:#e3f2fd}.action-btn.delete{border-color:#e74c3c;color:#e74c3c}.action-btn.delete:hover{background:#ffebee}@media (max-width:768px){.milestone-card{padding:16px}.milestone-title{font-size:16px}.milestone-description{font-size:13px}.milestone-actions{flex-direction:column}.action-btn{justify-content:center;width:100%}}.milestone-form-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.milestone-form-container{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.milestone-form-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.milestone-form-header h2{color:#212121;font-size:20px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#757575;cursor:pointer;display:flex;padding:4px;transition:all .2s}.close-btn:hover{background:#f5f5f5;color:#212121}.milestone-form{display:flex;flex-direction:column;gap:20px;padding:24px}.form-group input,.form-group select,.form-group textarea{border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:14px;padding:10px 14px;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1f57c3;box-shadow:0 0 0 3px #1f57c31a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;color:#9e9e9e;cursor:not-allowed}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px;padding:10px 0}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-label span{color:#212121;font-size:14px}.form-actions{padding-top:8px}.btn-cancel,.btn-save{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s}.btn-cancel{background:#fff;border:1px solid #e0e0e0}.btn-cancel:hover{background:#f5f5f5}.btn-save{background:#1f57c3}.btn-save:hover{background:#1a4ba8}@media (max-width:768px){.milestone-form-overlay{padding:0}.milestone-form-container{border-radius:0;max-height:100vh;max-width:100%}.milestone-form{padding:20px 16px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-save{width:100%}}.project-detail{margin:0 auto;max-width:1200px;padding:0}.project-detail-error,.project-detail-loading{align-items:center;color:#757575;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:400px}.project-detail-header{margin-bottom:24px}.btn-back{align-items:center;border:1px solid #e0e0e0;color:#757575;display:flex;gap:8px;padding:10px 16px;transition:all .2s}.btn-back:hover{background:#f5f5f5;color:#212121}.project-info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:32px;padding:24px}.project-info-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:16px}.project-info-header h1{color:#212121;font-size:28px;margin:0}.project-client{font-size:14px;margin:4px 0 0}.project-status-badge{border-radius:16px;font-size:13px;font-weight:600;padding:6px 14px;white-space:nowrap}.project-status-badge.active{background:#e3f2fd;color:#1976d2}.project-status-badge.completed{background:#e8f5e9;color:#388e3c}.project-status-badge.paid{background:#f3e5f5;color:#7b1fa2}.project-description{color:#616161;font-size:15px;line-height:1.6;margin:0 0 20px}.project-metadata{border-bottom:1px solid #f5f5f5;border-top:1px solid #f5f5f5;display:flex;flex-wrap:wrap;gap:16px;padding:16px 0}.metadata-item{align-items:center;color:#757575;display:flex;font-size:14px;gap:8px}.project-progress-section{margin-top:20px}.progress-header{margin-bottom:12px}.progress-info{color:#212121;font-size:15px;font-weight:600;gap:8px}.progress-percentage{color:#1f57c3;font-size:24px}.progress-bar{margin-bottom:8px}.progress-text{color:#9e9e9e;margin:0}.project-actions{border-top:1px solid #f5f5f5;margin-top:20px;padding-top:20px}.btn-complete-project{align-items:center;background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:background .2s}.btn-complete-project:hover{background:#45a049}.btn-reopen-project{align-items:center;background:#ff9800;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:background .2s}.btn-reopen-project:hover{background:#fb8c00}.project-locked-notice{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin-bottom:20px;padding:16px}.project-locked-notice p{color:#856404;font-size:14px;margin:0}.project-locked-notice strong{text-transform:capitalize}.milestones-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.milestones-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.milestones-header h2{color:#212121;font-size:20px;margin:0}.btn-add-first,.btn-add-milestone{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:background .2s}.btn-add-first:hover,.btn-add-milestone:hover{background:#1a4ba8}.milestones-list{gap:16px}.milestone-group{gap:12px}.group-list{display:flex;flex-direction:column;gap:12px}.milestones-empty{color:#757575;padding:48px 24px;text-align:center}.milestones-empty p{font-size:16px;margin:0 0 16px}@media (max-width:768px){.milestones-section,.project-info-card{border-radius:0;padding:20px 16px}.project-info-header{align-items:flex-start;flex-direction:column}.project-info-header h1{font-size:24px}.project-metadata{flex-direction:column;gap:12px}.progress-percentage{font-size:20px}.milestones-header{align-items:stretch;flex-direction:column}.milestones-header h2{font-size:18px}.btn-add-milestone{justify-content:center;width:100%}}.projects-manager{padding:0}.projects-loading{align-items:center;color:#757575;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:400px}.projects-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:16px}.projects-header h1{color:#212121;font-size:28px;margin:0}.projects-header p{color:#757575;font-size:14px;margin:4px 0 0}.projects-stats-compact{align-items:center;color:#616161;display:flex;font-size:15px;gap:12px;margin-bottom:20px;padding:12px 0}.stat-text{color:#212121;font-weight:500}.stat-separator{color:#e0e0e0}.stat-active{color:#4caf50;font-weight:600}.projects-filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.search-box{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;flex:1 1;gap:10px;min-width:250px;padding:10px 16px;transition:all .2s}.search-box:focus-within{border-color:#1f57c3;box-shadow:0 0 0 3px #1f57c31a}.search-box input{border:none;flex:1 1;font-size:14px;outline:none}.filter-group{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:8px;padding:10px 16px}.filter-group select{background:#0000;border:none;cursor:pointer;font-size:14px;outline:none}.projects-list{display:flex;flex-direction:column;gap:12px}.projects-empty{background:#fff;border-radius:12px;color:#757575;padding:48px;text-align:center}.projects-empty p{font-size:16px;margin:0 0 16px}.project-row{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;cursor:pointer;display:flex;flex-direction:column;gap:16px;padding:20px;transition:all .2s}.project-row:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.project-main-info{display:flex;flex-direction:column;gap:8px}.project-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.project-title-row h3{color:#212121;flex-shrink:0;font-size:18px;margin:0}.status-badge{border-radius:12px;flex-shrink:0;padding:4px 10px}.status-active{background:#e3f2fd;color:#1976d2}.status-completed{background:#e8f5e9;color:#388e3c}.status-paid{background:#f3e5f5;color:#7b1fa2}.status-archived{background:#f5f5f5;color:#757575}.project-meta-row{align-items:center;display:flex;flex-wrap:wrap;font-size:14px;gap:12px}.project-client{color:#757575;font-weight:500}.project-description{color:#9e9e9e;font-style:italic}.project-stats-row{align-items:center;border-top:1px solid #f5f5f5;display:flex;gap:20px;justify-content:space-between;padding-top:12px}.progress-compact{align-items:center;display:flex;flex:1 1;gap:12px}.progress-label{color:#757575;font-size:13px;font-weight:500}.progress-bar-small{background:#f5f5f5;border-radius:4px;flex:1 1;height:8px;max-width:200px;overflow:hidden}.progress-fill-small{background:linear-gradient(90deg,#1f57c3,#2979ff);border-radius:4px;height:100%;transition:width .3s ease}.progress-text-small{color:#616161;font-size:13px;font-weight:500}.progress-percentage-small{color:#1f57c3;font-size:15px;font-weight:700;min-width:45px;text-align:right}.project-details-compact{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.detail-compact{align-items:center;color:#757575;display:flex;font-size:13px;gap:4px}.detail-compact.paid{color:#7b1fa2;font-weight:500}.project-actions-row{border-top:1px solid #f5f5f5;display:flex;flex-wrap:wrap;gap:8px;padding-top:12px}.action-btn-small{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s}.action-btn-small:hover{background:#f5f5f5}.action-btn-small.paid{background:#9c27b0;border-color:#9c27b0;color:#fff}.action-btn-small.paid:hover{background:#8e24aa}.action-btn-small.reopen{background:#ff9800;border-color:#ff9800;color:#fff}.action-btn-small.reopen:hover{background:#fb8c00}.action-btn-small.edit{border-color:#1f57c3;color:#1f57c3}.action-btn-small.edit:hover{background:#e3f2fd}.action-btn-small.delete{border-color:#e74c3c;color:#e74c3c}.action-btn-small.delete:hover{background:#ffebee}.btn-create,.btn-create-empty{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:background .2s;white-space:nowrap}.btn-create-empty:hover,.btn-create:hover{background:#1a4ba8}@media (max-width:768px){.projects-header{align-items:stretch;flex-direction:column}.projects-header h1{font-size:24px}.btn-create{justify-content:center;width:100%}.projects-filters{flex-direction:column}.filter-group,.search-box{width:100%}.project-row{padding:16px}.project-stats-row{align-items:flex-start;flex-direction:column;gap:12px}.progress-compact{width:100%}.progress-bar-small{max-width:none}.project-details-compact{align-items:flex-start;flex-direction:column;gap:8px}.project-actions-row{flex-direction:column}.action-btn-small{justify-content:center;width:100%}}.storage-upload-modal{max-width:600px;width:100%}.upload-form{gap:20px}.form-group,.upload-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#212121;font-size:14px;font-weight:500}.required{color:#e74c3c}.form-group select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#212121;cursor:pointer;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s}.form-group select:focus{border-color:#1f57c3;box-shadow:0 0 0 3px #1f57c31a;outline:none}.form-group select:disabled{background:#f5f5f5;color:#9e9e9e;cursor:not-allowed}.form-hint{color:#9e9e9e;font-size:12px;font-style:italic}.upload-area{align-items:center;background:#fafafa;border:2px dashed #e0e0e0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:250px;padding:48px 24px;transition:all .3s}.upload-area svg{color:#9e9e9e;margin-bottom:16px}.upload-area p{color:#757575;font-size:14px;margin:4px 0}.upload-hint{color:#9e9e9e;font-size:13px}.upload-limits{color:#9e9e9e;font-size:12px;margin-top:8px}.upload-area.drag-active{background:#1f57c30d;border-color:#1f57c3}.upload-area.drag-active svg{color:#1f57c3}.btn-browse{align-items:center;background:#1f57c3;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;margin-top:8px;padding:10px 20px;transition:background .2s}.btn-browse:hover{background:#1a4ba8}.upload-area.has-file{background:#4caf500d;border-color:#4caf50}.file-preview{align-items:center;display:flex;flex-direction:column;gap:8px}.file-preview svg{color:#4caf50}.file-name{font-size:15px;max-width:90%;text-align:center;word-break:break-word}.file-size{color:#757575;font-size:13px}.btn-remove-file{background:#ffebee;border:none;border-radius:6px;color:#c62828;cursor:pointer;font-size:13px;margin-top:8px;padding:6px 16px;transition:background .2s}.btn-remove-file:hover{background:#ffcdd2}.upload-progress{flex-direction:column;gap:8px}.progress-bar{background:#e0e0e0;width:100%}.progress-fill{background:linear-gradient(90deg,#1f57c3,#4285f4)}.progress-text{color:#757575;font-size:13px;text-align:center}.form-actions{display:flex;gap:12px;margin-top:8px}.btn-cancel,.btn-upload-submit{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.btn-cancel{background:#f5f5f5;color:#757575}.btn-cancel:hover:not(:disabled){background:#e0e0e0}.btn-upload-submit{background:#1f57c3;color:#fff}.btn-upload-submit:hover:not(:disabled){background:#1a4ba8}.btn-upload-submit:disabled{background:#e0e0e0;color:#9e9e9e;cursor:not-allowed}.btn-upload-submit .spinner{animation:spin 1s linear infinite}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;max-height:90vh;overflow-y:auto;padding:24px}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.modal-header h2{color:#212121;font-size:20px;margin:0}.btn-close{align-items:center;background:#f5f5f5;border:none;border-radius:8px;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .2s;width:32px}.btn-close:hover:not(:disabled){background:#e0e0e0}.btn-close:disabled{cursor:not-allowed;opacity:.5}@media (max-width:600px){.modal-content{align-self:flex-end;border-radius:16px 16px 0 0;max-height:95vh;max-width:100%;width:100%}.upload-area{min-height:200px;padding:32px 16px}.form-actions{flex-direction:column}}.storage-manager{margin:0 auto;max-width:1400px;padding:24px}.storage-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.storage-loading .spinner{animation:spin 1s linear infinite}.storage-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:32px}.storage-header h1{margin:0 0 4px}.storage-header p{margin:0}.btn-upload{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:background .2s}.btn-upload:hover{background:#1a4ba8}.storage-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:16px;padding:20px}.stat-card svg{color:#1f57c3}.stat-info{display:flex;flex-direction:column;gap:4px}.stat-value{color:#212121;font-size:24px;font-weight:600}.stat-label{color:#757575;font-size:13px}.storage-filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.filter-group,.search-group{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:8px;padding:10px 14px}.filter-group svg,.search-group svg{color:#757575}.filter-group select,.search-group input{border:none;color:#212121;font-family:inherit;font-size:14px;min-width:150px;outline:none}.search-group input{min-width:200px}.search-group{flex:1 1;max-width:400px}.storage-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.storage-table{border-collapse:collapse;width:100%}.storage-table thead{background:#f5f5f5}.storage-table th{color:#757575;font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.storage-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.storage-table tbody tr:hover{background:#fafafa}.storage-table td{color:#212121;font-size:14px;padding:16px}.file-name-cell{align-items:center;display:flex;gap:10px}.file-name-cell svg{color:#757575;flex-shrink:0}.file-name-cell span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.category-draft{background:#fff3e0;color:#e65100}.category-final{background:#e8f5e9;color:#2e7d32}.category-client{background:#e3f2fd;color:#1565c0}.actions-cell{display:flex;gap:8px}.btn-action{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.btn-download{background:#e3f2fd;color:#1565c0}.btn-download:hover{background:#bbdefb}.btn-delete{background:#ffebee;color:#c62828}.btn-delete:hover{background:#ffcdd2}.no-files{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:64px 24px}.no-files svg{margin-bottom:16px}.no-files p{font-size:16px}@media (max-width:768px){.storage-manager{padding:16px}.storage-header{align-items:flex-start;gap:16px}.storage-filters,.storage-header{flex-direction:column}.filter-group,.filter-group select,.search-group,.search-group input{width:100%}.storage-table-container{overflow-x:auto}.storage-table{min-width:800px}}.admin-dashboard{background:#f5f5f5;display:flex;min-height:100vh}.admin-nav{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100vh;overflow-y:auto;position:fixed;width:260px;z-index:100}.admin-content{flex:1 1;margin-left:260px;padding:24px}.settings-placeholder{background:#fff;border-radius:8px;padding:32px}.settings-placeholder h2{color:#212121;font-size:20px;margin:0 0 24px}.signout-button{align-items:center;background:#e74c3c;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:background .2s}.signout-button:hover{background:#c0392b}@media (max-width:768px){.admin-nav{border-right:none;border-top:1px solid #e0e0e0;bottom:0;box-shadow:0 -2px 8px #0000001a;flex-direction:row;height:auto;position:fixed;top:auto;width:100%;z-index:1000}.nav-footer,.nav-header{display:none}.nav-tabs{display:flex;overflow-x:auto;padding:0;width:100%}.nav-tab{border-left:none;border-top:3px solid #0000;flex:1 1;flex-direction:column;gap:4px;justify-content:center;min-width:70px;padding:12px 8px;text-align:center}.nav-tab.active{border-left:none;border-top-color:#1f57c3}.nav-tab span{font-size:11px;white-space:nowrap}.admin-content{margin-bottom:65px;margin-left:0;padding:16px}.placeholder{font-size:14px;padding:32px 16px}.settings-placeholder{padding:24px 16px}.settings-placeholder h2{font-size:18px;margin-bottom:16px}}@media (min-width:769px) and (max-width:1024px){.admin-nav{width:200px}.admin-content{margin-left:200px;padding:20px}.nav-tab span{font-size:13px}}.client-chat-container{background:#fff;border-radius:8px;height:calc(100vh - 80px);overflow:hidden}@media (max-width:768px){.client-chat-container{border-radius:0;height:100vh}}.client-project-form{max-width:500px}.client-project-form .form-group{margin-bottom:20px}.client-project-form label{color:#212121;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.client-project-form .required{color:#e74c3c}.client-project-form input,.client-project-form textarea{border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.client-project-form input:focus,.client-project-form textarea:focus{border-color:#1f57c3;box-shadow:0 0 0 3px #1f57c31a;outline:none}.client-project-form textarea{resize:vertical}.client-project-form .form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.client-project-form .form-actions{display:flex;gap:12px;margin-top:24px}.client-project-form .btn-cancel,.client-project-form .btn-save{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s}.client-project-form .btn-cancel{background:#f5f5f5;color:#757575}.client-project-form .btn-cancel:hover{background:#e0e0e0}.client-project-form .btn-save{background:#1f57c3;color:#fff}.client-project-form .btn-save:hover{background:#1a4ba8}@media (max-width:600px){.client-project-form .form-row{grid-template-columns:1fr}}.project-milestones{margin:0 auto;max-width:900px;padding:0}.project-milestones-loading{align-items:center;color:#757575;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:400px}.project-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:24px}.project-header h1{color:#212121;font-size:28px;margin:0}.project-header p{color:#757575;font-size:14px;margin:4px 0 0}.no-active-project{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-top:32px;padding:48px;text-align:center}.no-active-project p{color:#212121;font-size:18px;margin:0 0 8px}.no-active-subtitle{color:#757575!important;font-size:14px!important}.btn-new-project{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;margin-top:8px;padding:12px 24px;transition:background .2s}.btn-new-project:hover{background:#1a4ba8}.btn-create{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:background .2s;white-space:nowrap}.btn-create:hover{background:#1a4ba8}.btn-create-empty{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;margin-top:16px;padding:12px 24px;transition:background .2s}.btn-create-empty:hover{background:#1a4ba8}.project-progress-card{background:linear-gradient(135deg,#1f57c3,#2979ff);border-radius:16px;box-shadow:0 8px 24px #1f57c333;margin-bottom:32px;padding:24px}.progress-header{align-items:center;color:#fff;display:flex;justify-content:space-between;margin-bottom:20px}.progress-info{align-items:center;display:flex;gap:16px}.progress-icon{flex-shrink:0}.progress-info h3{font-size:18px;font-weight:600;margin:0}.progress-info p{font-size:13px;margin:4px 0 0;opacity:.9}.progress-percentage{font-size:36px;font-weight:700}.progress-bar-container{margin-bottom:12px}.progress-bar{background:#fff3;border-radius:6px;height:12px}.progress-fill{background:#fff;border-radius:6px;transition:width .6s ease}.project-completed{align-items:center;background:#ffffff26;border-radius:8px;color:#fff;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 12px;width:-webkit-fit-content;width:fit-content}.project-timeline{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;padding:24px}.timeline-empty{color:#757575;padding:48px 24px;text-align:center}.timeline-empty p{font-size:16px;margin:0 0 8px}.timeline-empty-subtitle{font-size:14px;opacity:.8}.timeline-grouped{display:flex;flex-direction:column;gap:32px}.milestone-group{display:flex;flex-direction:column;gap:16px}.group-title{align-items:center;border-bottom:2px solid #f5f5f5;display:flex;font-size:16px;font-weight:600;gap:8px;margin:0;padding-bottom:8px}.group-title.in-progress{border-bottom-color:#2196f3;color:#2196f3}.group-title.pending{border-bottom-color:#ff9800;color:#ff9800}.group-title.completed{border-bottom-color:#4caf50;color:#4caf50}.timeline-list{display:flex;flex-direction:column}.timeline-item{display:flex;gap:20px;position:relative}.timeline-item:not(:last-child){margin-bottom:24px}.timeline-connector{align-items:center;display:flex;flex-direction:column;flex-shrink:0;padding-top:24px;width:24px}.timeline-dot{background:#e0e0e0;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:16px;width:16px;z-index:1}.timeline-dot.pending{background:#9e9e9e}.timeline-dot.in_progress{animation:pulse 2s infinite;background:#2196f3}.timeline-dot.completed{background:#4caf50}@keyframes pulse{0%,to{box-shadow:0 2px 4px #0000001a,0 0 0 0 #2196f366}50%{box-shadow:0 2px 4px #0000001a,0 0 0 8px #2196f300}}.timeline-line{background:linear-gradient(180deg,#e0e0e0,#0000);flex:1 1;margin-top:8px;width:2px}.timeline-content{flex:1 1}@media (max-width:768px){.project-milestones{padding:0}.project-header{align-items:stretch;flex-direction:column}.project-header h1{font-size:24px}.btn-create{justify-content:center;width:100%}.project-progress-card{border-radius:12px;margin-bottom:24px;padding:20px 16px}.progress-header{align-items:flex-start;flex-direction:column;gap:16px}.progress-percentage{font-size:28px}.project-timeline{border-radius:12px;padding:16px}.timeline-item{gap:12px}.timeline-connector{padding-top:20px;width:20px}.timeline-dot{height:14px;width:14px}}.client-storage{margin:0 auto;max-width:1200px;padding:0}.client-storage-loading{align-items:center;color:#757575;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:400px}.storage-header{margin-bottom:24px}.storage-header h1{color:#212121;font-size:28px;margin:0}.storage-header p{color:#757575;font-size:14px;margin:4px 0 0}.upload-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px;padding:20px}.upload-section h3{align-items:center;color:#212121;display:flex;font-size:16px;gap:8px;margin:0 0 16px}.upload-controls{align-items:center;display:flex;gap:12px}.project-select{border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;padding:10px 14px;transition:border-color .2s}.project-select:focus{border-color:#1f57c3;outline:none}.upload-button{align-items:center;background:#1f57c3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:background .2s}.upload-button:hover{background:#1a4ba8}.upload-button:disabled{background:#e0e0e0;color:#9e9e9e;cursor:not-allowed}.upload-progress{align-items:center;display:flex;gap:12px;margin-top:16px}.progress-bar{background:#f5f5f5;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#1f57c3,#2979ff);border-radius:4px;height:100%;transition:width .3s ease}.upload-progress span{color:#1f57c3;font-size:14px;font-weight:600;min-width:45px;text-align:right}.projects-files-list{display:flex;flex-direction:column;gap:24px}.no-projects{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:64px 24px;text-align:center}.no-projects svg{color:#bdbdbd;margin-bottom:16px}.no-projects p{color:#212121;font-size:18px;margin:0 0 8px}.no-projects-subtitle{color:#757575!important;font-size:14px!important}.project-files-section{background:#fff;border-left:4px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.project-files-section.active{border-left-color:#4caf50}.project-files-section.completed{border-left-color:#9e9e9e}.project-files-header{align-items:center;border-bottom:2px solid #f5f5f5;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.project-files-header h2{align-items:center;color:#212121;display:flex;font-size:20px;gap:8px;margin:0}.status-indicator{font-size:12px}.status-indicator.active{color:#4caf50}.status-indicator.completed{color:#9e9e9e}.file-count{color:#757575;font-size:13px;font-weight:500}.no-files{color:#9e9e9e;padding:32px;text-align:center}.no-files p{font-size:14px;margin:0}.files-categories{gap:20px}.file-category,.files-categories{display:flex;flex-direction:column}.file-category{gap:12px}.category-title{align-items:center;border-bottom:2px solid #f5f5f5;display:flex;font-size:15px;font-weight:600;gap:6px;margin:0;padding-bottom:8px}.category-title.drafts{border-bottom-color:#ff9800;color:#ff9800}.category-title.finals{border-bottom-color:#4caf50;color:#4caf50}.category-title.client{border-bottom-color:#2196f3;color:#2196f3}.file-item{align-items:center;background:#fafafa;border-radius:8px;display:flex;justify-content:space-between;padding:12px 16px;transition:background .2s}.file-item:hover{background:#f5f5f5}.file-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.file-name{color:#212121;font-size:14px;font-weight:500}.file-size{color:#9e9e9e;font-size:12px}.file-actions{display:flex;gap:8px}.file-action-btn{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s}.file-action-btn:hover{background:#f5f5f5}.file-action-btn.view{border-color:#2196f3;color:#2196f3}.file-action-btn.view:hover{background:#e3f2fd}.file-action-btn.download{border-color:#4caf50;color:#4caf50}.file-action-btn.download:hover{background:#e8f5e9}.file-action-btn.delete{border-color:#e74c3c;color:#e74c3c}.file-action-btn.delete:hover{background:#ffebee}.preview-modal{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.preview-content{background:#fff;border-radius:12px;display:flex;flex-direction:column;max-height:90%;max-width:90%;overflow:hidden;position:relative}.preview-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:background .2s;width:36px;z-index:1001}.preview-close:hover{background:#000000e6}.preview-content img{max-height:calc(90vh - 100px);max-width:100%;object-fit:contain}.preview-info{background:#f5f5f5;padding:16px;text-align:center}.preview-info p{color:#212121;font-size:14px;margin:0}.preview-size{color:#757575!important;font-size:12px!important;margin-top:4px!important}@media (max-width:768px){.upload-controls{flex-direction:column}.project-select{width:100%}.upload-button{justify-content:center;width:100%}.file-item{align-items:flex-start;flex-direction:column;gap:12px}.file-actions{flex-wrap:wrap;width:100%}.file-action-btn{flex:1 1;justify-content:center}}.project-history{margin:0 auto;max-width:900px;padding:32px}.history-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:300px}.history-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:28px}.history-header h1{align-items:center;color:#111827;display:flex;font-size:24px;font-weight:700;gap:10px;margin:0 0 4px}.history-header p{color:#6b7280;font-size:14px;margin:0}.history-count{background:#f3f4f6;border-radius:20px;color:#6b7280;font-size:13px;font-weight:600;padding:6px 14px;white-space:nowrap}.history-empty{color:#9ca3af;padding:80px 20px;text-align:center}.history-empty svg{color:#d1d5db;margin-bottom:16px}.history-empty h3{color:#374151;font-size:18px;font-weight:600;margin:0 0 8px}.history-empty p{font-size:14px;margin:0}.history-list{display:flex;flex-direction:column;gap:12px}.history-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.history-card:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000f}.history-card.expanded{border-color:#2563eb;box-shadow:0 4px 16px #2563eb1a}.history-card-header{align-items:flex-start;cursor:pointer;display:flex;gap:16px;justify-content:space-between;padding:20px 24px}.history-card-main{flex:1 1;min-width:0}.history-card-title{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:6px}.history-card-title h3{color:#111827;font-size:16px;font-weight:700;margin:0}.status-badge{border-radius:20px;font-size:12px;font-weight:600;padding:3px 10px}.status-badge.completed{background:#dcfce7;color:#16a34a}.status-badge.paid{background:#dbeafe;color:#1d4ed8}.history-description{color:#6b7280;font-size:13px;line-height:1.5;margin:0 0 10px}.history-card-meta{display:flex;flex-wrap:wrap;gap:12px}.meta-item{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:5px}.meta-item.paid{color:#1d4ed8}.meta-item.budget{color:#16a34a;font-weight:600}.expand-btn{background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;flex-shrink:0;padding:4px;transition:color .2s,background .2s}.expand-btn:hover{background:#f3f4f6;color:#374151}.history-card-body{border-top:1px solid #f3f4f6;display:flex;flex-direction:column;gap:24px;padding:20px 24px}.details-loading{color:#6b7280;gap:10px;padding:12px 0}.details-loading,.details-section h4{align-items:center;display:flex;font-size:14px}.details-section h4{color:#374151;font-weight:700;gap:8px;margin:0 0 12px}.section-count{background:#f3f4f6;border-radius:10px;color:#6b7280;font-size:12px;font-weight:500;margin-left:4px;padding:2px 8px}.details-empty{color:#9ca3af;font-size:13px;margin:0;padding:8px 0}.milestones-list{display:flex;flex-direction:column;gap:8px}.milestone-row{align-items:flex-start;background:#f9fafb;border-radius:8px;display:flex;gap:10px;padding:10px 12px}.status-icon.completed{color:#16a34a}.status-icon.in-progress{color:#f59e0b}.status-icon.pending{color:#9ca3af}.milestone-info{flex:1 1;min-width:0}.milestone-title{color:#374151;display:block;font-size:13px;font-weight:600}.milestone-desc{color:#6b7280;display:block;font-size:12px;margin-top:2px}.milestone-date{color:#9ca3af;flex-shrink:0;font-size:11px;white-space:nowrap}.files-list{display:flex;flex-direction:column;gap:8px}.file-row{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:12px;padding:10px 12px;transition:background .2s}.file-row:hover{background:#f3f4f6}.file-row-info{flex:1 1;min-width:0}.file-row-name{color:#374151;display:block;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:3px}.file-category-badge{background:#e5e7eb;border-radius:6px;color:#6b7280;font-size:11px;padding:1px 7px}.file-row-date,.file-row-size{color:#9ca3af;font-size:11px}.download-btn{align-items:center;background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:7px 10px;transition:background .2s}.download-btn:hover{background:#1d4ed8}.client-profile{margin:0 auto;max-width:960px;padding:32px}.profile-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:300px}.profile-header{margin-bottom:28px}.profile-header h1{align-items:center;color:#111827;display:flex;font-size:24px;font-weight:700;gap:10px;margin:0 0 4px}.profile-header p{color:#6b7280;font-size:14px;margin:0}.profile-grid{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:260px 1fr}@media (max-width:768px){.profile-grid{grid-template-columns:1fr}}.profile-sidebar{display:flex;flex-direction:column;gap:16px}.profile-avatar-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:24px;text-align:center}.avatar-container{height:80px;margin:0 auto 12px;position:relative;width:80px}.avatar-img{object-fit:cover}.avatar-img,.avatar-placeholder{border-radius:50%;height:80px;width:80px}.avatar-placeholder{background:#2563eb;color:#fff;font-size:32px;font-weight:700}.avatar-badge,.avatar-placeholder{align-items:center;display:flex;justify-content:center}.avatar-badge{background:#fff;border:2px solid #e5e7eb;border-radius:50%;bottom:0;color:#6b7280;height:26px;position:absolute;right:0;width:26px}.avatar-name{color:#111827;font-size:16px;font-weight:700;margin:0 0 4px}.avatar-email{color:#6b7280;font-size:12px;margin:0 0 10px;word-break:break-all}.avatar-role{background:#dbeafe;border-radius:20px;color:#1d4ed8;display:inline-block;font-size:12px;font-weight:600;padding:3px 12px}.storage-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:20px}.storage-card h4{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:700;gap:8px;margin:0 0 14px}.storage-bar-container{margin-bottom:8px}.storage-bar{background:#f3f4f6;border-radius:4px;height:8px;overflow:hidden}.storage-bar-fill{border-radius:4px;height:100%;transition:width .5s ease}.storage-labels{color:#9ca3af;display:flex;font-size:11px;justify-content:space-between;margin-bottom:4px}.storage-percent{color:#6b7280;font-size:12px;font-weight:500;margin:0;text-align:right}.btn-logout{align-items:center;background:#fff;border:1.5px solid #fecaca;border-radius:12px;color:#dc2626;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:11px;transition:background .2s,border-color .2s;width:100%}.btn-logout:hover{background:#fef2f2;border-color:#fca5a5}.profile-form-section{display:flex;flex-direction:column;gap:16px}.form-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:24px}.form-card h3{align-items:center;border-bottom:1px solid #f3f4f6;color:#111827;display:flex;font-size:15px;font-weight:700;gap:8px;margin:0 0 20px;padding-bottom:14px}.form-group:last-child{margin-bottom:0}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:500px){.form-row{grid-template-columns:1fr}}.read-only-card{background:#f9fafb}.account-info-row{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;font-size:14px;justify-content:space-between;padding:10px 0}.account-info-row:last-child{border-bottom:none}.account-label{color:#6b7280;font-weight:500}.account-value{color:#111827;font-weight:600}.status-approved{color:#16a34a}.profile-actions{display:flex;justify-content:flex-end}.btn-save{align-items:center;background:#2563eb;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-width:160px;padding:12px 24px;transition:background .2s}.btn-save:hover:not(:disabled){background:#1d4ed8}.btn-save.saved{background:#16a34a}.btn-save:disabled{cursor:not-allowed;opacity:.7}.onboarding-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.onboarding-modal{animation:slideUp .3s ease;background:#fff;border-radius:20px;box-shadow:0 24px 60px #0003;max-width:480px;padding:40px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.onboarding-header{margin-bottom:28px;text-align:center}.onboarding-logo{align-items:center;background:#2563eb;border-radius:14px;color:#fff;display:flex;font-size:18px;font-weight:800;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.onboarding-header h1{color:#111827;font-size:20px;font-weight:700;margin:0 0 8px}.onboarding-header p{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.onboarding-steps{align-items:center;display:flex;gap:0;justify-content:center;margin-bottom:28px}.step-dot{background:#e5e7eb;border-radius:50%;height:10px;transition:background .3s;width:10px}.step-dot.active{background:#2563eb}.step-line{background:#e5e7eb;height:2px;width:40px}.onboarding-step h2{align-items:center;color:#111827;display:flex;font-size:16px;font-weight:700;gap:8px;margin:0 0 4px}.step-description{color:#6b7280;font-size:13px;margin:0 0 20px}.form-group{margin-bottom:16px}.form-group label{align-items:center;color:#374151;display:flex;font-size:13px;font-weight:600;gap:6px;margin-bottom:6px}.form-group input,.form-group select{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;box-sizing:border-box;color:#111827;font-size:14px;padding:10px 12px;transition:border-color .2s,background .2s;width:100%}.form-group input:focus,.form-group select:focus{background:#fff;border-color:#2563eb;outline:none}.required{color:#ef4444}.optional{color:#9ca3af;font-size:12px;font-weight:400}.onboarding-actions{align-items:center;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-top:28px;padding-top:20px}.onboarding-nav{display:flex;gap:10px}.btn-skip{align-items:center;background:none;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 14px;transition:color .2s,background .2s}.btn-skip:hover{background:#f3f4f6;color:#6b7280}.btn-back{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:10px 18px;transition:border-color .2s}.btn-back:hover{border-color:#9ca3af}.btn-finish,.btn-next{align-items:center;background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:background .2s}.btn-finish:hover,.btn-next:hover{background:#1d4ed8}.btn-back:disabled,.btn-finish:disabled,.btn-next:disabled,.btn-skip:disabled{cursor:not-allowed;opacity:.6}.client-dashboard{background:#f5f5f5;display:flex;min-height:100vh}.client-nav{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100vh;overflow-y:auto;position:fixed;width:260px;z-index:100}.nav-header{border-bottom:1px solid #e0e0e0;padding:24px 20px}.logo{align-items:center;background:linear-gradient(135deg,#1f57c3,#2979ff);border-radius:12px;display:flex;height:48px;justify-content:center;margin-bottom:12px;width:48px}.logo-text{color:#fff;font-size:18px;font-weight:700;letter-spacing:1px}.nav-header h1{color:#212121;font-size:16px;font-weight:600;margin:0}.nav-tabs{flex:1 1;padding:16px 0}.nav-tab{align-items:center;border-left:3px solid #0000;color:#757575;display:flex;gap:12px;padding:12px 20px;text-decoration:none;transition:all .2s}.nav-tab:hover{background:#f5f5f5;color:#1f57c3}.nav-tab.active{background:#e3f2fd;border-left-color:#1f57c3;color:#1f57c3}.nav-tab span{font-size:14px;font-weight:500}.nav-footer{border-top:1px solid #e0e0e0;padding:20px}.user-info{align-items:center;display:flex;gap:12px}.user-avatar{border-radius:50%;height:36px;width:36px}.user-name{color:#212121;font-size:14px;font-weight:500}.client-content{flex:1 1;margin-left:260px;padding:24px}.placeholder{background:#fff;border-radius:8px;color:#757575;font-size:16px;padding:48px;text-align:center}@media (max-width:768px){.client-nav{border-right:none;border-top:1px solid #e0e0e0;bottom:0;box-shadow:0 -2px 8px #0000001a;flex-direction:row;height:auto;position:fixed;top:auto;width:100%;z-index:1000}.nav-footer,.nav-header{display:none}.nav-tabs{display:flex;overflow-x:auto;padding:0;width:100%}.nav-tab{border-left:none;border-top:3px solid #0000;flex:1 1;flex-direction:column;gap:4px;justify-content:center;min-width:70px;padding:12px 8px;text-align:center}.nav-tab.active{border-left:none;border-top-color:#1f57c3}.nav-tab span{font-size:11px;white-space:nowrap}.client-content{margin-bottom:65px;margin-left:0;padding:0}.placeholder{font-size:14px;margin:16px;padding:32px 16px}}@media (min-width:769px) and (max-width:1024px){.client-nav{width:200px}.client-content{margin-left:200px;padding:20px}.nav-tab span{font-size:13px}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#212121;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.loading-screen{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#1f57c3;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen p{color:#757575;font-size:14px}.badge{align-items:center;border-radius:12px;display:inline-flex;font-size:12px;font-weight:500;padding:4px 10px}.badge-pending{background:#fff3e0;color:#e65100}.badge-in-progress{background:#e3f2fd;color:#1565c0}.badge-completed{background:#e8f5e9;color:#2e7d32}.badge-cancelled{background:#ffebee;color:#c62828}.badge-client-files{background:#e3f2fd;color:#1565c0}.badge-draft{background:#fff3e0;color:#e65100}.badge-approved{background:#e8f5e9;color:#2e7d32}.badge-final{background:#f3e5f5;color:#6a1b9a}.toast{align-items:center;animation:slideIn .3s ease;background:#fff;border-radius:8px;bottom:24px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;max-width:400px;padding:16px 20px;position:fixed;right:24px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-success{border-left:4px solid #14a800}.toast-error{border-left:4px solid #e74c3c}.toast-info{border-left:4px solid #1f57c3}.toast-warning{border-left:4px solid #f2994a}@media (max-width:768px){.toast{bottom:16px;left:16px;max-width:none;right:16px}}
/*# sourceMappingURL=main.de0a9371.css.map*/