:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.home-container{display:flex;height:100vh;width:100vw;justify-content:center;align-items:center;padding:20px;background-color:#f4f4f4;box-sizing:border-box;gap:30px}.role-box{flex:1;max-width:300px;height:400px;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;font-size:24px;font-weight:700;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;color:#fff;box-shadow:0 4px 12px #0000001a;background-color:#fff}.role-box:hover{transform:translateY(-5px);box-shadow:0 6px 16px #00000026}.role-image{width:100%;height:75%;background-size:cover;background-position:center;filter:grayscale(50%);transition:filter .3s ease}.role-box:hover .role-image{filter:grayscale(0%)}.role-label{height:25%;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:28px;color:#888;background-color:#fff;transition:background-color .3s ease,color .3s ease}.role-label .subtext{font-size:14px;color:#aaa}.role-box.student:hover .role-label{background-color:#8cd1a6;color:#fff}.role-box.tutor:hover .role-label{background-color:#4d9de0;color:#fff}.role-box.admin:hover .role-label{background-color:#f2644b;color:#fff}.role-box.student:hover .role-label .subtext,.role-box.tutor:hover .role-label .subtext,.role-box.admin:hover .role-label .subtext{color:#eee}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100vW;background-color:#f9f9f9}.login-form{width:300px;padding:50px 30px;border-radius:16px;display:flex;align-items:center;box-shadow:0 4px 12px #0000001a;background-color:#fff}.login-content{display:flex;flex-direction:column;align-items:center;width:100%}.login-title{font-size:20px;font-weight:700;color:#333}.role-info{font-size:14px;color:#666;margin-bottom:20px;text-align:center;display:inline-flex;align-items:center;gap:8px}.login-button{display:flex;width:100%;align-items:center;justify-content:center;gap:10px;font-size:16px;color:#fff;background-color:#4285f4;border:none;border-radius:5px;cursor:pointer;transition:background-color .3s ease;margin-top:15px}.login-button:hover{background-color:#357ae8}.login-button:disabled{background-color:#7eb2ff;cursor:not-allowed}.login-error{width:100%;box-sizing:border-box;margin-top:10px;background-color:#ecc3c0;color:#912d26;font-size:12px;padding:8px 12px;border-radius:4px;text-align:center;max-width:100%;word-break:break-word;white-space:normal}.google-logo{width:25px;height:25px}.loading-spinner{border:4px solid rgba(0,0,0,.1);border-top:4px solid;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.side-window{display:flex;flex:1;flex-direction:column;height:100vh;border-right:1px solid #ddd;background-color:#f1f1f1}.profile-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;position:relative;background-color:#f1f1f1;padding:10px 0}.profile-name{font-size:14px;font-weight:700;color:#333;margin-top:10px}.profile-role{font-size:12px;color:#555;text-transform:capitalize}.signout-icon{position:absolute;top:10px;right:15px;font-size:18px;color:#ccc;cursor:pointer;transition:color .3s ease}.signout-icon:hover{color:#ff4d4d}.avatar{border-radius:50%;border:2px solid #ddd;object-fit:cover;overflow:hidden;display:inline-block}.search-bar{display:flex;align-items:center;width:100%;border:1px solid #ddd;border-radius:5px;padding:5px 10px;background-color:#fff;box-shadow:0 1px 3px #0000001a;box-sizing:border-box}.search-input{flex:1;border:none;outline:none;font-size:14px;padding:5px;border-radius:5px}.search-icon{margin-left:10px;font-size:14px;color:#888;cursor:pointer;display:flex;align-items:center}.search-bar:hover{box-shadow:0 2px 5px #0000001a}.search-bar:focus-within{box-shadow:0 2px 5px #0003}.chat{position:relative;display:flex;align-items:center;padding:5px 10px;width:100%;border:1px solid #ddd;border-radius:5px;box-shadow:0 1px 3px #0000001a;margin-bottom:10px;background-color:#fff;transition:background-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.chat:hover{background-color:#f9f9f9;box-shadow:0 2px 5px #0003;cursor:pointer}.chat-active{background-color:#e8f0fe;border:2px solid #4285f4}.chat-name{margin-left:20px;font-size:16px;font-weight:700;color:#333}.unread-indicator{position:absolute;top:10px;right:10px;width:10px;height:10px;background-color:#4285f4;border-radius:50%;z-index:1}.popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.popup{background-color:#fff;padding:20px;border-radius:10px;box-shadow:0 4px 8px #0003;position:relative;max-width:90%}.popup-close{position:absolute;top:5px;right:10px;background-color:transparent;border:none;font-size:18px;font-weight:700;color:#ccc;cursor:pointer;transition:color .3s ease}.popup-close:hover{color:#f44336}.popup-content{align-items:center;justify-content:center}.chat-list-container{display:flex;flex-direction:column;flex:1;min-height:0;height:100%}.chat-list-header{display:flex;align-items:center;justify-content:space-between;padding:15px;font-size:14px;gap:12px;flex-wrap:wrap}.chat-icons{display:flex;align-items:center;gap:10px;margin-left:auto;align-self:flex-start}.chat-list-search{padding:5px 15px 20px}.chat-list-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:5px 15px}.chat-list-scroll::-webkit-scrollbar{width:6px}.chat-list-scroll::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.chat-list-scroll::-webkit-scrollbar-track{background-color:#f1f1f1;margin:10px 0;border-radius:4px}.chip-section{display:flex;flex-wrap:wrap;flex:1;gap:5px}.chip{padding:5px 10px;background-color:#e0e0e0;border-radius:16px;font-size:12px;cursor:pointer;color:#333;transition:background-color .2s;-webkit-user-select:none;user-select:none}.chip:hover{background-color:#d5d5d5}.chip.active{background-color:#4285f4;color:#fff}.find-user-container{display:flex;flex-direction:column}.error-message{background-color:#ecc3c0;font-size:12px;font-weight:700;padding:10px;border-radius:5px;text-align:center}.find-user-header{display:flex;align-items:center;margin-bottom:12px;font-size:16px;font-weight:500;text-align:center;gap:10px}.search-bar-container{margin:15px 0 12px}.chip-section-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 5px 12px}.chip-section-title{font-size:14px;color:#333}.chip-section-content{display:flex;justify-content:flex-end}.user-details-card{display:flex;align-items:center;padding:10px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9;cursor:pointer;transition:background-color .2s ease;gap:10px}.user-details-card:hover{background-color:#f0f0f0}.user-avatar img{width:40px;height:40px;border-radius:50%}.user-info{display:flex;flex-direction:column;justify-content:center;max-width:100%}.user-name{font-weight:700;font-size:16px;color:#333}.user-email{font-size:12px;color:#555;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.user-email:hover{text-decoration:underline}.user-role{font-size:12px;color:#777}.card-section{display:flex;flex-direction:column;gap:10px;max-height:105px;width:100%;overflow-y:auto;padding:10px;border:1px solid #ddd;border-radius:6px;background-color:#f9f9f9;box-sizing:border-box}.card-section::-webkit-scrollbar{width:4px}.card-section::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.card-section::-webkit-scrollbar-thumb:hover{background-color:#aaa}.card-section::-webkit-scrollbar-track{background-color:#f1f1f1;margin:10px 0;border-radius:4px}.new-chat-container{padding:20px 10px}.new-chat-title{display:flex;align-items:center;justify-content:center;width:100%;gap:8px;font-size:20px;font-weight:500;margin-bottom:15px}.new-chat-group-toggle{display:flex;flex-direction:column;align-items:stretch;margin-bottom:16px;gap:8px}.checkbox-label{display:flex;justify-content:space-between;align-items:center;font-weight:500;font-size:16px;width:100%}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#4285f4;cursor:pointer;border-radius:5px;margin:0}.group-name-input{outline:none;font-size:14px;border-radius:5px;display:flex;align-items:center;width:100%;border:1px solid #ddd;padding:10px 15px;background-color:#fff;box-shadow:0 1px 3px #0000001a;box-sizing:border-box}.selected-users-header{margin:15px 0 12px;font-size:16px;font-weight:500}.selected-users-section{display:flex;flex-direction:column;align-items:center}.selected-users-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:15px}.selected-users-actions button{padding:8px 0;width:100px;border:none;border-radius:4px;background-color:#4285f4;color:#fff;cursor:pointer;transition:background .3s}.selected-users-actions .cancel-btn{background-color:#999}.selected-users-actions button:hover{filter:brightness(1.1)}.tabs-container{display:flex;flex-direction:column;flex:1;overflow:hidden}.tabs-header{display:flex;background:transparent;padding:4px 4px 0}.tabs-content{flex:1;overflow:hidden;background:#fff;padding:5px;color:#333;display:flex;flex-direction:column}.tab{padding:6px 14px;margin-right:4px;background:#e0e0e0;color:#333;border-radius:8px 8px 0 0;cursor:pointer;font-size:13px;transition:background .2s,color .2s;max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}.tab.active{background:#fff;color:#000;border-bottom:2px solid transparent;font-weight:500}.tab:hover:not(.active){background:#d5d5d5}.add-assignment-container{display:flex;flex-direction:column;gap:12px;padding:20px 10px;max-width:400px}.form-title{display:flex;align-items:center;justify-content:center;width:100%;gap:8px;font-size:20px;font-weight:500;margin-bottom:10px}.add-assignment-container input,.add-assignment-container textarea{padding:12px;font-size:14px;color:#333;border-radius:4px;border:1px solid #ccc}.add-assignment-container input:focus,.add-assignment-container select:focus,.add-assignment-container textarea:focus{outline:none;border:1px solid #4285f4}textarea{resize:vertical}.add-assignment-container select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:12px;font-size:14px;border-radius:4px;border:1px solid #ccc;background-color:#fff;color:#333;background-image:url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12"><polygon points="0,0 12,0 6,6" fill="%23666"/></svg>');background-repeat:no-repeat;background-position:right 10px center;background-size:12px;cursor:pointer}.add-assignment-container select option{background-color:#fff;color:#333;font-size:12px}.due-by-wrapper{display:flex;gap:8px;width:100%;border:1px solid #ccc;border-radius:4px;padding:12px;box-sizing:border-box}.due-by-label{flex:1;font-size:14px;color:#333}.add-assignment-container input[type=date]{font-size:14px;padding:0;color:#333;border:none;cursor:pointer}.file-upload-wrapper{display:flex;flex-direction:column;gap:8px;width:100%;border:1px solid #ccc;border-radius:4px;padding:12px;box-sizing:border-box}.file-upload-top-row{display:flex;align-items:center;justify-content:space-between;width:100%;gap:10px}.upload-label{flex:1;font-size:14px;color:#333}.file-upload-button{display:inline-flex;align-items:center;justify-content:center;background-color:#555;color:#fff;width:50px;padding:4px 0;border-radius:4px;cursor:pointer;font-size:10px;position:relative;overflow:hidden;gap:6px;transition:background .3s}.file-upload-button:hover{filter:brightness(1.1)}.file-upload-button input[type=file]{position:absolute;opacity:0;left:0;top:0;height:100%;width:100%;cursor:pointer}.file-list-container{background-color:#f1f1f1;padding:10px 15px;border-radius:4px;max-height:50px;overflow-y:auto;border:1px solid #ccc}.file-list{list-style:none;padding-left:0;margin:0;font-size:13px}.file-list li{margin-bottom:2px}.file-list a{color:#333;text-decoration:none;word-break:break-word}.file-list a:hover{text-decoration:underline}.file-list-item{display:flex;align-items:center;gap:10px;justify-content:flex-start}.remove-file-button{display:flex;align-items:center;justify-content:center;border:none;color:#fff;background-color:#ca2723;border-radius:4px;font-size:8px;font-weight:700;cursor:pointer;padding:3px 5px;transition:color .2s}.remove-file-button:hover{filter:brightness(1.1)}.remove-file-button:disabled{cursor:not-allowed;opacity:.5}.file-list-container::-webkit-scrollbar{width:10px}.file-list-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.file-list-container::-webkit-scrollbar-thumb{background-color:#bbb;border-radius:4px;border:2px solid #f0f0f0}.file-list-container::-webkit-scrollbar-thumb:hover{background-color:#888;cursor:pointer}.assignment-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.assignment-actions button{padding:8px 0;width:100px;border:none;border-radius:4px;background-color:#4285f4;color:#fff;cursor:pointer;transition:background .3s}.assignment-actions button:disabled{background-color:#ccc}.assignment-actions button:disabled:hover{filter:none;cursor:not-allowed}.assignment-actions .cancel-btn{background-color:#999}.assignment-actions button:hover{filter:brightness(1.1)}.assignment-error{color:#d32f2f;font-size:12px;background-color:#ffe0e0;padding:8px;margin:0;border-radius:4px}.assignment-card{position:relative;display:flex;flex-direction:column;width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:5px;background-color:#fff;box-shadow:0 1px 3px #0000001a;margin-bottom:10px;transition:background-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.assignment-card:hover{background-color:#f9f9f9;box-shadow:0 2px 5px #0003;cursor:pointer}.assignment-active{background-color:#e8f0fe;border:2px solid #4285f4}.assignment-name{font-size:16px;font-weight:700;color:#333}.assignment-details{display:flex;justify-content:space-between;font-size:13px;color:#666;margin-bottom:4px}.assignment-field{font-weight:500;color:#333}.assignment-due{font-style:italic}.assignment-list-container{display:flex;flex-direction:column;flex:1;min-height:0;height:100%}.assignment-list-header{display:flex;align-items:center;justify-content:space-between;padding:15px;font-size:14px;gap:12px;flex-wrap:wrap}.assignment-icons{display:flex;align-items:center;gap:10px;margin-left:auto;align-self:flex-start}.icon-button{font-size:18px;font-weight:700;color:#bbb;cursor:pointer;transition:color .3s ease}.icon-button:hover{color:#4285f4}.assignment-list-search{padding:5px 15px 20px}.assignment-list-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:5px 15px}.assignment-list-scroll::-webkit-scrollbar{width:6px}.assignment-list-scroll::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.assignment-list-scroll::-webkit-scrollbar-track{background-color:#f1f1f1;margin:10px 0;border-radius:4px}.chat-window{display:flex;flex-direction:column;height:100vh;width:calc(100vw - 280px);background-color:#f9f9f9}.chat-messages{flex:1;overflow-y:auto;padding:10px;position:relative}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.chat-messages::-webkit-scrollbar-track{background-color:#f1f1f1}.date-divider{display:flex;justify-content:center;align-items:center;position:relative;margin:10px 0}.date-divider:before{content:"";position:absolute;top:50%;left:10%;width:80%;height:1px;background-color:#ddd;z-index:1}.date-text{position:relative;background-color:#f9f9f9;padding:0 10px;font-size:12px;color:#555;z-index:2}.message-container{display:flex;flex-direction:column;max-width:70%;min-width:50px;margin:2px;padding:5px 10px 2px;border-radius:8px;position:relative}.sender{align-self:flex-end;background-color:#dcf8c6}.receiver{align-self:flex-start;background-color:#fff;border:1px solid #ddd}.message-body{position:relative}.message-text{margin:0 60px 5px 0;font-size:14px;color:#333;word-wrap:break-word}.message-time{font-size:10px;color:#888;text-align:right;position:absolute;bottom:0;right:0}.message-author{font-size:10px;font-weight:600;color:#3b5998;margin-top:5px}.chat-info-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;background-color:#fff;border-bottom:1px solid #ddd;position:sticky;top:0;z-index:10;height:60px}.chat-info-name{font-size:18px;font-weight:700;color:#333;margin-left:20px;flex-grow:1}.chat-info-spinner{margin-left:auto;display:flex;align-items:center}.footer-bar{display:flex;align-items:center;padding:10px 15px;background-color:#fff;border-top:1px solid #ddd;position:sticky;bottom:0;z-index:10}.message-input{flex:1;padding:10px;font-size:16px;border:1px solid #ddd;border-radius:20px;outline:none}.attach-btn{background:none;border:none;font-size:18px;margin-right:10px;cursor:pointer;color:#555}.attach-btn:hover{color:#007bff}.file-upload-container{display:flex;flex-direction:column;align-items:center;padding:10px}.file-input-hidden{display:none}.choose-btn{padding:8px 16px;background-color:#4285f4;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .3s ease}.choose-btn:hover{background-color:#357ae8}.file-preview{display:flex;flex-direction:column;align-items:center;background-color:#f5f5f5;padding:10px;border:1px solid #ddd;border-radius:8px;width:100%;max-width:350px;text-align:center;word-wrap:break-word;overflow-wrap:break-word;margin-top:10px}.file-name{font-size:14px;font-weight:500;color:#444;margin-bottom:10px;word-break:break-word}.file-buttons{display:flex;gap:10px;margin-top:10px}.upload-btn{padding:6px 12px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s ease}.upload-btn:hover{background-color:#45a049}.remove-btn{padding:6px 12px;background-color:#e53935;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s ease}.remove-btn:hover{background-color:#d32f2f}.upload-success{color:#4caf50;margin-top:8px;font-size:13px}.upload-error{color:#e53935;margin-top:8px;font-size:13px}.container{display:flex;width:100vw}
