:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;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}}#root{padding:0!important;margin:0}html,body{height:100%;font-family:Arial,sans-serif;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.auth-container{overflow-x:hidden;display:flex;height:100vh;width:100vw;position:relative}.auth-left{display:flex;flex-direction:column;align-items:center;justify-content:center;width:50%;padding:2rem;background-color:#7c8cfd;color:#fff;text-align:center;position:relative;overflow:hidden}.auth-message{position:absolute;top:50%;width:100%;transform:translate(20px) translateY(-50%);opacity:0;transition:opacity 1s ease,transform 1s ease;pointer-events:none}.auth-message.active{opacity:1;transform:translateY(-50%);pointer-events:auto;z-index:1}.auth-message.inactive{z-index:0}.auth-message h2{font-size:3.5rem;margin-bottom:2.5rem;font-family:Cambria,Georgia,serif}.auth-message p{font-size:1.4rem;margin-bottom:2.5rem;line-height:1.5;font-family:Cambria,Georgia,serif}.auth-message button{width:150px;margin-top:1rem;padding:12px 20px;background-color:#fff;color:#7c8cfd;border:none;font-weight:700;border-radius:80px;cursor:pointer;transition:background-color .3s ease,color .3s ease}.auth-message button:hover{background-color:#e5e5e5;color:#5c6cfd}.auth-right{display:flex;flex-direction:column;align-items:center;justify-content:center;width:50%;background-color:#fff;position:relative;overflow:hidden}.auth-form{transition:opacity .5s ease-in-out;width:100%;max-width:350px;padding:20px;box-sizing:border-box;text-align:center}.auth-form h2{font-size:2.4rem;margin-bottom:2.5rem;font-family:Cambria,Georgia,serif;color:#7c8cfd}.auth-form input{width:calc(100% - 24px);margin-bottom:20px;padding:12px;font-size:1rem;border:1px solid #ccc;background-color:#f5f5f5;color:#000;border-radius:5px;box-sizing:border-box}.auth-form button{padding:12px 25px;background-color:#7c8cfd;color:#fff;border:none;cursor:pointer;font-weight:700;border-radius:80px;width:150px;transition:background-color .3s ease}.auth-form button:hover{background-color:#187bcd}.guest-access{position:absolute;top:1rem;right:1rem;font-size:.95rem;color:#666;text-align:right;z-index:10}.guest-button{font-size:1rem;background:none;border:none;color:#7c8cfd;font-weight:700;cursor:pointer;padding:0;transition:color .3s ease}.guest-button:hover{color:#187bcd}@media (max-width: 900px){.auth-container{flex-direction:column;height:auto;min-height:100vh;overflow-y:scroll}.auth-left,.auth-right{width:100%;min-height:50vh}.auth-left{padding:1.5rem;text-align:center}.auth-message h2{font-size:2.5rem;margin-left:0;margin-right:10px;text-align:center}.auth-message p{font-size:1.2rem;max-width:85%;word-break:break-word;overflow-wrap:break-word;margin-left:10px;margin-right:0;text-align:center}.auth-form h2{font-size:2rem}.auth-form{max-width:90%;padding:1rem}.guest-access{position:static}}.home{min-height:100vh;width:100vw;background:linear-gradient(135deg,#e3eafe,#f9f9ff);font-family:Segoe UI,Arial,sans-serif;overflow-x:hidden;position:relative;padding-top:4.5rem}.homepage-profile{display:flex;align-items:center;justify-content:flex-end;gap:.7rem;font-size:1.1rem;position:absolute;top:4rem;right:1vw;z-index:20;margin:0;background:transparent;flex-direction:column}.homepage-profile img{width:32px;height:32px;object-fit:cover;border-radius:50%}.homepage-profile span{cursor:pointer}.profile-dropdown{position:absolute;top:110%;right:0;background:#fff;box-shadow:0 2px 12px #7c8cfd1f;border-radius:1rem;min-width:120px;z-index:10;padding:.5rem .7rem;display:flex;flex-direction:column;align-items:flex-start;animation:fadeIn .2s}.profile-dropdown button{background:none;color:#7c8cfd;border:none;font-size:1rem;font-weight:500;cursor:pointer;padding:.4rem .7rem;border-radius:.7rem;width:100%;text-align:left;transition:background .2s,color .2s}.profile-dropdown button:hover{background:#e3eafe;color:#4a5fc1}.homepage-logout{background:#fff;color:#7c8cfd;border:none;border-radius:1rem;padding:.5rem 1.2rem;font-size:1rem;font-weight:500;cursor:pointer;margin-left:1rem;transition:background .2s,color .2s}.homepage-logout:hover{background:#e3eafe;color:#4a5fc1}.homepage-topbar,.homepage-title,.homepage-nav,.homepage-nav-btn,.toggle-arrow-btn{display:none!important}.homepage-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;padding:2rem 2vw;margin-top:2rem}.homepage-card{background:#fff;border-radius:1.5rem;box-shadow:0 2px 12px #7c8cfd1a;padding:2rem 1.5rem;text-align:center;color:#4a5fc1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;transition:box-shadow .3s,transform .3s,background .3s;opacity:0;transform:translateY(30px) scale(.98);animation:cardFadeIn .7s cubic-bezier(.23,1,.32,1) forwards}.homepage-card:hover{box-shadow:0 6px 24px #7c8cfd2e;transform:translateY(-6px) scale(1.03);background:#e3eafe}.homepage-card:nth-child(2){animation-delay:.12s}.homepage-card:nth-child(3){animation-delay:.24s}.homepage-card:nth-child(4){animation-delay:.36s}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.homepage-card h3{font-size:1.3rem;margin-bottom:.7rem}.homepage-card p{font-size:1rem;margin-bottom:1.2rem}.homepage-card button{background:#7c8cfd;color:#fff;border:none;border-radius:1rem;padding:.7rem 1.5rem;font-size:1rem;cursor:pointer;transition:background .2s}.homepage-card button:hover{background:#4a5fc1}.homepage-welcome{text-align:center;margin-top:2.5rem;margin-bottom:1.5rem;animation:fadeInDown .8s}.homepage-welcome-title{font-size:2.2rem;font-weight:700;color:#4a5fc1;margin-bottom:.5rem;letter-spacing:1px}.homepage-welcome-note{font-size:1.1rem;color:#7c8cfd;opacity:.85;margin-bottom:.5rem;animation:fadeIn 1.2s}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.homepage-footer{width:100vw;max-width:100vw;display:flex;flex-direction:row;justify-content:space-between;align-items:center;position:static;margin-top:1rem;padding:.1rem 1vw .1rem 1vw;background:transparent;box-sizing:border-box}.footer-social{display:flex;flex-direction:row;gap:1.2rem;align-items:center}.footer-links{display:flex;flex-direction:row;gap:0rem;align-items:center;flex-wrap:wrap;justify-content:flex-end;max-width:70vw;overflow-x:auto}.footer-links a{color:#7c8cfd;font-size:1rem;text-decoration:none;font-weight:500;background:#fff;padding:.4rem 1rem;border-radius:1rem;box-shadow:0 2px 8px #7c8cfd14;transition:background .2s,color .2s;white-space:nowrap;margin-bottom:0}.footer-links a:hover{background:#e3eafe;color:#4a5fc1}@media (max-width: 700px){.home{padding-top:30.2rem;min-height:85vh}.homepage-profile{position:fixed;top:.5rem;right:1vw;font-size:.9rem;padding:.2rem .5rem;z-index:100}.homepage-welcome{margin-top:-1rem;margin-bottom:1rem;font-size:1.1rem}.homepage-cards{grid-template-columns:1fr;gap:1.2rem;padding:1rem 2vw;margin-top:1rem;min-height:60vh;overflow-y:auto}}@media (max-width: 500px){.home{padding-top:9.2rem;min-height:85vh}.homepage-profile{position:relative;font-size:1.5rem;top:-1rem;right:0vw;z-index:100}.homepage-welcome-title{font-size:1.3rem}.homepage-welcome-note{font-size:.9rem}.homepage-cards{gap:.7rem;padding:.5rem 1vw}}@media (max-width: 380px){.home{padding-top:17.2rem;min-height:85vh}.homepage-profile{position:relative;font-size:.8rem;top:-2rem;right:0vw;z-index:100}.homepage-welcome-title{font-size:1.3rem}.homepage-welcome-note{font-size:.9rem}.homepage-cards{gap:.7rem;padding:.5rem 1vw}}.footer-social a img{width:22px;height:22px;border-radius:50%;background:#e3eafe;box-shadow:0 2px 8px #7c8cfd1f;transition:transform .2s}.footer-social a:hover img{transform:scale(1.15) rotate(-8deg);box-shadow:0 4px 16px #7c8cfd2e}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#e3eafe,#f9f9ff);display:flex;align-items:center;justify-content:center;z-index:999;animation:fadeIn .4s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;padding:2.5rem 2rem 2rem;border-radius:2rem;width:92%;max-width:480px;box-shadow:0 6px 32px #7c8cfd2e;border:2px solid #e3eafe;position:relative;animation:modalPop .7s cubic-bezier(.23,1,.32,1)}@keyframes modalPop{0%{opacity:0;transform:scale(.95) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.university-list{list-style:none;padding:0;margin:1.2rem 0;max-height:220px;overflow-y:auto;border-radius:1rem;background:#f9f9ff;box-shadow:0 2px 8px #7c8cfd14}.university-list li{padding:12px 18px;cursor:pointer;border-bottom:1px solid #e3eafe;color:#4a5fc1;font-weight:500;transition:background .2s,color .2s,transform .2s}.university-list li:last-child{border-bottom:none}.university-list li:hover{background:#e3eafe;color:#7c8cfd;transform:scale(1.03)}input[type=text]{width:100%;padding:15px;margin-top:10px;margin-bottom:15px;border-radius:1rem;border:1.5px solid #e3eafe;font-size:1.1rem;background:#f9f9ff;color:#4a5fc1;box-shadow:0 2px 8px #7c8cfd14;transition:border .2s}input[type=text]:focus{border:2px solid #7c8cfd;outline:none}.close-btn{background:linear-gradient(90deg,#7c8cfd,#4a5fc1);color:#fff;border:none;padding:10px 22px;border-radius:1rem;cursor:pointer;font-size:1rem;font-weight:600;box-shadow:0 2px 8px #7c8cfd1f;position:absolute;top:1.2rem;right:1.2rem;transition:background .2s,transform .2s}.close-btn:hover{background:linear-gradient(90deg,#e3eafe,#7c8cfd);color:#4a5fc1;transform:scale(1.08)}.dm-modal-overlay{position:fixed;inset:0;background:#0006;z-index:1000;display:flex;align-items:center;justify-content:center}.dm-modal{background:linear-gradient(135deg,#e3eafe,#f9f9ff);border-radius:2rem;box-shadow:0 6px 32px #7c8cfd2e;width:95vw;max-width:420px;max-height:80vh;display:flex;flex-direction:column;padding:2.2rem 1.2rem 1.2rem;position:relative;animation:dm-fade-in .5s cubic-bezier(.23,1,.32,1)}.dm-modal:before{content:"";position:absolute;inset:0;border-radius:2rem;pointer-events:none;box-shadow:0 0 0 6px #e3eafe inset;opacity:.2}@keyframes dm-fade-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.dm-close{position:absolute;top:1.2rem;right:1.2rem;background:linear-gradient(90deg,#7c8cfd,#4a5fc1);color:#fff;border:none;font-size:1.7rem;border-radius:1rem;cursor:pointer;transition:background .2s,color .2s,transform .2s}.dm-close:hover{background:linear-gradient(90deg,#e3eafe,#7c8cfd);color:#4a5fc1;transform:scale(1.08)}.dm-messages{flex:1;overflow-y:auto;margin-bottom:12px;padding-right:4px}.dm-message{margin-bottom:10px;padding:10px 16px;border-radius:14px;max-width:80%;word-break:break-word;font-size:1.05rem;position:relative;box-shadow:0 2px 8px #7c8cfd14;transition:background .2s,transform .2s}.dm-sent{background:#e3eafe;align-self:flex-end;margin-left:auto;color:#4a5fc1}.dm-received{background:#f9f9ff;align-self:flex-start;margin-right:auto;color:#7c8cfd}.dm-message:hover{background:#dbeafe;transform:scale(1.03)}.dm-sender{font-weight:600;color:#7c8cfd;margin-right:6px}.dm-timestamp{font-size:.8rem;color:#888;margin-top:2px;text-align:right}.dm-empty{text-align:center;color:#aaa;margin-top:24px}.dm-loading{text-align:center;color:#7c8cfd;margin-bottom:8px}.dm-error{text-align:center;color:#e74c3c;margin-bottom:8px}.dm-input-row{display:flex;gap:8px;align-items:center;margin-top:.5rem}.dm-input{flex:1;padding:10px 14px;border-radius:1rem;border:1.5px solid #e3eafe;font-size:1.05rem;outline:none;background:#f9f9ff;color:#4a5fc1;box-shadow:0 2px 8px #7c8cfd14;transition:border .2s}.dm-input:focus{border:2px solid #7c8cfd}.dm-send-btn{background:linear-gradient(90deg,#7c8cfd,#4a5fc1);color:#fff;border:none;border-radius:1rem;padding:10px 22px;font-size:1rem;cursor:pointer;transition:background .2s,transform .2s;font-weight:600;box-shadow:0 2px 8px #7c8cfd1f}.dm-send-btn:disabled{background:#b3d3ea;cursor:not-allowed}.dm-send-btn:not(:disabled):hover{background:linear-gradient(90deg,#e3eafe,#7c8cfd);color:#4a5fc1;transform:scale(1.08)}@media (max-width: 600px){.dm-modal{max-width:98vw;padding:16px 6px 10px}.dm-message{font-size:.95rem;padding:7px 8px}}html,body{overflow-y:auto;overflow-x:hidden}.thread-detail-panel{position:fixed;top:0;right:0;width:40%;height:100%;background:linear-gradient(135deg,#e3eafe,#f9f9ff);overflow-y:auto;padding:2.5rem 2rem 2rem;box-shadow:-2px 0 24px #7c8cfd2e;border-radius:2rem 0 0 2rem;z-index:1000;animation:modalPop .7s cubic-bezier(.23,1,.32,1)}@keyframes modalPop{0%{opacity:0;transform:scale(.97) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.schedule-forum ul{max-height:350px;overflow-y:auto;padding-left:0;margin:1rem 0;border:1.5px solid #e3eafe;border-radius:1rem;background:#f9f9ff;box-shadow:0 2px 8px #7c8cfd14}.schedule-forum ul li{padding:12px 18px;border-bottom:1px solid #e3eafe;cursor:pointer;color:#4a5fc1;font-weight:500;transition:background .2s,color .2s,transform .2s}.schedule-forum ul li:last-child{border-bottom:none}.schedule-forum ul li:hover{background:#e3eafe;color:#7c8cfd;transform:scale(1.03)}.close-button{position:absolute;top:1.2rem;right:1.2rem;background:linear-gradient(90deg,#7c8cfd,#4a5fc1);color:#fff;border:none;padding:8px 18px;border-radius:1rem;cursor:pointer;font-size:1.1rem;font-weight:600;box-shadow:0 2px 8px #7c8cfd1f;transition:background .2s,transform .2s;z-index:10}.close-button:hover{background:linear-gradient(90deg,#e3eafe,#7c8cfd);color:#4a5fc1;transform:scale(1.08)}.schedule-forum input[type=text]{padding:15px;font-size:1.1rem;border:1.5px solid #e3eafe;border-radius:1rem;width:100%;background:#f9f9ff;color:#4a5fc1;box-shadow:0 2px 8px #7c8cfd14;transition:border .2s;margin-bottom:1rem}.schedule-forum input[type=text]:focus{border:2px solid #7c8cfd;outline:none}html,body{overflow-y:auto}.rate-scheduler{margin-left:0;padding:2rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f9f9f9;min-height:100vh;min-width:100vw;transition:margin-left .3s}.forum-section,.class-rating-section{background-color:#fff;border-radius:1rem;padding-left:.5rem;margin-bottom:1rem;box-shadow:0 2px 10px #0000000d;margin-top:2rem}.forum-section h2,.class-rating-section h2{font-size:1.5rem;margin-bottom:1rem;color:#444;border-bottom:1px solid #ddd;padding-bottom:0rem}.scheduler-sidebar{position:fixed;top:0;left:0;height:100vh;width:180px;background:#7c8cfd;color:#fff;display:flex;flex-direction:column;align-items:center;padding-top:2rem;box-shadow:2px 0 8px #7c8cfd14;z-index:20;transition:left .3s,opacity .3s;opacity:1}.scheduler-sidebar.open{left:0;opacity:1;pointer-events:auto}.scheduler-sidebar:not(.open){left:-200px;opacity:.2;pointer-events:none}.sidebar-nav-btn{color:#fff;background:none;border:none;font-size:1.1rem;margin:1rem 0;padding:.7rem 1.2rem;border-radius:.7rem;transition:background .2s,color .2s;width:100%;text-align:center;cursor:pointer}.sidebar-nav-btn:hover{background:#e3eafe;color:#4a5fc1}.sidebar-toggle-btn{position:fixed;top:1.2rem;left:1.2rem;background:#7c8cfd;border:none;color:#fff;font-size:2rem;border-radius:.7rem;z-index:30;cursor:pointer;box-shadow:0 2px 8px #7c8cfd1f;padding:.3rem .7rem;transition:background .2s}.sidebar-toggle-btn:hover{background:#4a5fc1}.sidebar-toggle-icon{display:block;line-height:1}@media screen and (max-width: 900px){.sidebar-toggle-btn{top:.7rem;left:.7rem;font-size:1.7rem;padding:.2rem .5rem}.scheduler-sidebar{position:fixed;top:0;left:0;width:70vw;height:100vh;background:#7c8cfd;flex-direction:column;align-items:center;padding-top:2rem;box-shadow:2px 0 8px #7c8cfd14;z-index:20;transition:left .3s,opacity .3s}.scheduler-sidebar.open{left:0;opacity:1;pointer-events:auto}.scheduler-sidebar:not(.open){left:-70vw;opacity:.2;pointer-events:none}.sidebar-open .rate-scheduler{margin-left:70vw}.rate-scheduler{margin-left:0;padding:0rem}}.dev-dashboard-container{background:#f7f8fa;min-height:100vh;font-family:Inter,Arial,sans-serif}.dev-home-section{margin:2rem auto;box-shadow:0 2px 12px #7c8cfd14;border-radius:12px;background:#fff;max-width:100vw;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:30rem}.dev-dashboard-container .home{min-height:85vh}.dev-dashboard-container .homepage-profile{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem;margin-right:2rem;margin-top:1rem}.homepage-cards{display:flex;flex-wrap:balanced;justify-content:space-evenly;gap:2rem;width:auto}.homepage-card{display:flex;flex-direction:column;align-items:center;justify-content:center}.homepage-welcome,.homepage-welcome-title,.homepage-welcome-note{text-align:center}.homepage-footer{display:flex;flex-direction:row;align-items:normal;width:100%;margin-top:2rem}.dev-separator{height:2px;background:linear-gradient(90deg,#7c8cfd,#e74c3c);margin:0rem 0;border-radius:2px;width:100%;max-width:100vw}.dev-moderation-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #7c8cfd14;padding:1rem;margin-bottom:1rem;max-width:100vw;width:100%}.dev-moderation-section h2{color:#7c8cfd;margin-bottom:1rem}.dev-moderation-section ul{list-style:disc inside;color:#333;font-size:1.1rem}.dev-audit-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #7c8cfd14;padding:2rem;max-width:100vw;width:100%}.dev-audit-section h2{color:#e74c3c;margin-bottom:1rem}.dev-audit-table{width:100%;border-collapse:collapse;font-size:.98rem}.dev-audit-table th,.dev-audit-table td{border:1px solid #eee;padding:.5rem .75rem;text-align:left}.dev-audit-table th{background:#f2f4fa;color:#7c8cfd}.dev-audit-table tr:nth-child(2n){background:#fafbff}.audit-log-container{max-height:100px;overflow-y:auto;border:1px solid #eee;background:#fff;padding:1rem;margin-bottom:1rem;border-radius:8px}
