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{margin-bottom:16px}.form-group label{color:#424242;display:block;font-size:13px;font-weight:500;margin-bottom:6px}.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{display:flex;gap:12px;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}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.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}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.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{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}.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{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.file-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:12px;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{align-items:center;color:#757575;display:flex;font-size:14px;gap:12px;margin-bottom:12px}.progress-bar{background:#e0e0e0;border-radius:2px;flex:1 1;height:4px;overflow:hidden}.progress-fill{background:#1f57c3;height:100%;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}}.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-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.7abce391.css.map*/