: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:auto!important;min-height:100vh;width:100vw;overflow-x:hidden;overflow-y:auto}.auth-container{display:flex;min-height:100vh;width:100vw;position:relative;overflow-y:auto}.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;min-height:100vh;height:auto!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch}.auth-left,.auth-right{width:100%;min-height:50vh;overflow:visible!important}.auth-left{padding:0rem;text-align:center}.auth-message{position:static!important;top:unset!important;left:unset!important;width:100%;transform:none!important;opacity:1!important;margin:1rem 0;pointer-events:auto;z-index:1;display:none}.auth-message.active{display:block!important;opacity:1;transform:none;pointer-events:auto;z-index:1;margin-top:0rem}.auth-message.inactive{display:none!important;z-index:0}.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:95%;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:2rem}.homepage-profile{display:flex;align-items:center;justify-content:flex-end;gap:.7rem;font-size:1.1rem;position:absolute;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;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{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}.homepage-footer{flex-direction:column!important;align-items:center!important;justify-content:flex-start!important;gap:1rem!important;padding:.5rem 2vw!important}.footer-social{flex-direction:row;gap:1.2rem;margin-bottom:.5rem}.footer-links{align-items:flex-start;gap:.5rem;max-width:100vw;margin-top:.5rem;overflow-x:visible}}@media (max-width: 500px){.home{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{min-height:85vh}.homepage-profile{position:relative;font-size: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}}.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:1rem;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}}.schedule-forum{max-width:900px;margin:0 auto;padding:2em;background:#fff;min-height:100vh}.schedule-forum h2{font-size:1.8em;margin-bottom:1.5em;color:#333;font-weight:600}.create-thread-btn{background:#1976d2;color:#fff;border:none;padding:.8em 1.5em;border-radius:8px;font-weight:600;cursor:pointer;margin-bottom:1.5em;transition:background .2s}.create-thread-btn:hover{background:#1565c0}.search-input{width:100%;padding:.8em;border:1px solid #ddd;border-radius:8px;font-size:1em;margin-bottom:1.5em;box-sizing:border-box}.search-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.threads-list{color:#000;list-style:none;padding:0;margin:0}.thread-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.2em;margin-bottom:1em;cursor:pointer;transition:all .2s}.thread-item:hover{background:#e9ecef;border-color:#1976d2}.thread-title{font-size:1.1em;font-weight:600;color:#333;margin-bottom:.5em}.thread-preview{color:#666;font-size:.9em;margin-bottom:.5em;line-height:1.4}.thread-meta{font-size:.8em;color:#999}.reply-count{color:#666;font-weight:500}.dm-author-link{color:#1976d2;text-decoration:none;font-weight:500}.search-match{font-size:.8em;color:#666;font-style:italic;margin-top:.5em;padding:.3em .6em;background:#f0f0f0;border-radius:4px;border-left:3px solid #1976d2}.search-match mark{background:#1976d2;color:#fff;padding:2px 4px;border-radius:3px}@media (max-width: 768px){.schedule-forum{padding:1em}.create-thread-btn{width:100%}body.modal-open{overflow:hidden!important;height:100vh!important;position:relative}}body.dark-mode .schedule-forum{background:#1a1a1a;color:#e0e0e0}body.dark-mode .schedule-forum h2{color:#e0e0e0}body.dark-mode .search-input{background:#2a2a2a;border-color:#444;color:#e0e0e0}body.dark-mode .thread-item{background:#2a2a2a;border-color:#444}body.dark-mode .thread-item:hover{background:#333;border-color:#90caf9}body.dark-mode .thread-title{color:#e0e0e0}body.dark-mode .create-thread-btn{background:#90caf9;color:#000}body.dark-mode .dm-author-link{color:#90caf9}body.dark-mode .search-match{background:#2a2a2a!important;color:#ccc!important;border-left-color:#90caf9!important}body.dark-mode .search-match *{color:#ccc!important}body.dark-mode .search-match mark{background:#90caf9!important;color:#000!important;padding:2px 4px!important;border-radius:3px!important}.post-reply-container{background:#f8f9fa;border-radius:8px;padding:1.2em;margin:1em 0;border:1px solid #e0e0e0}.post-reply-form{width:100%}.post-reply-form h4{margin:0 0 .8em;font-size:1.1em;color:#222;font-weight:600}.post-reply-textarea{width:100%;min-height:100px;padding:.8em;border:1px solid #ddd;border-radius:6px;font-size:.9em;font-family:inherit;resize:vertical;box-sizing:border-box;margin-bottom:.8em}.post-reply-textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.post-reply-file{margin-bottom:.8em;font-size:.85em}.post-reply-btn{background:#1976d2;color:#fff;border:none;padding:.7em 1.5em;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-left:0;font-size:.9em}.post-reply-btn:hover{background:#1565c0;transform:translateY(-1px)}.post-reply-guidelines{font-size:.8em;color:#666;background:#f0f0f0;border-radius:6px;padding:.6em;margin-top:1em;line-height:1.4}.dm-author-link{color:#1976d2;text-decoration:none;font-weight:500;cursor:pointer}.dm-author-link:hover{text-decoration:underline}.post-reply-btn:hover{background:#1565c0;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.post-reply-guidelines{font-size:.75em;color:#999;background:var(--card-light);border:1px solid var(--border-light);border-radius:6px;padding:.6em;margin-top:.5em;line-height:1.4}.post-reply-close-btn{position:sticky;top:0;z-index:10;background:var(--primary);border:none;color:#fff;font-size:1em;font-weight:700;padding:.4em .8em;border-radius:6px;cursor:pointer;box-shadow:0 2px 8px #1976d226;transition:all .2s ease}.post-reply-close-btn:hover{background:#1565c0;transform:translateY(-1px)}body.dark-mode .post-reply-container{background:var(--card-dark);border-color:var(--border-dark)}body.dark-mode .post-reply-textarea{background:var(--bg-dark);color:var(--text-dark);border-color:var(--border-dark)}body.dark-mode .post-reply-file::file-selector-button{background:var(--card-dark);border-color:var(--border-dark);color:var(--text-dark)}body.dark-mode .post-reply-guidelines{background:var(--card-dark);border-color:var(--border-dark);color:#ccc}body.dark-mode .post-reply-form h4,body.dark-mode .post-reply-file{color:var(--text-dark)}.thread-detail-panel{position:fixed;top:0;right:0;width:40%;height:100%;background:#fff;box-shadow:-4px 0 20px #00000026;z-index:1000;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:2em;color:#333;max-width:600px;touch-action:manipulation;max-height:100vh}.close-button{position:absolute;top:1em;right:1em;background:#dc3545;color:#fff;border:none;border-radius:50%;width:35px;height:35px;cursor:pointer;font-size:1.1em;font-weight:700}.close-button:hover{background:#c82333}.thread-detail-panel h2{font-size:1.4em;margin-bottom:.8em;padding-right:3em;color:#333}.thread-detail-panel>p{margin-bottom:1em;line-height:1.5}.thread-detail-panel>p:first-of-type{font-size:.9em;color:#666}.thread-detail-panel button:not(.close-button){background:#1976d2;color:#fff;border:none;padding:.6em 1.2em;border-radius:6px;cursor:pointer;margin-right:.8em;margin-bottom:.5em;font-size:.85em}.thread-detail-panel button[style*="background: rgb(243, 156, 18)"]{background:#f39c12!important}.thread-detail-panel button[style*="background: rgb(231, 76, 60)"]{background:#dc3545!important}.thread-detail-panel button:not(.close-button):hover{opacity:.9}.thread-detail-panel h3{font-size:1.1em;margin:2em 0 1em;padding-top:1em;border-top:1px solid #eee;color:#333}.thread-detail-panel hr{border:none;border-top:1px solid #eee;margin:1.5em 0}.thread-detail-panel>div[style*=border-bottom]{border-bottom:1px solid #eee!important;padding:1em!important;margin-bottom:1em!important;margin-left:0!important}.thread-detail-panel>div[style*=border-bottom]:last-child{border-bottom:none!important}.thread-detail-panel>div strong{color:#1976d2;font-weight:600}.thread-detail-panel>div p{margin:.5em 0 1em;line-height:1.5;color:#333}.thread-detail-panel>div button{background:#1976d2!important;color:#fff!important;border:none!important;padding:.4em .8em!important;border-radius:4px!important;font-size:.8em!important;cursor:pointer!important;margin-right:.5em!important}.thread-detail-panel>div button[style*="background: rgb(231, 76, 60)"]{background:#dc3545!important}.thread-detail-panel>div button:hover{opacity:.9}.dm-author-link{color:#1976d2!important;text-decoration:none!important;font-weight:500}.dm-author-link:hover{text-decoration:underline!important}.loading-content{padding:2em 0}.skeleton-title{background:#f0f0f0;height:1.4em;border-radius:4px;margin-bottom:1em;color:#666;padding:.5em;font-size:1.2em}.skeleton-meta{background:#f8f8f8;height:1em;border-radius:4px;margin-bottom:1.5em;color:#888;padding:.3em;font-size:.9em}.skeleton-content{background:#f5f5f5;height:3em;border-radius:4px;margin-bottom:2em;color:#666;padding:.8em}.skeleton-replies{background:#f8f8f8;height:2em;border-radius:4px;color:#666;padding:.5em}body.dark-mode .thread-detail-panel{background:#1a1a1a;color:#e0e0e0;box-shadow:-4px 0 20px #0000004d}body.dark-mode .thread-detail-panel h2,body.dark-mode .thread-detail-panel h3{color:#e0e0e0}body.dark-mode .thread-detail-panel>p{color:#ccc}body.dark-mode .thread-detail-panel hr{border-color:#444}body.dark-mode .skeleton-title{background:#2a2a2a;color:#ccc}body.dark-mode .skeleton-meta{background:#333;color:#999}body.dark-mode .skeleton-content{background:#2a2a2a;color:#ccc}body.dark-mode .skeleton-replies{background:#333;color:#ccc}.modal-open{overflow:hidden}@media (max-width: 768px){.thread-detail-panel{width:85%}.close-button{width:40px;height:40px}}:root{--bg-light: #fff;--bg-dark: #181a20;--container-light: #fff;--container-dark: #23263a;--text-light: #222;--text-dark: #f3f3f3;--primary: #1976d2;--primary-dark: #90caf9;--error: #d32f2f;--border-light: #e0e0e0;--border-dark: #444;--card-light: #f8f9fa;--card-dark: #2a2d3f;--shadow: 0 2px 12px rgba(0, 0, 0, .1);--shadow-dark: 0 2px 12px rgba(0, 0, 0, .3)}.class-ratings-container{padding:2em;background:var(--container-light);color:var(--text-light);border-radius:16px;box-shadow:var(--shadow);max-width:1200px;margin:2em auto}.class-ratings-container h2{text-align:center;margin-bottom:2em;font-size:2.2em;font-weight:700;color:var(--primary)}body.dark-mode{background:var(--bg-dark);color:var(--text-dark)}body.dark-mode .class-ratings-container{background:var(--container-dark);color:var(--text-dark);box-shadow:var(--shadow-dark)}body.dark-mode .class-ratings-container h2,body.dark-mode .add-course-section h3,body.dark-mode .courses-header h3,body.dark-mode .course-title,body.dark-mode .add-rating-section h4,body.dark-mode .ratings-section h4,body.dark-mode .modal-header h3{color:var(--primary-dark)}body.dark-mode .form-group label,body.dark-mode .sort-controls label,body.dark-mode .course-name,body.dark-mode .rating-comment{color:var(--text-dark)}body.dark-mode .form-group input,body.dark-mode .form-group textarea,body.dark-mode .form-group select,body.dark-mode .sort-controls select{background:var(--container-dark);color:var(--text-dark);border-color:var(--border-dark)}body.dark-mode .add-course-section,body.dark-mode .course-card,body.dark-mode .rating-card,body.dark-mode .modal-header,body.dark-mode .no-ratings{background:var(--card-dark);border-color:var(--border-dark)}body.dark-mode .modal-content{background:var(--container-dark);box-shadow:0 8px 32px #00000080}body.dark-mode .courses-header,body.dark-mode .add-rating-section{border-color:var(--border-dark)}body.dark-mode .course-card:hover{box-shadow:0 4px 16px #0000004d}body.dark-mode .add-course-btn,body.dark-mode .submit-rating-btn,body.dark-mode .view-ratings-btn{background:var(--primary-dark);color:var(--text-light)}body.dark-mode .close-modal{color:#aaa}body.dark-mode .close-modal:hover{background:#ffffff1a}body.dark-mode .no-ratings,body.dark-mode .course-description,body.dark-mode .rating-info{color:#aaa}body.dark-mode .rating-score{color:var(--primary-dark)}body.dark-mode .rating-user{color:#bbb}.main-content{display:grid;grid-template-columns:1fr 2fr;gap:3em;margin-top:2em}.left-column,.right-column{display:flex;flex-direction:column}.add-course-section{background:var(--card-light);padding:1.5em;border-radius:12px;border:1px solid var(--border-light);box-shadow:0 2px 8px #0000000d}.add-course-section h3,.courses-header h3,.add-rating-section h4,.ratings-section h4{margin-bottom:1em;font-size:1.4em;font-weight:600;color:var(--primary)}.add-rating-section h4,.ratings-section h4{font-size:1.2em}.add-course-form{display:flex;flex-direction:column;gap:1em}.form-group{display:flex;flex-direction:column;gap:.5em}.form-group label{font-weight:500;font-size:.95em;color:var(--text-light)}.form-group input,.form-group textarea,.form-group select,.sort-controls select{padding:.75em;border-radius:8px;border:1px solid var(--border-light);font-size:1em;background:var(--bg-light);color:var(--text-light);transition:border-color .3s ease;font-family:inherit}.sort-controls select{padding:.5em;border-radius:6px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1976d21a}.form-group textarea{resize:vertical;min-height:80px}.add-course-btn,.submit-rating-btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:.8em 1.5em;font-size:1em;font-weight:600;cursor:pointer;transition:background-color .3s ease}.add-course-btn:hover,.submit-rating-btn:hover,.view-ratings-btn:hover{background:#1565c0}.view-ratings-btn{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:.5em 1em;font-size:.9em;cursor:pointer;transition:background-color .3s ease;width:100%;margin-top:auto}.delete-btn{background:var(--error);color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease}.delete-btn:hover{background:#c62828}.courses-section{display:flex;flex-direction:column;height:100%}.courses-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5em;padding-bottom:1em;border-bottom:2px solid var(--border-light)}.courses-header h3{margin:0}.sort-controls{display:flex;align-items:center;gap:.5em}.sort-controls label{font-weight:500;color:var(--text-light)}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5em;max-height:600px;overflow-y:auto;padding-right:.5em}.course-card{background:var(--card-light);border:1px solid var(--border-light);border-radius:12px;padding:1.5em;box-shadow:0 2px 8px #0000000d;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;min-height:200px}.course-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5em}.course-title{font-size:1.1em;font-weight:700;color:var(--primary);margin:0}.course-actions{display:flex;gap:.5em}.course-name{font-size:1em;font-weight:500;margin:.5em 0;color:var(--text-light)}.course-description{font-size:.9em;color:#666;margin-bottom:1em;line-height:1.4;flex-grow:1}.course-info{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1em;border-top:1px solid var(--border-light);font-size:.9em;color:#666}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1em}.modal-content{background:var(--bg-light);border-radius:16px;box-shadow:0 8px 32px #0003;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5em 2em;border-bottom:1px solid var(--border-light);background:var(--card-light);border-radius:16px 16px 0 0;position:sticky;top:0}.modal-header h3{margin:0;font-size:1.3em;font-weight:600;color:var(--primary);line-height:1.3}.close-modal{background:none;border:none;font-size:2em;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s ease}.close-modal:hover{background:#0000001a}.modal-body{padding:2em}.add-rating-section{margin-bottom:2em;padding-bottom:2em;border-bottom:1px solid var(--border-light)}.rating-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1em;margin-bottom:1em}.no-ratings{text-align:center;color:#666;font-style:italic;padding:2em;background:var(--card-light);border-radius:8px}.ratings-list{display:flex;flex-direction:column;gap:1em}.rating-card{background:var(--card-light);border:1px solid var(--border-light);border-radius:12px;padding:1.5em}.rating-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5em}.rating-info{display:flex;align-items:center;gap:1em;font-size:.9em;color:#666}.rating-score{font-weight:600;color:var(--primary)}.rating-difficulty{color:var(--error)}.rating-actions{display:flex;gap:.5em}.rating-comment{margin-top:.5em;line-height:1.4;color:var(--text-light)}.rating-user{font-size:.8em;color:#888;margin-top:.5em;font-style:italic}@media (max-width: 768px){.main-content{grid-template-columns:1fr;gap:2em}.course-grid{grid-template-columns:1fr;max-height:400px}.rating-inputs{grid-template-columns:1fr}.modal-content{margin:.5em;max-height:95vh}.modal-header,.modal-body{padding:1em}.rating-header{flex-direction:column;align-items:flex-start;gap:.5em}.rating-info{flex-wrap:wrap;gap:.5em}.rating-actions{align-self:flex-end}}@media (max-width: 480px){.class-ratings-container{padding:.5em;margin:.5em}.class-ratings-container h2{font-size:1.8em}.course-card,.rating-card{padding:1em}.courses-header{flex-direction:column;align-items:stretch;gap:1em}.modal-header h3{font-size:1.1em}.course-grid{gap:1em}.course-title{font-size:1em}.course-name{font-size:.9em}}.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}}@media (max-width: 768px){body.modal-open{overflow:hidden!important;height:100vh!important;position:relative}}.dev-dashboard-container{background:#f7f8fa;font-family:Inter,Arial,sans-serif;height:100vh;overflow-y:auto}.dev-home-section{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-bottom:2rem}.dev-dashboard-container .home{min-height:unset}.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{color:#000;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{color:#000;background:#fff;border-radius:12px;box-shadow:0 2px 12px #7c8cfd14;max-width:100vw;width:100%}.dev-audit-section h2{color:#e74c3c;margin-bottom:1rem}.dev-audit-table{color:#000;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}.dev-users-section{color:#000;margin-top:2rem}.dev-users-section table{color:#000;max-height:250px;overflow-y:auto;display:block}:root{--background-light: #fff;--background-dark: #181a20;--container-light: #fff;--container-dark: #23263a;--text-light: #222;--text-dark: #f3f3f3;--primary: #1976d2;--primary-dark: #90caf9;--error: #d32f2f;--success: #388e3c;--selected-light: #e3f2fd;--selected-dark: #26334a;--list-light: #f5f5f5;--list-dark: #23263a;--stat-light: #555;--stat-dark: #b0b8c1}body.dark-mode .resources-container{background:#23263a;color:#f3f3f3}body.dark-mode{background:var(--background-dark);color:var(--text-dark)}.resources-container{padding:1.5em;background:var(--container-light);color:var(--text-light);border-radius:12px;box-shadow:0 2px 8px #00000012;max-width:700px;margin:2em auto}.resource-list{list-style:none;padding:0;margin-bottom:2em}.resource-list li{margin-bottom:.5em;background:var(--list-light);border-radius:6px;padding:.5em;display:flex;align-items:center;gap:12px}body.dark-mode .resource-list li{background:#23263a}.resource-list .resource-title{font-weight:600;color:var(--primary)}body.dark-mode .resource-list .resource-title{color:#fff}.resource-list .resource-url{color:var(--stat-light)}body.dark-mode .resource-list .resource-url{color:#b0b8c1}.resource-list .resource-date{font-size:.95em;color:var(--stat-light)}body.dark-mode .resource-list .resource-date{color:#b0b8c1}.resource-form input,.resource-form textarea{padding:.5em;border-radius:6px;border:1px solid #ccc;font-size:1em;background:inherit;color:inherit}.resource-form button,.resource-list button{background:#fff;color:#222;border:1px solid #ccc;border-radius:6px;padding:.5em 1em;cursor:pointer;font-weight:600}body.dark-mode .resource-form button,body.dark-mode .resource-list button{background:#fff;color:#222;border:1px solid #888}.resource-list button[style*="color: red"]{color:#d32f2f!important}.resource-form button:hover,.resource-list button:hover{background:#f5f5f5}.success-msg{color:var(--success);margin-bottom:.5em;font-weight:500}.error-msg{color:var(--error);font-weight:500;margin-bottom:.5em}.button{color:#000;background-color:#fff}
